<html>
    <head>
      <base href="https://bugs.freedesktop.org/">
    </head>
    <body>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - Driver 0.4.0 crashes with recent linux kernel version"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=95420#c2">Comment # 2</a>
              on <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - Driver 0.4.0 crashes with recent linux kernel version"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=95420">bug 95420</a>
              from <span class="vcard"><a class="email" href="mailto:kevinbrace@gmx.com" title="Kevin Brace <kevinbrace@gmx.com>"> <span class="fn">Kevin Brace</span></a>
</span></b>
        <pre>Hi Torsten,

I looked at the log files, and I do see something weird.
Here is the Xorg.0.log with Linux kernel 4.4.5.

____________________________________________________________
. . .
[    11.364] (II) CHROME(0): VIAMapMMIO
[    11.364] (--) CHROME(0): mapping MMIO @ 0xfb000000 with size 0xd000
[    11.364] (--) CHROME(0): mapping BitBlt MMIO @ 0xfb200000 with size
0x200000
[    11.364] (II) CHROME(0): vgaHWGetIOBase: hwp->IOBase is 0x03d0
[    11.364] (II) CHROME(0): VIAMapFB
[    11.364] (--) CHROME(0): mapping framebuffer @ 0xf0000000 with size
0x4000000
[    11.364] (--) CHROME(0): Frame buffer start: 0x7f2bc12cb000, free start:
0x0 end: 0x4000000
[    11.364] (II) CHROME(0): Creating default Display subsection in Screen
section
. . .
____________________________________________________________


Here is the Xorg.0.log with Linux kernel 4.5.1.

____________________________________________________________
. . .
[   354.283] (II) CHROME(0): VIAMapMMIO
[   354.283] (--) CHROME(0): mapping MMIO @ 0xfb000000 with size 0xd000
[   354.283] (--) CHROME(0): mapping BitBlt MMIO @ 0xfb200000 with size
0x200000
[   354.283] (II) CHROME(0): vgaHWGetIOBase: hwp->IOBase is 0x03d0
[   354.283] (II) CHROME(0): VIAMapFB
[   354.283] (--) CHROME(0): mapping framebuffer @ 0xf0000000 with size
0x4000000
[   354.284] (EE) CHROME(0): Unable to map mmio BAR. Invalid argument (22)
[   354.284] (II) CHROME(0): VIAFreeRec
[   354.284] (II) CHROME(0): Entered VIAUnmapMMIO.
[   354.284] (II) CHROME(0): Exiting VIAUnmapMMIO.
[   354.284] (II) CHROME(0): VIAFreeScreen
[   354.284] (II) CHROME(0): VIAFreeRec
[   354.284] (EE) 
[   354.284] (EE) Backtrace:
[   354.284] (EE) 0: /usr/lib/xorg-server/Xorg (OsLookupColor+0x139) [0x594d49]
[   354.285] (EE) 1: /usr/lib/libc.so.6 (__restore_rt+0x0) [0x7fa7fb6eb32f]
[   354.286] (EE) 2: /usr/lib/xorg/modules/drivers/openchrome_drv.so
(_init+0xd0fe) [0x7fa7f65c4fde]
[   354.286] (EE) 3: /usr/lib/xorg-server/Xorg (xf86DeleteScreen+0x5a)
[0x480c2a]
[   354.286] (EE) 4: /usr/lib/xorg-server/Xorg (InitOutput+0xcdb) [0x47b29b]
[   354.287] (EE) 5: /usr/lib/xorg-server/Xorg (remove_fs_handlers+0x264)
[0x43a074]
[   354.288] (EE) 6: /usr/lib/libc.so.6 (__libc_start_main+0xf0)
[0x7fa7fb6d8710]
[   354.288] (EE) 7: /usr/lib/xorg-server/Xorg (_start+0x29) [0x424589]
[   354.289] (EE) 8: ? (?+0x29) [0x29]
[   354.289] (EE) 
[   354.289] (EE) Segmentation fault at address 0xa4
[   354.289] (EE) 
. . .
____________________________________________________________


I do not recall the exact commit that fixed the above segmentation fault, but
it could have been this one.

<a href="https://cgit.freedesktop.org/openchrome/xf86-video-openchrome/commit/?id=c6fd0017eeafc796124437e7bfc9906433b3f28a">https://cgit.freedesktop.org/openchrome/xf86-video-openchrome/commit/?id=c6fd0017eeafc796124437e7bfc9906433b3f28a</a>

However, before the segmentation fault, there is an error.

____________________________________________________________
. . .
[   354.284] (EE) CHROME(0): Unable to map mmio BAR. Invalid argument (22)
. . .
____________________________________________________________


This is the code that likely tripped up OpenChrome.
____________________________________________________________________________
. . .
        err = pci_device_map_range(pVia->PciInfo, pVia->FrameBufferBase,
                                   pVia->videoRambytes,
                                   (PCI_DEV_MAP_FLAG_WRITABLE |
                                    PCI_DEV_MAP_FLAG_WRITE_COMBINE),
                                   (void **)&pVia->FBBase);

         if (err) {
             xf86DrvMsg(pScrn->scrnIndex, X_ERROR,
                        "Unable to map mmio BAR. %s (%d)\n", strerror(err),
err);
             return FALSE;
         }
. . .
____________________________________________________________________________


It appears that pci_device_map_range API's arguments or behavior has changed.
I probably should not say that OpenChrome is not responsible for it, but I feel
like this is a Linux kernel or libpciaccess problem (bug).</pre>
        </div>
      </p>


      <hr>
      <span>You are receiving this mail because:</span>

      <ul>
          <li>You are the assignee for the bug.</li>
      </ul>
    </body>
</html>