summaryrefslogtreecommitdiffstats
path: root/freed-ora
diff options
context:
space:
mode:
Diffstat (limited to 'freed-ora')
-rw-r--r--freed-ora/current/f15/drm-i915-snb-irq-stalls-fix.patch53
-rw-r--r--freed-ora/current/f15/drm-radeon-update3.patch820
-rw-r--r--freed-ora/current/f15/hid-ntrig-deref-unclaimed-input.patch46
-rw-r--r--freed-ora/current/f15/kernel.spec20
4 files changed, 938 insertions, 1 deletions
diff --git a/freed-ora/current/f15/drm-i915-snb-irq-stalls-fix.patch b/freed-ora/current/f15/drm-i915-snb-irq-stalls-fix.patch
new file mode 100644
index 000000000..acf64da47
--- /dev/null
+++ b/freed-ora/current/f15/drm-i915-snb-irq-stalls-fix.patch
@@ -0,0 +1,53 @@
+commit 498e720b96379d8ee9c294950a01534a73defcf3
+Author: Daniel J Blueman <daniel.blueman@gmail.com>
+Date: Fri Jun 17 11:32:19 2011 -0700
+
+ drm/i915: Fix gen6 (SNB) missed BLT ring interrupts.
+
+ The failure appeared in dmesg as:
+
+ [drm:i915_hangcheck_ring_idle] *ERROR* Hangcheck timer elapsed... blt
+ ring idle [waiting on 35064155, at 35064155], missed IRQ?
+
+ This works around that problem on by making the blitter command
+ streamer write interrupt state to the Hardware Status Page when a
+ MI_USER_INTERRUPT command is decoded, which appears to force the seqno
+ out to memory before the interrupt happens.
+
+ v1->v2: Moved to prior interrupt handler installation and RMW flags as
+ per feedback.
+ v2->v3: Removed RMW of flags (by anholt)
+
+ Cc: stable@kernel.org
+ Signed-off-by: Daniel J Blueman <daniel.blueman@gmail.com>
+ Signed-off-by: Eric Anholt <eric@anholt.net>
+ Tested-by: Chris Wilson <chris@chris-wilson.co.uk> [v1]
+ Tested-by: Eric Anholt <eric@anholt.net> [v1,v3]
+ (incidence of the bug with a testcase went from avg 2/1000 to
+ 0/12651 in the latest test run (plus more for v1))
+ Tested-by: Kenneth Graunke <kenneth@whitecape.org> [v1]
+ Tested-by: Robert Hooker <robert.hooker@canonical.com> [v1]
+ Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=33394
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c
+index b9fafe3..9e34a1a 100644
+--- a/drivers/gpu/drm/i915/i915_irq.c
++++ b/drivers/gpu/drm/i915/i915_irq.c
+@@ -1740,6 +1740,16 @@ void ironlake_irq_preinstall(struct drm_device *dev)
+ INIT_WORK(&dev_priv->rps_work, gen6_pm_rps_work);
+
+ I915_WRITE(HWSTAM, 0xeffe);
++ if (IS_GEN6(dev)) {
++ /* Workaround stalls observed on Sandy Bridge GPUs by
++ * making the blitter command streamer generate a
++ * write to the Hardware Status Page for
++ * MI_USER_INTERRUPT. This appears to serialize the
++ * previous seqno write out before the interrupt
++ * happens.
++ */
++ I915_WRITE(GEN6_BLITTER_HWSTAM, ~GEN6_BLITTER_USER_INTERRUPT);
++ }
+
+ /* XXX hotplug from PCH */
+
diff --git a/freed-ora/current/f15/drm-radeon-update3.patch b/freed-ora/current/f15/drm-radeon-update3.patch
new file mode 100644
index 000000000..626ccdc4b
--- /dev/null
+++ b/freed-ora/current/f15/drm-radeon-update3.patch
@@ -0,0 +1,820 @@
+commit 3c79cf677a2eca93762d15f69744937d43185573
+Author: Alex Deucher <alexdeucher@gmail.com>
+Date: Thu Jun 23 12:19:32 2011 -0400
+
+ drm/radeon/kms: handle special cases for vddc
+
+ A voltage value of 0xff01 requires that the driver
+ look up the max voltage for the board based using the
+ atom SetVoltage command table.
+
+ Setting the proper voltage should fix stability on
+ some newer asics.
+
+ Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+commit 63311583922e52b7687233c18e9eebe83207d2e8
+Author: Alex Deucher <alexdeucher@gmail.com>
+Date: Thu Jun 23 00:49:29 2011 -0400
+
+ drm/radeon/kms: fix num_banks tiling config for fusion
+
+ The field is encoded:
+ 0 = 4 banks
+ 1 = 8 banks
+ 2 = 16 banks
+
+ Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+commit 1421991c155016ce31777d09ebfdfe3eb04cb78c
+Author: Alex Deucher <alexdeucher@gmail.com>
+Date: Mon Jun 20 13:00:31 2011 -0400
+
+ drm/radeon/kms/r6xx+: voltage fixes
+
+ 0xff01 is not an actual voltage value, but a flag
+ for the driver. If the power state as that value,
+ skip setting the voltage.
+
+ Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+commit a7b65dda144af8ba443f1745875440c87a41b0a3
+Author: Dave Airlie <airlied@redhat.com>
+Date: Sat Jun 18 03:59:51 2011 +0000
+
+ drm/radeon: avoid warnings from r600/eg irq handlers on powered off card.
+
+ Since we were calling the wptr function before checking if the IH was
+ even enabled, or the GPU wasn't shutdown, we'd get spam in the logs when
+ the GPU readback 0xffffffff. This reorders things so we return early
+ in the no IH and GPU shutdown cases.
+
+ Reported-and-tested-by: ManDay on #radeon
+ Reviewed-by: Alex Deucher <alexdeucher@gmail.com>
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+commit 3f662051e0acf55bc8c2ea246c9f05e004a2d698
+Author: Alex Deucher <alexdeucher@gmail.com>
+Date: Fri Jun 17 06:11:30 2011 +0000
+
+ drm/radeon/kms: add missing param for dce3.2 DP transmitter setup
+
+ This is used during phy init to set up the phy for DP. This may
+ fix DP problems on DCE3.2 cards.
+
+ Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+commit dc4f34ba0796f4b09501b035825c02c405335063
+Author: Alex Deucher <alexdeucher@gmail.com>
+Date: Fri Jun 17 13:13:52 2011 -0400
+
+ drm/radeon/kms/atom: fix duallink on some early DCE3.2 cards
+
+ Certain revisions of the vbios on DCE3.2 cards have a bug
+ in the transmitter control table which prevents duallink from
+ being enabled properly on some cards. The action switch statement
+ jumps to the wrong offset for the OUTPUT_ENABLE action. The fix
+ is to use the ENABLE action rather than the OUTPUT_ENABLE action
+ on the affected cards. In fixed version of the vbios, both
+ actions jump to the same offset, so the change should be safe.
+
+ Reported-and-tested-by: Dave Airlie <airlied@redhat.com>
+ Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
+ Cc: stable@kernel.org
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+commit b5097472f2119480f60657f92b17dd79bcf8e24a
+Author: Alex Deucher <alexdeucher@gmail.com>
+Date: Mon Jun 13 17:39:06 2011 -0400
+
+ drm/radeon/kms: use helper functions for fence read/write
+
+ The existing code assumed scratch registers in a number
+ of places while in most cases we are be using writeback
+ and events rather than scratch registers.
+
+ Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+commit 4414ac4ea84407d14e9fde512c1c229f9cfc96c4
+Author: Alex Deucher <alexdeucher@gmail.com>
+Date: Thu Jun 16 18:14:22 2011 +0000
+
+ drm/radeon/kms: fix num crtcs for Cedar and Caicos
+
+ Only support 4 rather than 6.
+
+ Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+commit c4eee24a87a71c14f223e85065cccea6bf32321d
+Author: Alex Deucher <alexdeucher@gmail.com>
+Date: Mon Jun 13 22:02:51 2011 +0000
+
+ drm/radeon/kms: clear wb memory by default
+
+ Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+commit 12ca85df2db5988ea5c53d0ee53ff1b1cf1257fd
+Author: Alex Deucher <alexdeucher@gmail.com>
+Date: Tue Jun 14 19:15:53 2011 +0000
+
+ drm/radeon/kms: signed fix for evergreen thermal
+
+ temperature is signed.
+
+ Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+commit dd53acd144d8fa6385e50949f4f635890420ba0b
+Author: Alex Deucher <alexdeucher@gmail.com>
+Date: Wed Jun 8 13:01:11 2011 -0400
+
+ drm/radeon/kms: check modes against max pixel clock
+
+ Filter out modes that are higher than the max pixel
+ clock.
+
+ Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+commit a812b560d0d041f2318ae4243ead692e26bae429
+Author: Daniel Haid <d.haid@gogi.tv>
+Date: Wed Jun 8 20:04:45 2011 +1000
+
+ drm/radeon/kms: fix for radeon on systems >4GB without hardware iommu
+
+ On my x86_64 system with >4GB of ram and swiotlb instead of
+ a hardware iommu (because I have a VIA chipset), the call
+ to pci_set_dma_mask (see below) with 40bits returns an error.
+
+ But it seems that the radeon driver is designed to have
+ need_dma32 = true exactly if pci_set_dma_mask is called
+ with 32 bits and false if it is called with 40 bits.
+
+ I have read somewhere that the default are 32 bits. So if the
+ call fails I suppose that need_dma32 should be set to true.
+
+ And indeed the patch fixes the problem I have had before
+ and which I had described here:
+ http://choon.net/forum/read.php?21,106131,115940
+
+ Acked-by: Alex Deucher <alexdeucher@gmail.com>
+ cc: stable@kernel.org
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+commit 262016fe924bbc06d50bcfc816c635d465cd503d
+Author: Alex Deucher <alexdeucher@gmail.com>
+Date: Fri May 27 10:05:03 2011 -0400
+
+ drm/radeon/kms: viewport height has to be even
+
+ Otherwise, no vblank interrupts.
+ Fixes:
+ https://bugs.freedesktop.org/show_bug.cgi?id=37522
+
+ Signed-off-by: Alex Deucher <alexdeucher@gmail.com>
+ Cc: stable@kernel.org
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+
+commit 36b3cb168810e68ae8dd2036189c4f2cfc0c6d49
+Author: Marek Olšák <maraeo@gmail.com>
+Date: Fri Jun 10 14:41:26 2011 +0000
+
+ drm/radeon/kms: do bounds checking for 3D_LOAD_VBPNTR and bump array limit
+
+ To my knowledge, the limit is 16 on r300.
+ (the docs don't say what the limit is)
+
+ The lack of bounds checking can be abused to do all sorts of things
+ (from bypassing parts of the CS checker to crashing the kernel).
+
+ Bugzilla:
+ https://bugs.freedesktop.org/show_bug.cgi?id=36745
+
+ Cc: stable@kernel.org
+ Signed-off-by: Marek Olšák <maraeo@gmail.com>
+ Signed-off-by: Dave Airlie <airlied@redhat.com>
+diff --git a/drivers/gpu/drm/radeon/atombios_crtc.c b/drivers/gpu/drm/radeon/atombios_crtc.c
+index 2bab32f..1fce6b7 100644
+--- a/drivers/gpu/drm/radeon/atombios_crtc.c
++++ b/drivers/gpu/drm/radeon/atombios_crtc.c
+@@ -1011,7 +1011,7 @@ static int dce4_crtc_do_set_base(struct drm_crtc *crtc,
+ uint64_t fb_location;
+ uint32_t fb_format, fb_pitch_pixels, tiling_flags;
+ u32 fb_swap = EVERGREEN_GRPH_ENDIAN_SWAP(EVERGREEN_GRPH_ENDIAN_NONE);
+- u32 tmp;
++ u32 tmp, viewport_w, viewport_h;
+ int r;
+
+ /* no fb bound */
+@@ -1137,8 +1137,10 @@ static int dce4_crtc_do_set_base(struct drm_crtc *crtc,
+ y &= ~1;
+ WREG32(EVERGREEN_VIEWPORT_START + radeon_crtc->crtc_offset,
+ (x << 16) | y);
++ viewport_w = crtc->mode.hdisplay;
++ viewport_h = (crtc->mode.vdisplay + 1) & ~1;
+ WREG32(EVERGREEN_VIEWPORT_SIZE + radeon_crtc->crtc_offset,
+- (crtc->mode.hdisplay << 16) | crtc->mode.vdisplay);
++ (viewport_w << 16) | viewport_h);
+
+ /* pageflip setup */
+ /* make sure flip is at vb rather than hb */
+@@ -1179,7 +1181,7 @@ static int avivo_crtc_do_set_base(struct drm_crtc *crtc,
+ uint64_t fb_location;
+ uint32_t fb_format, fb_pitch_pixels, tiling_flags;
+ u32 fb_swap = R600_D1GRPH_SWAP_ENDIAN_NONE;
+- u32 tmp;
++ u32 tmp, viewport_w, viewport_h;
+ int r;
+
+ /* no fb bound */
+@@ -1304,8 +1306,10 @@ static int avivo_crtc_do_set_base(struct drm_crtc *crtc,
+ y &= ~1;
+ WREG32(AVIVO_D1MODE_VIEWPORT_START + radeon_crtc->crtc_offset,
+ (x << 16) | y);
++ viewport_w = crtc->mode.hdisplay;
++ viewport_h = (crtc->mode.vdisplay + 1) & ~1;
+ WREG32(AVIVO_D1MODE_VIEWPORT_SIZE + radeon_crtc->crtc_offset,
+- (crtc->mode.hdisplay << 16) | crtc->mode.vdisplay);
++ (viewport_w << 16) | viewport_h);
+
+ /* pageflip setup */
+ /* make sure flip is at vb rather than hb */
+diff --git a/drivers/gpu/drm/radeon/evergreen.c b/drivers/gpu/drm/radeon/evergreen.c
+index 1b583f8..81f5211 100644
+--- a/drivers/gpu/drm/radeon/evergreen.c
++++ b/drivers/gpu/drm/radeon/evergreen.c
+@@ -88,7 +88,8 @@ u32 evergreen_page_flip(struct radeon_device *rdev, int crtc_id, u64 crtc_base)
+ /* get temperature in millidegrees */
+ int evergreen_get_temp(struct radeon_device *rdev)
+ {
+- u32 temp, toffset, actual_temp = 0;
++ u32 temp, toffset;
++ int actual_temp = 0;
+
+ if (rdev->family == CHIP_JUNIPER) {
+ toffset = (RREG32(CG_THERMAL_CTRL) & TOFFSET_MASK) >>
+@@ -139,11 +140,17 @@ void evergreen_pm_misc(struct radeon_device *rdev)
+ struct radeon_voltage *voltage = &ps->clock_info[req_cm_idx].voltage;
+
+ if (voltage->type == VOLTAGE_SW) {
++ /* 0xff01 is a flag rather then an actual voltage */
++ if (voltage->voltage == 0xff01)
++ return;
+ if (voltage->voltage && (voltage->voltage != rdev->pm.current_vddc)) {
+ radeon_atom_set_voltage(rdev, voltage->voltage, SET_VOLTAGE_TYPE_ASIC_VDDC);
+ rdev->pm.current_vddc = voltage->voltage;
+ DRM_DEBUG("Setting: vddc: %d\n", voltage->voltage);
+ }
++ /* 0xff01 is a flag rather then an actual voltage */
++ if (voltage->vddci == 0xff01)
++ return;
+ if (voltage->vddci && (voltage->vddci != rdev->pm.current_vddci)) {
+ radeon_atom_set_voltage(rdev, voltage->vddci, SET_VOLTAGE_TYPE_ASIC_VDDCI);
+ rdev->pm.current_vddci = voltage->vddci;
+@@ -1954,9 +1961,9 @@ static void evergreen_gpu_init(struct radeon_device *rdev)
+ rdev->config.evergreen.tile_config |= (3 << 0);
+ break;
+ }
+- /* num banks is 8 on all fusion asics */
++ /* num banks is 8 on all fusion asics. 0 = 4, 1 = 8, 2 = 16 */
+ if (rdev->flags & RADEON_IS_IGP)
+- rdev->config.evergreen.tile_config |= 8 << 4;
++ rdev->config.evergreen.tile_config |= 1 << 4;
+ else
+ rdev->config.evergreen.tile_config |=
+ ((mc_arb_ramcfg & NOOFBANK_MASK) >> NOOFBANK_SHIFT) << 4;
+@@ -2636,28 +2643,25 @@ static inline u32 evergreen_get_ih_wptr(struct radeon_device *rdev)
+
+ int evergreen_irq_process(struct radeon_device *rdev)
+ {
+- u32 wptr = evergreen_get_ih_wptr(rdev);
+- u32 rptr = rdev->ih.rptr;
++ u32 wptr;
++ u32 rptr;
+ u32 src_id, src_data;
+ u32 ring_index;
+ unsigned long flags;
+ bool queue_hotplug = false;
+
+- DRM_DEBUG("r600_irq_process start: rptr %d, wptr %d\n", rptr, wptr);
+- if (!rdev->ih.enabled)
++ if (!rdev->ih.enabled || rdev->shutdown)
+ return IRQ_NONE;
+
+- spin_lock_irqsave(&rdev->ih.lock, flags);
++ wptr = evergreen_get_ih_wptr(rdev);
++ rptr = rdev->ih.rptr;
++ DRM_DEBUG("r600_irq_process start: rptr %d, wptr %d\n", rptr, wptr);
+
++ spin_lock_irqsave(&rdev->ih.lock, flags);
+ if (rptr == wptr) {
+ spin_unlock_irqrestore(&rdev->ih.lock, flags);
+ return IRQ_NONE;
+ }
+- if (rdev->shutdown) {
+- spin_unlock_irqrestore(&rdev->ih.lock, flags);
+- return IRQ_NONE;
+- }
+-
+ restart_ih:
+ /* display interrupts */
+ evergreen_irq_ack(rdev);
+diff --git a/drivers/gpu/drm/radeon/r100_track.h b/drivers/gpu/drm/radeon/r100_track.h
+index 2fef9de..686f9dc 100644
+--- a/drivers/gpu/drm/radeon/r100_track.h
++++ b/drivers/gpu/drm/radeon/r100_track.h
+@@ -63,7 +63,7 @@ struct r100_cs_track {
+ unsigned num_arrays;
+ unsigned max_indx;
+ unsigned color_channel_mask;
+- struct r100_cs_track_array arrays[11];
++ struct r100_cs_track_array arrays[16];
+ struct r100_cs_track_cb cb[R300_MAX_CB];
+ struct r100_cs_track_cb zb;
+ struct r100_cs_track_cb aa;
+@@ -146,6 +146,12 @@ static inline int r100_packet3_load_vbpntr(struct radeon_cs_parser *p,
+ ib = p->ib->ptr;
+ track = (struct r100_cs_track *)p->track;
+ c = radeon_get_ib_value(p, idx++) & 0x1F;
++ if (c > 16) {
++ DRM_ERROR("Only 16 vertex buffers are allowed %d\n",
++ pkt->opcode);
++ r100_cs_dump_packet(p, pkt);
++ return -EINVAL;
++ }
+ track->num_arrays = c;
+ for (i = 0; i < (c - 1); i+=2, idx+=3) {
+ r = r100_cs_packet_next_reloc(p, &reloc);
+diff --git a/drivers/gpu/drm/radeon/r600.c b/drivers/gpu/drm/radeon/r600.c
+index 70e9fb0..e7157b7 100644
+--- a/drivers/gpu/drm/radeon/r600.c
++++ b/drivers/gpu/drm/radeon/r600.c
+@@ -586,6 +586,9 @@ void r600_pm_misc(struct radeon_device *rdev)
+ struct radeon_voltage *voltage = &ps->clock_info[req_cm_idx].voltage;
+
+ if ((voltage->type == VOLTAGE_SW) && voltage->voltage) {
++ /* 0xff01 is a flag rather then an actual voltage */
++ if (voltage->voltage == 0xff01)
++ return;
+ if (voltage->voltage != rdev->pm.current_vddc) {
+ radeon_atom_set_voltage(rdev, voltage->voltage, SET_VOLTAGE_TYPE_ASIC_VDDC);
+ rdev->pm.current_vddc = voltage->voltage;
+@@ -3286,27 +3289,26 @@ static inline u32 r600_get_ih_wptr(struct radeon_device *rdev)
+
+ int r600_irq_process(struct radeon_device *rdev)
+ {
+- u32 wptr = r600_get_ih_wptr(rdev);
+- u32 rptr = rdev->ih.rptr;
++ u32 wptr;
++ u32 rptr;
+ u32 src_id, src_data;
+ u32 ring_index;
+ unsigned long flags;
+ bool queue_hotplug = false;
+
+- DRM_DEBUG("r600_irq_process start: rptr %d, wptr %d\n", rptr, wptr);
+- if (!rdev->ih.enabled)
++ if (!rdev->ih.enabled || rdev->shutdown)
+ return IRQ_NONE;
+
++ wptr = r600_get_ih_wptr(rdev);
++ rptr = rdev->ih.rptr;
++ DRM_DEBUG("r600_irq_process start: rptr %d, wptr %d\n", rptr, wptr);
++
+ spin_lock_irqsave(&rdev->ih.lock, flags);
+
+ if (rptr == wptr) {
+ spin_unlock_irqrestore(&rdev->ih.lock, flags);
+ return IRQ_NONE;
+ }
+- if (rdev->shutdown) {
+- spin_unlock_irqrestore(&rdev->ih.lock, flags);
+- return IRQ_NONE;
+- }
+
+ restart_ih:
+ /* display interrupts */
+diff --git a/drivers/gpu/drm/radeon/radeon.h b/drivers/gpu/drm/radeon/radeon.h
+index 27df931..c46552d 100644
+--- a/drivers/gpu/drm/radeon/radeon.h
++++ b/drivers/gpu/drm/radeon/radeon.h
+@@ -165,6 +165,7 @@ struct radeon_clock {
+ uint32_t default_sclk;
+ uint32_t default_dispclk;
+ uint32_t dp_extclk;
++ uint32_t max_pixel_clock;
+ };
+
+ /*
+@@ -178,6 +179,7 @@ void radeon_pm_resume(struct radeon_device *rdev);
+ void radeon_combios_get_power_modes(struct radeon_device *rdev);
+ void radeon_atombios_get_power_modes(struct radeon_device *rdev);
+ void radeon_atom_set_voltage(struct radeon_device *rdev, u16 voltage_level, u8 voltage_type);
++int radeon_atom_get_max_vddc(struct radeon_device *rdev, u16 *voltage);
+ void rs690_pm_info(struct radeon_device *rdev);
+ extern int rv6xx_get_temp(struct radeon_device *rdev);
+ extern int rv770_get_temp(struct radeon_device *rdev);
+diff --git a/drivers/gpu/drm/radeon/radeon_asic.c b/drivers/gpu/drm/radeon/radeon_asic.c
+index b9b3c2a..6f5bd29 100644
+--- a/drivers/gpu/drm/radeon/radeon_asic.c
++++ b/drivers/gpu/drm/radeon/radeon_asic.c
+@@ -938,6 +938,13 @@ static struct radeon_asic cayman_asic = {
+ int radeon_asic_init(struct radeon_device *rdev)
+ {
+ radeon_register_accessor_init(rdev);
++
++ /* set the number of crtcs */
++ if (rdev->flags & RADEON_SINGLE_CRTC)
++ rdev->num_crtc = 1;
++ else
++ rdev->num_crtc = 2;
++
+ switch (rdev->family) {
+ case CHIP_R100:
+ case CHIP_RV100:
+@@ -1017,6 +1024,11 @@ int radeon_asic_init(struct radeon_device *rdev)
+ case CHIP_JUNIPER:
+ case CHIP_CYPRESS:
+ case CHIP_HEMLOCK:
++ /* set num crtcs */
++ if (rdev->family == CHIP_CEDAR)
++ rdev->num_crtc = 4;
++ else
++ rdev->num_crtc = 6;
+ rdev->asic = &evergreen_asic;
+ break;
+ case CHIP_PALM:
+@@ -1025,10 +1037,17 @@ int radeon_asic_init(struct radeon_device *rdev)
+ case CHIP_BARTS:
+ case CHIP_TURKS:
+ case CHIP_CAICOS:
++ /* set num crtcs */
++ if (rdev->family == CHIP_CAICOS)
++ rdev->num_crtc = 4;
++ else
++ rdev->num_crtc = 6;
+ rdev->asic = &btc_asic;
+ break;
+ case CHIP_CAYMAN:
+ rdev->asic = &cayman_asic;
++ /* set num crtcs */
++ rdev->num_crtc = 6;
+ break;
+ default:
+ /* FIXME: not supported yet */
+@@ -1040,18 +1059,6 @@ int radeon_asic_init(struct radeon_device *rdev)
+ rdev->asic->set_memory_clock = NULL;
+ }
+
+- /* set the number of crtcs */
+- if (rdev->flags & RADEON_SINGLE_CRTC)
+- rdev->num_crtc = 1;
+- else {
+- if (ASIC_IS_DCE41(rdev))
+- rdev->num_crtc = 2;
+- else if (ASIC_IS_DCE4(rdev))
+- rdev->num_crtc = 6;
+- else
+- rdev->num_crtc = 2;
+- }
+-
+ return 0;
+ }
+
+diff --git a/drivers/gpu/drm/radeon/radeon_atombios.c b/drivers/gpu/drm/radeon/radeon_atombios.c
+index f116516..ce861ff 100644
+--- a/drivers/gpu/drm/radeon/radeon_atombios.c
++++ b/drivers/gpu/drm/radeon/radeon_atombios.c
+@@ -1246,6 +1246,10 @@ bool radeon_atom_get_clock_info(struct drm_device *dev)
+ }
+ *dcpll = *p1pll;
+
++ rdev->clock.max_pixel_clock = le16_to_cpu(firmware_info->info.usMaxPixelClock);
++ if (rdev->clock.max_pixel_clock == 0)
++ rdev->clock.max_pixel_clock = 40000;
++
+ return true;
+ }
+
+@@ -2308,6 +2312,14 @@ static bool radeon_atombios_parse_pplib_clock_info(struct radeon_device *rdev,
+ le16_to_cpu(clock_info->r600.usVDDC);
+ }
+
++ /* patch up vddc if necessary */
++ if (rdev->pm.power_state[state_index].clock_info[mode_index].voltage.voltage == 0xff01) {
++ u16 vddc;
++
++ if (radeon_atom_get_max_vddc(rdev, &vddc) == 0)
++ rdev->pm.power_state[state_index].clock_info[mode_index].voltage.voltage = vddc;
++ }
++
+ if (rdev->flags & RADEON_IS_IGP) {
+ /* skip invalid modes */
+ if (rdev->pm.power_state[state_index].clock_info[mode_index].sclk == 0)
+@@ -2595,6 +2607,10 @@ void radeon_atom_set_voltage(struct radeon_device *rdev, u16 voltage_level, u8 v
+ if (!atom_parse_cmd_header(rdev->mode_info.atom_context, index, &frev, &crev))
+ return;
+
++ /* 0xff01 is a flag rather then an actual voltage */
++ if (voltage_level == 0xff01)
++ return;
++
+ switch (crev) {
+ case 1:
+ args.v1.ucVoltageType = voltage_type;
+@@ -2614,7 +2630,35 @@ void radeon_atom_set_voltage(struct radeon_device *rdev, u16 voltage_level, u8 v
+ atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args);
+ }
+
++int radeon_atom_get_max_vddc(struct radeon_device *rdev,
++ u16 *voltage)
++{
++ union set_voltage args;
++ int index = GetIndexIntoMasterTable(COMMAND, SetVoltage);
++ u8 frev, crev;
++
++ if (!atom_parse_cmd_header(rdev->mode_info.atom_context, index, &frev, &crev))
++ return -EINVAL;
+
++ switch (crev) {
++ case 1:
++ return -EINVAL;
++ case 2:
++ args.v2.ucVoltageType = SET_VOLTAGE_GET_MAX_VOLTAGE;
++ args.v2.ucVoltageMode = 0;
++ args.v2.usVoltageLevel = 0;
++
++ atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args);
++
++ *voltage = le16_to_cpu(args.v2.usVoltageLevel);
++ break;
++ default:
++ DRM_ERROR("Unknown table version %d, %d\n", frev, crev);
++ return -EINVAL;
++ }
++
++ return 0;
++}
+
+ void radeon_atom_initialize_bios_scratch_regs(struct drm_device *dev)
+ {
+diff --git a/drivers/gpu/drm/radeon/radeon_clocks.c b/drivers/gpu/drm/radeon/radeon_clocks.c
+index 5249af8..2d48e7a 100644
+--- a/drivers/gpu/drm/radeon/radeon_clocks.c
++++ b/drivers/gpu/drm/radeon/radeon_clocks.c
+@@ -117,7 +117,7 @@ static bool __devinit radeon_read_clocks_OF(struct drm_device *dev)
+ p1pll->reference_div = RREG32_PLL(RADEON_PPLL_REF_DIV) & 0x3ff;
+ if (p1pll->reference_div < 2)
+ p1pll->reference_div = 12;
+- p2pll->reference_div = p1pll->reference_div;
++ p2pll->reference_div = p1pll->reference_div;
+
+ /* These aren't in the device-tree */
+ if (rdev->family >= CHIP_R420) {
+@@ -139,6 +139,8 @@ static bool __devinit radeon_read_clocks_OF(struct drm_device *dev)
+ p2pll->pll_out_min = 12500;
+ p2pll->pll_out_max = 35000;
+ }
++ /* not sure what the max should be in all cases */
++ rdev->clock.max_pixel_clock = 35000;
+
+ spll->reference_freq = mpll->reference_freq = p1pll->reference_freq;
+ spll->reference_div = mpll->reference_div =
+@@ -151,7 +153,7 @@ static bool __devinit radeon_read_clocks_OF(struct drm_device *dev)
+ else
+ rdev->clock.default_sclk =
+ radeon_legacy_get_engine_clock(rdev);
+-
++
+ val = of_get_property(dp, "ATY,MCLK", NULL);
+ if (val && *val)
+ rdev->clock.default_mclk = (*val) / 10;
+@@ -160,7 +162,7 @@ static bool __devinit radeon_read_clocks_OF(struct drm_device *dev)
+ radeon_legacy_get_memory_clock(rdev);
+
+ DRM_INFO("Using device-tree clock info\n");
+-
++
+ return true;
+ }
+ #else
+diff --git a/drivers/gpu/drm/radeon/radeon_combios.c b/drivers/gpu/drm/radeon/radeon_combios.c
+index 089ab92..8a53691 100644
+--- a/drivers/gpu/drm/radeon/radeon_combios.c
++++ b/drivers/gpu/drm/radeon/radeon_combios.c
+@@ -833,6 +833,11 @@ bool radeon_combios_get_clock_info(struct drm_device *dev)
+ rdev->clock.default_sclk = sclk;
+ rdev->clock.default_mclk = mclk;
+
++ if (RBIOS32(pll_info + 0x16))
++ rdev->clock.max_pixel_clock = RBIOS32(pll_info + 0x16);
++ else
++ rdev->clock.max_pixel_clock = 35000; /* might need something asic specific */
++
+ return true;
+ }
+ return false;
+diff --git a/drivers/gpu/drm/radeon/radeon_connectors.c b/drivers/gpu/drm/radeon/radeon_connectors.c
+index a186673..33cb72b 100644
+--- a/drivers/gpu/drm/radeon/radeon_connectors.c
++++ b/drivers/gpu/drm/radeon/radeon_connectors.c
+@@ -621,8 +621,14 @@ static int radeon_vga_get_modes(struct drm_connector *connector)
+ static int radeon_vga_mode_valid(struct drm_connector *connector,
+ struct drm_display_mode *mode)
+ {
++ struct drm_device *dev = connector->dev;
++ struct radeon_device *rdev = dev->dev_private;
++
+ /* XXX check mode bandwidth */
+- /* XXX verify against max DAC output frequency */
++
++ if ((mode->clock / 10) > rdev->clock.max_pixel_clock)
++ return MODE_CLOCK_HIGH;
++
+ return MODE_OK;
+ }
+
+@@ -1010,6 +1016,11 @@ static int radeon_dvi_mode_valid(struct drm_connector *connector,
+ } else
+ return MODE_CLOCK_HIGH;
+ }
++
++ /* check against the max pixel clock */
++ if ((mode->clock / 10) > rdev->clock.max_pixel_clock)
++ return MODE_CLOCK_HIGH;
++
+ return MODE_OK;
+ }
+
+diff --git a/drivers/gpu/drm/radeon/radeon_device.c b/drivers/gpu/drm/radeon/radeon_device.c
+index 207d43f..8a64a3b 100644
+--- a/drivers/gpu/drm/radeon/radeon_device.c
++++ b/drivers/gpu/drm/radeon/radeon_device.c
+@@ -213,6 +213,8 @@ int radeon_wb_init(struct radeon_device *rdev)
+ return r;
+ }
+
++ /* clear wb memory */
++ memset((char *)rdev->wb.wb, 0, RADEON_GPU_PAGE_SIZE);
+ /* disable event_write fences */
+ rdev->wb.use_event = false;
+ /* disabled via module param */
+@@ -752,6 +754,7 @@ int radeon_device_init(struct radeon_device *rdev,
+ dma_bits = rdev->need_dma32 ? 32 : 40;
+ r = pci_set_dma_mask(rdev->pdev, DMA_BIT_MASK(dma_bits));
+ if (r) {
++ rdev->need_dma32 = true;
+ printk(KERN_WARNING "radeon: No suitable DMA available.\n");
+ }
+
+diff --git a/drivers/gpu/drm/radeon/radeon_encoders.c b/drivers/gpu/drm/radeon/radeon_encoders.c
+index b427488..e2a1c7d 100644
+--- a/drivers/gpu/drm/radeon/radeon_encoders.c
++++ b/drivers/gpu/drm/radeon/radeon_encoders.c
+@@ -994,9 +994,10 @@ atombios_dig_transmitter_setup(struct drm_encoder *encoder, int action, uint8_t
+ break;
+ }
+
+- if (is_dp)
++ if (is_dp) {
+ args.v2.acConfig.fCoherentMode = 1;
+- else if (radeon_encoder->devices & (ATOM_DEVICE_DFP_SUPPORT)) {
++ args.v2.acConfig.fDPConnector = 1;
++ } else if (radeon_encoder->devices & (ATOM_DEVICE_DFP_SUPPORT)) {
+ if (dig->coherent_mode)
+ args.v2.acConfig.fCoherentMode = 1;
+ if (radeon_encoder->pixel_clock > 165000)
+@@ -1294,7 +1295,11 @@ radeon_atom_encoder_dpms(struct drm_encoder *encoder, int mode)
+ if (is_dig) {
+ switch (mode) {
+ case DRM_MODE_DPMS_ON:
+- atombios_dig_transmitter_setup(encoder, ATOM_TRANSMITTER_ACTION_ENABLE_OUTPUT, 0, 0);
++ /* some early dce3.2 boards have a bug in their transmitter control table */
++ if ((rdev->family == CHIP_RV710) || (rdev->family == CHIP_RV730))
++ atombios_dig_transmitter_setup(encoder, ATOM_TRANSMITTER_ACTION_ENABLE, 0, 0);
++ else
++ atombios_dig_transmitter_setup(encoder, ATOM_TRANSMITTER_ACTION_ENABLE_OUTPUT, 0, 0);
+ if (atombios_get_encoder_mode(encoder) == ATOM_ENCODER_MODE_DP) {
+ struct drm_connector *connector = radeon_get_connector_for_encoder(encoder);
+
+diff --git a/drivers/gpu/drm/radeon/radeon_fence.c b/drivers/gpu/drm/radeon/radeon_fence.c
+index 2b0ee62..3285de1 100644
+--- a/drivers/gpu/drm/radeon/radeon_fence.c
++++ b/drivers/gpu/drm/radeon/radeon_fence.c
+@@ -40,6 +40,35 @@
+ #include "radeon.h"
+ #include "radeon_trace.h"
+
++static void radeon_fence_write(struct radeon_device *rdev, u32 seq)
++{
++ if (rdev->wb.enabled) {
++ u32 scratch_index;
++ if (rdev->wb.use_event)
++ scratch_index = R600_WB_EVENT_OFFSET + rdev->fence_drv.scratch_reg - rdev->scratch.reg_base;
++ else
++ scratch_index = RADEON_WB_SCRATCH_OFFSET + rdev->fence_drv.scratch_reg - rdev->scratch.reg_base;
++ rdev->wb.wb[scratch_index/4] = cpu_to_le32(seq);;
++ } else
++ WREG32(rdev->fence_drv.scratch_reg, seq);
++}
++
++static u32 radeon_fence_read(struct radeon_device *rdev)
++{
++ u32 seq;
++
++ if (rdev->wb.enabled) {
++ u32 scratch_index;
++ if (rdev->wb.use_event)
++ scratch_index = R600_WB_EVENT_OFFSET + rdev->fence_drv.scratch_reg - rdev->scratch.reg_base;
++ else
++ scratch_index = RADEON_WB_SCRATCH_OFFSET + rdev->fence_drv.scratch_reg - rdev->scratch.reg_base;
++ seq = le32_to_cpu(rdev->wb.wb[scratch_index/4]);
++ } else
++ seq = RREG32(rdev->fence_drv.scratch_reg);
++ return seq;
++}
++
+ int radeon_fence_emit(struct radeon_device *rdev, struct radeon_fence *fence)
+ {
+ unsigned long irq_flags;
+@@ -50,12 +79,12 @@ int radeon_fence_emit(struct radeon_device *rdev, struct radeon_fence *fence)
+ return 0;
+ }
+ fence->seq = atomic_add_return(1, &rdev->fence_drv.seq);
+- if (!rdev->cp.ready) {
++ if (!rdev->cp.ready)
+ /* FIXME: cp is not running assume everythings is done right
+ * away
+ */
+- WREG32(rdev->fence_drv.scratch_reg, fence->seq);
+- } else
++ radeon_fence_write(rdev, fence->seq);
++ else
+ radeon_fence_ring_emit(rdev, fence);
+
+ trace_radeon_fence_emit(rdev->ddev, fence->seq);
+@@ -74,15 +103,7 @@ static bool radeon_fence_poll_locked(struct radeon_device *rdev)
+ bool wake = false;
+ unsigned long cjiffies;
+
+- if (rdev->wb.enabled) {
+- u32 scratch_index;
+- if (rdev->wb.use_event)
+- scratch_index = R600_WB_EVENT_OFFSET + rdev->fence_drv.scratch_reg - rdev->scratch.reg_base;
+- else
+- scratch_index = RADEON_WB_SCRATCH_OFFSET + rdev->fence_drv.scratch_reg - rdev->scratch.reg_base;
+- seq = le32_to_cpu(rdev->wb.wb[scratch_index/4]);
+- } else
+- seq = RREG32(rdev->fence_drv.scratch_reg);
++ seq = radeon_fence_read(rdev);
+ if (seq != rdev->fence_drv.last_seq) {
+ rdev->fence_drv.last_seq = seq;
+ rdev->fence_drv.last_jiffies = jiffies;
+@@ -253,7 +274,7 @@ retry:
+ r = radeon_gpu_reset(rdev);
+ if (r)
+ return r;
+- WREG32(rdev->fence_drv.scratch_reg, fence->seq);
++ radeon_fence_write(rdev, fence->seq);
+ rdev->gpu_lockup = false;
+ }
+ timeout = RADEON_FENCE_JIFFIES_TIMEOUT;
+@@ -353,7 +374,7 @@ int radeon_fence_driver_init(struct radeon_device *rdev)
+ write_unlock_irqrestore(&rdev->fence_drv.lock, irq_flags);
+ return r;
+ }
+- WREG32(rdev->fence_drv.scratch_reg, 0);
++ radeon_fence_write(rdev, 0);
+ atomic_set(&rdev->fence_drv.seq, 0);
+ INIT_LIST_HEAD(&rdev->fence_drv.created);
+ INIT_LIST_HEAD(&rdev->fence_drv.emited);
+@@ -393,7 +414,7 @@ static int radeon_debugfs_fence_info(struct seq_file *m, void *data)
+ struct radeon_fence *fence;
+
+ seq_printf(m, "Last signaled fence 0x%08X\n",
+- RREG32(rdev->fence_drv.scratch_reg));
++ radeon_fence_read(rdev));
+ if (!list_empty(&rdev->fence_drv.emited)) {
+ fence = list_entry(rdev->fence_drv.emited.prev,
+ struct radeon_fence, list);
+diff --git a/drivers/gpu/drm/radeon/rv770.c b/drivers/gpu/drm/radeon/rv770.c
+index 114e5cc..cd9578b 100644
+--- a/drivers/gpu/drm/radeon/rv770.c
++++ b/drivers/gpu/drm/radeon/rv770.c
+@@ -105,6 +105,9 @@ void rv770_pm_misc(struct radeon_device *rdev)
+ struct radeon_voltage *voltage = &ps->clock_info[req_cm_idx].voltage;
+
+ if ((voltage->type == VOLTAGE_SW) && voltage->voltage) {
++ /* 0xff01 is a flag rather then an actual voltage */
++ if (voltage->voltage == 0xff01)
++ return;
+ if (voltage->voltage != rdev->pm.current_vddc) {
+ radeon_atom_set_voltage(rdev, voltage->voltage, SET_VOLTAGE_TYPE_ASIC_VDDC);
+ rdev->pm.current_vddc = voltage->voltage;
diff --git a/freed-ora/current/f15/hid-ntrig-deref-unclaimed-input.patch b/freed-ora/current/f15/hid-ntrig-deref-unclaimed-input.patch
new file mode 100644
index 000000000..8719eae30
--- /dev/null
+++ b/freed-ora/current/f15/hid-ntrig-deref-unclaimed-input.patch
@@ -0,0 +1,46 @@
+commit f41a52d3010579949a3b9fd76783120d9643b60b
+Author: Rafi Rubin <rafi@seas.upenn.edu>
+Date: Tue Mar 8 00:24:29 2011 -0500
+
+ HID: ntrig don't dereference unclaimed hidinput
+
+ Check before dereferencing field->hidinput to fix a reported invalid
+ deference bug.
+
+ Signed-off-by: Rafi Rubin <rafi@seas.upenn.edu>
+ Signed-off-by: Jiri Kosina <jkosina@suse.cz>
+
+diff --git a/drivers/hid/hid-ntrig.c b/drivers/hid/hid-ntrig.c
+index beb4034..a93e58c 100644
+--- a/drivers/hid/hid-ntrig.c
++++ b/drivers/hid/hid-ntrig.c
+@@ -539,8 +539,19 @@ static int ntrig_input_mapped(struct hid_device *hdev, struct hid_input *hi,
+ static int ntrig_event (struct hid_device *hid, struct hid_field *field,
+ struct hid_usage *usage, __s32 value)
+ {
+- struct input_dev *input = field->hidinput->input;
+ struct ntrig_data *nd = hid_get_drvdata(hid);
++ struct input_dev *input;
++
++ /* Skip processing if not a claimed input */
++ if (!(hid->claimed & HID_CLAIMED_INPUT))
++ goto not_claimed_input;
++
++ /* This function is being called before the structures are fully
++ * initialized */
++ if(!(field->hidinput && field->hidinput->input))
++ return -EINVAL;
++
++ input = field->hidinput->input;
+
+ /* No special handling needed for the pen */
+ if (field->application == HID_DG_PEN)
+@@ -810,6 +821,8 @@ static int ntrig_event (struct hid_device *hid, struct hid_field *field,
+ }
+ }
+
++not_claimed_input:
++
+ /* we have handled the hidinput part, now remains hiddev */
+ if ((hid->claimed & HID_CLAIMED_HIDDEV) && hid->hiddev_hid_event)
+ hid->hiddev_hid_event(hid, field, usage, value);
diff --git a/freed-ora/current/f15/kernel.spec b/freed-ora/current/f15/kernel.spec
index f10f2b131..2f217ba46 100644
--- a/freed-ora/current/f15/kernel.spec
+++ b/freed-ora/current/f15/kernel.spec
@@ -51,7 +51,7 @@ Summary: The Linux kernel
# For non-released -rc kernels, this will be prepended with "0.", so
# for example a 3 here will become 0.3
#
-%global baserelease 33
+%global baserelease 34
%global fedora_build %{baserelease}
# base_sublevel is the kernel version we're starting with and patching
@@ -708,11 +708,13 @@ Patch1825: drm-intel-make-lvds-work.patch
Patch1826: drm-intel-edp-fixes.patch
Patch1828: drm-intel-eeebox-eb1007-quirk.patch
Patch1829: drm-intel-restore-mode.patch
+Patch1830: drm-i915-snb-irq-stalls-fix.patch
# radeon - new hw + fixes for fusion and t500 regression
Patch1839: drm-radeon-fix-regression-on-atom-cards-with-hardcoded-EDID-record.patch
Patch1840: drm-radeon-update.patch
Patch1841: drm-radeon-update2.patch
Patch1842: drm-radeon-pageflip-oops-fix.patch
+Patch1843: drm-radeon-update3.patch
Patch1900: linux-2.6-intel-iommu-igfx.patch
@@ -769,9 +771,12 @@ Patch12404: x86-pci-preserve-existing-pci-bfsort-whitelist-for-dell-systems.patc
Patch12407: scsi_dh_hp_sw-fix-deadlock-in-start_stop_endio.patch
+Patch12410: hid-ntrig-deref-unclaimed-input.patch
+
Patch12415: hid-multitouch-add-support-for-elo-touchsystems.patch
Patch12416: bluetooth-device-ids-for-ath3k-on-pegatron-lucid-tablets.patch
+
Patch12418: ath5k-disable-fast-channel-switching-by-default.patch
Patch12419: iwlagn-use-cts-to-self-protection-on-5000-adapters-series.patch
@@ -1391,12 +1396,14 @@ ApplyPatch drm-intel-edp-fixes.patch
ApplyPatch drm-i915-fix-pipelined-fencing.patch
ApplyPatch drm-intel-eeebox-eb1007-quirk.patch
ApplyPatch drm-intel-restore-mode.patch
+ApplyPatch drm-i915-snb-irq-stalls-fix.patch
# radeon DRM (add cayman support)
ApplyPatch drm-radeon-fix-regression-on-atom-cards-with-hardcoded-EDID-record.patch -R
ApplyPatch drm-radeon-update.patch
ApplyPatch drm-radeon-update2.patch
ApplyPatch drm-radeon-pageflip-oops-fix.patch
+ApplyPatch drm-radeon-update3.patch
# linux1394 git patches
#ApplyPatch linux-2.6-firewire-git-update.patch
@@ -1446,6 +1453,8 @@ ApplyPatch bonding-incorrect-tx-queue-offset.patch
ApplyPatch scsi_dh_hp_sw-fix-deadlock-in-start_stop_endio.patch
+ApplyPatch hid-ntrig-deref-unclaimed-input.patch
+
ApplyPatch hid-multitouch-add-support-for-elo-touchsystems.patch
ApplyPatch bluetooth-device-ids-for-ath3k-on-pegatron-lucid-tablets.patch
@@ -2066,6 +2075,15 @@ fi
# and build.
%changelog
+* Thu Jun 23 2011 Dave Airlie <airlied@redhat.com> 2.6.38.8-34
+- drm-i915-snb-irq-stalls-fix.patch: fix Sandybridge IRQ stalls
+
+* Thu Jun 23 2011 Dave Airlie <airlied@redhat.com>
+- drm-radeon-update3.patch: more radeon fixes backport
+
+* Tue Jun 21 2011 Dave Jones <davej@redhat.com>
+- HID: ntrig don't dereference unclaimed hidinput (rhbz#714827)
+
* Mon Jun 20 2011 Kyle McMartin <kmcmartin@redhat.com> 2.6.38.8-33
- [sgruszka@] iwlwifi: fix general 11n instability (rhbz#648732)
OpenPOWER on IntegriCloud