Created attachment 62130 [details]
- when startx is run, the resulting desktop is rendered in one of 2 ways:
1. the resolution is fairly ok, and the screen dimensions are 1280x1024, but it is shifted to the right such that part of it wraps-around to the LHS! See attached image.
2. an unshifted screen, but very low resolution.
- syslog always shows
[drm:i915_init] *ERROR* drm/i915 can't work without intel_agp module!
- The graphics performance of the box is far from its best. Video playback runs OK, but far from optimal. A simple 2D test, the old utility 'ico', confirms this: the polygon bounces around like 'pong'!
2) System environment:
- chipset: i915, as far as I can tell!
- uname -m: x86_64
- uname -r 3.3.7
- cpu: Intel(R) Core(TM) i3 CPU 540 @ 3.07GHz
- mobo: Gigabyte H55M-S2V. In other words, the Intel H55 chipset.
- pkg-config --modversion libdrm: 2.4.27
- glxinfo usually shows Mesa to be Mesa 7.11.
- xf86-video-intel seems to be 12.0 (as shown by Xorg.0.log)
- X.Org X Server 220.127.116.112 (1.12.2 RC 2)
-- Linux distribution:
Debian 6.0, but the Testing branch. However, the problem (low resolution and poor performance) is reproducible with Debian Stable as well.
-- Display connector: (e.g. VGA, DVI, HDMI, S-video, ...)
3) Reproduce steps. Probability if not 100% reproducible.
a. run 'startx'. It happens each and every time. 100%.
-- dmesg output (better with boot option "drm.debug=0x06")
A few printks were added to the i915 code, denoted by "alidbg".
-- screenshot or photo (optional, a picture is worth a thousand words)
-- output of "xrandr --verbose" for display mode issue
Other combinations of CPU/mobo have been involved as well. The G41 chipset (Gigabyte G41M-Combo, with a celeron e3400 CPU) used to be fine, when run in Debian 6.0 (Stable branch). Today's Debian Testing (with its Xorg upgrades) seems to have broken that; even glxinfo fails!
A Radeon 5450 card shows the same low resolution, and low 'ico' performance; but no AGP failures in syslog.
Debian's Stable kernel, 2.6.32-5-amd64, did not fix the problems.
Testing was with, and without, /etc/X11/xorg.conf.
Created attachment 62131 [details]
Resulting from 'startx'.
Created attachment 62132 [details]
I don't usually run this, so I can't tell you much about any variance in its output.
Created attachment 62133 [details]
To trace behaviour, I had added a few printk statements to
You will see these flagged by 'alidbg'.
Manual loading of the intel_agp module will cause no warnings. But subsequent loading of i915 will cause:
FATAL: Error inserting i915 (/lib/modules/3.3.7_Sat26may2012/kernel/drivers/gpu/drm/i915/i915.ko): No such device
All of the following do get loaded, though not i915 itself:
root@misery Sat May 26 22:07:14 ~$ modinfo i915|egrep -i depends
root@misery Sat May 26 22:19:55 ~$
The following is very similar to my symptoms:
The kernel was built locally, though different kernels (including a debian Stable one) have been tried.
I _have_ had such problems before, with various h/w & s/w including i915, but they'd all been eventually resolved.
intel_reg_dumper etc can be provided upon request.
Correction: The Display connector is VGA.
The symptoms toggle, between shifted and unshifted, every time startx is run. That is, one run will be shifted, and the next run will be unshifted.
The G41M + e3400 box used to run perfectly, in resolution and performance, in both Debian Stable and Debian Testing. Its recent failure was due only to another Testing upgrade.
With Debian 6.0, Stable, the error string
[drm:i915_init] *ERROR* drm/i915 can't work without intel_agp module!
does not occur in syslog. However, everything else (shifting, resolution, performance) does. The behaviour has been consistent for months.
- As usual, glxnfo shows:
direct rendering: Yes
OpenGL renderer string: Software Rasterizer
- xvinfo shows:
X-Video Extension version 2.2
no adaptors present
- and xdriinfo shows:
Screen 0: not direct rendering capable.
Could you please attach the output of 'lspci -nn' as well?
(In reply to comment #8)
> Could you please attach the output of 'lspci -nn' as well?
Created attachment 62167 [details]
Looks like you are missing something in your kernel build.. Could you please also attach your kernel .config file, and lsmod output?
Created attachment 62168 [details]
Created attachment 62169 [details]
The kernel was locally built, and has far more stuff than it ought to.
Created attachment 62170 [details]
The kernel was locally built, and has far too much stuff than it ought to.
Created attachment 62175 [details] [review]
Streamline agp-intel find
Step 1, can you please apply this patch.
Step 2, instrument the find function with all the pdev->vendor / pdev->device / pdev->class / pdev->devfn that is tries to match against.
Created attachment 62176 [details] [review]
Check for another host bridge
Additionally, could you please try with this patch and check if it makes things work?
I'll apply the patches later today, and will update you.
Bad news. The box died. Testing with different motherboards point to the CPU, though this is not definitive (because mobos are not consistent with respect to their beeps and interaction with the power supply.)
So I can no longer reproduce the problem. The patch had not been applied.
Thanks for you help, though.
Ok I'll close this as invalid because the box died. Thanks for reporting this issue and please reopen this bug if the problem happens again (on fixed hw).
Note, if we can confirm the 0x0069 HostBridge then Eugeni's patch should go upstream. And mine if you don't like O(nm) searches ;-)
"The re-animation of dead tissue!"
Don't ask me how -- I've given on the reliability of post-Pentium x86 hardware! -- but the box came back up again!
I applied both patches. Now, the i915 module does get loaded, but startx hangs. I will attach some files, but I have not managed to figure out how to "instrument" the code as Chris Wilson asked. In syslog it shows that it finds the 00:02.0 graphics controller. So please clarify what you want done.
Created attachment 62621 [details]
syslog, patches applied.
Older, earlier, parts of syslog have been edited out.
Created attachment 62622 [details]
lsmod, patches applied.
Created attachment 62623 [details]
dmesg, patches applied.
Created attachment 62624 [details]
lspci -vv, patches applied.
Created attachment 62625 [details]
Xorg.0.log, patches applied.
I run 'startx'. It ends up with a non-blinking cursor on the top left-hand side of the screen. The box continues to run fine (when connected-to remotely), but there is no response on the display, and I find no /usr/bin/X process to kill.
Ok, that sounds like X crashed during startup. Can you also attach your gdm.log (or equivalent kdm.log, xdm.log etc) as the fault doesn't appear in the Xorg.log and so I hope it went to stderr instead...
(In reply to comment #27)
> Ok, that sounds like X crashed during startup. Can you also attach your gdm.log
> (or equivalent kdm.log, xdm.log etc) as the fault doesn't appear in the
> Xorg.log and so I hope it went to stderr instead...
Good tip. Thanks.
There is no display manager, but I caught the stderr+stdin of startx anyway. See attachment; there seems to be an undefined symbol:
/usr/bin/X: symbol lookup error: /usr/lib/xorg/modules/drivers/intel_drv.so: undefined symbol: drm_intel_bufmgr_gem_set_vma_cache_size
I updated the driver just today, but it did not help.
I am assuming that I may need to contact the Debian crew for this matter.
In the next few days, I will see if I can try this hardware with Debian Stable. As the patches have caused the i915 driver to be loaded, then I suppose there has been some progress.
Thanks for your help.
Created attachment 62664 [details]
startx's stderr & stdin
The capture command was something like
startx > startx_stdin_stderr_W06jun2012 2>&1
If you update libdrm_intel, that should resolve the missing symbol. drm_intel_bufmgr_gem_set_vma_cache_size was introduced in libdrm_intel-2.4.29
(In reply to comment #30)
> If you update libdrm_intel, that should resolve the missing symbol.
> drm_intel_bufmgr_gem_set_vma_cache_size was introduced in libdrm_intel-2.4.29
It's already at
On Wed, Jun 6, 2012 at 1:29 PM, <email@example.com> wrote:
> --- Comment #31 from Ali Bahar <firstname.lastname@example.org> 2012-06-06 04:29:30 PDT ---
> (In reply to comment #30)
>> If you update libdrm_intel, that should resolve the missing symbol.
>> drm_intel_bufmgr_gem_set_vma_cache_size was introduced in libdrm_intel-2.4.29
> It's already at
> Package: libdrm-intel1
> Version: 2.4.33-1
> and installed.
Well, that missing symbol is in libdrm-intel1 and Xorg can't find it.
So something has gone wrong with your install. Can you please check
what ldd says for your intel_drv.so (i.e. the xf86-video-intel driver
you've manually installed) and whether it indeed links to the libdrm
that you've compiled and installed?
(In reply to comment #32)
> Well, that missing symbol is in libdrm-intel1 and Xorg can't find it.
> So something has gone wrong with your install. Can you please check
Yes, I'd thought so. Hence the plan to test Debian Stable.
> what ldd says for your intel_drv.so (i.e. the xf86-video-intel driver
> you've manually installed) and whether it indeed links to the libdrm
> that you've compiled and installed?
You're right on the mark. ldd showed that forgotten libdrm libs from /usr/local/ were being used. Removing them has now restored proper display. No shifting, high resolution, 'ico' runs blazing fast again, and xvinfo/xdriinfo/glxinfo/vainfo seem to find everything. glxgears is running at suspiciously low FPS, but I do not know enough to consider this a problem.
So, the patches were key to the fix, of course. And, on my particular box, old DRM libs (from Nov. 2011) needed to be upgraded.
Thanks very much for all your help. I will close this bug.
The patches seem to have fixed the problem.
(In my particular case, some stale libdrm files were hiding around as well.)
A patch referencing this bug report has been merged in Linux v3.5-rc2:
Author: Eugeni Dodonov <email@example.com>
Date: Wed Jun 6 11:59:06 2012 -0300
char/agp: add another Ironlake host bridge