aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafael J. Wysocki <rjw@sisk.pl>2009-07-30 13:38:04 -0400
committerRafael J. Wysocki <rjw@sisk.pl>2009-07-30 13:38:04 -0400
commit2e6713c7662cc5ebc7346b033c404cb2f708fd51 (patch)
tree8492ea548fea2d8243e4af4b877906afc4e32783
parentb4093d6235b7e4249616651ee328600ced48a18a (diff)
parent658874f05d040ca96eb5ba9b1c30ce0ff287d762 (diff)
Merge branch 'master' into for-linus
-rw-r--r--CREDITS6
-rw-r--r--Documentation/filesystems/sysfs.txt3
-rw-r--r--Documentation/sysrq.txt7
-rw-r--r--MAINTAINERS2769
-rw-r--r--arch/x86/mm/highmem_32.c1
-rw-r--r--drivers/acpi/sleep.c8
-rw-r--r--drivers/ata/ahci.c4
-rw-r--r--drivers/ata/ata_piix.c3
-rw-r--r--drivers/ata/libata-core.c30
-rw-r--r--drivers/ata/libata-eh.c2
-rw-r--r--drivers/ata/pata_at91.c67
-rw-r--r--drivers/ata/pata_octeon_cf.c3
-rw-r--r--drivers/ata/pata_pcmcia.c1
-rw-r--r--drivers/ata/sata_mv.c2
-rw-r--r--drivers/ata/sata_sil.c2
-rw-r--r--drivers/base/firmware_class.c1
-rw-r--r--drivers/base/sys.c2
-rw-r--r--drivers/char/n_tty.c1
-rw-r--r--drivers/char/pty.c2
-rw-r--r--drivers/char/sysrq.c8
-rw-r--r--drivers/char/tty_buffer.c13
-rw-r--r--drivers/char/vr41xx_giu.c0
-rw-r--r--drivers/edac/x38_edac.c2
-rw-r--r--drivers/gpu/drm/radeon/Makefile3
-rw-r--r--drivers/gpu/drm/radeon/atombios_crtc.c293
-rw-r--r--drivers/gpu/drm/radeon/r100.c770
-rw-r--r--drivers/gpu/drm/radeon/r300.c78
-rw-r--r--drivers/gpu/drm/radeon/r300_reg.h4
-rw-r--r--drivers/gpu/drm/radeon/r500_reg.h2
-rw-r--r--drivers/gpu/drm/radeon/r520.c22
-rw-r--r--drivers/gpu/drm/radeon/r600.c5
-rw-r--r--drivers/gpu/drm/radeon/radeon.h87
-rw-r--r--drivers/gpu/drm/radeon/radeon_asic.h32
-rw-r--r--drivers/gpu/drm/radeon/radeon_atombios.c9
-rw-r--r--drivers/gpu/drm/radeon/radeon_benchmark.c4
-rw-r--r--drivers/gpu/drm/radeon/radeon_cs.c8
-rw-r--r--drivers/gpu/drm/radeon/radeon_cursor.c9
-rw-r--r--drivers/gpu/drm/radeon/radeon_device.c59
-rw-r--r--drivers/gpu/drm/radeon/radeon_display.c74
-rw-r--r--drivers/gpu/drm/radeon/radeon_drv.c4
-rw-r--r--drivers/gpu/drm/radeon/radeon_encoders.c359
-rw-r--r--drivers/gpu/drm/radeon/radeon_fb.c70
-rw-r--r--drivers/gpu/drm/radeon/radeon_fence.c2
-rw-r--r--drivers/gpu/drm/radeon/radeon_gart.c2
-rw-r--r--drivers/gpu/drm/radeon/radeon_gem.c45
-rw-r--r--drivers/gpu/drm/radeon/radeon_kms.c2
-rw-r--r--drivers/gpu/drm/radeon/radeon_legacy_crtc.c687
-rw-r--r--drivers/gpu/drm/radeon/radeon_legacy_encoders.c188
-rw-r--r--drivers/gpu/drm/radeon/radeon_mode.h51
-rw-r--r--drivers/gpu/drm/radeon/radeon_object.c158
-rw-r--r--drivers/gpu/drm/radeon/radeon_ring.c15
-rw-r--r--drivers/gpu/drm/radeon/radeon_share.h39
-rw-r--r--drivers/gpu/drm/radeon/radeon_test.c209
-rw-r--r--drivers/gpu/drm/radeon/radeon_ttm.c24
-rw-r--r--drivers/gpu/drm/radeon/rs400.c30
-rw-r--r--drivers/gpu/drm/radeon/rs600.c7
-rw-r--r--drivers/gpu/drm/radeon/rs690.c479
-rw-r--r--drivers/gpu/drm/radeon/rs690r.h99
-rw-r--r--drivers/gpu/drm/radeon/rv515.c798
-rw-r--r--drivers/gpu/drm/radeon/rv515r.h170
-rw-r--r--drivers/gpu/drm/radeon/rv770.c2
-rw-r--r--drivers/gpu/drm/ttm/ttm_bo.c63
-rw-r--r--drivers/gpu/drm/ttm/ttm_bo_util.c69
-rw-r--r--drivers/gpu/drm/ttm/ttm_bo_vm.c3
-rw-r--r--drivers/gpu/drm/ttm/ttm_tt.c25
-rw-r--r--drivers/i2c/busses/i2c-omap.c42
-rw-r--r--drivers/i2c/busses/i2c-s3c2410.c5
-rw-r--r--drivers/i2c/busses/i2c-sh_mobile.c2
-rw-r--r--drivers/misc/eeprom/at25.c4
-rw-r--r--drivers/mmc/host/sdhci-of.c8
-rw-r--r--drivers/mmc/host/sdhci.c5
-rw-r--r--drivers/mmc/host/sdhci.h1
-rw-r--r--drivers/rtc/rtc-cmos.c23
-rw-r--r--drivers/serial/atmel_serial.c2
-rw-r--r--drivers/spi/omap2_mcspi.c32
-rw-r--r--drivers/staging/Kconfig2
-rw-r--r--drivers/staging/Makefile1
-rw-r--r--drivers/staging/android/lowmemorykiller.c8
-rw-r--r--drivers/staging/serqt_usb2/serqt_usb2.c20
-rw-r--r--drivers/staging/uc2322/Kconfig10
-rw-r--r--drivers/staging/uc2322/Makefile1
-rw-r--r--drivers/staging/uc2322/TODO7
-rw-r--r--drivers/staging/uc2322/aten2011.c2430
-rw-r--r--drivers/staging/udlfb/udlfb.c1
-rw-r--r--drivers/usb/core/config.c48
-rw-r--r--drivers/usb/host/ehci-orion.c2
-rw-r--r--drivers/usb/host/ohci-omap.c1
-rw-r--r--drivers/usb/host/xhci-dbg.c199
-rw-r--r--drivers/usb/host/xhci-hcd.c290
-rw-r--r--drivers/usb/host/xhci-mem.c300
-rw-r--r--drivers/usb/host/xhci-pci.c1
-rw-r--r--drivers/usb/host/xhci-ring.c305
-rw-r--r--drivers/usb/host/xhci.h148
-rw-r--r--drivers/usb/misc/Kconfig2
-rw-r--r--drivers/usb/musb/musb_core.c3
-rw-r--r--drivers/usb/musb/musb_gadget_ep0.c2
-rw-r--r--drivers/usb/musb/musb_regs.h1
-rw-r--r--drivers/usb/serial/cp210x.c3
-rw-r--r--drivers/usb/serial/ftdi_sio.c1
-rw-r--r--drivers/usb/serial/ftdi_sio.h7
-rw-r--r--drivers/usb/serial/mos7840.c9
-rw-r--r--drivers/usb/serial/option.c133
-rw-r--r--drivers/usb/storage/transport.c2
-rw-r--r--drivers/video/backlight/jornada720_bl.c2
-rw-r--r--drivers/video/s3c-fb.c4
-rw-r--r--fs/block_dev.c10
-rw-r--r--fs/ramfs/file-nommu.c1
-rw-r--r--fs/sysfs/dir.c2
-rw-r--r--include/drm/radeon_drm.h23
-rw-r--r--include/drm/ttm/ttm_bo_driver.h20
-rw-r--r--include/drm/ttm/ttm_module.h2
-rw-r--r--include/linux/cgroup.h28
-rw-r--r--include/linux/flex_array.h47
-rw-r--r--include/linux/fs.h1
-rw-r--r--include/linux/libata.h1
-rw-r--r--include/linux/pps.h2
-rw-r--r--include/linux/tty.h1
-rw-r--r--include/linux/uio.h17
-rw-r--r--kernel/cgroup.c151
-rw-r--r--kernel/fork.c1
-rw-r--r--kernel/kexec.c2
-rw-r--r--kernel/profile.c5
-rw-r--r--lib/Makefile2
-rw-r--r--lib/atomic64.c11
-rw-r--r--lib/dynamic_debug.c2
-rw-r--r--lib/flex_array.c269
-rw-r--r--mm/hugetlb.c2
-rw-r--r--mm/kmemleak.c4
-rw-r--r--mm/memcontrol.c23
-rw-r--r--mm/page_alloc.c21
-rw-r--r--mm/swapfile.c4
-rw-r--r--net/dccp/proto.c4
-rwxr-xr-xscripts/get_maintainer.pl42
-rw-r--r--scripts/markup_oops.pl5
134 files changed, 6318 insertions, 6448 deletions
diff --git a/CREDITS b/CREDITS
index e76d300e9fe4..1a41bf4addd0 100644
--- a/CREDITS
+++ b/CREDITS
@@ -2006,6 +2006,9 @@ E: paul@laufernet.com
2006D: Soundblaster driver fixes, ISAPnP quirk 2006D: Soundblaster driver fixes, ISAPnP quirk
2007S: California, USA 2007S: California, USA
2008 2008
2009N: Jonathan Layes
2010D: ARPD support
2011
2009N: Tom Lees 2012N: Tom Lees
2010E: tom@lpsg.demon.co.uk 2013E: tom@lpsg.demon.co.uk
2011W: http://www.lpsg.demon.co.uk/ 2014W: http://www.lpsg.demon.co.uk/
@@ -3802,6 +3805,9 @@ S: van Bronckhorststraat 12
3802S: 2612 XV Delft 3805S: 2612 XV Delft
3803S: The Netherlands 3806S: The Netherlands
3804 3807
3808N: Thomas Woller
3809D: CS461x Cirrus Logic sound driver
3810
3805N: David Woodhouse 3811N: David Woodhouse
3806E: dwmw2@infradead.org 3812E: dwmw2@infradead.org
3807D: JFFS2 file system, Memory Technology Device subsystem, 3813D: JFFS2 file system, Memory Technology Device subsystem,
diff --git a/Documentation/filesystems/sysfs.txt b/Documentation/filesystems/sysfs.txt
index 7e81e37c0b1e..b245d524d568 100644
--- a/Documentation/filesystems/sysfs.txt
+++ b/Documentation/filesystems/sysfs.txt
@@ -23,7 +23,8 @@ interface.
23Using sysfs 23Using sysfs
24~~~~~~~~~~~ 24~~~~~~~~~~~
25 25
26sysfs is always compiled in. You can access it by doing: 26sysfs is always compiled in if CONFIG_SYSFS is defined. You can access
27it by doing:
27 28
28 mount -t sysfs sysfs /sys 29 mount -t sysfs sysfs /sys
29 30
diff --git a/Documentation/sysrq.txt b/Documentation/sysrq.txt
index cf42b820ff9d..d56a01775423 100644
--- a/Documentation/sysrq.txt
+++ b/Documentation/sysrq.txt
@@ -66,7 +66,8 @@ On all - write a character to /proc/sysrq-trigger. e.g.:
66'b' - Will immediately reboot the system without syncing or unmounting 66'b' - Will immediately reboot the system without syncing or unmounting
67 your disks. 67 your disks.
68 68
69'c' - Will perform a kexec reboot in order to take a crashdump. 69'c' - Will perform a system crash by a NULL pointer dereference.
70 A crashdump will be taken if configured.
70 71
71'd' - Shows all locks that are held. 72'd' - Shows all locks that are held.
72 73
@@ -141,8 +142,8 @@ useful when you want to exit a program that will not let you switch consoles.
141re'B'oot is good when you're unable to shut down. But you should also 'S'ync 142re'B'oot is good when you're unable to shut down. But you should also 'S'ync
142and 'U'mount first. 143and 'U'mount first.
143 144
144'C'rashdump can be used to manually trigger a crashdump when the system is hung. 145'C'rash can be used to manually trigger a crashdump when the system is hung.
145The kernel needs to have been built with CONFIG_KEXEC enabled. 146Note that this just triggers a crash if there is no dump mechanism available.
146 147
147'S'ync is great when your system is locked up, it allows you to sync your 148'S'ync is great when your system is locked up, it allows you to sync your
148disks and will certainly lessen the chance of data loss and fscking. Note 149disks and will certainly lessen the chance of data loss and fscking. Note
diff --git a/MAINTAINERS b/MAINTAINERS
index ebc269152faf..66a3865da88d 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -73,8 +73,8 @@ Note: For the hard of thinking, this list is meant to remain in alphabetical
73order. If you could add yourselves to it in alphabetical order that would be 73order. If you could add yourselves to it in alphabetical order that would be
74so much easier [Ed] 74so much easier [Ed]
75 75
76P: Person 76P: Person (obsolete)
77M: Mail patches to 77M: Mail patches to: FullName <address@domain>
78L: Mailing list that is relevant to this area 78L: Mailing list that is relevant to this area
79W: Web-page with status/info 79W: Web-page with status/info
80T: SCM tree type and location. Type is one of: git, hg, quilt, stgit. 80T: SCM tree type and location. Type is one of: git, hg, quilt, stgit.
@@ -104,67 +104,58 @@ X: Files and directories that are NOT maintained, same rules as F:
104 matches all files in and below net excluding net/ipv6/ 104 matches all files in and below net excluding net/ipv6/
105 105
1063C505 NETWORK DRIVER 1063C505 NETWORK DRIVER
107P: Philip Blundell 107M: Philip Blundell <philb@gnu.org>
108M: philb@gnu.org
109L: netdev@vger.kernel.org 108L: netdev@vger.kernel.org
110S: Maintained 109S: Maintained
111F: drivers/net/3c505* 110F: drivers/net/3c505*
112 111
1133C59X NETWORK DRIVER 1123C59X NETWORK DRIVER
114P: Steffen Klassert 113M: Steffen Klassert <klassert@mathematik.tu-chemnitz.de>
115M: klassert@mathematik.tu-chemnitz.de
116L: netdev@vger.kernel.org 114L: netdev@vger.kernel.org
117S: Maintained 115S: Maintained
118F: Documentation/networking/vortex.txt 116F: Documentation/networking/vortex.txt
119F: drivers/net/3c59x.c 117F: drivers/net/3c59x.c
120 118
1213CR990 NETWORK DRIVER 1193CR990 NETWORK DRIVER
122P: David Dillow 120M: David Dillow <dave@thedillows.org>
123M: dave@thedillows.org
124L: netdev@vger.kernel.org 121L: netdev@vger.kernel.org
125S: Maintained 122S: Maintained
126F: drivers/net/typhoon* 123F: drivers/net/typhoon*
127 124
1283W-9XXX SATA-RAID CONTROLLER DRIVER 1253W-9XXX SATA-RAID CONTROLLER DRIVER
129P: Adam Radford 126M: Adam Radford <linuxraid@amcc.com>
130M: linuxraid@amcc.com
131L: linux-scsi@vger.kernel.org 127L: linux-scsi@vger.kernel.org
132W: http://www.amcc.com 128W: http://www.amcc.com
133S: Supported 129S: Supported
134F: drivers/scsi/3w-9xxx* 130F: drivers/scsi/3w-9xxx*
135 131
1363W-XXXX ATA-RAID CONTROLLER DRIVER 1323W-XXXX ATA-RAID CONTROLLER DRIVER
137P: Adam Radford 133M: Adam Radford <linuxraid@amcc.com>
138M: linuxraid@amcc.com
139L: linux-scsi@vger.kernel.org 134L: linux-scsi@vger.kernel.org
140W: http://www.amcc.com 135W: http://www.amcc.com
141S: Supported 136S: Supported
142F: drivers/scsi/3w-xxxx* 137F: drivers/scsi/3w-xxxx*
143 138
14453C700 AND 53C700-66 SCSI DRIVER 13953C700 AND 53C700-66 SCSI DRIVER
145P: James E.J. Bottomley 140M: "James E.J. Bottomley" <James.Bottomley@HansenPartnership.com>
146M: James.Bottomley@HansenPartnership.com
147L: linux-scsi@vger.kernel.org 141L: linux-scsi@vger.kernel.org
148S: Maintained 142S: Maintained
149F: drivers/scsi/53c700* 143F: drivers/scsi/53c700*
150 144
1516PACK NETWORK DRIVER FOR AX.25 1456PACK NETWORK DRIVER FOR AX.25
152P: Andreas Koensgen 146M: Andreas Koensgen <ajk@comnets.uni-bremen.de>
153M: ajk@comnets.uni-bremen.de
154L: linux-hams@vger.kernel.org 147L: linux-hams@vger.kernel.org
155S: Maintained 148S: Maintained
156F: drivers/net/hamradio/6pack.c 149F: drivers/net/hamradio/6pack.c
157 150
1588169 10/100/1000 GIGABIT ETHERNET DRIVER 1518169 10/100/1000 GIGABIT ETHERNET DRIVER
159P: Francois Romieu 152M: Francois Romieu <romieu@fr.zoreil.com>
160M: romieu@fr.zoreil.com
161L: netdev@vger.kernel.org 153L: netdev@vger.kernel.org
162S: Maintained 154S: Maintained
163F: drivers/net/r8169.c 155F: drivers/net/r8169.c
164 156
1658250/16?50 (AND CLONE UARTS) SERIAL DRIVER 1578250/16?50 (AND CLONE UARTS) SERIAL DRIVER
166P: Alan Cox 158M: Alan Cox <alan@lxorguk.ukuu.org.uk>
167M: alan@lxorguk.ukuu.org.uk
168L: linux-serial@vger.kernel.org 159L: linux-serial@vger.kernel.org
169W: http://serial.sourceforge.net 160W: http://serial.sourceforge.net
170S: Odd Fixes 161S: Odd Fixes
@@ -172,20 +163,16 @@ F: drivers/serial/8250*
172F: include/linux/serial_8250.h 163F: include/linux/serial_8250.h
173 164
1748390 NETWORK DRIVERS [WD80x3/SMC-ELITE, SMC-ULTRA, NE2000, 3C503, etc.] 1658390 NETWORK DRIVERS [WD80x3/SMC-ELITE, SMC-ULTRA, NE2000, 3C503, etc.]
175P: Paul Gortmaker 166M: Paul Gortmaker <p_gortmaker@yahoo.com>
176M: p_gortmaker@yahoo.com
177L: netdev@vger.kernel.org 167L: netdev@vger.kernel.org
178S: Maintained 168S: Maintained
179F: drivers/net/*8390* 169F: drivers/net/*8390*
180F: drivers/net/ax88796.c 170F: drivers/net/ax88796.c
181 171
1829P FILE SYSTEM 1729P FILE SYSTEM
183P: Eric Van Hensbergen 173M: Eric Van Hensbergen <ericvh@gmail.com>
184M: ericvh@gmail.com 174M: Ron Minnich <rminnich@sandia.gov>
185P: Ron Minnich 175M: Latchesar Ionkov <lucho@ionkov.net>
186M: rminnich@sandia.gov
187P: Latchesar Ionkov
188M: lucho@ionkov.net
189L: v9fs-developer@lists.sourceforge.net 176L: v9fs-developer@lists.sourceforge.net
190W: http://swik.net/v9fs 177W: http://swik.net/v9fs
191T: git git://git.kernel.org/pub/scm/linux/kernel/ericvh/v9fs.git 178T: git git://git.kernel.org/pub/scm/linux/kernel/ericvh/v9fs.git
@@ -194,15 +181,13 @@ F: Documentation/filesystems/9p.txt
194F: fs/9p/ 181F: fs/9p/
195 182
196A2232 SERIAL BOARD DRIVER 183A2232 SERIAL BOARD DRIVER
197P: Enver Haase 184M: Enver Haase <A2232@gmx.net>
198M: A2232@gmx.net
199L: linux-m68k@lists.linux-m68k.org 185L: linux-m68k@lists.linux-m68k.org
200S: Maintained 186S: Maintained
201F: drivers/char/ser_a2232* 187F: drivers/char/ser_a2232*
202 188
203AACRAID SCSI RAID DRIVER 189AACRAID SCSI RAID DRIVER
204P: Adaptec OEM Raid Solutions 190M: Adaptec OEM Raid Solutions <aacraid@adaptec.com>
205M: aacraid@adaptec.com
206L: linux-scsi@vger.kernel.org 191L: linux-scsi@vger.kernel.org
207W: http://www.adaptec.com/ 192W: http://www.adaptec.com/
208S: Supported 193S: Supported
@@ -210,44 +195,38 @@ F: Documentation/scsi/aacraid.txt
210F: drivers/scsi/aacraid/ 195F: drivers/scsi/aacraid/
211 196
212ABIT UGURU 1,2 HARDWARE MONITOR DRIVER 197ABIT UGURU 1,2 HARDWARE MONITOR DRIVER
213P: Hans de Goede 198M: Hans de Goede <j.w.r.degoede@hhs.nl>
214M: j.w.r.degoede@hhs.nl
215L: lm-sensors@lm-sensors.org 199L: lm-sensors@lm-sensors.org
216S: Maintained 200S: Maintained
217F: drivers/hwmon/abituguru.c 201F: drivers/hwmon/abituguru.c
218 202
219ABIT UGURU 3 HARDWARE MONITOR DRIVER 203ABIT UGURU 3 HARDWARE MONITOR DRIVER
220P: Alistair John Strachan 204M: Alistair John Strachan <alistair@devzero.co.uk>
221M: alistair@devzero.co.uk
222L: lm-sensors@lm-sensors.org 205L: lm-sensors@lm-sensors.org
223S: Maintained 206S: Maintained
224F: drivers/hwmon/abituguru3.c 207F: drivers/hwmon/abituguru3.c
225 208
226ACENIC DRIVER 209ACENIC DRIVER
227P: Jes Sorensen 210M: Jes Sorensen <jes@trained-monkey.org>
228M: jes@trained-monkey.org
229L: linux-acenic@sunsite.dk 211L: linux-acenic@sunsite.dk
230S: Maintained 212S: Maintained
231F: drivers/net/acenic* 213F: drivers/net/acenic*
232 214
233ACER ASPIRE ONE TEMPERATURE AND FAN DRIVER 215ACER ASPIRE ONE TEMPERATURE AND FAN DRIVER
234P: Peter Feuerer 216M: Peter Feuerer <peter@piie.net>
235M: peter@piie.net 217W: http://piie.net/?section=acerhdf
236W: http://piie.net/?section=acerhdf 218S: Maintained
237S: Maintained 219F: drivers/platform/x86/acerhdf.c
238F: drivers/platform/x86/acerhdf.c
239 220
240ACER WMI LAPTOP EXTRAS 221ACER WMI LAPTOP EXTRAS
241P: Carlos Corbacho 222M: Carlos Corbacho <carlos@strangeworlds.co.uk>
242M: carlos@strangeworlds.co.uk
243L: aceracpi@googlegroups.com (subscribers-only) 223L: aceracpi@googlegroups.com (subscribers-only)
244W: http://code.google.com/p/aceracpi 224W: http://code.google.com/p/aceracpi
245S: Maintained 225S: Maintained
246F: drivers/platform/x86/acer-wmi.c 226F: drivers/platform/x86/acer-wmi.c
247 227
248ACPI 228ACPI
249P: Len Brown 229M: Len Brown <lenb@kernel.org>
250M: lenb@kernel.org
251L: linux-acpi@vger.kernel.org 230L: linux-acpi@vger.kernel.org
252W: http://www.lesswatts.org/projects/acpi/ 231W: http://www.lesswatts.org/projects/acpi/
253T: git git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux-acpi-2.6.git 232T: git git://git.kernel.org/pub/scm/linux/kernel/git/lenb/linux-acpi-2.6.git
@@ -257,8 +236,7 @@ F: drivers/pnp/pnpacpi/
257F: include/linux/acpi.h 236F: include/linux/acpi.h
258 237
259ACPI BATTERY DRIVERS 238ACPI BATTERY DRIVERS
260P: Alexey Starikovskiy 239M: Alexey Starikovskiy <astarikovskiy@suse.de>
261M: astarikovskiy@suse.de
262L: linux-acpi@vger.kernel.org 240L: linux-acpi@vger.kernel.org
263W: http://www.lesswatts.org/projects/acpi/ 241W: http://www.lesswatts.org/projects/acpi/
264S: Supported 242S: Supported
@@ -266,80 +244,69 @@ F: drivers/acpi/battery.c
266F: drivers/acpi/*sbs* 244F: drivers/acpi/*sbs*
267 245
268ACPI EC DRIVER 246ACPI EC DRIVER
269P: Alexey Starikovskiy 247M: Alexey Starikovskiy <astarikovskiy@suse.de>
270M: astarikovskiy@suse.de
271L: linux-acpi@vger.kernel.org 248L: linux-acpi@vger.kernel.org
272W: http://www.lesswatts.org/projects/acpi/ 249W: http://www.lesswatts.org/projects/acpi/
273S: Supported 250S: Supported
274F: drivers/acpi/ec.c 251F: drivers/acpi/ec.c
275 252
276ACPI FAN DRIVER 253ACPI FAN DRIVER
277P: Zhang Rui 254M: Zhang Rui <rui.zhang@intel.com>
278M: rui.zhang@intel.com
279L: linux-acpi@vger.kernel.org 255L: linux-acpi@vger.kernel.org
280W: http://www.lesswatts.org/projects/acpi/ 256W: http://www.lesswatts.org/projects/acpi/
281S: Supported 257S: Supported
282F: drivers/acpi/fan.c 258F: drivers/acpi/fan.c
283 259
284ACPI PCI HOTPLUG DRIVER 260ACPI PCI HOTPLUG DRIVER
285P: Kristen Carlson Accardi 261M: Kristen Carlson Accardi <kristen.c.accardi@intel.com>
286M: kristen.c.accardi@intel.com
287L: linux-pci@vger.kernel.org 262L: linux-pci@vger.kernel.org
288S: Supported 263S: Supported
289F: drivers/pci/hotplug/acpi* 264F: drivers/pci/hotplug/acpi*
290 265
291ACPI THERMAL DRIVER 266ACPI THERMAL DRIVER
292P: Zhang Rui 267M: Zhang Rui <rui.zhang@intel.com>
293M: rui.zhang@intel.com
294L: linux-acpi@vger.kernel.org 268L: linux-acpi@vger.kernel.org
295W: http://www.lesswatts.org/projects/acpi/ 269W: http://www.lesswatts.org/projects/acpi/
296S: Supported 270S: Supported
297F: drivers/acpi/*thermal* 271F: drivers/acpi/*thermal*
298 272
299ACPI VIDEO DRIVER 273ACPI VIDEO DRIVER
300P: Zhang Rui 274M: Zhang Rui <rui.zhang@intel.com>
301M: rui.zhang@intel.com
302L: linux-acpi@vger.kernel.org 275L: linux-acpi@vger.kernel.org
303W: http://www.lesswatts.org/projects/acpi/ 276W: http://www.lesswatts.org/projects/acpi/
304S: Supported 277S: Supported
305F: drivers/acpi/video.c 278F: drivers/acpi/video.c
306 279
307ACPI WMI DRIVER 280ACPI WMI DRIVER
308P: Carlos Corbacho 281M: Carlos Corbacho <carlos@strangeworlds.co.uk>
309M: carlos@strangeworlds.co.uk
310L: linux-acpi@vger.kernel.org 282L: linux-acpi@vger.kernel.org
311W: http://www.lesswatts.org/projects/acpi/ 283W: http://www.lesswatts.org/projects/acpi/
312S: Maintained 284S: Maintained
313F: drivers/platform/x86/wmi.c 285F: drivers/platform/x86/wmi.c
314 286
315AD1889 ALSA SOUND DRIVER 287AD1889 ALSA SOUND DRIVER
316P: Kyle McMartin 288M: Kyle McMartin <kyle@mcmartin.ca>
317M: kyle@mcmartin.ca 289M: Thibaut Varene <T-Bone@parisc-linux.org>
318P: Thibaut Varene
319M: T-Bone@parisc-linux.org
320W: http://wiki.parisc-linux.org/AD1889 290W: http://wiki.parisc-linux.org/AD1889
321L: linux-parisc@vger.kernel.org 291L: linux-parisc@vger.kernel.org
322S: Maintained 292S: Maintained
323F: sound/pci/ad1889.* 293F: sound/pci/ad1889.*
324 294
325ADM1025 HARDWARE MONITOR DRIVER 295ADM1025 HARDWARE MONITOR DRIVER
326P: Jean Delvare 296M: Jean Delvare <khali@linux-fr.org>
327M: khali@linux-fr.org
328L: lm-sensors@lm-sensors.org 297L: lm-sensors@lm-sensors.org
329S: Maintained 298S: Maintained
330F: Documentation/hwmon/adm1025 299F: Documentation/hwmon/adm1025
331F: drivers/hwmon/adm1025.c 300F: drivers/hwmon/adm1025.c
332 301
333ADM1029 HARDWARE MONITOR DRIVER 302ADM1029 HARDWARE MONITOR DRIVER
334P: Corentin Labbe 303M: Corentin Labbe <corentin.labbe@geomatys.fr>
335M: corentin.labbe@geomatys.fr
336L: lm-sensors@lm-sensors.org 304L: lm-sensors@lm-sensors.org
337S: Maintained 305S: Maintained
338F: drivers/hwmon/adm1029.c 306F: drivers/hwmon/adm1029.c
339 307
340ADM8211 WIRELESS DRIVER 308ADM8211 WIRELESS DRIVER
341P: Michael Wu 309M: Michael Wu <flamingice@sourmilk.net>
342M: flamingice@sourmilk.net
343L: linux-wireless@vger.kernel.org 310L: linux-wireless@vger.kernel.org
344W: http://linuxwireless.org/ 311W: http://linuxwireless.org/
345T: git git://git.kernel.org/pub/scm/linux/kernel/git/mwu/mac80211-drivers.git 312T: git git://git.kernel.org/pub/scm/linux/kernel/git/mwu/mac80211-drivers.git
@@ -347,35 +314,30 @@ S: Maintained
347F: drivers/net/wireless/adm8211.* 314F: drivers/net/wireless/adm8211.*
348 315
349ADT746X FAN DRIVER 316ADT746X FAN DRIVER
350P: Colin Leroy 317M: Colin Leroy <colin@colino.net>
351M: colin@colino.net
352S: Maintained 318S: Maintained
353F: drivers/macintosh/therm_adt746x.c 319F: drivers/macintosh/therm_adt746x.c
354 320
355ADVANSYS SCSI DRIVER 321ADVANSYS SCSI DRIVER
356P: Matthew Wilcox 322M: Matthew Wilcox <matthew@wil.cx>
357M: matthew@wil.cx
358L: linux-scsi@vger.kernel.org 323L: linux-scsi@vger.kernel.org
359S: Maintained 324S: Maintained
360F: Documentation/scsi/advansys.txt 325F: Documentation/scsi/advansys.txt
361F: drivers/scsi/advansys.c 326F: drivers/scsi/advansys.c
362 327
363AEDSP16 DRIVER 328AEDSP16 DRIVER
364P: Riccardo Facchetti 329M: Riccardo Facchetti <fizban@tin.it>
365M: fizban@tin.it
366S: Maintained 330S: Maintained
367F: sound/oss/aedsp16.c 331F: sound/oss/aedsp16.c
368 332
369AFFS FILE SYSTEM 333AFFS FILE SYSTEM
370P: Roman Zippel 334M: Roman Zippel <zippel@linux-m68k.org>
371M: zippel@linux-m68k.org
372S: Maintained 335S: Maintained
373F: Documentation/filesystems/affs.txt 336F: Documentation/filesystems/affs.txt
374F: fs/affs/ 337F: fs/affs/
375 338
376AFS FILESYSTEM & AF_RXRPC SOCKET DOMAIN 339AFS FILESYSTEM & AF_RXRPC SOCKET DOMAIN
377P: David Howells 340M: David Howells <dhowells@redhat.com>
378M: dhowells@redhat.com
379L: linux-afs@lists.infradead.org 341L: linux-afs@lists.infradead.org
380S: Supported 342S: Supported
381F: fs/afs/ 343F: fs/afs/
@@ -383,40 +345,35 @@ F: include/net/af_rxrpc.h
383F: net/rxrpc/af_rxrpc.c 345F: net/rxrpc/af_rxrpc.c
384 346
385AGPGART DRIVER 347AGPGART DRIVER
386P: David Airlie 348M: David Airlie <airlied@linux.ie>
387M: airlied@linux.ie
388T: git git://git.kernel.org/pub/scm/linux/kernel/git/airlied/drm-2.6.git 349T: git git://git.kernel.org/pub/scm/linux/kernel/git/airlied/drm-2.6.git
389S: Maintained 350S: Maintained
390F: drivers/char/agp/ 351F: drivers/char/agp/
391F: include/linux/agp* 352F: include/linux/agp*
392 353
393AHA152X SCSI DRIVER 354AHA152X SCSI DRIVER
394P: Juergen E. Fischer 355M: "Juergen E. Fischer" <fischer@norbit.de>
395M: fischer@norbit.de
396L: linux-scsi@vger.kernel.org 356L: linux-scsi@vger.kernel.org
397S: Maintained 357S: Maintained
398F: drivers/scsi/aha152x* 358F: drivers/scsi/aha152x*
399F: drivers/scsi/pcmcia/aha152x* 359F: drivers/scsi/pcmcia/aha152x*
400 360
401AIC7XXX / AIC79XX SCSI DRIVER 361AIC7XXX / AIC79XX SCSI DRIVER
402P: Hannes Reinecke 362M: Hannes Reinecke <hare@suse.de>
403M: hare@suse.de
404L: linux-scsi@vger.kernel.org 363L: linux-scsi@vger.kernel.org
405S: Maintained 364S: Maintained
406F: drivers/scsi/aic7xxx/ 365F: drivers/scsi/aic7xxx/
407F: drivers/scsi/aic7xxx_old/ 366F: drivers/scsi/aic7xxx_old/
408 367
409AIO 368AIO
410P: Benjamin LaHaise 369M: Benjamin LaHaise <bcrl@kvack.org>
411M: bcrl@kvack.org
412L: linux-aio@kvack.org 370L: linux-aio@kvack.org
413S: Supported 371S: Supported
414F: fs/aio.c 372F: fs/aio.c
415F: include/linux/*aio*.h 373F: include/linux/*aio*.h
416 374
417ALCATEL SPEEDTOUCH USB DRIVER 375ALCATEL SPEEDTOUCH USB DRIVER
418P: Duncan Sands 376M: Duncan Sands <duncan.sands@free.fr>
419M: duncan.sands@free.fr
420L: linux-usb@vger.kernel.org 377L: linux-usb@vger.kernel.org
421W: http://www.linux-usb.org/SpeedTouch/ 378W: http://www.linux-usb.org/SpeedTouch/
422S: Maintained 379S: Maintained
@@ -424,32 +381,27 @@ F: drivers/usb/atm/speedtch.c
424F: drivers/usb/atm/usbatm.c 381F: drivers/usb/atm/usbatm.c
425 382
426ALCHEMY AU1XX0 MMC DRIVER 383ALCHEMY AU1XX0 MMC DRIVER
427P: Manuel Lauss 384M: Manuel Lauss <manuel.lauss@gmail.com>
428M: manuel.lauss@gmail.com
429S: Maintained 385S: Maintained
430F: drivers/mmc/host/au1xmmc.c 386F: drivers/mmc/host/au1xmmc.c
431 387
432ALI1563 I2C DRIVER 388ALI1563 I2C DRIVER
433P: Rudolf Marek 389M: Rudolf Marek <r.marek@assembler.cz>
434M: r.marek@assembler.cz
435L: linux-i2c@vger.kernel.org 390L: linux-i2c@vger.kernel.org
436S: Maintained 391S: Maintained
437F: Documentation/i2c/busses/i2c-ali1563 392F: Documentation/i2c/busses/i2c-ali1563
438F: drivers/i2c/busses/i2c-ali1563.c 393F: drivers/i2c/busses/i2c-ali1563.c
439 394
440ALPHA PORT 395ALPHA PORT
441P: Richard Henderson 396M: Richard Henderson <rth@twiddle.net>
442M: rth@twiddle.net
443S: Odd Fixes for 2.4; Maintained for 2.6. 397S: Odd Fixes for 2.4; Maintained for 2.6.
444P: Ivan Kokshaysky 398M: Ivan Kokshaysky <ink@jurassic.park.msu.ru>
445M: ink@jurassic.park.msu.ru
446S: Maintained for 2.4; PCI support for 2.6. 399S: Maintained for 2.4; PCI support for 2.6.
447L: linux-alpha@vger.kernel.org 400L: linux-alpha@vger.kernel.org
448F: arch/alpha/ 401F: arch/alpha/
449 402
450AMD GEODE CS5536 USB DEVICE CONTROLLER DRIVER 403AMD GEODE CS5536 USB DEVICE CONTROLLER DRIVER
451P: Thomas Dahlmann 404M: Thomas Dahlmann <dahlmann.thomas@arcor.de>
452M: dahlmann.thomas@arcor.de
453L: linux-geode@lists.infradead.org (moderated for non-subscribers) 405L: linux-geode@lists.infradead.org (moderated for non-subscribers)
454S: Supported 406S: Supported
455F: drivers/usb/gadget/amd5536udc.* 407F: drivers/usb/gadget/amd5536udc.*
@@ -466,8 +418,7 @@ F: drivers/video/geode/
466F: arch/x86/include/asm/geode.h 418F: arch/x86/include/asm/geode.h
467 419
468AMD IOMMU (AMD-VI) 420AMD IOMMU (AMD-VI)
469P: Joerg Roedel 421M: Joerg Roedel <joerg.roedel@amd.com>
470M: joerg.roedel@amd.com
471L: iommu@lists.linux-foundation.org 422L: iommu@lists.linux-foundation.org
472T: git git://git.kernel.org/pub/scm/linux/kernel/git/joro/linux-2.6-iommu.git 423T: git git://git.kernel.org/pub/scm/linux/kernel/git/joro/linux-2.6-iommu.git
473S: Supported 424S: Supported
@@ -475,40 +426,33 @@ F: arch/x86/kernel/amd_iommu*.c
475F: arch/x86/include/asm/amd_iommu*.h 426F: arch/x86/include/asm/amd_iommu*.h
476 427
477AMD MICROCODE UPDATE SUPPORT 428AMD MICROCODE UPDATE SUPPORT
478P: Andreas Herrmann 429M: Andreas Herrmann <andreas.herrmann3@amd.com>
479M: andreas.herrmann3@amd.com
480L: amd64-microcode@amd64.org 430L: amd64-microcode@amd64.org
481S: Supported 431S: Supported
482F: arch/x86/kernel/microcode_amd.c 432F: arch/x86/kernel/microcode_amd.c
483 433
484AMS (Apple Motion Sensor) DRIVER 434AMS (Apple Motion Sensor) DRIVER
485P: Stelian Pop 435M: Stelian Pop <stelian@popies.net>
486M: stelian@popies.net 436M: Michael Hanselmann <linux-kernel@hansmi.ch>
487P: Michael Hanselmann
488M: linux-kernel@hansmi.ch
489S: Supported 437S: Supported
490F: drivers/hwmon/ams/ 438F: drivers/hwmon/ams/
491 439
492AMSO1100 RNIC DRIVER 440AMSO1100 RNIC DRIVER
493P: Tom Tucker 441M: Tom Tucker <tom@opengridcomputing.com>
494M: tom@opengridcomputing.com 442M: Steve Wise <swise@opengridcomputing.com>
495P: Steve Wise
496M: swise@opengridcomputing.com
497L: general@lists.openfabrics.org 443L: general@lists.openfabrics.org
498S: Maintained 444S: Maintained
499F: drivers/infiniband/hw/amso1100/ 445F: drivers/infiniband/hw/amso1100/
500 446
501AOA (Apple Onboard Audio) ALSA DRIVER 447AOA (Apple Onboard Audio) ALSA DRIVER
502P: Johannes Berg 448M: Johannes Berg <johannes@sipsolutions.net>
503M: johannes@sipsolutions.net
504L: linuxppc-dev@ozlabs.org 449L: linuxppc-dev@ozlabs.org
505L: alsa-devel@alsa-project.org (moderated for non-subscribers) 450L: alsa-devel@alsa-project.org (moderated for non-subscribers)
506S: Maintained 451S: Maintained
507F: sound/aoa/ 452F: sound/aoa/
508 453
509APM DRIVER 454APM DRIVER
510P: Stephen Rothwell 455M: Stephen Rothwell <sfr@canb.auug.org.au>
511M: sfr@canb.auug.org.au
512L: linux-laptop@vger.kernel.org 456L: linux-laptop@vger.kernel.org
513W: http://www.canb.auug.org.au/~sfr/ 457W: http://www.canb.auug.org.au/~sfr/
514S: Supported 458S: Supported
@@ -516,51 +460,44 @@ F: arch/x86/kernel/apm_32.c
516F: include/linux/apm_bios.h 460F: include/linux/apm_bios.h
517 461
518APPLE BCM5974 MULTITOUCH DRIVER 462APPLE BCM5974 MULTITOUCH DRIVER
519P: Henrik Rydberg 463M: Henrik Rydberg <rydberg@euromail.se>
520M: rydberg@euromail.se
521L: linux-input@vger.kernel.org 464L: linux-input@vger.kernel.org
522S: Maintained 465S: Maintained
523F: drivers/input/mouse/bcm5974.c 466F: drivers/input/mouse/bcm5974.c
524 467
525APPLE SMC DRIVER 468APPLE SMC DRIVER
526P: Nicolas Boichat 469M: Nicolas Boichat <nicolas@boichat.ch>
527M: nicolas@boichat.ch
528L: mactel-linux-devel@lists.sourceforge.net 470L: mactel-linux-devel@lists.sourceforge.net
529S: Maintained 471S: Maintained
530F: drivers/hwmon/applesmc.c 472F: drivers/hwmon/applesmc.c
531 473
532APPLETALK NETWORK LAYER 474APPLETALK NETWORK LAYER
533P: Arnaldo Carvalho de Melo 475M: Arnaldo Carvalho de Melo <acme@ghostprotocols.net>
534M: acme@ghostprotocols.net
535S: Maintained 476S: Maintained
536F: drivers/net/appletalk/ 477F: drivers/net/appletalk/
537F: net/appletalk/ 478F: net/appletalk/
538 479
539APPLETOUCH TOUCHPAD DRIVER 480APPLETOUCH TOUCHPAD DRIVER
540P: Johannes Berg 481M: Johannes Berg <johannes@sipsolutions.net>
541M: johannes@sipsolutions.net
542L: linux-input@vger.kernel.org 482L: linux-input@vger.kernel.org
543S: Maintained 483S: Maintained
544F: Documentation/input/appletouch.txt 484F: Documentation/input/appletouch.txt
545F: drivers/input/mouse/appletouch.c 485F: drivers/input/mouse/appletouch.c
546 486
547ARC FRAMEBUFFER DRIVER 487ARC FRAMEBUFFER DRIVER
548P: Jaya Kumar 488M: Jaya Kumar <jayalk@intworks.biz>
549M: jayalk@intworks.biz
550S: Maintained 489S: Maintained
551F: drivers/video/arcfb.c 490F: drivers/video/arcfb.c
552F: drivers/video/fb_defio.c 491F: drivers/video/fb_defio.c
553 492
554ARM MFM AND FLOPPY DRIVERS 493ARM MFM AND FLOPPY DRIVERS
555P: Ian Molton 494M: Ian Molton <spyro@f2s.com>
556M: spyro@f2s.com
557S: Maintained 495S: Maintained
558F: arch/arm/lib/floppydma.S 496F: arch/arm/lib/floppydma.S
559F: arch/arm/include/asm/floppy.h 497F: arch/arm/include/asm/floppy.h
560 498
561ARM PORT 499ARM PORT
562P: Russell King 500M: Russell King <linux@arm.linux.org.uk>
563M: linux@arm.linux.org.uk
564L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 501L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
565W: http://www.arm.linux.org.uk/ 502W: http://www.arm.linux.org.uk/
566S: Maintained 503S: Maintained
@@ -571,79 +508,67 @@ S: Orphan
571F: drivers/mmc/host/mmci.* 508F: drivers/mmc/host/mmci.*
572 509
573ARM/ADI ROADRUNNER MACHINE SUPPORT 510ARM/ADI ROADRUNNER MACHINE SUPPORT
574P: Lennert Buytenhek 511M: Lennert Buytenhek <kernel@wantstofly.org>
575M: kernel@wantstofly.org
576L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 512L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
577S: Maintained 513S: Maintained
578F: arch/arm/mach-ixp23xx/ 514F: arch/arm/mach-ixp23xx/
579F: arch/arm/mach-ixp23xx/include/mach/ 515F: arch/arm/mach-ixp23xx/include/mach/
580 516
581ARM/ADS SPHERE MACHINE SUPPORT 517ARM/ADS SPHERE MACHINE SUPPORT
582P: Lennert Buytenhek 518M: Lennert Buytenhek <kernel@wantstofly.org>
583M: kernel@wantstofly.org
584L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 519L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
585S: Maintained 520S: Maintained
586 521
587ARM/AFEB9260 MACHINE SUPPORT 522ARM/AFEB9260 MACHINE SUPPORT
588P: Sergey Lapin 523M: Sergey Lapin <slapin@ossfans.org>
589M: slapin@ossfans.org
590L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 524L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
591S: Maintained 525S: Maintained
592 526
593ARM/AJECO 1ARM MACHINE SUPPORT 527ARM/AJECO 1ARM MACHINE SUPPORT
594P: Lennert Buytenhek 528M: Lennert Buytenhek <kernel@wantstofly.org>
595M: kernel@wantstofly.org
596L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 529L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
597S: Maintained 530S: Maintained
598 531
599ARM/ATMEL AT91RM9200 ARM ARCHITECTURE 532ARM/ATMEL AT91RM9200 ARM ARCHITECTURE
600P: Andrew Victor 533M: Andrew Victor <linux@maxim.org.za>
601M: linux@maxim.org.za
602L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 534L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
603W: http://maxim.org.za/at91_26.html 535W: http://maxim.org.za/at91_26.html
604S: Maintained 536S: Maintained
605 537
606ARM/CIRRUS LOGIC EP93XX ARM ARCHITECTURE 538ARM/CIRRUS LOGIC EP93XX ARM ARCHITECTURE
607P: Lennert Buytenhek 539M: Lennert Buytenhek <kernel@wantstofly.org>
608M: kernel@wantstofly.org
609L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 540L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
610S: Maintained 541S: Maintained
611 542
612ARM/CIRRUS LOGIC EDB9315A MACHINE SUPPORT 543ARM/CIRRUS LOGIC EDB9315A MACHINE SUPPORT
613P: Lennert Buytenhek 544M: Lennert Buytenhek <kernel@wantstofly.org>
614M: kernel@wantstofly.org
615L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 545L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
616S: Maintained 546S: Maintained
617 547
618ARM/CLKDEV SUPPORT 548ARM/CLKDEV SUPPORT
619P: Russell King 549M: Russell King <linux@arm.linux.org.uk>
620M: linux@arm.linux.org.uk
621L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 550L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
622F: arch/arm/common/clkdev.c 551F: arch/arm/common/clkdev.c
623F: arch/arm/include/asm/clkdev.h 552F: arch/arm/include/asm/clkdev.h
624 553
625ARM/COMPULAB CM-X270/EM-X270 and CM-X300 MACHINE SUPPORT 554ARM/COMPULAB CM-X270/EM-X270 and CM-X300 MACHINE SUPPORT
626P: Mike Rapoport 555M: Mike Rapoport <mike@compulab.co.il>
627M: mike@compulab.co.il
628L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 556L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
629S: Maintained 557S: Maintained
630 558
631ARM/CORGI MACHINE SUPPORT 559ARM/CORGI MACHINE SUPPORT
632P: Richard Purdie 560M: Richard Purdie <rpurdie@rpsys.net>
633M: rpurdie@rpsys.net
634S: Maintained 561S: Maintained
635 562
636ARM/CORTINA SYSTEMS GEMINI ARM ARCHITECTURE 563ARM/CORTINA SYSTEMS GEMINI ARM ARCHITECTURE
637P: Paulius Zaleckas 564M: Paulius Zaleckas <paulius.zaleckas@teltonika.lt>
638M: paulius.zaleckas@teltonika.lt
639L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 565L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
640T: git git://gitorious.org/linux-gemini/mainline.git 566T: git git://gitorious.org/linux-gemini/mainline.git
641S: Maintained 567S: Maintained
642F: arch/arm/mach-gemini/ 568F: arch/arm/mach-gemini/
643 569
644ARM/EBSA110 MACHINE SUPPORT 570ARM/EBSA110 MACHINE SUPPORT
645P: Russell King 571M: Russell King <linux@arm.linux.org.uk>
646M: linux@arm.linux.org.uk
647L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 572L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
648W: http://www.arm.linux.org.uk/ 573W: http://www.arm.linux.org.uk/
649S: Maintained 574S: Maintained
@@ -651,12 +576,9 @@ F: arch/arm/mach-ebsa110/
651F: drivers/net/arm/am79c961a.* 576F: drivers/net/arm/am79c961a.*
652 577
653ARM/EZX SMARTPHONES (A780, A910, A1200, E680, ROKR E2 and ROKR E6) 578ARM/EZX SMARTPHONES (A780, A910, A1200, E680, ROKR E2 and ROKR E6)
654P: Daniel Ribeiro 579M: Daniel Ribeiro <drwyrm@gmail.com>
655M: drwyrm@gmail.com 580M: Stefan Schmidt <stefan@openezx.org>
656P: Stefan Schmidt 581M: Harald Welte <laforge@openezx.org>
657M: stefan@openezx.org
658P: Harald Welte
659M: laforge@openezx.org
660L: openezx-devel@lists.openezx.org (subscribers-only) 582L: openezx-devel@lists.openezx.org (subscribers-only)
661W: http://www.openezx.org/ 583W: http://www.openezx.org/
662S: Maintained 584S: Maintained
@@ -664,15 +586,13 @@ T: topgit git://git.openezx.org/openezx.git
664F: arch/arm/mach-pxa/ezx.c 586F: arch/arm/mach-pxa/ezx.c
665 587
666ARM/FARADAY FA526 PORT 588ARM/FARADAY FA526 PORT
667P: Paulius Zaleckas 589M: Paulius Zaleckas <paulius.zaleckas@teltonika.lt>
668M: paulius.zaleckas@teltonika.lt
669L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 590L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
670S: Maintained 591S: Maintained
671F: arch/arm/mm/*-fa* 592F: arch/arm/mm/*-fa*
672 593
673ARM/FOOTBRIDGE ARCHITECTURE 594ARM/FOOTBRIDGE ARCHITECTURE
674P: Russell King 595M: Russell King <linux@arm.linux.org.uk>
675M: linux@arm.linux.org.uk
676L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 596L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
677W: http://www.arm.linux.org.uk/ 597W: http://www.arm.linux.org.uk/
678S: Maintained 598S: Maintained
@@ -680,175 +600,146 @@ F: arch/arm/include/asm/hardware/dec21285.h
680F: arch/arm/mach-footbridge/ 600F: arch/arm/mach-footbridge/
681 601
682ARM/FREESCALE IMX / MXC ARM ARCHITECTURE 602ARM/FREESCALE IMX / MXC ARM ARCHITECTURE
683P: Sascha Hauer 603M: Sascha Hauer <kernel@pengutronix.de>
684M: kernel@pengutronix.de
685L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 604L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
686S: Maintained 605S: Maintained
687 606
688ARM/GLOMATION GESBC9312SX MACHINE SUPPORT 607ARM/GLOMATION GESBC9312SX MACHINE SUPPORT
689P: Lennert Buytenhek 608M: Lennert Buytenhek <kernel@wantstofly.org>
690M: kernel@wantstofly.org
691L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 609L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
692S: Maintained 610S: Maintained
693 611
694ARM/GUMSTIX MACHINE SUPPORT 612ARM/GUMSTIX MACHINE SUPPORT
695P: Steve Sakoman 613M: Steve Sakoman <sakoman@gmail.com>
696M: sakoman@gmail.com
697L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 614L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
698S: Maintained 615S: Maintained
699 616
700ARM/H4700 (HP IPAQ HX4700) MACHINE SUPPORT 617ARM/H4700 (HP IPAQ HX4700) MACHINE SUPPORT
701P: Philipp Zabel 618M: Philipp Zabel <philipp.zabel@gmail.com>
702M: philipp.zabel@gmail.com
703S: Maintained 619S: Maintained
704F: arch/arm/mach-pxa/hx4700.c 620F: arch/arm/mach-pxa/hx4700.c
705F: arch/arm/mach-pxa/include/mach/hx4700.h 621F: arch/arm/mach-pxa/include/mach/hx4700.h
706 622
707ARM/HP JORNADA 7XX MACHINE SUPPORT 623ARM/HP JORNADA 7XX MACHINE SUPPORT
708P: Kristoffer Ericson 624M: Kristoffer Ericson <kristoffer.ericson@gmail.com>
709M: kristoffer.ericson@gmail.com
710W: www.jlime.com 625W: www.jlime.com
711S: Maintained 626S: Maintained
627T: git git://git.kernel.org/pub/scm/linux/kernel/git/kristoffer/linux-hpc.git
628F: arch/arm/mach-sa1100/jornada720.c
629F: arch/arm/mach-sa1100/include/mach/jornada720.h
712 630
713ARM/INTEL IOP32X ARM ARCHITECTURE 631ARM/INTEL IOP32X ARM ARCHITECTURE
714P: Lennert Buytenhek 632M: Lennert Buytenhek <kernel@wantstofly.org>
715M: kernel@wantstofly.org 633M: Dan Williams <dan.j.williams@intel.com>
716P: Dan Williams
717M: dan.j.williams@intel.com
718L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 634L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
719S: Supported 635S: Supported
720 636
721ARM/INTEL IOP33X ARM ARCHITECTURE 637ARM/INTEL IOP33X ARM ARCHITECTURE
722P: Dan Williams 638M: Dan Williams <dan.j.williams@intel.com>
723M: dan.j.williams@intel.com
724L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 639L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
725S: Supported 640S: Supported
726 641
727ARM/INTEL IOP13XX ARM ARCHITECTURE 642ARM/INTEL IOP13XX ARM ARCHITECTURE
728P: Lennert Buytenhek 643M: Lennert Buytenhek <kernel@wantstofly.org>
729M: kernel@wantstofly.org 644M: Dan Williams <dan.j.williams@intel.com>
730P: Dan Williams
731M: dan.j.williams@intel.com
732L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 645L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
733S: Supported 646S: Supported
734 647
735ARM/INTEL IQ81342EX MACHINE SUPPORT 648ARM/INTEL IQ81342EX MACHINE SUPPORT
736P: Lennert Buytenhek 649M: Lennert Buytenhek <kernel@wantstofly.org>
737M: kernel@wantstofly.org 650M: Dan Williams <dan.j.williams@intel.com>
738P: Dan Williams
739M: dan.j.williams@intel.com
740L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 651L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
741S: Supported 652S: Supported
742 653
743ARM/INTEL IXP2000 ARM ARCHITECTURE 654ARM/INTEL IXP2000 ARM ARCHITECTURE
744P: Lennert Buytenhek 655M: Lennert Buytenhek <kernel@wantstofly.org>
745M: kernel@wantstofly.org
746L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 656L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
747S: Maintained 657S: Maintained
748 658
749ARM/INTEL IXDP2850 MACHINE SUPPORT 659ARM/INTEL IXDP2850 MACHINE SUPPORT
750P: Lennert Buytenhek 660M: Lennert Buytenhek <kernel@wantstofly.org>
751M: kernel@wantstofly.org
752L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 661L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
753S: Maintained 662S: Maintained
754 663
755ARM/INTEL IXP23XX ARM ARCHITECTURE 664ARM/INTEL IXP23XX ARM ARCHITECTURE
756P: Lennert Buytenhek 665M: Lennert Buytenhek <kernel@wantstofly.org>
757M: kernel@wantstofly.org
758L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 666L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
759S: Maintained 667S: Maintained
760 668
761ARM/INTEL XSC3 (MANZANO) ARM CORE 669ARM/INTEL XSC3 (MANZANO) ARM CORE
762P: Lennert Buytenhek 670M: Lennert Buytenhek <kernel@wantstofly.org>
763M: kernel@wantstofly.org 671M: Dan Williams <dan.j.williams@intel.com>
764P: Dan Williams
765M: dan.j.williams@intel.com
766L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 672L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
767S: Supported 673S: Supported
768 674
769ARM/IP FABRICS DOUBLE ESPRESSO MACHINE SUPPORT 675ARM/IP FABRICS DOUBLE ESPRESSO MACHINE SUPPORT
770P: Lennert Buytenhek 676M: Lennert Buytenhek <kernel@wantstofly.org>
771M: kernel@wantstofly.org
772L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 677L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
773S: Maintained 678S: Maintained
774 679
775ARM/LOGICPD PXA270 MACHINE SUPPORT 680ARM/LOGICPD PXA270 MACHINE SUPPORT
776P: Lennert Buytenhek 681M: Lennert Buytenhek <kernel@wantstofly.org>
777M: kernel@wantstofly.org
778L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 682L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
779S: Maintained 683S: Maintained
780 684
781ARM/MAGICIAN MACHINE SUPPORT 685ARM/MAGICIAN MACHINE SUPPORT
782P: Philipp Zabel 686M: Philipp Zabel <philipp.zabel@gmail.com>
783M: philipp.zabel@gmail.com
784S: Maintained 687S: Maintained
785 688
786ARM/MIOA701 MACHINE SUPPORT 689ARM/MIOA701 MACHINE SUPPORT
787P: Robert Jarzmik 690M: Robert Jarzmik <robert.jarzmik@free.fr>
788M: robert.jarzmik@free.fr
789L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 691L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
790F: arch/arm/mach-pxa/mioa701.c 692F: arch/arm/mach-pxa/mioa701.c
791S: Maintained 693S: Maintained
792 694
793ARM/NEC MOBILEPRO 900/c MACHINE SUPPORT 695ARM/NEC MOBILEPRO 900/c MACHINE SUPPORT
794P: Michael Petchkovsky 696M: Michael Petchkovsky <mkpetch@internode.on.net>
795M: mkpetch@internode.on.net
796S: Maintained 697S: Maintained
797 698
798ARM/OPENMOKO NEO FREERUNNER (GTA02) MACHINE SUPPORT 699ARM/OPENMOKO NEO FREERUNNER (GTA02) MACHINE SUPPORT
799P: Nelson Castillo 700M: Nelson Castillo <arhuaco@freaks-unidos.net>
800M: arhuaco@freaks-unidos.net
801L: openmoko-kernel@lists.openmoko.org (subscribers-only) 701L: openmoko-kernel@lists.openmoko.org (subscribers-only)
802W: http://wiki.openmoko.org/wiki/Neo_FreeRunner 702W: http://wiki.openmoko.org/wiki/Neo_FreeRunner
803S: Supported 703S: Supported
804 704
805ARM/TOSA MACHINE SUPPORT 705ARM/TOSA MACHINE SUPPORT
806P: Dmitry Eremin-Solenikov 706M: Dmitry Eremin-Solenikov <dbaryshkov@gmail.com>
807M: dbaryshkov@gmail.com 707M: Dirk Opfer <dirk@opfer-online.de>
808P: Dirk Opfer
809M: dirk@opfer-online.de
810S: Maintained 708S: Maintained
811 709
812ARM/PALMTX,PALMT5,PALMLD,PALMTE2 SUPPORT 710ARM/PALMTX,PALMT5,PALMLD,PALMTE2 SUPPORT
813P: Marek Vasut 711M: Marek Vasut <marek.vasut@gmail.com>
814M: marek.vasut@gmail.com
815W: http://hackndev.com 712W: http://hackndev.com
816S: Maintained 713S: Maintained
817 714
818ARM/PALM TREO 680 SUPPORT 715ARM/PALM TREO 680 SUPPORT
819P: Tomas Cech 716M: Tomas Cech <sleep_walker@suse.cz>
820M: sleep_walker@suse.cz
821W: http://hackndev.com 717W: http://hackndev.com
822S: Maintained 718S: Maintained
823 719
824ARM/PALMZ72 SUPPORT 720ARM/PALMZ72 SUPPORT
825P: Sergey Lapin 721M: Sergey Lapin <slapin@ossfans.org>
826M: slapin@ossfans.org
827W: http://hackndev.com 722W: http://hackndev.com
828S: Maintained 723S: Maintained
829 724
830ARM/PLEB SUPPORT 725ARM/PLEB SUPPORT
831P: Peter Chubb 726M: Peter Chubb <pleb@gelato.unsw.edu.au>
832M: pleb@gelato.unsw.edu.au
833W: http://www.disy.cse.unsw.edu.au/Hardware/PLEB 727W: http://www.disy.cse.unsw.edu.au/Hardware/PLEB
834S: Maintained 728S: Maintained
835 729
836ARM/PT DIGITAL BOARD PORT 730ARM/PT DIGITAL BOARD PORT
837P: Stefan Eletzhofer 731M: Stefan Eletzhofer <stefan.eletzhofer@eletztrick.de>
838M: stefan.eletzhofer@eletztrick.de
839L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 732L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
840W: http://www.arm.linux.org.uk/ 733W: http://www.arm.linux.org.uk/
841S: Maintained 734S: Maintained
842 735
843ARM/RADISYS ENP2611 MACHINE SUPPORT 736ARM/RADISYS ENP2611 MACHINE SUPPORT
844P: Lennert Buytenhek 737M: Lennert Buytenhek <kernel@wantstofly.org>
845M: kernel@wantstofly.org
846L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 738L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
847S: Maintained 739S: Maintained
848 740
849ARM/RISCPC ARCHITECTURE 741ARM/RISCPC ARCHITECTURE
850P: Russell King 742M: Russell King <linux@arm.linux.org.uk>
851M: linux@arm.linux.org.uk
852L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 743L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
853W: http://www.arm.linux.org.uk/ 744W: http://www.arm.linux.org.uk/
854S: Maintained 745S: Maintained
@@ -862,14 +753,12 @@ F: drivers/net/arm/ether*
862F: drivers/scsi/arm/ 753F: drivers/scsi/arm/
863 754
864ARM/SHARK MACHINE SUPPORT 755ARM/SHARK MACHINE SUPPORT
865P: Alexander Schulz 756M: Alexander Schulz <alex@shark-linux.de>
866M: alex@shark-linux.de
867W: http://www.shark-linux.de/shark.html 757W: http://www.shark-linux.de/shark.html
868S: Maintained 758S: Maintained
869 759
870ARM/SAMSUNG ARM ARCHITECTURES 760ARM/SAMSUNG ARM ARCHITECTURES
871P: Ben Dooks 761M: Ben Dooks <ben-linux@fluff.org>
872M: ben-linux@fluff.org
873L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 762L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
874W: http://www.fluff.org/ben/linux/ 763W: http://www.fluff.org/ben/linux/
875S: Maintained 764S: Maintained
@@ -877,91 +766,73 @@ F: arch/arm/plat-s3c/
877F: arch/arm/plat-s3c24xx/ 766F: arch/arm/plat-s3c24xx/
878 767
879ARM/S3C2410 ARM ARCHITECTURE 768ARM/S3C2410 ARM ARCHITECTURE
880P: Ben Dooks 769M: Ben Dooks <ben-linux@fluff.org>
881M: ben-linux@fluff.org
882L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 770L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
883W: http://www.fluff.org/ben/linux/ 771W: http://www.fluff.org/ben/linux/
884S: Maintained 772S: Maintained
885F: arch/arm/mach-s3c2410/ 773F: arch/arm/mach-s3c2410/
886 774
887ARM/S3C2440 ARM ARCHITECTURE 775ARM/S3C2440 ARM ARCHITECTURE
888P: Ben Dooks 776M: Ben Dooks <ben-linux@fluff.org>
889M: ben-linux@fluff.org
890L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 777L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
891W: http://www.fluff.org/ben/linux/ 778W: http://www.fluff.org/ben/linux/
892S: Maintained 779S: Maintained
893F: arch/arm/mach-s3c2440/ 780F: arch/arm/mach-s3c2440/
894 781
895ARM/S3C2442 ARM ARCHITECTURE 782ARM/S3C2442 ARM ARCHITECTURE
896P: Ben Dooks 783M: Ben Dooks <ben-linux@fluff.org>
897M: ben-linux@fluff.org
898L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 784L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
899W: http://www.fluff.org/ben/linux/ 785W: http://www.fluff.org/ben/linux/
900S: Maintained 786S: Maintained
901F: arch/arm/mach-s3c2442/ 787F: arch/arm/mach-s3c2442/
902 788
903ARM/S3C2443 ARM ARCHITECTURE 789ARM/S3C2443 ARM ARCHITECTURE
904P: Ben Dooks 790M: Ben Dooks <ben-linux@fluff.org>
905M: ben-linux@fluff.org
906L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 791L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
907W: http://www.fluff.org/ben/linux/ 792W: http://www.fluff.org/ben/linux/
908S: Maintained 793S: Maintained
909F: arch/arm/mach-s3c2443/ 794F: arch/arm/mach-s3c2443/
910 795
911ARM/S3C6400 ARM ARCHITECTURE 796ARM/S3C6400 ARM ARCHITECTURE
912P: Ben Dooks 797M: Ben Dooks <ben-linux@fluff.org>
913M: ben-linux@fluff.org
914L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 798L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
915W: http://www.fluff.org/ben/linux/ 799W: http://www.fluff.org/ben/linux/
916S: Maintained 800S: Maintained
917F: arch/arm/mach-s3c6400/ 801F: arch/arm/mach-s3c6400/
918 802
919ARM/S3C6410 ARM ARCHITECTURE 803ARM/S3C6410 ARM ARCHITECTURE
920P: Ben Dooks 804M: Ben Dooks <ben-linux@fluff.org>
921M: ben-linux@fluff.org
922L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 805L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
923W: http://www.fluff.org/ben/linux/ 806W: http://www.fluff.org/ben/linux/
924S: Maintained 807S: Maintained
925F: arch/arm/mach-s3c6410/ 808F: arch/arm/mach-s3c6410/
926 809
927ARM/TECHNOLOGIC SYSTEMS TS7250 MACHINE SUPPORT 810ARM/TECHNOLOGIC SYSTEMS TS7250 MACHINE SUPPORT
928P: Lennert Buytenhek 811M: Lennert Buytenhek <kernel@wantstofly.org>
929M: kernel@wantstofly.org
930L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 812L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
931S: Maintained 813S: Maintained
932 814
933ARM/THECUS N2100 MACHINE SUPPORT 815ARM/THECUS N2100 MACHINE SUPPORT
934P: Lennert Buytenhek 816M: Lennert Buytenhek <kernel@wantstofly.org>
935M: kernel@wantstofly.org
936L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 817L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
937S: Maintained 818S: Maintained
938 819
939ARM/NUVOTON W90X900 ARM ARCHITECTURE 820ARM/NUVOTON W90X900 ARM ARCHITECTURE
940P: Wan ZongShun 821M: Wan ZongShun <mcuos.com@gmail.com>
941M: mcuos.com@gmail.com
942L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 822L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
943W: http://www.mcuos.com 823W: http://www.mcuos.com
944S: Maintained 824S: Maintained
945 825
946ARM/VFP SUPPORT 826ARM/VFP SUPPORT
947P: Russell King 827M: Russell King <linux@arm.linux.org.uk>
948M: linux@arm.linux.org.uk
949L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 828L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
950W: http://www.arm.linux.org.uk/ 829W: http://www.arm.linux.org.uk/
951S: Maintained 830S: Maintained
952F: arch/arm/vfp/ 831F: arch/arm/vfp/
953 832
954ARPD SUPPORT
955P: Jonathan Layes
956L: netdev@vger.kernel.org
957S: Maintained
958F: net/ipv4/arp.c
959
960ASUS ACPI EXTRAS DRIVER 833ASUS ACPI EXTRAS DRIVER
961P: Corentin Chary 834M: Corentin Chary <corentincj@iksaif.net>
962M: corentincj@iksaif.net 835M: Karol Kozimor <sziwan@users.sourceforge.net>
963P: Karol Kozimor
964M: sziwan@users.sourceforge.net
965L: acpi4asus-user@lists.sourceforge.net 836L: acpi4asus-user@lists.sourceforge.net
966W: http://acpi4asus.sf.net 837W: http://acpi4asus.sf.net
967S: Maintained 838S: Maintained
@@ -969,25 +840,21 @@ F: arch/x86/kernel/acpi/boot.c
969F: drivers/platform/x86/asus_acpi.c 840F: drivers/platform/x86/asus_acpi.c
970 841
971ASUS ASB100 HARDWARE MONITOR DRIVER 842ASUS ASB100 HARDWARE MONITOR DRIVER
972P: Mark M. Hoffman 843M: "Mark M. Hoffman" <mhoffman@lightlink.com>
973M: mhoffman@lightlink.com
974L: lm-sensors@lm-sensors.org 844L: lm-sensors@lm-sensors.org
975S: Maintained 845S: Maintained
976F: drivers/hwmon/asb100.c 846F: drivers/hwmon/asb100.c
977 847
978ASUS LAPTOP EXTRAS DRIVER 848ASUS LAPTOP EXTRAS DRIVER
979P: Corentin Chary 849M: Corentin Chary <corentincj@iksaif.net>
980M: corentincj@iksaif.net
981L: acpi4asus-user@lists.sourceforge.net 850L: acpi4asus-user@lists.sourceforge.net
982W: http://acpi4asus.sf.net 851W: http://acpi4asus.sf.net
983S: Maintained 852S: Maintained
984F: drivers/platform/x86/asus-laptop.c 853F: drivers/platform/x86/asus-laptop.c
985 854
986ASYNCHRONOUS TRANSFERS/TRANSFORMS (IOAT) API 855ASYNCHRONOUS TRANSFERS/TRANSFORMS (IOAT) API
987P: Dan Williams 856M: Dan Williams <dan.j.williams@intel.com>
988M: dan.j.williams@intel.com 857M: Maciej Sosnowski <maciej.sosnowski@intel.com>
989P: Maciej Sosnowski
990M: maciej.sosnowski@intel.com
991W: http://sourceforge.net/projects/xscaleiop 858W: http://sourceforge.net/projects/xscaleiop
992S: Supported 859S: Supported
993F: Documentation/crypto/async-tx-api.txt 860F: Documentation/crypto/async-tx-api.txt
@@ -997,64 +864,49 @@ F: include/linux/dmaengine.h
997F: include/linux/async_tx.h 864F: include/linux/async_tx.h
998 865
999ATA OVER ETHERNET (AOE) DRIVER 866ATA OVER ETHERNET (AOE) DRIVER
1000P: Ed L. Cashin 867M: "Ed L. Cashin" <ecashin@coraid.com>
1001M: ecashin@coraid.com
1002W: http://www.coraid.com/support/linux 868W: http://www.coraid.com/support/linux
1003S: Supported 869S: Supported
1004F: Documentation/aoe/ 870F: Documentation/aoe/
1005F: drivers/block/aoe/ 871F: drivers/block/aoe/
1006 872
1007ATHEROS ATH5K WIRELESS DRIVER 873ATHEROS ATH5K WIRELESS DRIVER
1008P: Jiri Slaby 874M: Jiri Slaby <jirislaby@gmail.com>
1009M: jirislaby@gmail.com 875M: Nick Kossifidis <mickflemm@gmail.com>
1010P: Nick Kossifidis 876M: "Luis R. Rodriguez" <lrodriguez@atheros.com>
1011M: mickflemm@gmail.com 877M: Bob Copeland <me@bobcopeland.com>
1012P: Luis R. Rodriguez
1013M: lrodriguez@atheros.com
1014P: Bob Copeland
1015M: me@bobcopeland.com
1016L: linux-wireless@vger.kernel.org 878L: linux-wireless@vger.kernel.org
1017L: ath5k-devel@lists.ath5k.org 879L: ath5k-devel@lists.ath5k.org
1018S: Maintained 880S: Maintained
1019F: drivers/net/wireless/ath/ath5k/ 881F: drivers/net/wireless/ath/ath5k/
1020 882
1021ATHEROS ATH9K WIRELESS DRIVER 883ATHEROS ATH9K WIRELESS DRIVER
1022P: Luis R. Rodriguez 884M: "Luis R. Rodriguez" <lrodriguez@atheros.com>
1023M: lrodriguez@atheros.com 885M: Jouni Malinen <jmalinen@atheros.com>
1024P: Jouni Malinen 886M: Sujith Manoharan <Sujith.Manoharan@atheros.com>
1025M: jmalinen@atheros.com 887M: Vasanthakumar Thiagarajan <vasanth@atheros.com>
1026P: Sujith Manoharan 888M: Senthil Balasubramanian <senthilkumar@atheros.com>
1027M: Sujith.Manoharan@atheros.com
1028P: Vasanthakumar Thiagarajan
1029M: vasanth@atheros.com
1030P: Senthil Balasubramanian
1031M: senthilkumar@atheros.com
1032L: linux-wireless@vger.kernel.org 889L: linux-wireless@vger.kernel.org
1033L: ath9k-devel@lists.ath9k.org 890L: ath9k-devel@lists.ath9k.org
1034S: Supported 891S: Supported
1035F: drivers/net/wireless/ath/ath9k/ 892F: drivers/net/wireless/ath/ath9k/
1036 893
1037ATHEROS AR9170 WIRELESS DRIVER 894ATHEROS AR9170 WIRELESS DRIVER
1038P: Christian Lamparter 895M: Christian Lamparter <chunkeey@web.de>
1039M: chunkeey@web.de
1040L: linux-wireless@vger.kernel.org 896L: linux-wireless@vger.kernel.org
1041W: http://wireless.kernel.org/en/users/Drivers/ar9170 897W: http://wireless.kernel.org/en/users/Drivers/ar9170
1042S: Maintained 898S: Maintained
1043F: drivers/net/wireless/ath/ar9170/ 899F: drivers/net/wireless/ath/ar9170/
1044 900
1045ATI_REMOTE2 DRIVER 901ATI_REMOTE2 DRIVER
1046P: Ville Syrjala 902M: Ville Syrjala <syrjala@sci.fi>
1047M: syrjala@sci.fi
1048S: Maintained 903S: Maintained
1049F: drivers/input/misc/ati_remote2.c 904F: drivers/input/misc/ati_remote2.c
1050 905
1051ATLX ETHERNET DRIVERS 906ATLX ETHERNET DRIVERS
1052P: Jay Cliburn 907M: Jay Cliburn <jcliburn@gmail.com>
1053M: jcliburn@gmail.com 908M: Chris Snook <csnook@redhat.com>
1054P: Chris Snook 909M: Jie Yang <jie.yang@atheros.com>
1055M: csnook@redhat.com
1056P: Jie Yang
1057M: jie.yang@atheros.com
1058L: atl1-devel@lists.sourceforge.net 910L: atl1-devel@lists.sourceforge.net
1059W: http://sourceforge.net/projects/atl1 911W: http://sourceforge.net/projects/atl1
1060W: http://atl1.sourceforge.net 912W: http://atl1.sourceforge.net
@@ -1062,8 +914,7 @@ S: Maintained
1062F: drivers/net/atlx/ 914F: drivers/net/atlx/
1063 915
1064ATM 916ATM
1065P: Chas Williams 917M: Chas Williams <chas@cmf.nrl.navy.mil>
1066M: chas@cmf.nrl.navy.mil
1067L: linux-atm-general@lists.sourceforge.net (subscribers-only) 918L: linux-atm-general@lists.sourceforge.net (subscribers-only)
1068L: netdev@vger.kernel.org 919L: netdev@vger.kernel.org
1069W: http://linux-atm.sourceforge.net 920W: http://linux-atm.sourceforge.net
@@ -1072,8 +923,7 @@ F: drivers/atm/
1072F: include/linux/atm* 923F: include/linux/atm*
1073 924
1074ATMEL AT91 MCI DRIVER 925ATMEL AT91 MCI DRIVER
1075P: Nicolas Ferre 926M: Nicolas Ferre <nicolas.ferre@atmel.com>
1076M: nicolas.ferre@atmel.com
1077L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 927L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
1078W: http://www.atmel.com/products/AT91/ 928W: http://www.atmel.com/products/AT91/
1079W: http://www.at91.com/ 929W: http://www.at91.com/
@@ -1081,49 +931,42 @@ S: Maintained
1081F: drivers/mmc/host/at91_mci.c 931F: drivers/mmc/host/at91_mci.c
1082 932
1083ATMEL AT91 / AT32 MCI DRIVER 933ATMEL AT91 / AT32 MCI DRIVER
1084P: Nicolas Ferre 934M: Nicolas Ferre <nicolas.ferre@atmel.com>
1085M: nicolas.ferre@atmel.com
1086S: Maintained 935S: Maintained
1087F: drivers/mmc/host/atmel-mci.c 936F: drivers/mmc/host/atmel-mci.c
1088F: drivers/mmc/host/atmel-mci-regs.h 937F: drivers/mmc/host/atmel-mci-regs.h
1089 938
1090ATMEL AT91 / AT32 SERIAL DRIVER 939ATMEL AT91 / AT32 SERIAL DRIVER
1091P: Haavard Skinnemoen 940M: Haavard Skinnemoen <hskinnemoen@atmel.com>
1092M: hskinnemoen@atmel.com
1093S: Supported 941S: Supported
1094F: drivers/serial/atmel_serial.c 942F: drivers/serial/atmel_serial.c
1095 943
1096ATMEL LCDFB DRIVER 944ATMEL LCDFB DRIVER
1097P: Nicolas Ferre 945M: Nicolas Ferre <nicolas.ferre@atmel.com>
1098M: nicolas.ferre@atmel.com
1099L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) 946L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers)
1100S: Maintained 947S: Maintained
1101F: drivers/video/atmel_lcdfb.c 948F: drivers/video/atmel_lcdfb.c
1102F: include/video/atmel_lcdc.h 949F: include/video/atmel_lcdc.h
1103 950
1104ATMEL MACB ETHERNET DRIVER 951ATMEL MACB ETHERNET DRIVER
1105P: Haavard Skinnemoen 952M: Haavard Skinnemoen <hskinnemoen@atmel.com>
1106M: hskinnemoen@atmel.com
1107S: Supported 953S: Supported
1108F: drivers/net/macb.* 954F: drivers/net/macb.*
1109 955
1110ATMEL SPI DRIVER 956ATMEL SPI DRIVER
1111P: Haavard Skinnemoen 957M: Haavard Skinnemoen <hskinnemoen@atmel.com>
1112M: hskinnemoen@atmel.com
1113S: Supported 958S: Supported
1114F: drivers/spi/atmel_spi.* 959F: drivers/spi/atmel_spi.*
1115 960
1116ATMEL USBA UDC DRIVER 961ATMEL USBA UDC DRIVER
1117P: Haavard Skinnemoen 962M: Haavard Skinnemoen <hskinnemoen@atmel.com>
1118M: hskinnemoen@atmel.com
1119L: kernel@avr32linux.org 963L: kernel@avr32linux.org
1120W: http://avr32linux.org/twiki/bin/view/Main/AtmelUsbDeviceDriver 964W: http://avr32linux.org/twiki/bin/view/Main/AtmelUsbDeviceDriver
1121S: Supported 965S: Supported
1122F: drivers/usb/gadget/atmel_usba_udc.* 966F: drivers/usb/gadget/atmel_usba_udc.*
1123 967
1124ATMEL WIRELESS DRIVER 968ATMEL WIRELESS DRIVER
1125P: Simon Kelley 969M: Simon Kelley <simon@thekelleys.org.uk>
1126M: simon@thekelleys.org.uk
1127L: linux-wireless@vger.kernel.org 970L: linux-wireless@vger.kernel.org
1128W: http://www.thekelleys.org.uk/atmel 971W: http://www.thekelleys.org.uk/atmel
1129W: http://atmelwlandriver.sourceforge.net/ 972W: http://atmelwlandriver.sourceforge.net/
@@ -1131,10 +974,8 @@ S: Maintained
1131F: drivers/net/wireless/atmel* 974F: drivers/net/wireless/atmel*
1132 975
1133AUDIT SUBSYSTEM 976AUDIT SUBSYSTEM
1134P: Al Viro 977M: Al Viro <viro@zeniv.linux.org.uk>
1135M: viro@zeniv.linux.org.uk 978M: Eric Paris <eparis@redhat.com>
1136P: Eric Paris
1137M: eparis@redhat.com
1138L: linux-audit@redhat.com (subscribers-only) 979L: linux-audit@redhat.com (subscribers-only)
1139W: http://people.redhat.com/sgrubb/audit/ 980W: http://people.redhat.com/sgrubb/audit/
1140T: git git://git.kernel.org/pub/scm/linux/kernel/git/viro/audit-current.git 981T: git git://git.kernel.org/pub/scm/linux/kernel/git/viro/audit-current.git
@@ -1143,8 +984,7 @@ F: include/linux/audit.h
1143F: kernel/audit* 984F: kernel/audit*
1144 985
1145AUXILIARY DISPLAY DRIVERS 986AUXILIARY DISPLAY DRIVERS
1146P: Miguel Ojeda Sandonis 987M: Miguel Ojeda Sandonis <miguel.ojeda.sandonis@gmail.com>
1147M: miguel.ojeda.sandonis@gmail.com
1148W: http://miguelojeda.es/auxdisplay.htm 988W: http://miguelojeda.es/auxdisplay.htm
1149W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm 989W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm
1150S: Maintained 990S: Maintained
@@ -1152,8 +992,7 @@ F: drivers/auxdisplay/
1152F: include/linux/cfag12864b.h 992F: include/linux/cfag12864b.h
1153 993
1154AVR32 ARCHITECTURE 994AVR32 ARCHITECTURE
1155P: Haavard Skinnemoen 995M: Haavard Skinnemoen <hskinnemoen@atmel.com>
1156M: hskinnemoen@atmel.com
1157W: http://www.atmel.com/products/AVR32/ 996W: http://www.atmel.com/products/AVR32/
1158W: http://avr32linux.org/ 997W: http://avr32linux.org/
1159W: http://avrfreaks.net/ 998W: http://avrfreaks.net/
@@ -1161,14 +1000,12 @@ S: Supported
1161F: arch/avr32/ 1000F: arch/avr32/
1162 1001
1163AVR32/AT32AP MACHINE SUPPORT 1002AVR32/AT32AP MACHINE SUPPORT
1164P: Haavard Skinnemoen 1003M: Haavard Skinnemoen <hskinnemoen@atmel.com>
1165M: hskinnemoen@atmel.com
1166S: Supported 1004S: Supported
1167F: arch/avr32/mach-at32ap/ 1005F: arch/avr32/mach-at32ap/
1168 1006
1169AX.25 NETWORK LAYER 1007AX.25 NETWORK LAYER
1170P: Ralf Baechle 1008M: Ralf Baechle <ralf@linux-mips.org>
1171M: ralf@linux-mips.org
1172L: linux-hams@vger.kernel.org 1009L: linux-hams@vger.kernel.org
1173W: http://www.linux-ax25.org/ 1010W: http://www.linux-ax25.org/
1174S: Maintained 1011S: Maintained
@@ -1177,128 +1014,110 @@ F: include/net/ax25.h
1177F: net/ax25/ 1014F: net/ax25/
1178 1015
1179B43 WIRELESS DRIVER 1016B43 WIRELESS DRIVER
1180P: Michael Buesch 1017M: Michael Buesch <mb@bu3sch.de>
1181M: mb@bu3sch.de 1018M: Stefano Brivio <stefano.brivio@polimi.it>
1182P: Stefano Brivio
1183M: stefano.brivio@polimi.it
1184L: linux-wireless@vger.kernel.org 1019L: linux-wireless@vger.kernel.org
1185W: http://linuxwireless.org/en/users/Drivers/b43 1020W: http://linuxwireless.org/en/users/Drivers/b43
1186S: Maintained 1021S: Maintained
1187F: drivers/net/wireless/b43/ 1022F: drivers/net/wireless/b43/
1188 1023
1189B43LEGACY WIRELESS DRIVER 1024B43LEGACY WIRELESS DRIVER
1190P: Larry Finger 1025M: Larry Finger <Larry.Finger@lwfinger.net>
1191M: Larry.Finger@lwfinger.net 1026M: Stefano Brivio <stefano.brivio@polimi.it>
1192P: Stefano Brivio
1193M: stefano.brivio@polimi.it
1194L: linux-wireless@vger.kernel.org 1027L: linux-wireless@vger.kernel.org
1195W: http://linuxwireless.org/en/users/Drivers/b43 1028W: http://linuxwireless.org/en/users/Drivers/b43
1196S: Maintained 1029S: Maintained
1197F: drivers/net/wireless/b43legacy/ 1030F: drivers/net/wireless/b43legacy/
1198 1031
1199BACKLIGHT CLASS/SUBSYSTEM 1032BACKLIGHT CLASS/SUBSYSTEM
1200P: Richard Purdie 1033M: Richard Purdie <rpurdie@rpsys.net>
1201M: rpurdie@rpsys.net
1202S: Maintained 1034S: Maintained
1203F: drivers/video/backlight/ 1035F: drivers/video/backlight/
1204F: include/linux/backlight.h 1036F: include/linux/backlight.h
1205 1037
1206BAYCOM/HDLCDRV DRIVERS FOR AX.25 1038BAYCOM/HDLCDRV DRIVERS FOR AX.25
1207P: Thomas Sailer 1039M: Thomas Sailer <t.sailer@alumni.ethz.ch>
1208M: t.sailer@alumni.ethz.ch
1209L: linux-hams@vger.kernel.org 1040L: linux-hams@vger.kernel.org
1210W: http://www.baycom.org/~tom/ham/ham.html 1041W: http://www.baycom.org/~tom/ham/ham.html
1211S: Maintained 1042S: Maintained
1212F: drivers/net/hamradio/baycom* 1043F: drivers/net/hamradio/baycom*
1213 1044
1214BEFS FILE SYSTEM 1045BEFS FILE SYSTEM
1215P: Sergey S. Kostyliov 1046M: "Sergey S. Kostyliov" <rathamahata@php4.ru>
1216M: rathamahata@php4.ru
1217S: Maintained 1047S: Maintained
1218F: Documentation/filesystems/befs.txt 1048F: Documentation/filesystems/befs.txt
1219F: fs/befs/ 1049F: fs/befs/
1220 1050
1221BFS FILE SYSTEM 1051BFS FILE SYSTEM
1222P: Tigran A. Aivazian 1052M: "Tigran A. Aivazian" <tigran@aivazian.fsnet.co.uk>
1223M: tigran@aivazian.fsnet.co.uk
1224S: Maintained 1053S: Maintained
1225F: Documentation/filesystems/bfs.txt 1054F: Documentation/filesystems/bfs.txt
1226F: fs/bfs/ 1055F: fs/bfs/
1227F: include/linux/bfs_fs.h 1056F: include/linux/bfs_fs.h
1228 1057
1229BLACKFIN ARCHITECTURE 1058BLACKFIN ARCHITECTURE
1230P: Mike Frysinger 1059M: Mike Frysinger <vapier@gentoo.org>
1231M: vapier@gentoo.org
1232L: uclinux-dist-devel@blackfin.uclinux.org 1060L: uclinux-dist-devel@blackfin.uclinux.org
1233W: http://blackfin.uclinux.org 1061W: http://blackfin.uclinux.org
1234S: Supported 1062S: Supported
1235F: arch/blackfin/ 1063F: arch/blackfin/
1236 1064
1237BLACKFIN EMAC DRIVER 1065BLACKFIN EMAC DRIVER
1238P: Michael Hennerich 1066M: Michael Hennerich <michael.hennerich@analog.com>
1239M: michael.hennerich@analog.com
1240L: uclinux-dist-devel@blackfin.uclinux.org 1067L: uclinux-dist-devel@blackfin.uclinux.org
1241W: http://blackfin.uclinux.org 1068W: http://blackfin.uclinux.org
1242S: Supported 1069S: Supported
1243F: drivers/net/bfin_mac.* 1070F: drivers/net/bfin_mac.*
1244 1071
1245BLACKFIN RTC DRIVER 1072BLACKFIN RTC DRIVER
1246P: Mike Frysinger 1073M: Mike Frysinger <vapier.adi@gmail.com>
1247M: vapier.adi@gmail.com
1248L: uclinux-dist-devel@blackfin.uclinux.org 1074L: uclinux-dist-devel@blackfin.uclinux.org
1249W: http://blackfin.uclinux.org 1075W: http://blackfin.uclinux.org
1250S: Supported 1076S: Supported
1251F: drivers/rtc/rtc-bfin.c 1077F: drivers/rtc/rtc-bfin.c
1252 1078
1253BLACKFIN SERIAL DRIVER 1079BLACKFIN SERIAL DRIVER
1254P: Sonic Zhang 1080M: Sonic Zhang <sonic.zhang@analog.com>
1255M: sonic.zhang@analog.com
1256L: uclinux-dist-devel@blackfin.uclinux.org 1081L: uclinux-dist-devel@blackfin.uclinux.org
1257W: http://blackfin.uclinux.org 1082W: http://blackfin.uclinux.org
1258S: Supported 1083S: Supported
1259F: drivers/serial/bfin_5xx.c 1084F: drivers/serial/bfin_5xx.c
1260 1085
1261BLACKFIN WATCHDOG DRIVER 1086BLACKFIN WATCHDOG DRIVER
1262P: Mike Frysinger 1087M: Mike Frysinger <vapier.adi@gmail.com>
1263M: vapier.adi@gmail.com
1264L: uclinux-dist-devel@blackfin.uclinux.org 1088L: uclinux-dist-devel@blackfin.uclinux.org
1265W: http://blackfin.uclinux.org 1089W: http://blackfin.uclinux.org
1266S: Supported 1090S: Supported
1267F: drivers/watchdog/bfin_wdt.c 1091F: drivers/watchdog/bfin_wdt.c
1268 1092
1269BLACKFIN I2C TWI DRIVER 1093BLACKFIN I2C TWI DRIVER
1270P: Sonic Zhang 1094M: Sonic Zhang <sonic.zhang@analog.com>
1271M: sonic.zhang@analog.com
1272L: uclinux-dist-devel@blackfin.uclinux.org 1095L: uclinux-dist-devel@blackfin.uclinux.org
1273W: http://blackfin.uclinux.org/ 1096W: http://blackfin.uclinux.org/
1274S: Supported 1097S: Supported
1275F: drivers/i2c/busses/i2c-bfin-twi.c 1098F: drivers/i2c/busses/i2c-bfin-twi.c
1276 1099
1277BLOCK LAYER 1100BLOCK LAYER
1278P: Jens Axboe 1101M: Jens Axboe <axboe@kernel.dk>
1279M: axboe@kernel.dk
1280T: git git://git.kernel.org/pub/scm/linux/kernel/git/axboe/linux-2.6-block.git 1102T: git git://git.kernel.org/pub/scm/linux/kernel/git/axboe/linux-2.6-block.git
1281S: Maintained 1103S: Maintained
1282F: block/ 1104F: block/
1283 1105
1284BLOCK2MTD DRIVER 1106BLOCK2MTD DRIVER
1285P: Joern Engel 1107M: Joern Engel <joern@lazybastard.org>
1286M: joern@lazybastard.org
1287L: linux-mtd@lists.infradead.org 1108L: linux-mtd@lists.infradead.org
1288S: Maintained 1109S: Maintained
1289F: drivers/mtd/devices/block2mtd.c 1110F: drivers/mtd/devices/block2mtd.c
1290 1111
1291BLUETOOTH DRIVERS 1112BLUETOOTH DRIVERS
1292P: Marcel Holtmann 1113M: Marcel Holtmann <marcel@holtmann.org>
1293M: marcel@holtmann.org
1294L: linux-bluetooth@vger.kernel.org 1114L: linux-bluetooth@vger.kernel.org
1295W: http://www.bluez.org/ 1115W: http://www.bluez.org/
1296S: Maintained 1116S: Maintained
1297F: drivers/bluetooth/ 1117F: drivers/bluetooth/
1298 1118
1299BLUETOOTH SUBSYSTEM 1119BLUETOOTH SUBSYSTEM
1300P: Marcel Holtmann 1120M: Marcel Holtmann <marcel@holtmann.org>
1301M: marcel@holtmann.org
1302L: linux-bluetooth@vger.kernel.org 1121L: linux-bluetooth@vger.kernel.org
1303W: http://www.bluez.org/ 1122W: http://www.bluez.org/
1304T: git git://git.kernel.org/pub/scm/linux/kernel/git/holtmann/bluetooth-2.6.git 1123T: git git://git.kernel.org/pub/scm/linux/kernel/git/holtmann/bluetooth-2.6.git
@@ -1307,8 +1126,7 @@ F: net/bluetooth/
1307F: include/net/bluetooth/ 1126F: include/net/bluetooth/
1308 1127
1309BONDING DRIVER 1128BONDING DRIVER
1310P: Jay Vosburgh 1129M: Jay Vosburgh <fubar@us.ibm.com>
1311M: fubar@us.ibm.com
1312L: bonding-devel@lists.sourceforge.net 1130L: bonding-devel@lists.sourceforge.net
1313W: http://sourceforge.net/projects/bonding/ 1131W: http://sourceforge.net/projects/bonding/
1314S: Supported 1132S: Supported
@@ -1316,54 +1134,46 @@ F: drivers/net/bonding/
1316F: include/linux/if_bonding.h 1134F: include/linux/if_bonding.h
1317 1135
1318BROADCOM B44 10/100 ETHERNET DRIVER 1136BROADCOM B44 10/100 ETHERNET DRIVER
1319P: Gary Zambrano 1137M: Gary Zambrano <zambrano@broadcom.com>
1320M: zambrano@broadcom.com
1321L: netdev@vger.kernel.org 1138L: netdev@vger.kernel.org
1322S: Supported 1139S: Supported
1323F: drivers/net/b44.* 1140F: drivers/net/b44.*
1324 1141
1325BROADCOM BNX2 GIGABIT ETHERNET DRIVER 1142BROADCOM BNX2 GIGABIT ETHERNET DRIVER
1326P: Michael Chan 1143M: Michael Chan <mchan@broadcom.com>
1327M: mchan@broadcom.com
1328L: netdev@vger.kernel.org 1144L: netdev@vger.kernel.org
1329S: Supported 1145S: Supported
1330F: drivers/net/bnx2.* 1146F: drivers/net/bnx2.*
1331F: drivers/net/bnx2_* 1147F: drivers/net/bnx2_*
1332 1148
1333BROADCOM BNX2X 10 GIGABIT ETHERNET DRIVER 1149BROADCOM BNX2X 10 GIGABIT ETHERNET DRIVER
1334P: Eilon Greenstein 1150M: Eilon Greenstein <eilong@broadcom.com>
1335M: eilong@broadcom.com
1336L: netdev@vger.kernel.org 1151L: netdev@vger.kernel.org
1337S: Supported 1152S: Supported
1338F: drivers/net/bnx2x* 1153F: drivers/net/bnx2x*
1339 1154
1340BROADCOM TG3 GIGABIT ETHERNET DRIVER 1155BROADCOM TG3 GIGABIT ETHERNET DRIVER
1341P: Matt Carlson 1156M: Matt Carlson <mcarlson@broadcom.com>
1342M: mcarlson@broadcom.com 1157M: Michael Chan <mchan@broadcom.com>
1343P: Michael Chan
1344M: mchan@broadcom.com
1345L: netdev@vger.kernel.org 1158L: netdev@vger.kernel.org
1346S: Supported 1159S: Supported
1347F: drivers/net/tg3.* 1160F: drivers/net/tg3.*
1348 1161
1349BSG (block layer generic sg v4 driver) 1162BSG (block layer generic sg v4 driver)
1350P: FUJITA Tomonori 1163M: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
1351M: fujita.tomonori@lab.ntt.co.jp
1352L: linux-scsi@vger.kernel.org 1164L: linux-scsi@vger.kernel.org
1353S: Supported 1165S: Supported
1354F: block/bsg.c 1166F: block/bsg.c
1355F: include/linux/bsg.h 1167F: include/linux/bsg.h
1356 1168
1357BT8XXGPIO DRIVER 1169BT8XXGPIO DRIVER
1358P: Michael Buesch 1170M: Michael Buesch <mb@bu3sch.de>
1359M: mb@bu3sch.de
1360W: http://bu3sch.de/btgpio.php 1171W: http://bu3sch.de/btgpio.php
1361S: Maintained 1172S: Maintained
1362F: drivers/gpio/bt8xxgpio.c 1173F: drivers/gpio/bt8xxgpio.c
1363 1174
1364BTRFS FILE SYSTEM 1175BTRFS FILE SYSTEM
1365P: Chris Mason 1176M: Chris Mason <chris.mason@oracle.com>
1366M: chris.mason@oracle.com
1367L: linux-btrfs@vger.kernel.org 1177L: linux-btrfs@vger.kernel.org
1368W: http://btrfs.wiki.kernel.org/ 1178W: http://btrfs.wiki.kernel.org/
1369T: git git://git.kernel.org/pub/scm/linux/kernel/git/mason/btrfs-unstable.git 1179T: git git://git.kernel.org/pub/scm/linux/kernel/git/mason/btrfs-unstable.git
@@ -1372,8 +1182,7 @@ F: Documentation/filesystems/btrfs.txt
1372F: fs/btrfs/ 1182F: fs/btrfs/
1373 1183
1374BTTV VIDEO4LINUX DRIVER 1184BTTV VIDEO4LINUX DRIVER
1375P: Mauro Carvalho Chehab 1185M: Mauro Carvalho Chehab <mchehab@infradead.org>
1376M: mchehab@infradead.org
1377L: linux-media@vger.kernel.org 1186L: linux-media@vger.kernel.org
1378W: http://linuxtv.org 1187W: http://linuxtv.org
1379T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 1188T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
@@ -1382,16 +1191,14 @@ F: Documentation/video4linux/bttv/
1382F: drivers/media/video/bt8xx/bttv* 1191F: drivers/media/video/bt8xx/bttv*
1383 1192
1384CACHEFILES: FS-CACHE BACKEND FOR CACHING ON MOUNTED FILESYSTEMS 1193CACHEFILES: FS-CACHE BACKEND FOR CACHING ON MOUNTED FILESYSTEMS
1385P: David Howells 1194M: David Howells <dhowells@redhat.com>
1386M: dhowells@redhat.com
1387L: linux-cachefs@redhat.com 1195L: linux-cachefs@redhat.com
1388S: Supported 1196S: Supported
1389F: Documentation/filesystems/caching/cachefiles.txt 1197F: Documentation/filesystems/caching/cachefiles.txt
1390F: fs/cachefiles/ 1198F: fs/cachefiles/
1391 1199
1392CAFE CMOS INTEGRATED CAMERA CONTROLLER DRIVER 1200CAFE CMOS INTEGRATED CAMERA CONTROLLER DRIVER
1393P: Jonathan Corbet 1201M: Jonathan Corbet <corbet@lwn.net>
1394M: corbet@lwn.net
1395L: linux-media@vger.kernel.org 1202L: linux-media@vger.kernel.org
1396T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 1203T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
1397S: Maintained 1204S: Maintained
@@ -1399,10 +1206,8 @@ F: Documentation/video4linux/cafe_ccic
1399F: drivers/media/video/cafe_ccic* 1206F: drivers/media/video/cafe_ccic*
1400 1207
1401CALGARY x86-64 IOMMU 1208CALGARY x86-64 IOMMU
1402P: Muli Ben-Yehuda 1209M: Muli Ben-Yehuda <muli@il.ibm.com>
1403M: muli@il.ibm.com 1210M: "Jon D. Mason" <jdmason@kudzu.us>
1404P: Jon D. Mason
1405M: jdmason@kudzu.us
1406L: discuss@x86-64.org 1211L: discuss@x86-64.org
1407S: Maintained 1212S: Maintained
1408F: arch/x86/kernel/pci-calgary_64.c 1213F: arch/x86/kernel/pci-calgary_64.c
@@ -1411,10 +1216,8 @@ F: arch/x86/include/asm/calgary.h
1411F: arch/x86/include/asm/tce.h 1216F: arch/x86/include/asm/tce.h
1412 1217
1413CAN NETWORK LAYER 1218CAN NETWORK LAYER
1414P: Urs Thuermann 1219M: Urs Thuermann <urs.thuermann@volkswagen.de>
1415M: urs.thuermann@volkswagen.de 1220M: Oliver Hartkopp <oliver.hartkopp@volkswagen.de>
1416P: Oliver Hartkopp
1417M: oliver.hartkopp@volkswagen.de
1418L: socketcan-core@lists.berlios.de (subscribers-only) 1221L: socketcan-core@lists.berlios.de (subscribers-only)
1419W: http://developer.berlios.de/projects/socketcan/ 1222W: http://developer.berlios.de/projects/socketcan/
1420S: Maintained 1223S: Maintained
@@ -1423,15 +1226,13 @@ F: include/linux/can/
1423F: include/linux/can.h 1226F: include/linux/can.h
1424 1227
1425CAN NETWORK DRIVERS 1228CAN NETWORK DRIVERS
1426P: Wolfgang Grandegger 1229M: Wolfgang Grandegger <wg@grandegger.com>
1427M: wg@grandegger.com
1428L: socketcan-core@lists.berlios.de (subscribers-only) 1230L: socketcan-core@lists.berlios.de (subscribers-only)
1429W: http://developer.berlios.de/projects/socketcan/ 1231W: http://developer.berlios.de/projects/socketcan/
1430S: Maintained 1232S: Maintained
1431 1233
1432CELL BROADBAND ENGINE ARCHITECTURE 1234CELL BROADBAND ENGINE ARCHITECTURE
1433P: Arnd Bergmann 1235M: Arnd Bergmann <arnd@arndb.de>
1434M: arnd@arndb.de
1435L: linuxppc-dev@ozlabs.org 1236L: linuxppc-dev@ozlabs.org
1436L: cbe-oss-dev@ozlabs.org 1237L: cbe-oss-dev@ozlabs.org
1437W: http://www.ibm.com/developerworks/power/cell/ 1238W: http://www.ibm.com/developerworks/power/cell/
@@ -1442,8 +1243,7 @@ F: arch/powerpc/oprofile/*cell*
1442F: arch/powerpc/platforms/cell/ 1243F: arch/powerpc/platforms/cell/
1443 1244
1444CERTIFIED WIRELESS USB (WUSB) SUBSYSTEM: 1245CERTIFIED WIRELESS USB (WUSB) SUBSYSTEM:
1445P: David Vrabel 1246M: David Vrabel <david.vrabel@csr.com>
1446M: david.vrabel@csr.com
1447L: linux-usb@vger.kernel.org 1247L: linux-usb@vger.kernel.org
1448S: Supported 1248S: Supported
1449F: Documentation/usb/WUSB-Design-overview.txt 1249F: Documentation/usb/WUSB-Design-overview.txt
@@ -1452,8 +1252,7 @@ F: drivers/usb/wusbcore/
1452F: include/linux/usb/wusb* 1252F: include/linux/usb/wusb*
1453 1253
1454CFAG12864B LCD DRIVER 1254CFAG12864B LCD DRIVER
1455P: Miguel Ojeda Sandonis 1255M: Miguel Ojeda Sandonis <miguel.ojeda.sandonis@gmail.com>
1456M: miguel.ojeda.sandonis@gmail.com
1457W: http://miguelojeda.es/auxdisplay.htm 1256W: http://miguelojeda.es/auxdisplay.htm
1458W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm 1257W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm
1459S: Maintained 1258S: Maintained
@@ -1461,8 +1260,7 @@ F: drivers/auxdisplay/cfag12864b.c
1461F: include/linux/cfag12864b.h 1260F: include/linux/cfag12864b.h
1462 1261
1463CFAG12864BFB LCD FRAMEBUFFER DRIVER 1262CFAG12864BFB LCD FRAMEBUFFER DRIVER
1464P: Miguel Ojeda Sandonis 1263M: Miguel Ojeda Sandonis <miguel.ojeda.sandonis@gmail.com>
1465M: miguel.ojeda.sandonis@gmail.com
1466W: http://miguelojeda.es/auxdisplay.htm 1264W: http://miguelojeda.es/auxdisplay.htm
1467W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm 1265W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm
1468S: Maintained 1266S: Maintained
@@ -1470,8 +1268,7 @@ F: drivers/auxdisplay/cfag12864bfb.c
1470F: include/linux/cfag12864b.h 1268F: include/linux/cfag12864b.h
1471 1269
1472CFG80211 and NL80211 1270CFG80211 and NL80211
1473P: Johannes Berg 1271M: Johannes Berg <johannes@sipsolutions.net>
1474M: johannes@sipsolutions.net
1475L: linux-wireless@vger.kernel.org 1272L: linux-wireless@vger.kernel.org
1476S: Maintained 1273S: Maintained
1477F: include/linux/nl80211.h 1274F: include/linux/nl80211.h
@@ -1480,66 +1277,47 @@ F: net/wireless/*
1480X: net/wireless/wext* 1277X: net/wireless/wext*
1481 1278
1482CHECKPATCH 1279CHECKPATCH
1483P: Andy Whitcroft 1280M: Andy Whitcroft <apw@canonical.com>
1484M: apw@canonical.com
1485S: Supported 1281S: Supported
1486F: scripts/checkpatch.pl 1282F: scripts/checkpatch.pl
1487 1283
1488CISCO 10G ETHERNET DRIVER 1284CISCO 10G ETHERNET DRIVER
1489P: Scott Feldman 1285M: Scott Feldman <scofeldm@cisco.com>
1490M: scofeldm@cisco.com 1286M: Joe Eykholt <jeykholt@cisco.com>
1491P: Joe Eykholt
1492M: jeykholt@cisco.com
1493S: Supported 1287S: Supported
1494F: drivers/net/enic/ 1288F: drivers/net/enic/
1495 1289
1496CIRRUS LOGIC EP93XX ETHERNET DRIVER 1290CIRRUS LOGIC EP93XX ETHERNET DRIVER
1497P: Lennert Buytenhek 1291M: Lennert Buytenhek <kernel@wantstofly.org>
1498M: kernel@wantstofly.org
1499L: netdev@vger.kernel.org 1292L: netdev@vger.kernel.org
1500S: Maintained 1293S: Maintained
1501F: drivers/net/arm/ep93xx_eth.c 1294F: drivers/net/arm/ep93xx_eth.c
1502 1295
1503CIRRUS LOGIC EP93XX OHCI USB HOST DRIVER 1296CIRRUS LOGIC EP93XX OHCI USB HOST DRIVER
1504P: Lennert Buytenhek 1297M: Lennert Buytenhek <kernel@wantstofly.org>
1505M: kernel@wantstofly.org
1506L: linux-usb@vger.kernel.org 1298L: linux-usb@vger.kernel.org
1507S: Maintained 1299S: Maintained
1508F: drivers/usb/host/ohci-ep93xx.c 1300F: drivers/usb/host/ohci-ep93xx.c
1509 1301
1510CIRRUS LOGIC CS4270 SOUND DRIVER 1302CIRRUS LOGIC CS4270 SOUND DRIVER
1511P: Timur Tabi 1303M: Timur Tabi <timur@freescale.com>
1512M: timur@freescale.com
1513L: alsa-devel@alsa-project.org (moderated for non-subscribers) 1304L: alsa-devel@alsa-project.org (moderated for non-subscribers)
1514S: Supported 1305S: Supported
1515F: sound/soc/codecs/cs4270* 1306F: sound/soc/codecs/cs4270*
1516 1307
1517CIRRUS LOGIC CS4280/CS461x SOUNDDRIVER
1518P: Cirrus Logic Corporation (kernel 2.2 driver)
1519M: Cirrus Logic Corporation, Thomas Woller <twoller@crystal.cirrus.com>
1520P: Nils Faerber (port to kernel 2.4)
1521M: Nils Faerber <nils@kernelconcepts.de>
1522S: Maintained
1523F: Documentation/input/cs461x.txt
1524F: sound/pci/cs46xx/
1525
1526CLK API 1308CLK API
1527P: Russell King 1309M: Russell King <linux@arm.linux.org.uk>
1528M: linux@arm.linux.org.uk
1529F: include/linux/clk.h 1310F: include/linux/clk.h
1530 1311
1531CISCO FCOE HBA DRIVER 1312CISCO FCOE HBA DRIVER
1532P: Abhijeet Joglekar 1313M: Abhijeet Joglekar <abjoglek@cisco.com>
1533M: abjoglek@cisco.com 1314M: Joe Eykholt <jeykholt@cisco.com>
1534P: Joe Eykholt
1535M: jeykholt@cisco.com
1536L: linux-scsi@vger.kernel.org 1315L: linux-scsi@vger.kernel.org
1537S: Supported 1316S: Supported
1538F: drivers/scsi/fnic/ 1317F: drivers/scsi/fnic/
1539 1318
1540CODA FILE SYSTEM 1319CODA FILE SYSTEM
1541P: Jan Harkes 1320M: Jan Harkes <jaharkes@cs.cmu.edu>
1542M: jaharkes@cs.cmu.edu
1543M: coda@cs.cmu.edu 1321M: coda@cs.cmu.edu
1544L: codalist@coda.cs.cmu.edu 1322L: codalist@coda.cs.cmu.edu
1545W: http://www.coda.cs.cmu.edu/ 1323W: http://www.coda.cs.cmu.edu/
@@ -1549,8 +1327,7 @@ F: fs/coda/
1549F: include/linux/coda*.h 1327F: include/linux/coda*.h
1550 1328
1551COMMON INTERNET FILE SYSTEM (CIFS) 1329COMMON INTERNET FILE SYSTEM (CIFS)
1552P: Steve French 1330M: Steve French <sfrench@samba.org>
1553M: sfrench@samba.org
1554L: linux-cifs-client@lists.samba.org 1331L: linux-cifs-client@lists.samba.org
1555L: samba-technical@lists.samba.org 1332L: samba-technical@lists.samba.org
1556W: http://linux-cifs.samba.org/ 1333W: http://linux-cifs.samba.org/
@@ -1560,70 +1337,57 @@ F: Documentation/filesystems/cifs.txt
1560F: fs/cifs/ 1337F: fs/cifs/
1561 1338
1562COMPACTPCI HOTPLUG CORE 1339COMPACTPCI HOTPLUG CORE
1563P: Scott Murray 1340M: Scott Murray <scott@spiteful.org>
1564M: scottm@somanetworks.com
1565M: scott@spiteful.org
1566L: linux-pci@vger.kernel.org 1341L: linux-pci@vger.kernel.org
1567S: Supported 1342S: Maintained
1568F: drivers/pci/hotplug/cpci_hotplug* 1343F: drivers/pci/hotplug/cpci_hotplug*
1569 1344
1570COMPACTPCI HOTPLUG ZIATECH ZT5550 DRIVER 1345COMPACTPCI HOTPLUG ZIATECH ZT5550 DRIVER
1571P: Scott Murray 1346M: Scott Murray <scott@spiteful.org>
1572M: scottm@somanetworks.com
1573M: scott@spiteful.org
1574L: linux-pci@vger.kernel.org 1347L: linux-pci@vger.kernel.org
1575S: Supported 1348S: Maintained
1576F: drivers/pci/hotplug/cpcihp_zt5550.* 1349F: drivers/pci/hotplug/cpcihp_zt5550.*
1577 1350
1578COMPACTPCI HOTPLUG GENERIC DRIVER 1351COMPACTPCI HOTPLUG GENERIC DRIVER
1579P: Scott Murray 1352M: Scott Murray <scott@spiteful.org>
1580M: scottm@somanetworks.com
1581M: scott@spiteful.org
1582L: linux-pci@vger.kernel.org 1353L: linux-pci@vger.kernel.org
1583S: Supported 1354S: Maintained
1584F: drivers/pci/hotplug/cpcihp_generic.c 1355F: drivers/pci/hotplug/cpcihp_generic.c
1585 1356
1586COMPAL LAPTOP SUPPORT 1357COMPAL LAPTOP SUPPORT
1587P: Cezary Jackiewicz 1358M: Cezary Jackiewicz <cezary.jackiewicz@gmail.com>
1588M: cezary.jackiewicz@gmail.com
1589S: Maintained 1359S: Maintained
1590F: drivers/platform/x86/compal-laptop.c 1360F: drivers/platform/x86/compal-laptop.c
1591 1361
1592COMPUTONE INTELLIPORT MULTIPORT CARD 1362COMPUTONE INTELLIPORT MULTIPORT CARD
1593P: Michael H. Warfield 1363M: "Michael H. Warfield" <mhw@wittsend.com>
1594M: mhw@wittsend.com
1595W: http://www.wittsend.com/computone.html 1364W: http://www.wittsend.com/computone.html
1596S: Maintained 1365S: Maintained
1597F: Documentation/serial/computone.txt 1366F: Documentation/serial/computone.txt
1598F: drivers/char/ip2/ 1367F: drivers/char/ip2/
1599 1368
1600CONEXANT ACCESSRUNNER USB DRIVER 1369CONEXANT ACCESSRUNNER USB DRIVER
1601P: Simon Arlott 1370M: Simon Arlott <cxacru@fire.lp0.eu>
1602M: cxacru@fire.lp0.eu
1603L: accessrunner-general@lists.sourceforge.net 1371L: accessrunner-general@lists.sourceforge.net
1604W: http://accessrunner.sourceforge.net/ 1372W: http://accessrunner.sourceforge.net/
1605S: Maintained 1373S: Maintained
1606F: drivers/usb/atm/cxacru.c 1374F: drivers/usb/atm/cxacru.c
1607 1375
1608CONFIGFS 1376CONFIGFS
1609P: Joel Becker 1377M: Joel Becker <joel.becker@oracle.com>
1610M: joel.becker@oracle.com
1611S: Supported 1378S: Supported
1612F: fs/configfs/ 1379F: fs/configfs/
1613F: include/linux/configfs.h 1380F: include/linux/configfs.h
1614 1381
1615CONNECTOR 1382CONNECTOR
1616P: Evgeniy Polyakov 1383M: Evgeniy Polyakov <zbr@ioremap.net>
1617M: zbr@ioremap.net
1618L: netdev@vger.kernel.org 1384L: netdev@vger.kernel.org
1619S: Maintained 1385S: Maintained
1620F: drivers/connector/ 1386F: drivers/connector/
1621 1387
1622CONTROL GROUPS (CGROUPS) 1388CONTROL GROUPS (CGROUPS)
1623P: Paul Menage 1389M: Paul Menage <menage@google.com>
1624M: menage@google.com 1390M: Li Zefan <lizf@cn.fujitsu.com>
1625P: Li Zefan
1626M: lizf@cn.fujitsu.com
1627L: containers@lists.linux-foundation.org 1391L: containers@lists.linux-foundation.org
1628S: Maintained 1392S: Maintained
1629F: include/linux/cgroup* 1393F: include/linux/cgroup*
@@ -1631,30 +1395,26 @@ F: kernel/cgroup*
1631F: mm/*cgroup* 1395F: mm/*cgroup*
1632 1396
1633CORETEMP HARDWARE MONITORING DRIVER 1397CORETEMP HARDWARE MONITORING DRIVER
1634P: Rudolf Marek 1398M: Rudolf Marek <r.marek@assembler.cz>
1635M: r.marek@assembler.cz
1636L: lm-sensors@lm-sensors.org 1399L: lm-sensors@lm-sensors.org
1637S: Maintained 1400S: Maintained
1638F: Documentation/hwmon/coretemp 1401F: Documentation/hwmon/coretemp
1639F: drivers/hwmon/coretemp.c 1402F: drivers/hwmon/coretemp.c
1640 1403
1641COSA/SRP SYNC SERIAL DRIVER 1404COSA/SRP SYNC SERIAL DRIVER
1642P: Jan "Yenya" Kasprzak 1405M: Jan "Yenya" Kasprzak <kas@fi.muni.cz>
1643M: kas@fi.muni.cz
1644W: http://www.fi.muni.cz/~kas/cosa/ 1406W: http://www.fi.muni.cz/~kas/cosa/
1645S: Maintained 1407S: Maintained
1646F: drivers/net/wan/cosa* 1408F: drivers/net/wan/cosa*
1647 1409
1648CPMAC ETHERNET DRIVER 1410CPMAC ETHERNET DRIVER
1649P: Florian Fainelli 1411M: Florian Fainelli <florian@openwrt.org>
1650M: florian@openwrt.org
1651L: netdev@vger.kernel.org 1412L: netdev@vger.kernel.org
1652S: Maintained 1413S: Maintained
1653F: drivers/net/cpmac.c 1414F: drivers/net/cpmac.c
1654 1415
1655CPU FREQUENCY DRIVERS 1416CPU FREQUENCY DRIVERS
1656P: Dave Jones 1417M: Dave Jones <davej@redhat.com>
1657M: davej@redhat.com
1658L: cpufreq@vger.kernel.org 1418L: cpufreq@vger.kernel.org
1659W: http://www.codemonkey.org.uk/projects/cpufreq/ 1419W: http://www.codemonkey.org.uk/projects/cpufreq/
1660T: git git://git.kernel.org/pub/scm/linux/kernel/git/davej/cpufreq.git 1420T: git git://git.kernel.org/pub/scm/linux/kernel/git/davej/cpufreq.git
@@ -1664,15 +1424,13 @@ F: drivers/cpufreq/
1664F: include/linux/cpufreq.h 1424F: include/linux/cpufreq.h
1665 1425
1666CPUID/MSR DRIVER 1426CPUID/MSR DRIVER
1667P: H. Peter Anvin 1427M: "H. Peter Anvin" <hpa@zytor.com>
1668M: hpa@zytor.com
1669S: Maintained 1428S: Maintained
1670F: arch/x86/kernel/cpuid.c 1429F: arch/x86/kernel/cpuid.c
1671F: arch/x86/kernel/msr.c 1430F: arch/x86/kernel/msr.c
1672 1431
1673CPUSETS 1432CPUSETS
1674P: Paul Menage 1433M: Paul Menage <menage@google.com>
1675M: menage@google.com
1676W: http://www.bullopensource.org/cpuset/ 1434W: http://www.bullopensource.org/cpuset/
1677W: http://oss.sgi.com/projects/cpusets/ 1435W: http://oss.sgi.com/projects/cpusets/
1678S: Supported 1436S: Supported
@@ -1687,20 +1445,16 @@ F: Documentation/filesystems/cramfs.txt
1687F: fs/cramfs/ 1445F: fs/cramfs/
1688 1446
1689CRIS PORT 1447CRIS PORT
1690P: Mikael Starvik 1448M: Mikael Starvik <starvik@axis.com>
1691M: starvik@axis.com 1449M: Jesper Nilsson <jesper.nilsson@axis.com>
1692P: Jesper Nilsson
1693M: jesper.nilsson@axis.com
1694L: linux-cris-kernel@axis.com 1450L: linux-cris-kernel@axis.com
1695W: http://developer.axis.com 1451W: http://developer.axis.com
1696S: Maintained 1452S: Maintained
1697F: arch/cris/ 1453F: arch/cris/
1698 1454
1699CRYPTO API 1455CRYPTO API
1700P: Herbert Xu 1456M: Herbert Xu <herbert@gondor.apana.org.au>
1701M: herbert@gondor.apana.org.au 1457M: "David S. Miller" <davem@davemloft.net>
1702P: David S. Miller
1703M: davem@davemloft.net
1704L: linux-crypto@vger.kernel.org 1458L: linux-crypto@vger.kernel.org
1705T: git git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6.git 1459T: git git://git.kernel.org/pub/scm/linux/kernel/git/herbert/crypto-2.6.git
1706S: Maintained 1460S: Maintained
@@ -1711,58 +1465,50 @@ F: drivers/crypto/
1711F: include/crypto/ 1465F: include/crypto/
1712 1466
1713CRYPTOGRAPHIC RANDOM NUMBER GENERATOR 1467CRYPTOGRAPHIC RANDOM NUMBER GENERATOR
1714P: Neil Horman 1468M: Neil Horman <nhorman@tuxdriver.com>
1715M: nhorman@tuxdriver.com
1716L: linux-crypto@vger.kernel.org 1469L: linux-crypto@vger.kernel.org
1717S: Maintained 1470S: Maintained
1718 1471
1719CS5535 Audio ALSA driver 1472CS5535 Audio ALSA driver
1720P: Jaya Kumar 1473M: Jaya Kumar <jayakumar.alsa@gmail.com>
1721M: jayakumar.alsa@gmail.com
1722S: Maintained 1474S: Maintained
1723F: sound/pci/cs5535audio/ 1475F: sound/pci/cs5535audio/
1724 1476
1725CX18 VIDEO4LINUX DRIVER 1477CX18 VIDEO4LINUX DRIVER
1726P: Hans Verkuil 1478M: Hans Verkuil <hverkuil@xs4all.nl>
1727M: hverkuil@xs4all.nl 1479M: Andy Walls <awalls@radix.net>
1728P: Andy Walls
1729M: awalls@radix.net
1730L: ivtv-devel@ivtvdriver.org 1480L: ivtv-devel@ivtvdriver.org
1731L: ivtv-users@ivtvdriver.org
1732L: linux-media@vger.kernel.org 1481L: linux-media@vger.kernel.org
1733T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 1482T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
1734W: http://linuxtv.org 1483W: http://linuxtv.org
1484W: http://www.ivtvdriver.org/index.php/Cx18
1735S: Maintained 1485S: Maintained
1736F: Documentation/video4linux/cx18.txt 1486F: Documentation/video4linux/cx18.txt
1737F: drivers/media/video/cx18/ 1487F: drivers/media/video/cx18/
1738 1488
1739CXGB3 ETHERNET DRIVER (CXGB3) 1489CXGB3 ETHERNET DRIVER (CXGB3)
1740P: Divy Le Ray 1490M: Divy Le Ray <divy@chelsio.com>
1741M: divy@chelsio.com
1742L: netdev@vger.kernel.org 1491L: netdev@vger.kernel.org
1743W: http://www.chelsio.com 1492W: http://www.chelsio.com
1744S: Supported 1493S: Supported
1745F: drivers/net/cxgb3/ 1494F: drivers/net/cxgb3/
1746 1495
1747CXGB3 IWARP RNIC DRIVER (IW_CXGB3) 1496CXGB3 IWARP RNIC DRIVER (IW_CXGB3)
1748P: Steve Wise 1497M: Steve Wise <swise@chelsio.com>
1749M: swise@chelsio.com
1750L: general@lists.openfabrics.org 1498L: general@lists.openfabrics.org
1751W: http://www.openfabrics.org 1499W: http://www.openfabrics.org
1752S: Supported 1500S: Supported
1753F: drivers/infiniband/hw/cxgb3/ 1501F: drivers/infiniband/hw/cxgb3/
1754 1502
1755CYBERPRO FB DRIVER 1503CYBERPRO FB DRIVER
1756P: Russell King 1504M: Russell King <linux@arm.linux.org.uk>
1757M: linux@arm.linux.org.uk
1758L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 1505L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
1759W: http://www.arm.linux.org.uk/ 1506W: http://www.arm.linux.org.uk/
1760S: Maintained 1507S: Maintained
1761F: drivers/video/cyber2000fb.* 1508F: drivers/video/cyber2000fb.*
1762 1509
1763CYCLADES 2X SYNC CARD DRIVER 1510CYCLADES 2X SYNC CARD DRIVER
1764P: Arnaldo Carvalho de Melo 1511M: Arnaldo Carvalho de Melo <acme@ghostprotocols.net>
1765M: acme@ghostprotocols.net
1766W: http://oops.ghostprotocols.net:81/blog 1512W: http://oops.ghostprotocols.net:81/blog
1767S: Maintained 1513S: Maintained
1768F: drivers/net/wan/cycx* 1514F: drivers/net/wan/cycx*
@@ -1779,8 +1525,7 @@ S: Orphan
1779F: drivers/net/wan/pc300* 1525F: drivers/net/wan/pc300*
1780 1526
1781DAMA SLAVE for AX.25 1527DAMA SLAVE for AX.25
1782P: Joerg Reuter 1528M: Joerg Reuter <jreuter@yaina.de>
1783M: jreuter@yaina.de
1784W: http://yaina.de/jreuter/ 1529W: http://yaina.de/jreuter/
1785W: http://www.qsl.net/dl1bke/ 1530W: http://www.qsl.net/dl1bke/
1786L: linux-hams@vger.kernel.org 1531L: linux-hams@vger.kernel.org
@@ -1794,29 +1539,23 @@ F: net/ax25/ax25_timer.c
1794F: net/ax25/sysctl_net_ax25.c 1539F: net/ax25/sysctl_net_ax25.c
1795 1540
1796DAVICOM FAST ETHERNET (DMFE) NETWORK DRIVER 1541DAVICOM FAST ETHERNET (DMFE) NETWORK DRIVER
1797P: Tobias Ringstrom 1542M: Tobias Ringstrom <tori@unhappy.mine.nu>
1798M: tori@unhappy.mine.nu
1799L: netdev@vger.kernel.org 1543L: netdev@vger.kernel.org
1800S: Maintained 1544S: Maintained
1801F: Documentation/networking/dmfe.txt 1545F: Documentation/networking/dmfe.txt
1802F: drivers/net/tulip/dmfe.c 1546F: drivers/net/tulip/dmfe.c
1803 1547
1804DC390/AM53C974 SCSI driver 1548DC390/AM53C974 SCSI driver
1805P: Kurt Garloff 1549M: Kurt Garloff <garloff@suse.de>
1806M: garloff@suse.de
1807W: http://www.garloff.de/kurt/linux/dc390/ 1550W: http://www.garloff.de/kurt/linux/dc390/
1808P: Guennadi Liakhovetski 1551M: Guennadi Liakhovetski <g.liakhovetski@gmx.de>
1809M: g.liakhovetski@gmx.de
1810S: Maintained 1552S: Maintained
1811F: drivers/scsi/tmscsim.* 1553F: drivers/scsi/tmscsim.*
1812 1554
1813DC395x SCSI driver 1555DC395x SCSI driver
1814P: Oliver Neukum 1556M: Oliver Neukum <oliver@neukum.name>
1815M: oliver@neukum.name 1557M: Ali Akcaagac <aliakc@web.de>
1816P: Ali Akcaagac 1558M: Jamie Lenehan <lenehan@twibble.org>
1817M: aliakc@web.de
1818P: Jamie Lenehan
1819M: lenehan@twibble.org
1820W: http://twibble.org/dist/dc395x/ 1559W: http://twibble.org/dist/dc395x/
1821L: dc395x@twibble.org 1560L: dc395x@twibble.org
1822L: http://lists.twibble.org/mailman/listinfo/dc395x/ 1561L: http://lists.twibble.org/mailman/listinfo/dc395x/
@@ -1825,8 +1564,7 @@ F: Documentation/scsi/dc395x.txt
1825F: drivers/scsi/dc395x.* 1564F: drivers/scsi/dc395x.*
1826 1565
1827DCCP PROTOCOL 1566DCCP PROTOCOL
1828P: Arnaldo Carvalho de Melo 1567M: Arnaldo Carvalho de Melo <acme@ghostprotocols.net>
1829M: acme@ghostprotocols.net
1830L: dccp@vger.kernel.org 1568L: dccp@vger.kernel.org
1831W: http://linux-net.osdl.org/index.php/DCCP 1569W: http://linux-net.osdl.org/index.php/DCCP
1832S: Maintained 1570S: Maintained
@@ -1835,8 +1573,7 @@ F: include/linux/tfrc.h
1835F: net/dccp/ 1573F: net/dccp/
1836 1574
1837DECnet NETWORK LAYER 1575DECnet NETWORK LAYER
1838P: Christine Caulfield 1576M: Christine Caulfield <christine.caulfield@googlemail.com>
1839M: christine.caulfield@googlemail.com
1840W: http://linux-decnet.sourceforge.net 1577W: http://linux-decnet.sourceforge.net
1841L: linux-decnet-user@lists.sourceforge.net 1578L: linux-decnet-user@lists.sourceforge.net
1842S: Maintained 1579S: Maintained
@@ -1844,40 +1581,34 @@ F: Documentation/networking/decnet.txt
1844F: net/decnet/ 1581F: net/decnet/
1845 1582
1846DEFXX FDDI NETWORK DRIVER 1583DEFXX FDDI NETWORK DRIVER
1847P: Maciej W. Rozycki 1584M: "Maciej W. Rozycki" <macro@linux-mips.org>
1848M: macro@linux-mips.org
1849S: Maintained 1585S: Maintained
1850F: drivers/net/defxx.* 1586F: drivers/net/defxx.*
1851 1587
1852DELL LAPTOP DRIVER 1588DELL LAPTOP DRIVER
1853P: Matthew Garrett 1589M: Matthew Garrett <mjg59@srcf.ucam.org>
1854M: mjg59@srcf.ucam.org
1855S: Maintained 1590S: Maintained
1856F: drivers/platform/x86/dell-laptop.c 1591F: drivers/platform/x86/dell-laptop.c
1857 1592
1858DELL LAPTOP SMM DRIVER 1593DELL LAPTOP SMM DRIVER
1859P: Massimo Dal Zotto 1594M: Massimo Dal Zotto <dz@debian.org>
1860M: dz@debian.org
1861W: http://www.debian.org/~dz/i8k/ 1595W: http://www.debian.org/~dz/i8k/
1862S: Maintained 1596S: Maintained
1863F: drivers/char/i8k.c 1597F: drivers/char/i8k.c
1864F: include/linux/i8k.h 1598F: include/linux/i8k.h
1865 1599
1866DELL SYSTEMS MANAGEMENT BASE DRIVER (dcdbas) 1600DELL SYSTEMS MANAGEMENT BASE DRIVER (dcdbas)
1867P: Doug Warzecha 1601M: Doug Warzecha <Douglas_Warzecha@dell.com>
1868M: Douglas_Warzecha@dell.com
1869S: Maintained 1602S: Maintained
1870F: Documentation/dcdbas.txt 1603F: Documentation/dcdbas.txt
1871F: drivers/firmware/dcdbas.* 1604F: drivers/firmware/dcdbas.*
1872 1605
1873DELL WMI EXTRAS DRIVER 1606DELL WMI EXTRAS DRIVER
1874P: Matthew Garrett 1607M: Matthew Garrett <mjg59@srcf.ucam.org>
1875M: mjg59@srcf.ucam.org
1876S: Maintained 1608S: Maintained
1877 1609
1878DEVICE NUMBER REGISTRY 1610DEVICE NUMBER REGISTRY
1879P: Torben Mathiasen 1611M: Torben Mathiasen <device@lanana.org>
1880M: device@lanana.org
1881W: http://lanana.org/docs/device-list/index.html 1612W: http://lanana.org/docs/device-list/index.html
1882S: Maintained 1613S: Maintained
1883 1614
@@ -1892,8 +1623,7 @@ F: include/linux/device-mapper.h
1892F: include/linux/dm-*.h 1623F: include/linux/dm-*.h
1893 1624
1894DIGI INTL. EPCA DRIVER 1625DIGI INTL. EPCA DRIVER
1895P: Digi International, Inc 1626M: "Digi International, Inc" <Eng.Linux@digi.com>
1896M: Eng.Linux@digi.com
1897L: Eng.Linux@digi.com 1627L: Eng.Linux@digi.com
1898W: http://www.digi.com 1628W: http://www.digi.com
1899S: Orphan 1629S: Orphan
@@ -1902,34 +1632,29 @@ F: drivers/char/epca*
1902F: drivers/char/digi* 1632F: drivers/char/digi*
1903 1633
1904DIRECTORY NOTIFICATION (DNOTIFY) 1634DIRECTORY NOTIFICATION (DNOTIFY)
1905P: Eric Paris 1635M: Eric Paris <eparis@parisplace.org>
1906M: eparis@parisplace.org
1907S: Maintained 1636S: Maintained
1908F: Documentation/filesystems/dnotify.txt 1637F: Documentation/filesystems/dnotify.txt
1909F: fs/notify/dnotify/ 1638F: fs/notify/dnotify/
1910F: include/linux/dnotify.h 1639F: include/linux/dnotify.h
1911 1640
1912DISK GEOMETRY AND PARTITION HANDLING 1641DISK GEOMETRY AND PARTITION HANDLING
1913P: Andries Brouwer 1642M: Andries Brouwer <aeb@cwi.nl>
1914M: aeb@cwi.nl
1915W: http://www.win.tue.nl/~aeb/linux/Large-Disk.html 1643W: http://www.win.tue.nl/~aeb/linux/Large-Disk.html
1916W: http://www.win.tue.nl/~aeb/linux/zip/zip-1.html 1644W: http://www.win.tue.nl/~aeb/linux/zip/zip-1.html
1917W: http://www.win.tue.nl/~aeb/partitions/partition_types-1.html 1645W: http://www.win.tue.nl/~aeb/partitions/partition_types-1.html
1918S: Maintained 1646S: Maintained
1919 1647
1920DISKQUOTA 1648DISKQUOTA
1921P: Jan Kara 1649M: Jan Kara <jack@suse.cz>
1922M: jack@suse.cz
1923S: Maintained 1650S: Maintained
1924F: Documentation/filesystems/quota.txt 1651F: Documentation/filesystems/quota.txt
1925F: fs/quota/ 1652F: fs/quota/
1926F: include/linux/quota*.h 1653F: include/linux/quota*.h
1927 1654
1928DISTRIBUTED LOCK MANAGER (DLM) 1655DISTRIBUTED LOCK MANAGER (DLM)
1929P: Christine Caulfield 1656M: Christine Caulfield <ccaulfie@redhat.com>
1930M: ccaulfie@redhat.com 1657M: David Teigland <teigland@redhat.com>
1931P: David Teigland
1932M: teigland@redhat.com
1933L: cluster-devel@redhat.com 1658L: cluster-devel@redhat.com
1934W: http://sources.redhat.com/cluster/ 1659W: http://sources.redhat.com/cluster/
1935T: git git://git.kernel.org/pub/scm/linux/kernel/git/teigland/dlm.git 1660T: git git://git.kernel.org/pub/scm/linux/kernel/git/teigland/dlm.git
@@ -1937,52 +1662,44 @@ S: Supported
1937F: fs/dlm/ 1662F: fs/dlm/
1938 1663
1939DMA GENERIC OFFLOAD ENGINE SUBSYSTEM 1664DMA GENERIC OFFLOAD ENGINE SUBSYSTEM
1940P: Maciej Sosnowski 1665M: Maciej Sosnowski <maciej.sosnowski@intel.com>
1941M: maciej.sosnowski@intel.com 1666M: Dan Williams <dan.j.williams@intel.com>
1942P: Dan Williams
1943M: dan.j.williams@intel.com
1944S: Supported 1667S: Supported
1945F: drivers/dma/ 1668F: drivers/dma/
1946F: include/linux/dma* 1669F: include/linux/dma*
1947 1670
1948DME1737 HARDWARE MONITOR DRIVER 1671DME1737 HARDWARE MONITOR DRIVER
1949P: Juerg Haefliger 1672M: Juerg Haefliger <juergh@gmail.com>
1950M: juergh@gmail.com
1951L: lm-sensors@lm-sensors.org 1673L: lm-sensors@lm-sensors.org
1952S: Maintained 1674S: Maintained
1953F: Documentation/hwmon/dme1737 1675F: Documentation/hwmon/dme1737
1954F: drivers/hwmon/dme1737.c 1676F: drivers/hwmon/dme1737.c
1955 1677
1956DOCBOOK FOR DOCUMENTATION 1678DOCBOOK FOR DOCUMENTATION
1957P: Randy Dunlap 1679M: Randy Dunlap <rdunlap@xenotime.net>
1958M: rdunlap@xenotime.net
1959S: Maintained 1680S: Maintained
1960 1681
1961DOCKING STATION DRIVER 1682DOCKING STATION DRIVER
1962P: Shaohua Li 1683M: Shaohua Li <shaohua.li@intel.com>
1963M: shaohua.li@intel.com
1964L: linux-acpi@vger.kernel.org 1684L: linux-acpi@vger.kernel.org
1965S: Supported 1685S: Supported
1966F: drivers/acpi/dock.c 1686F: drivers/acpi/dock.c
1967 1687
1968DOCUMENTATION 1688DOCUMENTATION
1969P: Randy Dunlap 1689M: Randy Dunlap <rdunlap@xenotime.net>
1970M: rdunlap@xenotime.net
1971L: linux-doc@vger.kernel.org 1690L: linux-doc@vger.kernel.org
1972S: Maintained 1691S: Maintained
1973F: Documentation/ 1692F: Documentation/
1974 1693
1975DOUBLETALK DRIVER 1694DOUBLETALK DRIVER
1976P: James R. Van Zandt 1695M: "James R. Van Zandt" <jrv@vanzandt.mv.com>
1977M: jrv@vanzandt.mv.com
1978L: blinux-list@redhat.com 1696L: blinux-list@redhat.com
1979S: Maintained 1697S: Maintained
1980F: drivers/char/dtlk.c 1698F: drivers/char/dtlk.c
1981F: include/linux/dtlk.h 1699F: include/linux/dtlk.h
1982 1700
1983DPT_I2O SCSI RAID DRIVER 1701DPT_I2O SCSI RAID DRIVER
1984P: Adaptec OEM Raid Solutions 1702M: Adaptec OEM Raid Solutions <aacraid@adaptec.com>
1985M: aacraid@adaptec.com
1986L: linux-scsi@vger.kernel.org 1703L: linux-scsi@vger.kernel.org
1987W: http://www.adaptec.com/ 1704W: http://www.adaptec.com/
1988S: Maintained 1705S: Maintained
@@ -1990,8 +1707,7 @@ F: drivers/scsi/dpt*
1990F: drivers/scsi/dpt/ 1707F: drivers/scsi/dpt/
1991 1708
1992DRIVER CORE, KOBJECTS, AND SYSFS 1709DRIVER CORE, KOBJECTS, AND SYSFS
1993P: Greg Kroah-Hartman 1710M: Greg Kroah-Hartman <gregkh@suse.de>
1994M: gregkh@suse.de
1995T: quilt kernel.org/pub/linux/kernel/people/gregkh/gregkh-2.6/ 1711T: quilt kernel.org/pub/linux/kernel/people/gregkh/gregkh-2.6/
1996S: Supported 1712S: Supported
1997F: Documentation/kobject.txt 1713F: Documentation/kobject.txt
@@ -2001,52 +1717,45 @@ F: include/linux/kobj*
2001F: lib/kobj* 1717F: lib/kobj*
2002 1718
2003DRM DRIVERS 1719DRM DRIVERS
2004P: David Airlie 1720M: David Airlie <airlied@linux.ie>
2005M: airlied@linux.ie
2006L: dri-devel@lists.sourceforge.net 1721L: dri-devel@lists.sourceforge.net
2007T: git git://git.kernel.org/pub/scm/linux/kernel/git/airlied/drm-2.6.git 1722T: git git://git.kernel.org/pub/scm/linux/kernel/git/airlied/drm-2.6.git
2008S: Maintained 1723S: Maintained
2009F: drivers/gpu/drm/ 1724F: drivers/gpu/drm/
2010 1725
2011DSCC4 DRIVER 1726DSCC4 DRIVER
2012P: Francois Romieu 1727M: Francois Romieu <romieu@fr.zoreil.com>
2013M: romieu@fr.zoreil.com
2014L: netdev@vger.kernel.org 1728L: netdev@vger.kernel.org
2015S: Maintained 1729S: Maintained
2016F: drivers/net/wan/dscc4.c 1730F: drivers/net/wan/dscc4.c
2017 1731
2018DZ DECSTATION DZ11 SERIAL DRIVER 1732DZ DECSTATION DZ11 SERIAL DRIVER
2019P: Maciej W. Rozycki 1733M: "Maciej W. Rozycki" <macro@linux-mips.org>
2020M: macro@linux-mips.org
2021S: Maintained 1734S: Maintained
2022F: drivers/serial/dz.* 1735F: drivers/serial/dz.*
2023 1736
2024EATA-DMA SCSI DRIVER 1737EATA-DMA SCSI DRIVER
2025P: Michael Neuffer 1738M: Michael Neuffer <mike@i-Connect.Net>
2026M: mike@i-Connect.Net
2027L: linux-eata@i-connect.net 1739L: linux-eata@i-connect.net
2028L: linux-scsi@vger.kernel.org 1740L: linux-scsi@vger.kernel.org
2029S: Maintained 1741S: Maintained
2030F: drivers/scsi/eata* 1742F: drivers/scsi/eata*
2031 1743
2032EATA ISA/EISA/PCI SCSI DRIVER 1744EATA ISA/EISA/PCI SCSI DRIVER
2033P: Dario Ballabio 1745M: Dario Ballabio <ballabio_dario@emc.com>
2034M: ballabio_dario@emc.com
2035L: linux-scsi@vger.kernel.org 1746L: linux-scsi@vger.kernel.org
2036S: Maintained 1747S: Maintained
2037F: drivers/scsi/eata.c 1748F: drivers/scsi/eata.c
2038 1749
2039EATA-PIO SCSI DRIVER 1750EATA-PIO SCSI DRIVER
2040P: Michael Neuffer 1751M: Michael Neuffer <mike@i-Connect.Net>
2041M: mike@i-Connect.Net
2042L: linux-eata@i-connect.net 1752L: linux-eata@i-connect.net
2043L: linux-scsi@vger.kernel.org 1753L: linux-scsi@vger.kernel.org
2044S: Maintained 1754S: Maintained
2045F: drivers/scsi/eata_pio.* 1755F: drivers/scsi/eata_pio.*
2046 1756
2047EBTABLES 1757EBTABLES
2048P: Bart De Schuymer 1758M: Bart De Schuymer <bart.de.schuymer@pandora.be>
2049M: bart.de.schuymer@pandora.be
2050L: ebtables-user@lists.sourceforge.net 1759L: ebtables-user@lists.sourceforge.net
2051L: ebtables-devel@lists.sourceforge.net 1760L: ebtables-devel@lists.sourceforge.net
2052W: http://ebtables.sourceforge.net/ 1761W: http://ebtables.sourceforge.net/
@@ -2055,10 +1764,8 @@ F: include/linux/netfilter_bridge/ebt_*.h
2055F: net/bridge/netfilter/ebt*.c 1764F: net/bridge/netfilter/ebt*.c
2056 1765
2057ECRYPT FILE SYSTEM 1766ECRYPT FILE SYSTEM
2058P: Tyler Hicks 1767M: Tyler Hicks <tyhicks@linux.vnet.ibm.com>
2059M: tyhicks@linux.vnet.ibm.com 1768M: Dustin Kirkland <kirkland@canonical.com>
2060P: Dustin Kirkland
2061M: kirkland@canonical.com
2062L: ecryptfs-devel@lists.launchpad.net 1769L: ecryptfs-devel@lists.launchpad.net
2063W: https://launchpad.net/ecryptfs 1770W: https://launchpad.net/ecryptfs
2064S: Supported 1771S: Supported
@@ -2066,8 +1773,7 @@ F: Documentation/filesystems/ecryptfs.txt
2066F: fs/ecryptfs/ 1773F: fs/ecryptfs/
2067 1774
2068EDAC-CORE 1775EDAC-CORE
2069P: Doug Thompson 1776M: Doug Thompson <dougthompson@xmission.com>
2070M: dougthompson@xmission.com
2071L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) 1777L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers)
2072W: bluesmoke.sourceforge.net 1778W: bluesmoke.sourceforge.net
2073S: Supported 1779S: Supported
@@ -2076,94 +1782,80 @@ F: drivers/edac/edac_*
2076F: include/linux/edac.h 1782F: include/linux/edac.h
2077 1783
2078EDAC-AMD64 1784EDAC-AMD64
2079P: Doug Thompson 1785M: Doug Thompson <dougthompson@xmission.com>
2080M: dougthompson@xmission.com 1786M: Borislav Petkov <borislav.petkov@amd.com>
2081P: Borislav Petkov
2082M: borislav.petkov@amd.com
2083L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) 1787L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers)
2084W: bluesmoke.sourceforge.net 1788W: bluesmoke.sourceforge.net
2085S: Supported 1789S: Supported
2086F: drivers/edac/amd64_edac* 1790F: drivers/edac/amd64_edac*
2087 1791
2088EDAC-E752X 1792EDAC-E752X
2089P: Mark Gross 1793M: Mark Gross <mark.gross@intel.com>
2090M: mark.gross@intel.com 1794M: Doug Thompson <dougthompson@xmission.com>
2091P: Doug Thompson
2092M: dougthompson@xmission.com
2093L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) 1795L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers)
2094W: bluesmoke.sourceforge.net 1796W: bluesmoke.sourceforge.net
2095S: Maintained 1797S: Maintained
2096F: drivers/edac/e752x_edac.c 1798F: drivers/edac/e752x_edac.c
2097 1799
2098EDAC-E7XXX 1800EDAC-E7XXX
2099P: Doug Thompson 1801M: Doug Thompson <dougthompson@xmission.com>
2100M: dougthompson@xmission.com
2101L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) 1802L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers)
2102W: bluesmoke.sourceforge.net 1803W: bluesmoke.sourceforge.net
2103S: Maintained 1804S: Maintained
2104F: drivers/edac/e7xxx_edac.c 1805F: drivers/edac/e7xxx_edac.c
2105 1806
2106EDAC-I82443BXGX 1807EDAC-I82443BXGX
2107P: Tim Small 1808M: Tim Small <tim@buttersideup.com>
2108M: tim@buttersideup.com
2109L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) 1809L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers)
2110W: bluesmoke.sourceforge.net 1810W: bluesmoke.sourceforge.net
2111S: Maintained 1811S: Maintained
2112F: drivers/edac/i82443bxgx_edac.c 1812F: drivers/edac/i82443bxgx_edac.c
2113 1813
2114EDAC-I3000 1814EDAC-I3000
2115P: Jason Uhlenkott 1815M: Jason Uhlenkott <juhlenko@akamai.com>
2116M: juhlenko@akamai.com
2117L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) 1816L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers)
2118W: bluesmoke.sourceforge.net 1817W: bluesmoke.sourceforge.net
2119S: Maintained 1818S: Maintained
2120F: drivers/edac/i3000_edac.c 1819F: drivers/edac/i3000_edac.c
2121 1820
2122EDAC-I5000 1821EDAC-I5000
2123P: Doug Thompson 1822M: Doug Thompson <dougthompson@xmission.com>
2124M: dougthompson@xmission.com
2125L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) 1823L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers)
2126W: bluesmoke.sourceforge.net 1824W: bluesmoke.sourceforge.net
2127S: Maintained 1825S: Maintained
2128F: drivers/edac/i5000_edac.c 1826F: drivers/edac/i5000_edac.c
2129 1827
2130EDAC-I5400 1828EDAC-I5400
2131P: Mauro Carvalho Chehab 1829M: Mauro Carvalho Chehab <mchehab@redhat.com>
2132M: mchehab@redhat.com
2133L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) 1830L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers)
2134W: bluesmoke.sourceforge.net 1831W: bluesmoke.sourceforge.net
2135S: Maintained 1832S: Maintained
2136F: drivers/edac/i5400_edac.c 1833F: drivers/edac/i5400_edac.c
2137 1834
2138EDAC-I82975X 1835EDAC-I82975X
2139P: Ranganathan Desikan 1836M: Ranganathan Desikan <ravi@jetztechnologies.com>
2140M: ravi@jetztechnologies.com 1837M: "Arvind R." <arvind@jetztechnologies.com>
2141P: Arvind R.
2142M: arvind@jetztechnologies.com
2143L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) 1838L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers)
2144W: bluesmoke.sourceforge.net 1839W: bluesmoke.sourceforge.net
2145S: Maintained 1840S: Maintained
2146F: drivers/edac/i82975x_edac.c 1841F: drivers/edac/i82975x_edac.c
2147 1842
2148EDAC-PASEMI 1843EDAC-PASEMI
2149P: Egor Martovetsky 1844M: Egor Martovetsky <egor@pasemi.com>
2150M: egor@pasemi.com
2151L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) 1845L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers)
2152W: bluesmoke.sourceforge.net 1846W: bluesmoke.sourceforge.net
2153S: Maintained 1847S: Maintained
2154F: drivers/edac/pasemi_edac.c 1848F: drivers/edac/pasemi_edac.c
2155 1849
2156EDAC-R82600 1850EDAC-R82600
2157P: Tim Small 1851M: Tim Small <tim@buttersideup.com>
2158M: tim@buttersideup.com
2159L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers) 1852L: bluesmoke-devel@lists.sourceforge.net (moderated for non-subscribers)
2160W: bluesmoke.sourceforge.net 1853W: bluesmoke.sourceforge.net
2161S: Maintained 1854S: Maintained
2162F: drivers/edac/r82600_edac.c 1855F: drivers/edac/r82600_edac.c
2163 1856
2164EEEPC LAPTOP EXTRAS DRIVER 1857EEEPC LAPTOP EXTRAS DRIVER
2165P: Corentin Chary 1858M: Corentin Chary <corentincj@iksaif.net>
2166M: corentincj@iksaif.net
2167L: acpi4asus-user@lists.sourceforge.net 1859L: acpi4asus-user@lists.sourceforge.net
2168W: http://acpi4asus.sf.net 1860W: http://acpi4asus.sf.net
2169S: Maintained 1861S: Maintained
@@ -2175,66 +1867,54 @@ S: Orphan
2175F: fs/efs/ 1867F: fs/efs/
2176 1868
2177EHCA (IBM GX bus InfiniBand adapter) DRIVER 1869EHCA (IBM GX bus InfiniBand adapter) DRIVER
2178P: Hoang-Nam Nguyen 1870M: Hoang-Nam Nguyen <hnguyen@de.ibm.com>
2179M: hnguyen@de.ibm.com 1871M: Christoph Raisch <raisch@de.ibm.com>
2180P: Christoph Raisch
2181M: raisch@de.ibm.com
2182L: general@lists.openfabrics.org 1872L: general@lists.openfabrics.org
2183S: Supported 1873S: Supported
2184F: drivers/infiniband/hw/ehca/ 1874F: drivers/infiniband/hw/ehca/
2185 1875
2186EMBEDDED LINUX 1876EMBEDDED LINUX
2187P: Paul Gortmaker 1877M: Paul Gortmaker <paul.gortmaker@windriver.com>
2188M: paul.gortmaker@windriver.com 1878M: Matt Mackall <mpm@selenic.com>
2189P: Matt Mackall 1879M: David Woodhouse <dwmw2@infradead.org>
2190M: mpm@selenic.com
2191P: David Woodhouse
2192M: dwmw2@infradead.org
2193L: linux-embedded@vger.kernel.org 1880L: linux-embedded@vger.kernel.org
2194S: Maintained 1881S: Maintained
2195 1882
2196EMULEX LPFC FC SCSI DRIVER 1883EMULEX LPFC FC SCSI DRIVER
2197P: James Smart 1884M: James Smart <james.smart@emulex.com>
2198M: james.smart@emulex.com
2199L: linux-scsi@vger.kernel.org 1885L: linux-scsi@vger.kernel.org
2200W: http://sourceforge.net/projects/lpfcxxxx 1886W: http://sourceforge.net/projects/lpfcxxxx
2201S: Supported 1887S: Supported
2202F: drivers/scsi/lpfc/ 1888F: drivers/scsi/lpfc/
2203 1889
2204ENE CB710 FLASH CARD READER DRIVER 1890ENE CB710 FLASH CARD READER DRIVER
2205P: Michał Mirosław 1891M: Michał Mirosław <mirq-linux@rere.qmqm.pl>
2206M: mirq-linux@rere.qmqm.pl
2207L: linux-kernel@vger.kernel.org
2208S: Maintained 1892S: Maintained
2209F: drivers/misc/cb710/ 1893F: drivers/misc/cb710/
2210F: drivers/mmc/host/cb710-mmc.* 1894F: drivers/mmc/host/cb710-mmc.*
2211F: include/linux/cb710.h 1895F: include/linux/cb710.h
2212 1896
2213EPSON 1355 FRAMEBUFFER DRIVER 1897EPSON 1355 FRAMEBUFFER DRIVER
2214P: Christopher Hoover 1898M: Christopher Hoover <ch@murgatroid.com>
2215M: ch@murgatroid.com 1899M: Christopher Hoover <ch@hpl.hp.com>
2216P: Christopher Hoover
2217M: ch@hpl.hp.com
2218S: Maintained 1900S: Maintained
2219F: drivers/video/epson1355fb.c 1901F: drivers/video/epson1355fb.c
2220 1902
2221EPSON S1D13XXX FRAMEBUFFER DRIVER 1903EPSON S1D13XXX FRAMEBUFFER DRIVER
2222P: Kristoffer Ericson 1904M: Kristoffer Ericson <kristoffer.ericson@gmail.com>
2223M: kristoffer.ericson@gmail.com
2224S: Maintained 1905S: Maintained
1906T: git git://git.kernel.org/pub/scm/linux/kernel/git/kristoffer/linux-hpc.git
2225F: drivers/video/s1d13xxxfb.c 1907F: drivers/video/s1d13xxxfb.c
2226F: include/video/s1d13xxxfb.h 1908F: include/video/s1d13xxxfb.h
2227 1909
2228ETHEREXPRESS-16 NETWORK DRIVER 1910ETHEREXPRESS-16 NETWORK DRIVER
2229P: Philip Blundell 1911M: Philip Blundell <philb@gnu.org>
2230M: philb@gnu.org
2231L: netdev@vger.kernel.org 1912L: netdev@vger.kernel.org
2232S: Maintained 1913S: Maintained
2233F: drivers/net/eexpress.* 1914F: drivers/net/eexpress.*
2234 1915
2235ETHERNET BRIDGE 1916ETHERNET BRIDGE
2236P: Stephen Hemminger 1917M: Stephen Hemminger <shemminger@linux-foundation.org>
2237M: shemminger@linux-foundation.org
2238L: bridge@lists.linux-foundation.org 1918L: bridge@lists.linux-foundation.org
2239W: http://www.linux-foundation.org/en/Net:Bridge 1919W: http://www.linux-foundation.org/en/Net:Bridge
2240S: Maintained 1920S: Maintained
@@ -2242,8 +1922,7 @@ F: include/linux/netfilter_bridge/
2242F: net/bridge/ 1922F: net/bridge/
2243 1923
2244ETHERTEAM 16I DRIVER 1924ETHERTEAM 16I DRIVER
2245P: Mika Kuoppala 1925M: Mika Kuoppala <miku@iki.fi>
2246M: miku@iki.fi
2247S: Maintained 1926S: Maintained
2248F: drivers/net/eth16i.c 1927F: drivers/net/eth16i.c
2249 1928
@@ -2255,12 +1934,9 @@ F: fs/ext2/
2255F: include/linux/ext2* 1934F: include/linux/ext2*
2256 1935
2257EXT3 FILE SYSTEM 1936EXT3 FILE SYSTEM
2258P: Stephen Tweedie 1937M: Stephen Tweedie <sct@redhat.com>
2259M: sct@redhat.com 1938M: Andrew Morton <akpm@linux-foundation.org>
2260P: Andrew Morton 1939M: Andreas Dilger <adilger@sun.com>
2261M: akpm@linux-foundation.org
2262P: Andreas Dilger
2263M: adilger@sun.com
2264L: linux-ext4@vger.kernel.org 1940L: linux-ext4@vger.kernel.org
2265S: Maintained 1941S: Maintained
2266F: Documentation/filesystems/ext3.txt 1942F: Documentation/filesystems/ext3.txt
@@ -2268,10 +1944,8 @@ F: fs/ext3/
2268F: include/linux/ext3* 1944F: include/linux/ext3*
2269 1945
2270EXT4 FILE SYSTEM 1946EXT4 FILE SYSTEM
2271P: Theodore Ts'o 1947M: "Theodore Ts'o" <tytso@mit.edu>
2272M: tytso@mit.edu 1948M: Andreas Dilger <adilger@sun.com>
2273P: Andreas Dilger
2274M: adilger@sun.com
2275L: linux-ext4@vger.kernel.org 1949L: linux-ext4@vger.kernel.org
2276W: http://ext4.wiki.kernel.org 1950W: http://ext4.wiki.kernel.org
2277S: Maintained 1951S: Maintained
@@ -2279,30 +1953,26 @@ F: Documentation/filesystems/ext4.txt
2279F: fs/ext4/ 1953F: fs/ext4/
2280 1954
2281F71805F HARDWARE MONITORING DRIVER 1955F71805F HARDWARE MONITORING DRIVER
2282P: Jean Delvare 1956M: Jean Delvare <khali@linux-fr.org>
2283M: khali@linux-fr.org
2284L: lm-sensors@lm-sensors.org 1957L: lm-sensors@lm-sensors.org
2285S: Maintained 1958S: Maintained
2286F: Documentation/hwmon/f71805f 1959F: Documentation/hwmon/f71805f
2287F: drivers/hwmon/f71805f.c 1960F: drivers/hwmon/f71805f.c
2288 1961
2289FARSYNC SYNCHRONOUS DRIVER 1962FARSYNC SYNCHRONOUS DRIVER
2290P: Kevin Curtis 1963M: Kevin Curtis <kevin.curtis@farsite.co.uk>
2291M: kevin.curtis@farsite.co.uk
2292W: http://www.farsite.co.uk/ 1964W: http://www.farsite.co.uk/
2293S: Supported 1965S: Supported
2294F: drivers/net/wan/farsync.* 1966F: drivers/net/wan/farsync.*
2295 1967
2296FAULT INJECTION SUPPORT 1968FAULT INJECTION SUPPORT
2297P: Akinobu Mita 1969M: Akinobu Mita <akinobu.mita@gmail.com>
2298M: akinobu.mita@gmail.com
2299S: Supported 1970S: Supported
2300F: Documentation/fault-injection/ 1971F: Documentation/fault-injection/
2301F: lib/fault-inject.c 1972F: lib/fault-inject.c
2302 1973
2303FILE LOCKING (flock() and fcntl()/lockf()) 1974FILE LOCKING (flock() and fcntl()/lockf())
2304P: Matthew Wilcox 1975M: Matthew Wilcox <matthew@wil.cx>
2305M: matthew@wil.cx
2306L: linux-fsdevel@vger.kernel.org 1976L: linux-fsdevel@vger.kernel.org
2307S: Maintained 1977S: Maintained
2308F: include/linux/fcntl.h 1978F: include/linux/fcntl.h
@@ -2311,25 +1981,21 @@ F: fs/fcntl.c
2311F: fs/locks.c 1981F: fs/locks.c
2312 1982
2313FILESYSTEMS (VFS and infrastructure) 1983FILESYSTEMS (VFS and infrastructure)
2314P: Alexander Viro 1984M: Alexander Viro <viro@zeniv.linux.org.uk>
2315M: viro@zeniv.linux.org.uk
2316L: linux-fsdevel@vger.kernel.org 1985L: linux-fsdevel@vger.kernel.org
2317S: Maintained 1986S: Maintained
2318F: fs/* 1987F: fs/*
2319 1988
2320FINTEK F75375S HARDWARE MONITOR AND FAN CONTROLLER DRIVER 1989FINTEK F75375S HARDWARE MONITOR AND FAN CONTROLLER DRIVER
2321P: Riku Voipio 1990M: Riku Voipio <riku.vipio@iki.fi>
2322M: riku.vipio@iki.fi
2323L: lm-sensors@lm-sensors.org 1991L: lm-sensors@lm-sensors.org
2324S: Maintained 1992S: Maintained
2325F: drivers/hwmon/f75375s.c 1993F: drivers/hwmon/f75375s.c
2326F: include/linux/f75375s.h 1994F: include/linux/f75375s.h
2327 1995
2328FIREWIRE SUBSYSTEM 1996FIREWIRE SUBSYSTEM
2329P: Kristian Hoegsberg 1997M: Kristian Hoegsberg <krh@redhat.com>
2330M: krh@redhat.com 1998M: Stefan Richter <stefanr@s5r6.in-berlin.de>
2331P: Stefan Richter
2332M: stefanr@s5r6.in-berlin.de
2333L: linux1394-devel@lists.sourceforge.net 1999L: linux1394-devel@lists.sourceforge.net
2334W: http://www.linux1394.org/ 2000W: http://www.linux1394.org/
2335T: git git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394-2.6.git 2001T: git git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394-2.6.git
@@ -2344,15 +2010,13 @@ F: drivers/base/firmware*.c
2344F: include/linux/firmware.h 2010F: include/linux/firmware.h
2345 2011
2346FPU EMULATOR 2012FPU EMULATOR
2347P: Bill Metzenthen 2013M: Bill Metzenthen <billm@melbpc.org.au>
2348M: billm@melbpc.org.au
2349W: http://floatingpoint.sourceforge.net/emulator/index.html 2014W: http://floatingpoint.sourceforge.net/emulator/index.html
2350S: Maintained 2015S: Maintained
2351F: arch/x86/math-emu/ 2016F: arch/x86/math-emu/
2352 2017
2353FRAME RELAY DLCI/FRAD (Sangoma drivers too) 2018FRAME RELAY DLCI/FRAD (Sangoma drivers too)
2354P: Mike McLagan 2019M: Mike McLagan <mike.mclagan@linux.org>
2355M: mike.mclagan@linux.org
2356L: netdev@vger.kernel.org 2020L: netdev@vger.kernel.org
2357S: Maintained 2021S: Maintained
2358F: drivers/net/wan/dlci.c 2022F: drivers/net/wan/dlci.c
@@ -2367,25 +2031,21 @@ F: drivers/video/fb*
2367F: include/linux/fb.h 2031F: include/linux/fb.h
2368 2032
2369FREESCALE DMA DRIVER 2033FREESCALE DMA DRIVER
2370P: Li Yang 2034M: Li Yang <leoli@freescale.com>
2371M: leoli@freescale.com 2035M: Zhang Wei <zw@zh-kernel.org>
2372P: Zhang Wei
2373M: zw@zh-kernel.org
2374L: linuxppc-dev@ozlabs.org 2036L: linuxppc-dev@ozlabs.org
2375S: Maintained 2037S: Maintained
2376F: drivers/dma/fsldma.* 2038F: drivers/dma/fsldma.*
2377 2039
2378FREESCALE I2C CPM DRIVER 2040FREESCALE I2C CPM DRIVER
2379P: Jochen Friedrich 2041M: Jochen Friedrich <jochen@scram.de>
2380M: jochen@scram.de
2381L: linuxppc-dev@ozlabs.org 2042L: linuxppc-dev@ozlabs.org
2382L: linux-i2c@vger.kernel.org 2043L: linux-i2c@vger.kernel.org
2383S: Maintained 2044S: Maintained
2384F: drivers/i2c/busses/i2c-cpm.c 2045F: drivers/i2c/busses/i2c-cpm.c
2385 2046
2386FREESCALE IMX / MXC FRAMEBUFFER DRIVER 2047FREESCALE IMX / MXC FRAMEBUFFER DRIVER
2387P: Sascha Hauer 2048M: Sascha Hauer <kernel@pengutronix.de>
2388M: kernel@pengutronix.de
2389L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) 2049L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers)
2390L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 2050L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
2391S: Maintained 2051S: Maintained
@@ -2393,10 +2053,8 @@ F: arch/arm/plat-mxc/include/mach/imxfb.h
2393F: drivers/video/imxfb.c 2053F: drivers/video/imxfb.c
2394 2054
2395FREESCALE SOC FS_ENET DRIVER 2055FREESCALE SOC FS_ENET DRIVER
2396P: Pantelis Antoniou 2056M: Pantelis Antoniou <pantelis.antoniou@gmail.com>
2397M: pantelis.antoniou@gmail.com 2057M: Vitaly Bordug <vbordug@ru.mvista.com>
2398P: Vitaly Bordug
2399M: vbordug@ru.mvista.com
2400L: linuxppc-dev@ozlabs.org 2058L: linuxppc-dev@ozlabs.org
2401L: netdev@vger.kernel.org 2059L: netdev@vger.kernel.org
2402S: Maintained 2060S: Maintained
@@ -2404,39 +2062,34 @@ F: drivers/net/fs_enet/
2404F: include/linux/fs_enet_pd.h 2062F: include/linux/fs_enet_pd.h
2405 2063
2406FREESCALE QUICC ENGINE LIBRARY 2064FREESCALE QUICC ENGINE LIBRARY
2407P: Timur Tabi 2065M: Timur Tabi <timur@freescale.com>
2408M: timur@freescale.com
2409L: linuxppc-dev@ozlabs.org 2066L: linuxppc-dev@ozlabs.org
2410S: Supported 2067S: Supported
2411F: arch/powerpc/sysdev/qe_lib/ 2068F: arch/powerpc/sysdev/qe_lib/
2412F: arch/powerpc/include/asm/*qe.h 2069F: arch/powerpc/include/asm/*qe.h
2413 2070
2414FREESCALE HIGHSPEED USB DEVICE DRIVER 2071FREESCALE HIGHSPEED USB DEVICE DRIVER
2415P: Li Yang 2072M: Li Yang <leoli@freescale.com>
2416M: leoli@freescale.com
2417L: linux-usb@vger.kernel.org 2073L: linux-usb@vger.kernel.org
2418L: linuxppc-dev@ozlabs.org 2074L: linuxppc-dev@ozlabs.org
2419S: Maintained 2075S: Maintained
2420F: drivers/usb/gadget/fsl_usb2_udc.c 2076F: drivers/usb/gadget/fsl_usb2_udc.c
2421 2077
2422FREESCALE QUICC ENGINE UCC ETHERNET DRIVER 2078FREESCALE QUICC ENGINE UCC ETHERNET DRIVER
2423P: Li Yang 2079M: Li Yang <leoli@freescale.com>
2424M: leoli@freescale.com
2425L: netdev@vger.kernel.org 2080L: netdev@vger.kernel.org
2426L: linuxppc-dev@ozlabs.org 2081L: linuxppc-dev@ozlabs.org
2427S: Maintained 2082S: Maintained
2428F: drivers/net/ucc_geth* 2083F: drivers/net/ucc_geth*
2429 2084
2430FREESCALE QUICC ENGINE UCC UART DRIVER 2085FREESCALE QUICC ENGINE UCC UART DRIVER
2431P: Timur Tabi 2086M: Timur Tabi <timur@freescale.com>
2432M: timur@freescale.com
2433L: linuxppc-dev@ozlabs.org 2087L: linuxppc-dev@ozlabs.org
2434S: Supported 2088S: Supported
2435F: drivers/serial/ucc_uart.c 2089F: drivers/serial/ucc_uart.c
2436 2090
2437FREESCALE SOC SOUND DRIVERS 2091FREESCALE SOC SOUND DRIVERS
2438P: Timur Tabi 2092M: Timur Tabi <timur@freescale.com>
2439M: timur@freescale.com
2440L: alsa-devel@alsa-project.org (moderated for non-subscribers) 2093L: alsa-devel@alsa-project.org (moderated for non-subscribers)
2441L: linuxppc-dev@ozlabs.org 2094L: linuxppc-dev@ozlabs.org
2442S: Supported 2095S: Supported
@@ -2444,17 +2097,14 @@ F: sound/soc/fsl/fsl*
2444F: sound/soc/fsl/mpc8610_hpcd.c 2097F: sound/soc/fsl/mpc8610_hpcd.c
2445 2098
2446FREEVXFS FILESYSTEM 2099FREEVXFS FILESYSTEM
2447P: Christoph Hellwig 2100M: Christoph Hellwig <hch@infradead.org>
2448M: hch@infradead.org
2449W: ftp://ftp.openlinux.org/pub/people/hch/vxfs 2101W: ftp://ftp.openlinux.org/pub/people/hch/vxfs
2450S: Maintained 2102S: Maintained
2451F: fs/freevxfs/ 2103F: fs/freevxfs/
2452 2104
2453FREEZER 2105FREEZER
2454P: Pavel Machek 2106M: Pavel Machek <pavel@ucw.cz>
2455M: pavel@ucw.cz 2107M: "Rafael J. Wysocki" <rjw@sisk.pl>
2456P: Rafael J. Wysocki
2457M: rjw@sisk.pl
2458L: linux-pm@lists.linux-foundation.org 2108L: linux-pm@lists.linux-foundation.org
2459S: Supported 2109S: Supported
2460F: Documentation/power/freezing-of-tasks.txt 2110F: Documentation/power/freezing-of-tasks.txt
@@ -2462,8 +2112,7 @@ F: include/linux/freezer.h
2462F: kernel/freezer.c 2112F: kernel/freezer.c
2463 2113
2464FS-CACHE: LOCAL CACHING FOR NETWORK FILESYSTEMS 2114FS-CACHE: LOCAL CACHING FOR NETWORK FILESYSTEMS
2465P: David Howells 2115M: David Howells <dhowells@redhat.com>
2466M: dhowells@redhat.com
2467L: linux-cachefs@redhat.com 2116L: linux-cachefs@redhat.com
2468S: Supported 2117S: Supported
2469F: Documentation/filesystems/caching/ 2118F: Documentation/filesystems/caching/
@@ -2471,8 +2120,7 @@ F: fs/fscache/
2471F: include/linux/fscache*.h 2120F: include/linux/fscache*.h
2472 2121
2473FTRACE 2122FTRACE
2474P: Steven Rostedt 2123M: Steven Rostedt <rostedt@goodmis.org>
2475M: rostedt@goodmis.org
2476S: Maintained 2124S: Maintained
2477F: Documentation/trace/ftrace.txt 2125F: Documentation/trace/ftrace.txt
2478F: arch/*/*/*/ftrace.h 2126F: arch/*/*/*/ftrace.h
@@ -2481,21 +2129,18 @@ F: include/*/ftrace.h
2481F: kernel/trace/ 2129F: kernel/trace/
2482 2130
2483FUJITSU FR-V (FRV) PORT 2131FUJITSU FR-V (FRV) PORT
2484P: David Howells 2132M: David Howells <dhowells@redhat.com>
2485M: dhowells@redhat.com
2486S: Maintained 2133S: Maintained
2487F: arch/frv/ 2134F: arch/frv/
2488 2135
2489FUJITSU LAPTOP EXTRAS 2136FUJITSU LAPTOP EXTRAS
2490P: Jonathan Woithe 2137M: Jonathan Woithe <jwoithe@physics.adelaide.edu.au>
2491M: jwoithe@physics.adelaide.edu.au
2492L: linux-acpi@vger.kernel.org 2138L: linux-acpi@vger.kernel.org
2493S: Maintained 2139S: Maintained
2494F: drivers/platform/x86/fujitsu-laptop.c 2140F: drivers/platform/x86/fujitsu-laptop.c
2495 2141
2496FUSE: FILESYSTEM IN USERSPACE 2142FUSE: FILESYSTEM IN USERSPACE
2497P: Miklos Szeredi 2143M: Miklos Szeredi <miklos@szeredi.hu>
2498M: miklos@szeredi.hu
2499L: fuse-devel@lists.sourceforge.net 2144L: fuse-devel@lists.sourceforge.net
2500W: http://fuse.sourceforge.net/ 2145W: http://fuse.sourceforge.net/
2501S: Maintained 2146S: Maintained
@@ -2503,30 +2148,26 @@ F: fs/fuse/
2503F: include/linux/fuse.h 2148F: include/linux/fuse.h
2504 2149
2505FUTURE DOMAIN TMC-16x0 SCSI DRIVER (16-bit) 2150FUTURE DOMAIN TMC-16x0 SCSI DRIVER (16-bit)
2506P: Rik Faith 2151M: Rik Faith <faith@cs.unc.edu>
2507M: faith@cs.unc.edu
2508L: linux-scsi@vger.kernel.org 2152L: linux-scsi@vger.kernel.org
2509S: Odd Fixes (e.g., new signatures) 2153S: Odd Fixes (e.g., new signatures)
2510F: drivers/scsi/fdomain.* 2154F: drivers/scsi/fdomain.*
2511 2155
2512GDT SCSI DISK ARRAY CONTROLLER DRIVER 2156GDT SCSI DISK ARRAY CONTROLLER DRIVER
2513P: Achim Leubner 2157M: Achim Leubner <achim_leubner@adaptec.com>
2514M: achim_leubner@adaptec.com
2515L: linux-scsi@vger.kernel.org 2158L: linux-scsi@vger.kernel.org
2516W: http://www.icp-vortex.com/ 2159W: http://www.icp-vortex.com/
2517S: Supported 2160S: Supported
2518F: drivers/scsi/gdt* 2161F: drivers/scsi/gdt*
2519 2162
2520GENERIC GPIO I2C DRIVER 2163GENERIC GPIO I2C DRIVER
2521P: Haavard Skinnemoen 2164M: Haavard Skinnemoen <hskinnemoen@atmel.com>
2522M: hskinnemoen@atmel.com
2523S: Supported 2165S: Supported
2524F: drivers/i2c/busses/i2c-gpio.c 2166F: drivers/i2c/busses/i2c-gpio.c
2525F: include/linux/i2c-gpio.h 2167F: include/linux/i2c-gpio.h
2526 2168
2527GENERIC HDLC (WAN) DRIVERS 2169GENERIC HDLC (WAN) DRIVERS
2528P: Krzysztof Halasa 2170M: Krzysztof Halasa <khc@pm.waw.pl>
2529M: khc@pm.waw.pl
2530W: http://www.kernel.org/pub/linux/utils/net/hdlc/ 2171W: http://www.kernel.org/pub/linux/utils/net/hdlc/
2531S: Maintained 2172S: Maintained
2532F: drivers/net/wan/c101.c 2173F: drivers/net/wan/c101.c
@@ -2538,16 +2179,14 @@ F: drivers/net/wan/pci200syn.c
2538F: drivers/net/wan/wanxl* 2179F: drivers/net/wan/wanxl*
2539 2180
2540GENERIC INCLUDE/ASM HEADER FILES 2181GENERIC INCLUDE/ASM HEADER FILES
2541P: Arnd Bergmann 2182M: Arnd Bergmann <arnd@arndb.de>
2542M: arnd@arndb.de
2543L: linux-arch@vger.kernel.org 2183L: linux-arch@vger.kernel.org
2544T: git git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic.git 2184T: git git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic.git
2545S: Maintained 2185S: Maintained
2546F: include/asm-generic 2186F: include/asm-generic
2547 2187
2548GFS2 FILE SYSTEM 2188GFS2 FILE SYSTEM
2549P: Steven Whitehouse 2189M: Steven Whitehouse <swhiteho@redhat.com>
2550M: swhiteho@redhat.com
2551L: cluster-devel@redhat.com 2190L: cluster-devel@redhat.com
2552W: http://sources.redhat.com/cluster/ 2191W: http://sources.redhat.com/cluster/
2553T: git git://git.kernel.org/pub/scm/linux/kernel/git/steve/gfs2-2.6-fixes.git 2192T: git git://git.kernel.org/pub/scm/linux/kernel/git/steve/gfs2-2.6-fixes.git
@@ -2558,10 +2197,8 @@ F: fs/gfs2/
2558F: include/linux/gfs2_ondisk.h 2197F: include/linux/gfs2_ondisk.h
2559 2198
2560GIGASET ISDN DRIVERS 2199GIGASET ISDN DRIVERS
2561P: Hansjoerg Lipp 2200M: Hansjoerg Lipp <hjlipp@web.de>
2562M: hjlipp@web.de 2201M: Tilman Schmidt <tilman@imap.cc>
2563P: Tilman Schmidt
2564M: tilman@imap.cc
2565L: gigaset307x-common@lists.sourceforge.net 2202L: gigaset307x-common@lists.sourceforge.net
2566W: http://gigaset307x.sourceforge.net/ 2203W: http://gigaset307x.sourceforge.net/
2567S: Maintained 2204S: Maintained
@@ -2570,8 +2207,7 @@ F: drivers/isdn/gigaset/
2570F: include/linux/gigaset_dev.h 2207F: include/linux/gigaset_dev.h
2571 2208
2572HARD DRIVE ACTIVE PROTECTION SYSTEM (HDAPS) DRIVER 2209HARD DRIVE ACTIVE PROTECTION SYSTEM (HDAPS) DRIVER
2573P: Frank Seidel 2210M: Frank Seidel <frank@f-seidel.de>
2574M: frank@f-seidel.de
2575L: lm-sensors@lm-sensors.org 2211L: lm-sensors@lm-sensors.org
2576W: http://www.kernel.org/pub/linux/kernel/people/fseidel/hdaps/ 2212W: http://www.kernel.org/pub/linux/kernel/people/fseidel/hdaps/
2577S: Maintained 2213S: Maintained
@@ -2583,40 +2219,35 @@ S: Odd Fixes
2583F: drivers/char/hvc_* 2219F: drivers/char/hvc_*
2584 2220
2585GSPCA FINEPIX SUBDRIVER 2221GSPCA FINEPIX SUBDRIVER
2586P: Frank Zago 2222M: Frank Zago <frank@zago.net>
2587M: frank@zago.net
2588L: linux-media@vger.kernel.org 2223L: linux-media@vger.kernel.org
2589T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 2224T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
2590S: Maintained 2225S: Maintained
2591F: drivers/media/video/gspca/finepix.c 2226F: drivers/media/video/gspca/finepix.c
2592 2227
2593GSPCA M5602 SUBDRIVER 2228GSPCA M5602 SUBDRIVER
2594P: Erik Andren 2229M: Erik Andren <erik.andren@gmail.com>
2595M: erik.andren@gmail.com
2596L: linux-media@vger.kernel.org 2230L: linux-media@vger.kernel.org
2597T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 2231T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
2598S: Maintained 2232S: Maintained
2599F: drivers/media/video/gspca/m5602/ 2233F: drivers/media/video/gspca/m5602/
2600 2234
2601GSPCA PAC207 SONIXB SUBDRIVER 2235GSPCA PAC207 SONIXB SUBDRIVER
2602P: Hans de Goede 2236M: Hans de Goede <hdegoede@redhat.com>
2603M: hdegoede@redhat.com
2604L: linux-media@vger.kernel.org 2237L: linux-media@vger.kernel.org
2605T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 2238T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
2606S: Maintained 2239S: Maintained
2607F: drivers/media/video/gspca/pac207.c 2240F: drivers/media/video/gspca/pac207.c
2608 2241
2609GSPCA T613 SUBDRIVER 2242GSPCA T613 SUBDRIVER
2610P: Leandro Costantino 2243M: Leandro Costantino <lcostantino@gmail.com>
2611M: lcostantino@gmail.com
2612L: linux-media@vger.kernel.org 2244L: linux-media@vger.kernel.org
2613T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 2245T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
2614S: Maintained 2246S: Maintained
2615F: drivers/media/video/gspca/t613.c 2247F: drivers/media/video/gspca/t613.c
2616 2248
2617GSPCA USB WEBCAM DRIVER 2249GSPCA USB WEBCAM DRIVER
2618P: Jean-Francois Moine 2250M: Jean-Francois Moine <moinejf@free.fr>
2619M: moinejf@free.fr
2620W: http://moinejf.free.fr 2251W: http://moinejf.free.fr
2621L: linux-media@vger.kernel.org 2252L: linux-media@vger.kernel.org
2622T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 2253T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
@@ -2636,31 +2267,27 @@ F: drivers/char/hw_random/
2636F: include/linux/hw_random.h 2267F: include/linux/hw_random.h
2637 2268
2638HARMONY SOUND DRIVER 2269HARMONY SOUND DRIVER
2639P: Kyle McMartin 2270M: Kyle McMartin <kyle@mcmartin.ca>
2640M: kyle@mcmartin.ca
2641L: linux-parisc@vger.kernel.org 2271L: linux-parisc@vger.kernel.org
2642S: Maintained 2272S: Maintained
2643F: sound/parisc/harmony.* 2273F: sound/parisc/harmony.*
2644 2274
2645HAYES ESP SERIAL DRIVER 2275HAYES ESP SERIAL DRIVER
2646P: Andrew J. Robinson 2276M: "Andrew J. Robinson" <arobinso@nyx.net>
2647M: arobinso@nyx.net
2648W: http://www.nyx.net/~arobinso 2277W: http://www.nyx.net/~arobinso
2649S: Maintained 2278S: Maintained
2650F: Documentation/serial/hayes-esp.txt 2279F: Documentation/serial/hayes-esp.txt
2651F: drivers/char/esp.c 2280F: drivers/char/esp.c
2652 2281
2653HEWLETT-PACKARD SMART2 RAID DRIVER 2282HEWLETT-PACKARD SMART2 RAID DRIVER
2654P: Chirag Kantharia 2283M: Chirag Kantharia <chirag.kantharia@hp.com>
2655M: chirag.kantharia@hp.com
2656L: iss_storagedev@hp.com 2284L: iss_storagedev@hp.com
2657S: Maintained 2285S: Maintained
2658F: Documentation/blockdev/cpqarray.txt 2286F: Documentation/blockdev/cpqarray.txt
2659F: drivers/block/cpqarray.* 2287F: drivers/block/cpqarray.*
2660 2288
2661HEWLETT-PACKARD SMART CISS RAID DRIVER (cciss) 2289HEWLETT-PACKARD SMART CISS RAID DRIVER (cciss)
2662P: Mike Miller 2290M: Mike Miller <mike.miller@hp.com>
2663M: mike.miller@hp.com
2664L: iss_storagedev@hp.com 2291L: iss_storagedev@hp.com
2665S: Supported 2292S: Supported
2666F: Documentation/blockdev/cciss.txt 2293F: Documentation/blockdev/cciss.txt
@@ -2668,25 +2295,21 @@ F: drivers/block/cciss*
2668F: include/linux/cciss_ioctl.h 2295F: include/linux/cciss_ioctl.h
2669 2296
2670HFS FILESYSTEM 2297HFS FILESYSTEM
2671P: Roman Zippel 2298M: Roman Zippel <zippel@linux-m68k.org>
2672M: zippel@linux-m68k.org
2673S: Maintained 2299S: Maintained
2674F: Documentation/filesystems/hfs.txt 2300F: Documentation/filesystems/hfs.txt
2675F: fs/hfs/ 2301F: fs/hfs/
2676 2302
2677HGA FRAMEBUFFER DRIVER 2303HGA FRAMEBUFFER DRIVER
2678P: Ferenc Bakonyi 2304M: Ferenc Bakonyi <fero@drama.obuda.kando.hu>
2679M: fero@drama.obuda.kando.hu
2680L: linux-nvidia@lists.surfsouth.com 2305L: linux-nvidia@lists.surfsouth.com
2681W: http://drama.obuda.kando.hu/~fero/cgi-bin/hgafb.shtml 2306W: http://drama.obuda.kando.hu/~fero/cgi-bin/hgafb.shtml
2682S: Maintained 2307S: Maintained
2683F: drivers/video/hgafb.c 2308F: drivers/video/hgafb.c
2684 2309
2685HIBERNATION (aka Software Suspend, aka swsusp) 2310HIBERNATION (aka Software Suspend, aka swsusp)
2686P: Pavel Machek 2311M: Pavel Machek <pavel@ucw.cz>
2687M: pavel@ucw.cz 2312M: "Rafael J. Wysocki" <rjw@sisk.pl>
2688P: Rafael J. Wysocki
2689M: rjw@sisk.pl
2690L: linux-pm@lists.linux-foundation.org 2313L: linux-pm@lists.linux-foundation.org
2691S: Supported 2314S: Supported
2692F: arch/x86/power/ 2315F: arch/x86/power/
@@ -2698,8 +2321,7 @@ F: include/linux/pm.h
2698F: arch/*/include/asm/suspend*.h 2321F: arch/*/include/asm/suspend*.h
2699 2322
2700HID CORE LAYER 2323HID CORE LAYER
2701P: Jiri Kosina 2324M: Jiri Kosina <jkosina@suse.cz>
2702M: jkosina@suse.cz
2703L: linux-input@vger.kernel.org 2325L: linux-input@vger.kernel.org
2704T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/hid.git 2326T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/hid.git
2705S: Maintained 2327S: Maintained
@@ -2707,16 +2329,14 @@ F: drivers/hid/
2707F: include/linux/hid* 2329F: include/linux/hid*
2708 2330
2709HIGH-RESOLUTION TIMERS, CLOCKEVENTS, DYNTICKS 2331HIGH-RESOLUTION TIMERS, CLOCKEVENTS, DYNTICKS
2710P: Thomas Gleixner 2332M: Thomas Gleixner <tglx@linutronix.de>
2711M: tglx@linutronix.de
2712S: Maintained 2333S: Maintained
2713F: Documentation/timers/ 2334F: Documentation/timers/
2714F: kernel/hrtimer.c 2335F: kernel/hrtimer.c
2715F: include/linux/hrtimer.h 2336F: include/linux/hrtimer.h
2716 2337
2717HIGH-SPEED SCC DRIVER FOR AX.25 2338HIGH-SPEED SCC DRIVER FOR AX.25
2718P: Klaus Kudielka 2339M: Klaus Kudielka <klaus.kudielka@ieee.org>
2719M: klaus.kudielka@ieee.org
2720L: linux-hams@vger.kernel.org 2340L: linux-hams@vger.kernel.org
2721W: http://www.nt.tuwien.ac.at/~kkudielk/Linux/ 2341W: http://www.nt.tuwien.ac.at/~kkudielk/Linux/
2722S: Maintained 2342S: Maintained
@@ -2724,16 +2344,14 @@ F: drivers/net/hamradio/dmascc.c
2724F: drivers/net/hamradio/scc.c 2344F: drivers/net/hamradio/scc.c
2725 2345
2726HIGHPOINT ROCKETRAID 3xxx RAID DRIVER 2346HIGHPOINT ROCKETRAID 3xxx RAID DRIVER
2727P: HighPoint Linux Team 2347M: HighPoint Linux Team <linux@highpoint-tech.com>
2728M: linux@highpoint-tech.com
2729W: http://www.highpoint-tech.com 2348W: http://www.highpoint-tech.com
2730S: Supported 2349S: Supported
2731F: Documentation/scsi/hptiop.txt 2350F: Documentation/scsi/hptiop.txt
2732F: drivers/scsi/hptiop.c 2351F: drivers/scsi/hptiop.c
2733 2352
2734HIPPI 2353HIPPI
2735P: Jes Sorensen 2354M: Jes Sorensen <jes@trained-monkey.org>
2736M: jes@trained-monkey.org
2737L: linux-hippi@sunsite.dk 2355L: linux-hippi@sunsite.dk
2738S: Maintained 2356S: Maintained
2739F: include/linux/hippidevice.h 2357F: include/linux/hippidevice.h
@@ -2741,8 +2359,7 @@ F: include/linux/if_hippi.h
2741F: net/802/hippi.c 2359F: net/802/hippi.c
2742 2360
2743HOST AP DRIVER 2361HOST AP DRIVER
2744P: Jouni Malinen 2362M: Jouni Malinen <j@w1.fi>
2745M: j@w1.fi
2746L: hostap@shmoo.com (subscribers-only) 2363L: hostap@shmoo.com (subscribers-only)
2747L: linux-wireless@vger.kernel.org 2364L: linux-wireless@vger.kernel.org
2748W: http://hostap.epitest.fi/ 2365W: http://hostap.epitest.fi/
@@ -2750,82 +2367,69 @@ S: Maintained
2750F: drivers/net/wireless/hostap/ 2367F: drivers/net/wireless/hostap/
2751 2368
2752HP COMPAQ TC1100 TABLET WMI EXTRAS DRIVER 2369HP COMPAQ TC1100 TABLET WMI EXTRAS DRIVER
2753P: Carlos Corbacho 2370M: Carlos Corbacho <carlos@strangeworlds.co.uk>
2754M: carlos@strangeworlds.co.uk
2755S: Odd Fixes 2371S: Odd Fixes
2756F: drivers/platform/x86/tc1100-wmi.c 2372F: drivers/platform/x86/tc1100-wmi.c
2757 2373
2758HP100: Driver for HP 10/100 Mbit/s Voice Grade Network Adapter Series 2374HP100: Driver for HP 10/100 Mbit/s Voice Grade Network Adapter Series
2759P: Jaroslav Kysela 2375M: Jaroslav Kysela <perex@perex.cz>
2760M: perex@perex.cz
2761S: Maintained 2376S: Maintained
2762F: drivers/net/hp100.* 2377F: drivers/net/hp100.*
2763 2378
2764HPET: High Precision Event Timers driver 2379HPET: High Precision Event Timers driver
2765P: Clemens Ladisch 2380M: Clemens Ladisch <clemens@ladisch.de>
2766M: clemens@ladisch.de
2767S: Maintained 2381S: Maintained
2768F: Documentation/timers/hpet.txt 2382F: Documentation/timers/hpet.txt
2769F: drivers/char/hpet.c 2383F: drivers/char/hpet.c
2770F: include/linux/hpet.h 2384F: include/linux/hpet.h
2771 2385
2772HPET: i386 2386HPET: i386
2773P: Venkatesh Pallipadi (Venki) 2387M: "Venkatesh Pallipadi (Venki)" <venkatesh.pallipadi@intel.com>
2774M: venkatesh.pallipadi@intel.com
2775S: Maintained 2388S: Maintained
2776F: arch/x86/kernel/hpet.c 2389F: arch/x86/kernel/hpet.c
2777F: arch/x86/include/asm/hpet.h 2390F: arch/x86/include/asm/hpet.h
2778 2391
2779HPET: x86_64 2392HPET: x86_64
2780P: Vojtech Pavlik 2393M: Vojtech Pavlik <vojtech@suse.cz>
2781M: vojtech@suse.cz
2782S: Maintained 2394S: Maintained
2783 2395
2784HPET: ACPI 2396HPET: ACPI
2785P: Bob Picco 2397M: Bob Picco <bob.picco@hp.com>
2786M: bob.picco@hp.com
2787S: Maintained 2398S: Maintained
2788F: drivers/char/hpet.c 2399F: drivers/char/hpet.c
2789 2400
2790HPFS FILESYSTEM 2401HPFS FILESYSTEM
2791P: Mikulas Patocka 2402M: Mikulas Patocka <mikulas@artax.karlin.mff.cuni.cz>
2792M: mikulas@artax.karlin.mff.cuni.cz
2793W: http://artax.karlin.mff.cuni.cz/~mikulas/vyplody/hpfs/index-e.cgi 2403W: http://artax.karlin.mff.cuni.cz/~mikulas/vyplody/hpfs/index-e.cgi
2794S: Maintained 2404S: Maintained
2795F: fs/hpfs/ 2405F: fs/hpfs/
2796 2406
2797HSO 3G MODEM DRIVER 2407HSO 3G MODEM DRIVER
2798P: Jan Dumon 2408M: Jan Dumon <j.dumon@option.com>
2799M: j.dumon@option.com
2800W: http://www.pharscape.org 2409W: http://www.pharscape.org
2801S: Maintained 2410S: Maintained
2802F: drivers/net/usb/hso.c 2411F: drivers/net/usb/hso.c
2803 2412
2804HTCPEN TOUCHSCREEN DRIVER 2413HTCPEN TOUCHSCREEN DRIVER
2805P: Pau Oliva Fora 2414M: Pau Oliva Fora <pof@eslack.org>
2806M: pof@eslack.org
2807L: linux-input@vger.kernel.org 2415L: linux-input@vger.kernel.org
2808S: Maintained 2416S: Maintained
2809F: drivers/input/touchscreen/htcpen.c 2417F: drivers/input/touchscreen/htcpen.c
2810 2418
2811HUGETLB FILESYSTEM 2419HUGETLB FILESYSTEM
2812P: William Irwin 2420M: William Irwin <wli@holomorphy.com>
2813M: wli@holomorphy.com
2814S: Maintained 2421S: Maintained
2815F: fs/hugetlbfs/ 2422F: fs/hugetlbfs/
2816 2423
2817I2C/SMBUS STUB DRIVER 2424I2C/SMBUS STUB DRIVER
2818P: Mark M. Hoffman 2425M: "Mark M. Hoffman" <mhoffman@lightlink.com>
2819M: mhoffman@lightlink.com
2820L: linux-i2c@vger.kernel.org 2426L: linux-i2c@vger.kernel.org
2821S: Maintained 2427S: Maintained
2822F: drivers/i2c/busses/i2c-stub.c 2428F: drivers/i2c/busses/i2c-stub.c
2823 2429
2824I2C SUBSYSTEM 2430I2C SUBSYSTEM
2825P: Jean Delvare (PC drivers, core) 2431M: "Jean Delvare (PC drivers, core)" <khali@linux-fr.org>
2826M: khali@linux-fr.org 2432M: "Ben Dooks (embedded platforms)" <ben-linux@fluff.org>
2827P: Ben Dooks (embedded platforms)
2828M: ben-linux@fluff.org
2829L: linux-i2c@vger.kernel.org 2433L: linux-i2c@vger.kernel.org
2830W: http://i2c.wiki.kernel.org/ 2434W: http://i2c.wiki.kernel.org/
2831T: quilt kernel.org/pub/linux/kernel/people/jdelvare/linux-2.6/jdelvare-i2c/ 2435T: quilt kernel.org/pub/linux/kernel/people/jdelvare/linux-2.6/jdelvare-i2c/
@@ -2837,30 +2441,25 @@ F: include/linux/i2c-dev.h
2837F: include/linux/i2c-id.h 2441F: include/linux/i2c-id.h
2838 2442
2839I2C-TINY-USB DRIVER 2443I2C-TINY-USB DRIVER
2840P: Till Harbaum 2444M: Till Harbaum <till@harbaum.org>
2841M: till@harbaum.org
2842L: linux-i2c@vger.kernel.org 2445L: linux-i2c@vger.kernel.org
2843W: http://www.harbaum.org/till/i2c_tiny_usb 2446W: http://www.harbaum.org/till/i2c_tiny_usb
2844S: Maintained 2447S: Maintained
2845F: drivers/i2c/busses/i2c-tiny-usb.c 2448F: drivers/i2c/busses/i2c-tiny-usb.c
2846 2449
2847i386 BOOT CODE 2450i386 BOOT CODE
2848P: H. Peter Anvin 2451M: "H. Peter Anvin" <hpa@zytor.com>
2849M: hpa@zytor.com
2850S: Maintained 2452S: Maintained
2851F: arch/x86/boot/ 2453F: arch/x86/boot/
2852 2454
2853i386 SETUP CODE / CPU ERRATA WORKAROUNDS 2455i386 SETUP CODE / CPU ERRATA WORKAROUNDS
2854P: H. Peter Anvin 2456M: "H. Peter Anvin" <hpa@zytor.com>
2855M: hpa@zytor.com
2856T: git git://git.kernel.org/pub/scm/linux/kernel/git/hpa/linux-2.6-x86setup.git 2457T: git git://git.kernel.org/pub/scm/linux/kernel/git/hpa/linux-2.6-x86setup.git
2857S: Maintained 2458S: Maintained
2858 2459
2859IA64 (Itanium) PLATFORM 2460IA64 (Itanium) PLATFORM
2860P: Tony Luck 2461M: Tony Luck <tony.luck@intel.com>
2861P: Fenghua Yu 2462M: Fenghua Yu <fenghua.yu@intel.com>
2862M: tony.luck@intel.com
2863M: fenghua.yu@intel.com
2864L: linux-ia64@vger.kernel.org 2463L: linux-ia64@vger.kernel.org
2865W: http://www.ia64-linux.org/ 2464W: http://www.ia64-linux.org/
2866T: git git://git.kernel.org/pub/scm/linux/kernel/git/aegl/linux-2.6.git 2465T: git git://git.kernel.org/pub/scm/linux/kernel/git/aegl/linux-2.6.git
@@ -2868,29 +2467,25 @@ S: Maintained
2868F: arch/ia64/ 2467F: arch/ia64/
2869 2468
2870IBM MCA SCSI SUBSYSTEM DRIVER 2469IBM MCA SCSI SUBSYSTEM DRIVER
2871P: Michael Lang 2470M: Michael Lang <langa2@kph.uni-mainz.de>
2872M: langa2@kph.uni-mainz.de
2873W: http://www.uni-mainz.de/~langm000/linux.html 2471W: http://www.uni-mainz.de/~langm000/linux.html
2874S: Maintained 2472S: Maintained
2875F: drivers/scsi/ibmmca.c 2473F: drivers/scsi/ibmmca.c
2876 2474
2877IBM Power Linux RAID adapter 2475IBM Power Linux RAID adapter
2878P: Brian King 2476M: Brian King <brking@us.ibm.com>
2879M: brking@us.ibm.com
2880S: Supported 2477S: Supported
2881F: drivers/scsi/ipr.* 2478F: drivers/scsi/ipr.*
2882 2479
2883IBM ServeRAID RAID DRIVER 2480IBM ServeRAID RAID DRIVER
2884P: Jack Hammer 2481P: Jack Hammer
2885P: Dave Jeffery 2482M: Dave Jeffery <ipslinux@adaptec.com>
2886M: ipslinux@adaptec.com
2887W: http://www.developer.ibm.com/welcome/netfinity/serveraid.html 2483W: http://www.developer.ibm.com/welcome/netfinity/serveraid.html
2888S: Supported 2484S: Supported
2889F: drivers/scsi/ips.* 2485F: drivers/scsi/ips.*
2890 2486
2891IDE SUBSYSTEM 2487IDE SUBSYSTEM
2892P: David S. Miller 2488M: "David S. Miller" <davem@davemloft.net>
2893M: davem@davemloft.net
2894L: linux-ide@vger.kernel.org 2489L: linux-ide@vger.kernel.org
2895T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/ide-2.6.git 2490T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/ide-2.6.git
2896S: Maintained 2491S: Maintained
@@ -2899,25 +2494,21 @@ F: drivers/ide/
2899F: include/linux/ide.h 2494F: include/linux/ide.h
2900 2495
2901IDE/ATAPI DRIVERS 2496IDE/ATAPI DRIVERS
2902P: Borislav Petkov 2497M: Borislav Petkov <petkovbb@gmail.com>
2903M: petkovbb@gmail.com
2904L: linux-ide@vger.kernel.org 2498L: linux-ide@vger.kernel.org
2905S: Maintained 2499S: Maintained
2906F: Documentation/cdrom/ide-cd 2500F: Documentation/cdrom/ide-cd
2907F: drivers/ide/ide-cd* 2501F: drivers/ide/ide-cd*
2908 2502
2909IDLE-I7300 2503IDLE-I7300
2910P: Andy Henroid 2504M: Andy Henroid <andrew.d.henroid@intel.com>
2911M: andrew.d.henroid@intel.com
2912L: linux-pm@lists.linux-foundation.org 2505L: linux-pm@lists.linux-foundation.org
2913S: Supported 2506S: Supported
2914F: drivers/idle/i7300_idle.c 2507F: drivers/idle/i7300_idle.c
2915 2508
2916IEEE 1394 SUBSYSTEM 2509IEEE 1394 SUBSYSTEM
2917P: Ben Collins 2510M: Ben Collins <ben.collins@ubuntu.com>
2918M: ben.collins@ubuntu.com 2511M: Stefan Richter <stefanr@s5r6.in-berlin.de>
2919P: Stefan Richter
2920M: stefanr@s5r6.in-berlin.de
2921L: linux1394-devel@lists.sourceforge.net 2512L: linux1394-devel@lists.sourceforge.net
2922W: http://www.linux1394.org/ 2513W: http://www.linux1394.org/
2923T: git git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394-2.6.git 2514T: git git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394-2.6.git
@@ -2925,19 +2516,15 @@ S: Maintained
2925F: drivers/ieee1394/ 2516F: drivers/ieee1394/
2926 2517
2927IEEE 1394 RAW I/O DRIVER 2518IEEE 1394 RAW I/O DRIVER
2928P: Dan Dennedy 2519M: Dan Dennedy <dan@dennedy.org>
2929M: dan@dennedy.org 2520M: Stefan Richter <stefanr@s5r6.in-berlin.de>
2930P: Stefan Richter
2931M: stefanr@s5r6.in-berlin.de
2932L: linux1394-devel@lists.sourceforge.net 2521L: linux1394-devel@lists.sourceforge.net
2933S: Maintained 2522S: Maintained
2934F: drivers/ieee1394/raw1394* 2523F: drivers/ieee1394/raw1394*
2935 2524
2936IEEE 802.15.4 SUBSYSTEM 2525IEEE 802.15.4 SUBSYSTEM
2937P: Dmitry Eremin-Solenikov 2526M: Dmitry Eremin-Solenikov <dbaryshkov@gmail.com>
2938M: dbaryshkov@gmail.com 2527M: Sergey Lapin <slapin@ossfans.org>
2939P: Sergey Lapin
2940M: slapin@ossfans.org
2941L: linux-zigbee-devel@lists.sourceforge.net (moderated for non-subscribers) 2528L: linux-zigbee-devel@lists.sourceforge.net (moderated for non-subscribers)
2942W: http://apps.sourceforge.net/trac/linux-zigbee 2529W: http://apps.sourceforge.net/trac/linux-zigbee
2943T: git git://git.kernel.org/pub/scm/linux/kernel/git/lowpan/lowpan.git 2530T: git git://git.kernel.org/pub/scm/linux/kernel/git/lowpan/lowpan.git
@@ -2946,8 +2533,7 @@ F: net/ieee802154/
2946F: drivers/ieee802154/ 2533F: drivers/ieee802154/
2947 2534
2948INTEGRITY MEASUREMENT ARCHITECTURE (IMA) 2535INTEGRITY MEASUREMENT ARCHITECTURE (IMA)
2949P: Mimi Zohar 2536M: Mimi Zohar <zohar@us.ibm.com>
2950M: zohar@us.ibm.com
2951S: Supported 2537S: Supported
2952F: security/integrity/ima/ 2538F: security/integrity/ima/
2953 2539
@@ -2957,12 +2543,9 @@ S: Orphan
2957F: drivers/video/imsttfb.c 2543F: drivers/video/imsttfb.c
2958 2544
2959INFINIBAND SUBSYSTEM 2545INFINIBAND SUBSYSTEM
2960P: Roland Dreier 2546M: Roland Dreier <rolandd@cisco.com>
2961M: rolandd@cisco.com 2547M: Sean Hefty <sean.hefty@intel.com>
2962P: Sean Hefty 2548M: Hal Rosenstock <hal.rosenstock@gmail.com>
2963M: sean.hefty@intel.com
2964P: Hal Rosenstock
2965M: hal.rosenstock@gmail.com
2966L: general@lists.openfabrics.org (moderated for non-subscribers) 2549L: general@lists.openfabrics.org (moderated for non-subscribers)
2967W: http://www.openib.org/ 2550W: http://www.openib.org/
2968T: git git://git.kernel.org/pub/scm/linux/kernel/git/roland/infiniband.git 2551T: git git://git.kernel.org/pub/scm/linux/kernel/git/roland/infiniband.git
@@ -2972,65 +2555,55 @@ F: drivers/infiniband/
2972F: include/linux/if_infiniband.h 2555F: include/linux/if_infiniband.h
2973 2556
2974INOTIFY 2557INOTIFY
2975P: John McCutchan 2558M: John McCutchan <john@johnmccutchan.com>
2976M: john@johnmccutchan.com 2559M: Robert Love <rlove@rlove.org>
2977P: Robert Love 2560M: Eric Paris <eparis@parisplace.org>
2978M: rlove@rlove.org
2979P: Eric Paris
2980M: eparis@parisplace.org
2981S: Maintained 2561S: Maintained
2982F: Documentation/filesystems/inotify.txt 2562F: Documentation/filesystems/inotify.txt
2983F: fs/notify/inotify/ 2563F: fs/notify/inotify/
2984F: include/linux/inotify.h 2564F: include/linux/inotify.h
2985 2565
2986INPUT (KEYBOARD, MOUSE, JOYSTICK, TOUCHSCREEN) DRIVERS 2566INPUT (KEYBOARD, MOUSE, JOYSTICK, TOUCHSCREEN) DRIVERS
2987P: Dmitry Torokhov 2567M: Dmitry Torokhov <dmitry.torokhov@gmail.com>
2988M: dmitry.torokhov@gmail.com 2568M: Dmitry Torokhov <dtor@mail.ru>
2989M: dtor@mail.ru
2990L: linux-input@vger.kernel.org 2569L: linux-input@vger.kernel.org
2991T: git git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input.git 2570T: git git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input.git
2992S: Maintained 2571S: Maintained
2993F: drivers/input/ 2572F: drivers/input/
2994 2573
2995INTEL FRAMEBUFFER DRIVER (excluding 810 and 815) 2574INTEL FRAMEBUFFER DRIVER (excluding 810 and 815)
2996P: Sylvain Meyer 2575M: Sylvain Meyer <sylvain.meyer@worldonline.fr>
2997M: sylvain.meyer@worldonline.fr
2998L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) 2576L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers)
2999S: Maintained 2577S: Maintained
3000F: Documentation/fb/intelfb.txt 2578F: Documentation/fb/intelfb.txt
3001F: drivers/video/intelfb/ 2579F: drivers/video/intelfb/
3002 2580
3003INTEL 810/815 FRAMEBUFFER DRIVER 2581INTEL 810/815 FRAMEBUFFER DRIVER
3004P: Antonino Daplas 2582M: Antonino Daplas <adaplas@gmail.com>
3005M: adaplas@gmail.com
3006L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) 2583L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers)
3007S: Maintained 2584S: Maintained
3008F: drivers/video/i810/ 2585F: drivers/video/i810/
3009 2586
3010INTEL MENLOW THERMAL DRIVER 2587INTEL MENLOW THERMAL DRIVER
3011P: Sujith Thomas 2588M: Sujith Thomas <sujith.thomas@intel.com>
3012M: sujith.thomas@intel.com
3013L: linux-acpi@vger.kernel.org 2589L: linux-acpi@vger.kernel.org
3014W: http://www.lesswatts.org/projects/acpi/ 2590W: http://www.lesswatts.org/projects/acpi/
3015S: Supported 2591S: Supported
3016F: drivers/platform/x86/intel_menlow.c 2592F: drivers/platform/x86/intel_menlow.c
3017 2593
3018INTEL IA32 MICROCODE UPDATE SUPPORT 2594INTEL IA32 MICROCODE UPDATE SUPPORT
3019P: Tigran Aivazian 2595M: Tigran Aivazian <tigran@aivazian.fsnet.co.uk>
3020M: tigran@aivazian.fsnet.co.uk
3021S: Maintained 2596S: Maintained
3022F: arch/x86/kernel/microcode_core.c 2597F: arch/x86/kernel/microcode_core.c
3023F: arch/x86/kernel/microcode_intel.c 2598F: arch/x86/kernel/microcode_intel.c
3024 2599
3025INTEL I/OAT DMA DRIVER 2600INTEL I/OAT DMA DRIVER
3026P: Maciej Sosnowski 2601M: Maciej Sosnowski <maciej.sosnowski@intel.com>
3027M: maciej.sosnowski@intel.com
3028S: Supported 2602S: Supported
3029F: drivers/dma/ioat* 2603F: drivers/dma/ioat*
3030 2604
3031INTEL IOMMU (VT-d) 2605INTEL IOMMU (VT-d)
3032P: David Woodhouse 2606M: David Woodhouse <dwmw2@infradead.org>
3033M: dwmw2@infradead.org
3034L: iommu@lists.linux-foundation.org 2607L: iommu@lists.linux-foundation.org
3035T: git git://git.infradead.org/iommu-2.6.git 2608T: git git://git.infradead.org/iommu-2.6.git
3036S: Supported 2609S: Supported
@@ -3038,14 +2611,12 @@ F: drivers/pci/intel-iommu.c
3038F: include/linux/intel-iommu.h 2611F: include/linux/intel-iommu.h
3039 2612
3040INTEL IOP-ADMA DMA DRIVER 2613INTEL IOP-ADMA DMA DRIVER
3041P: Dan Williams 2614M: Dan Williams <dan.j.williams@intel.com>
3042M: dan.j.williams@intel.com
3043S: Supported 2615S: Supported
3044F: drivers/dma/iop-adma.c 2616F: drivers/dma/iop-adma.c
3045 2617
3046INTEL IXP4XX QMGR, NPE, ETHERNET and HSS SUPPORT 2618INTEL IXP4XX QMGR, NPE, ETHERNET and HSS SUPPORT
3047P: Krzysztof Halasa 2619M: Krzysztof Halasa <khc@pm.waw.pl>
3048M: khc@pm.waw.pl
3049S: Maintained 2620S: Maintained
3050F: arch/arm/mach-ixp4xx/include/mach/qmgr.h 2621F: arch/arm/mach-ixp4xx/include/mach/qmgr.h
3051F: arch/arm/mach-ixp4xx/include/mach/npe.h 2622F: arch/arm/mach-ixp4xx/include/mach/npe.h
@@ -3055,29 +2626,22 @@ F: drivers/net/arm/ixp4xx_eth.c
3055F: drivers/net/wan/ixp4xx_hss.c 2626F: drivers/net/wan/ixp4xx_hss.c
3056 2627
3057INTEL IXP4XX RANDOM NUMBER GENERATOR SUPPORT 2628INTEL IXP4XX RANDOM NUMBER GENERATOR SUPPORT
3058P: Deepak Saxena 2629M: Deepak Saxena <dsaxena@plexity.net>
3059M: dsaxena@plexity.net
3060S: Maintained 2630S: Maintained
3061F: drivers/char/hw_random/ixp4xx-rng.c 2631F: drivers/char/hw_random/ixp4xx-rng.c
3062 2632
3063INTEL IXP2000 ETHERNET DRIVER 2633INTEL IXP2000 ETHERNET DRIVER
3064P: Lennert Buytenhek 2634M: Lennert Buytenhek <kernel@wantstofly.org>
3065M: kernel@wantstofly.org
3066L: netdev@vger.kernel.org 2635L: netdev@vger.kernel.org
3067S: Maintained 2636S: Maintained
3068F: drivers/net/ixp2000/ 2637F: drivers/net/ixp2000/
3069 2638
3070INTEL ETHERNET DRIVERS (e100/e1000/e1000e/igb/ixgb/ixgbe) 2639INTEL ETHERNET DRIVERS (e100/e1000/e1000e/igb/ixgb/ixgbe)
3071P: Jeff Kirsher 2640M: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
3072M: jeffrey.t.kirsher@intel.com 2641M: Jesse Brandeburg <jesse.brandeburg@intel.com>
3073P: Jesse Brandeburg 2642M: Bruce Allan <bruce.w.allan@intel.com>
3074M: jesse.brandeburg@intel.com 2643M: PJ Waskiewicz <peter.p.waskiewicz.jr@intel.com>
3075P: Bruce Allan 2644M: John Ronciak <john.ronciak@intel.com>
3076M: bruce.w.allan@intel.com
3077P: PJ Waskiewicz
3078M: peter.p.waskiewicz.jr@intel.com
3079P: John Ronciak
3080M: john.ronciak@intel.com
3081L: e1000-devel@lists.sourceforge.net 2645L: e1000-devel@lists.sourceforge.net
3082W: http://e1000.sourceforge.net/ 2646W: http://e1000.sourceforge.net/
3083S: Supported 2647S: Supported
@@ -3089,12 +2653,9 @@ F: drivers/net/ixgb/
3089F: drivers/net/ixgbe/ 2653F: drivers/net/ixgbe/
3090 2654
3091INTEL PRO/WIRELESS 2100 NETWORK CONNECTION SUPPORT 2655INTEL PRO/WIRELESS 2100 NETWORK CONNECTION SUPPORT
3092P: Zhu Yi 2656M: Zhu Yi <yi.zhu@intel.com>
3093M: yi.zhu@intel.com 2657M: James Ketrenos <jketreno@linux.intel.com>
3094P: James Ketrenos 2658M: Reinette Chatre <reinette.chatre@intel.com>
3095M: jketreno@linux.intel.com
3096P: Reinette Chatre
3097M: reinette.chatre@intel.com
3098L: linux-wireless@vger.kernel.org 2659L: linux-wireless@vger.kernel.org
3099L: ipw2100-devel@lists.sourceforge.net 2660L: ipw2100-devel@lists.sourceforge.net
3100W: http://lists.sourceforge.net/mailman/listinfo/ipw2100-devel 2661W: http://lists.sourceforge.net/mailman/listinfo/ipw2100-devel
@@ -3104,12 +2665,9 @@ F: Documentation/networking/README.ipw2100
3104F: drivers/net/wireless/ipw2x00/ipw2100.* 2665F: drivers/net/wireless/ipw2x00/ipw2100.*
3105 2666
3106INTEL PRO/WIRELESS 2915ABG NETWORK CONNECTION SUPPORT 2667INTEL PRO/WIRELESS 2915ABG NETWORK CONNECTION SUPPORT
3107P: Zhu Yi 2668M: Zhu Yi <yi.zhu@intel.com>
3108M: yi.zhu@intel.com 2669M: James Ketrenos <jketreno@linux.intel.com>
3109P: James Ketrenos 2670M: Reinette Chatre <reinette.chatre@intel.com>
3110M: jketreno@linux.intel.com
3111P: Reinette Chatre
3112M: reinette.chatre@intel.com
3113L: linux-wireless@vger.kernel.org 2671L: linux-wireless@vger.kernel.org
3114L: ipw2100-devel@lists.sourceforge.net 2672L: ipw2100-devel@lists.sourceforge.net
3115W: http://lists.sourceforge.net/mailman/listinfo/ipw2100-devel 2673W: http://lists.sourceforge.net/mailman/listinfo/ipw2100-devel
@@ -3119,8 +2677,7 @@ F: Documentation/networking/README.ipw2200
3119F: drivers/net/wireless/ipw2x00/ipw2200.* 2677F: drivers/net/wireless/ipw2x00/ipw2200.*
3120 2678
3121INTEL WIRELESS WIMAX CONNECTION 2400 2679INTEL WIRELESS WIMAX CONNECTION 2400
3122P: Inaky Perez-Gonzalez 2680M: Inaky Perez-Gonzalez <inaky.perez-gonzalez@intel.com>
3123M: inaky.perez-gonzalez@intel.com
3124M: linux-wimax@intel.com 2681M: linux-wimax@intel.com
3125L: wimax@linuxwimax.org 2682L: wimax@linuxwimax.org
3126S: Supported 2683S: Supported
@@ -3130,10 +2687,8 @@ F: drivers/net/wimax/i2400m/
3130F: include/linux/wimax/i2400m.h 2687F: include/linux/wimax/i2400m.h
3131 2688
3132INTEL WIRELESS WIFI LINK (iwlwifi) 2689INTEL WIRELESS WIFI LINK (iwlwifi)
3133P: Zhu Yi 2690M: Zhu Yi <yi.zhu@intel.com>
3134M: yi.zhu@intel.com 2691M: Reinette Chatre <reinette.chatre@intel.com>
3135P: Reinette Chatre
3136M: reinette.chatre@intel.com
3137L: linux-wireless@vger.kernel.org 2692L: linux-wireless@vger.kernel.org
3138L: ipw3945-devel@lists.sourceforge.net 2693L: ipw3945-devel@lists.sourceforge.net
3139W: http://intellinuxwireless.org 2694W: http://intellinuxwireless.org
@@ -3142,47 +2697,39 @@ S: Supported
3142F: drivers/net/wireless/iwlwifi/ 2697F: drivers/net/wireless/iwlwifi/
3143 2698
3144IOC3 ETHERNET DRIVER 2699IOC3 ETHERNET DRIVER
3145P: Ralf Baechle 2700M: Ralf Baechle <ralf@linux-mips.org>
3146M: ralf@linux-mips.org
3147L: linux-mips@linux-mips.org 2701L: linux-mips@linux-mips.org
3148S: Maintained 2702S: Maintained
3149F: drivers/net/ioc3-eth.c 2703F: drivers/net/ioc3-eth.c
3150 2704
3151IOC3 SERIAL DRIVER 2705IOC3 SERIAL DRIVER
3152P: Pat Gefre 2706M: Pat Gefre <pfg@sgi.com>
3153M: pfg@sgi.com
3154L: linux-mips@linux-mips.org 2707L: linux-mips@linux-mips.org
3155S: Maintained 2708S: Maintained
3156F: drivers/serial/ioc3_serial.c 2709F: drivers/serial/ioc3_serial.c
3157 2710
3158IP MASQUERADING 2711IP MASQUERADING
3159P: Juanjo Ciarlante 2712M: Juanjo Ciarlante <jjciarla@raiz.uncu.edu.ar>
3160M: jjciarla@raiz.uncu.edu.ar
3161S: Maintained 2713S: Maintained
3162F: net/ipv4/netfilter/ipt_MASQUERADE.c 2714F: net/ipv4/netfilter/ipt_MASQUERADE.c
3163 2715
3164IP1000A 10/100/1000 GIGABIT ETHERNET DRIVER 2716IP1000A 10/100/1000 GIGABIT ETHERNET DRIVER
3165P: Francois Romieu 2717M: Francois Romieu <romieu@fr.zoreil.com>
3166M: romieu@fr.zoreil.com 2718M: Sorbica Shieh <sorbica@icplus.com.tw>
3167P: Sorbica Shieh 2719M: Jesse Huang <jesse@icplus.com.tw>
3168M: sorbica@icplus.com.tw
3169P: Jesse Huang
3170M: jesse@icplus.com.tw
3171L: netdev@vger.kernel.org 2720L: netdev@vger.kernel.org
3172S: Maintained 2721S: Maintained
3173F: drivers/net/ipg.c 2722F: drivers/net/ipg.c
3174 2723
3175IPATH DRIVER 2724IPATH DRIVER
3176P: Ralph Campbell 2725M: Ralph Campbell <infinipath@qlogic.com>
3177M: infinipath@qlogic.com
3178L: general@lists.openfabrics.org 2726L: general@lists.openfabrics.org
3179T: git git://git.qlogic.com/ipath-linux-2.6 2727T: git git://git.qlogic.com/ipath-linux-2.6
3180S: Supported 2728S: Supported
3181F: drivers/infiniband/hw/ipath/ 2729F: drivers/infiniband/hw/ipath/
3182 2730
3183IPMI SUBSYSTEM 2731IPMI SUBSYSTEM
3184P: Corey Minyard 2732M: Corey Minyard <minyard@acm.org>
3185M: minyard@acm.org
3186L: openipmi-developer@lists.sourceforge.net 2733L: openipmi-developer@lists.sourceforge.net
3187W: http://openipmi.sourceforge.net/ 2734W: http://openipmi.sourceforge.net/
3188S: Supported 2735S: Supported
@@ -3191,20 +2738,16 @@ F: drivers/char/ipmi/
3191F: include/linux/ipmi* 2738F: include/linux/ipmi*
3192 2739
3193IPS SCSI RAID DRIVER 2740IPS SCSI RAID DRIVER
3194P: Adaptec OEM Raid Solutions 2741M: Adaptec OEM Raid Solutions <aacraid@adaptec.com>
3195M: aacraid@adaptec.com
3196L: linux-scsi@vger.kernel.org 2742L: linux-scsi@vger.kernel.org
3197W: http://www.adaptec.com/ 2743W: http://www.adaptec.com/
3198S: Maintained 2744S: Maintained
3199F: drivers/scsi/ips* 2745F: drivers/scsi/ips*
3200 2746
3201IPVS 2747IPVS
3202P: Wensong Zhang 2748M: Wensong Zhang <wensong@linux-vs.org>
3203M: wensong@linux-vs.org 2749M: Simon Horman <horms@verge.net.au>
3204P: Simon Horman 2750M: Julian Anastasov <ja@ssi.bg>
3205M: horms@verge.net.au
3206P: Julian Anastasov
3207M: ja@ssi.bg
3208L: netdev@vger.kernel.org 2751L: netdev@vger.kernel.org
3209L: lvs-devel@vger.kernel.org 2752L: lvs-devel@vger.kernel.org
3210S: Maintained 2753S: Maintained
@@ -3212,17 +2755,14 @@ F: Documentation/networking/ipvs-sysctl.txt
3212F: net/netfilter/ipvs/ 2755F: net/netfilter/ipvs/
3213 2756
3214IPWIRELESS DRIVER 2757IPWIRELESS DRIVER
3215P: Jiri Kosina 2758M: Jiri Kosina <jkosina@suse.cz>
3216M: jkosina@suse.cz 2759M: David Sterba <dsterba@suse.cz>
3217P: David Sterba
3218M: dsterba@suse.cz
3219S: Maintained 2760S: Maintained
3220T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/ipwireless_cs.git 2761T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/ipwireless_cs.git
3221F: drivers/char/pcmcia/ipwireless/ 2762F: drivers/char/pcmcia/ipwireless/
3222 2763
3223IPX NETWORK LAYER 2764IPX NETWORK LAYER
3224P: Arnaldo Carvalho de Melo 2765M: Arnaldo Carvalho de Melo <acme@ghostprotocols.net>
3225M: acme@ghostprotocols.net
3226L: netdev@vger.kernel.org 2766L: netdev@vger.kernel.org
3227S: Maintained 2767S: Maintained
3228F: include/linux/ipx.h 2768F: include/linux/ipx.h
@@ -3230,8 +2770,7 @@ F: include/net/ipx.h
3230F: net/ipx/ 2770F: net/ipx/
3231 2771
3232IRDA SUBSYSTEM 2772IRDA SUBSYSTEM
3233P: Samuel Ortiz 2773M: Samuel Ortiz <samuel@sortiz.org>
3234M: samuel@sortiz.org
3235L: irda-users@lists.sourceforge.net (subscribers-only) 2774L: irda-users@lists.sourceforge.net (subscribers-only)
3236W: http://irda.sourceforge.net/ 2775W: http://irda.sourceforge.net/
3237S: Maintained 2776S: Maintained
@@ -3242,16 +2781,14 @@ F: include/net/irda/
3242F: net/irda/ 2781F: net/irda/
3243 2782
3244ISAPNP 2783ISAPNP
3245P: Jaroslav Kysela 2784M: Jaroslav Kysela <perex@perex.cz>
3246M: perex@perex.cz
3247S: Maintained 2785S: Maintained
3248F: Documentation/isapnp.txt 2786F: Documentation/isapnp.txt
3249F: drivers/pnp/isapnp/ 2787F: drivers/pnp/isapnp/
3250F: include/linux/isapnp.h 2788F: include/linux/isapnp.h
3251 2789
3252ISCSI 2790ISCSI
3253P: Mike Christie 2791M: Mike Christie <michaelc@cs.wisc.edu>
3254M: michaelc@cs.wisc.edu
3255L: open-iscsi@googlegroups.com 2792L: open-iscsi@googlegroups.com
3256W: www.open-iscsi.org 2793W: www.open-iscsi.org
3257T: git git://git.kernel.org/pub/scm/linux/kernel/git/mnc/linux-2.6-iscsi.git 2794T: git git://git.kernel.org/pub/scm/linux/kernel/git/mnc/linux-2.6-iscsi.git
@@ -3260,8 +2797,7 @@ F: drivers/scsi/*iscsi*
3260F: include/scsi/*iscsi* 2797F: include/scsi/*iscsi*
3261 2798
3262ISDN SUBSYSTEM 2799ISDN SUBSYSTEM
3263P: Karsten Keil 2800M: Karsten Keil <isdn@linux-pingi.de>
3264M: isdn@linux-pingi.de
3265L: isdn4linux@listserv.isdn4linux.de (subscribers-only) 2801L: isdn4linux@listserv.isdn4linux.de (subscribers-only)
3266W: http://www.isdn4linux.de 2802W: http://www.isdn4linux.de
3267T: git git://git.kernel.org/pub/scm/linux/kernel/git/kkeil/isdn-2.6.git 2803T: git git://git.kernel.org/pub/scm/linux/kernel/git/kkeil/isdn-2.6.git
@@ -3272,18 +2808,15 @@ F: include/linux/isdn.h
3272F: include/linux/isdn/ 2808F: include/linux/isdn/
3273 2809
3274ISDN SUBSYSTEM (Eicon active card driver) 2810ISDN SUBSYSTEM (Eicon active card driver)
3275P: Armin Schindler 2811M: Armin Schindler <mac@melware.de>
3276M: mac@melware.de
3277L: isdn4linux@listserv.isdn4linux.de (subscribers-only) 2812L: isdn4linux@listserv.isdn4linux.de (subscribers-only)
3278W: http://www.melware.de 2813W: http://www.melware.de
3279S: Maintained 2814S: Maintained
3280F: drivers/isdn/hardware/eicon/ 2815F: drivers/isdn/hardware/eicon/
3281 2816
3282IVTV VIDEO4LINUX DRIVER 2817IVTV VIDEO4LINUX DRIVER
3283P: Hans Verkuil 2818M: Hans Verkuil <hverkuil@xs4all.nl>
3284M: hverkuil@xs4all.nl
3285L: ivtv-devel@ivtvdriver.org 2819L: ivtv-devel@ivtvdriver.org
3286L: ivtv-users@ivtvdriver.org
3287L: linux-media@vger.kernel.org 2820L: linux-media@vger.kernel.org
3288T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 2821T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
3289W: http://www.ivtvdriver.org 2822W: http://www.ivtvdriver.org
@@ -3293,8 +2826,7 @@ F: drivers/media/video/ivtv/
3293F: include/linux/ivtv* 2826F: include/linux/ivtv*
3294 2827
3295JFS FILESYSTEM 2828JFS FILESYSTEM
3296P: Dave Kleikamp 2829M: Dave Kleikamp <shaggy@linux.vnet.ibm.com>
3297M: shaggy@linux.vnet.ibm.com
3298L: jfs-discussion@lists.sourceforge.net 2830L: jfs-discussion@lists.sourceforge.net
3299W: http://jfs.sourceforge.net/ 2831W: http://jfs.sourceforge.net/
3300T: git git://git.kernel.org/pub/scm/linux/kernel/git/shaggy/jfs-2.6.git 2832T: git git://git.kernel.org/pub/scm/linux/kernel/git/shaggy/jfs-2.6.git
@@ -3303,15 +2835,13 @@ F: Documentation/filesystems/jfs.txt
3303F: fs/jfs/ 2835F: fs/jfs/
3304 2836
3305JME NETWORK DRIVER 2837JME NETWORK DRIVER
3306P: Guo-Fu Tseng 2838M: Guo-Fu Tseng <cooldavid@cooldavid.org>
3307M: cooldavid@cooldavid.org
3308L: netdev@vger.kernel.org 2839L: netdev@vger.kernel.org
3309S: Maintained 2840S: Maintained
3310F: drivers/net/jme.* 2841F: drivers/net/jme.*
3311 2842
3312JOURNALLING FLASH FILE SYSTEM V2 (JFFS2) 2843JOURNALLING FLASH FILE SYSTEM V2 (JFFS2)
3313P: David Woodhouse 2844M: David Woodhouse <dwmw2@infradead.org>
3314M: dwmw2@infradead.org
3315L: linux-mtd@lists.infradead.org 2845L: linux-mtd@lists.infradead.org
3316W: http://www.linux-mtd.infradead.org/doc/jffs2.html 2846W: http://www.linux-mtd.infradead.org/doc/jffs2.html
3317S: Maintained 2847S: Maintained
@@ -3319,10 +2849,8 @@ F: fs/jffs2/
3319F: include/linux/jffs2.h 2849F: include/linux/jffs2.h
3320 2850
3321JOURNALLING LAYER FOR BLOCK DEVICES (JBD) 2851JOURNALLING LAYER FOR BLOCK DEVICES (JBD)
3322P: Stephen Tweedie 2852M: Stephen Tweedie <sct@redhat.com>
3323M: sct@redhat.com 2853M: Andrew Morton <akpm@linux-foundation.org>
3324P: Andrew Morton
3325M: akpm@linux-foundation.org
3326L: linux-ext4@vger.kernel.org 2854L: linux-ext4@vger.kernel.org
3327S: Maintained 2855S: Maintained
3328F: fs/jbd*/ 2856F: fs/jbd*/
@@ -3330,48 +2858,41 @@ F: include/linux/ext*jbd*.h
3330F: include/linux/jbd*.h 2858F: include/linux/jbd*.h
3331 2859
3332K8TEMP HARDWARE MONITORING DRIVER 2860K8TEMP HARDWARE MONITORING DRIVER
3333P: Rudolf Marek 2861M: Rudolf Marek <r.marek@assembler.cz>
3334M: r.marek@assembler.cz
3335L: lm-sensors@lm-sensors.org 2862L: lm-sensors@lm-sensors.org
3336S: Maintained 2863S: Maintained
3337F: Documentation/hwmon/k8temp 2864F: Documentation/hwmon/k8temp
3338F: drivers/hwmon/k8temp.c 2865F: drivers/hwmon/k8temp.c
3339 2866
3340KCONFIG 2867KCONFIG
3341P: Roman Zippel 2868M: Roman Zippel <zippel@linux-m68k.org>
3342M: zippel@linux-m68k.org
3343L: linux-kbuild@vger.kernel.org 2869L: linux-kbuild@vger.kernel.org
3344S: Maintained 2870S: Maintained
3345F: Documentation/kbuild/kconfig-language.txt 2871F: Documentation/kbuild/kconfig-language.txt
3346F: scripts/kconfig/ 2872F: scripts/kconfig/
3347 2873
3348KDUMP 2874KDUMP
3349P: Vivek Goyal 2875M: Vivek Goyal <vgoyal@redhat.com>
3350M: vgoyal@redhat.com 2876M: Haren Myneni <hbabu@us.ibm.com>
3351P: Haren Myneni
3352M: hbabu@us.ibm.com
3353L: kexec@lists.infradead.org 2877L: kexec@lists.infradead.org
3354W: http://lse.sourceforge.net/kdump/ 2878W: http://lse.sourceforge.net/kdump/
3355S: Maintained 2879S: Maintained
3356F: Documentation/kdump/ 2880F: Documentation/kdump/
3357 2881
3358KERNEL AUTOMOUNTER (AUTOFS) 2882KERNEL AUTOMOUNTER (AUTOFS)
3359P: H. Peter Anvin 2883M: "H. Peter Anvin" <hpa@zytor.com>
3360M: hpa@zytor.com
3361L: autofs@linux.kernel.org 2884L: autofs@linux.kernel.org
3362S: Odd Fixes 2885S: Odd Fixes
3363F: fs/autofs/ 2886F: fs/autofs/
3364 2887
3365KERNEL AUTOMOUNTER v4 (AUTOFS4) 2888KERNEL AUTOMOUNTER v4 (AUTOFS4)
3366P: Ian Kent 2889M: Ian Kent <raven@themaw.net>
3367M: raven@themaw.net
3368L: autofs@linux.kernel.org 2890L: autofs@linux.kernel.org
3369S: Maintained 2891S: Maintained
3370F: fs/autofs4/ 2892F: fs/autofs4/
3371 2893
3372KERNEL BUILD 2894KERNEL BUILD
3373P: Sam Ravnborg 2895M: Sam Ravnborg <sam@ravnborg.org>
3374M: sam@ravnborg.org
3375T: git git://git.kernel.org/pub/scm/linux/kernel/git/sam/kbuild-next.git 2896T: git git://git.kernel.org/pub/scm/linux/kernel/git/sam/kbuild-next.git
3376T: git git://git.kernel.org/pub/scm/linux/kernel/git/sam/kbuild-fixes.git 2897T: git git://git.kernel.org/pub/scm/linux/kernel/git/sam/kbuild-fixes.git
3377L: linux-kbuild@vger.kernel.org 2898L: linux-kbuild@vger.kernel.org
@@ -3381,16 +2902,13 @@ F: Makefile
3381F: scripts/Makefile.* 2902F: scripts/Makefile.*
3382 2903
3383KERNEL JANITORS 2904KERNEL JANITORS
3384P: Several
3385L: kernel-janitors@vger.kernel.org 2905L: kernel-janitors@vger.kernel.org
3386W: http://www.kerneljanitors.org/ 2906W: http://www.kerneljanitors.org/
3387S: Maintained 2907S: Odd fixes
3388 2908
3389KERNEL NFSD, SUNRPC, AND LOCKD SERVERS 2909KERNEL NFSD, SUNRPC, AND LOCKD SERVERS
3390P: J. Bruce Fields 2910M: "J. Bruce Fields" <bfields@fieldses.org>
3391M: bfields@fieldses.org 2911M: Neil Brown <neilb@suse.de>
3392P: Neil Brown
3393M: neilb@suse.de
3394L: linux-nfs@vger.kernel.org 2912L: linux-nfs@vger.kernel.org
3395W: http://nfs.sourceforge.net/ 2913W: http://nfs.sourceforge.net/
3396S: Supported 2914S: Supported
@@ -3403,8 +2921,7 @@ F: include/linux/lockd/
3403F: include/linux/sunrpc/ 2921F: include/linux/sunrpc/
3404 2922
3405KERNEL VIRTUAL MACHINE (KVM) 2923KERNEL VIRTUAL MACHINE (KVM)
3406P: Avi Kivity 2924M: Avi Kivity <avi@redhat.com>
3407M: avi@redhat.com
3408L: kvm@vger.kernel.org 2925L: kvm@vger.kernel.org
3409W: http://kvm.qumranet.com 2926W: http://kvm.qumranet.com
3410S: Supported 2927S: Supported
@@ -3415,8 +2932,7 @@ F: include/linux/kvm*
3415F: virt/kvm/ 2932F: virt/kvm/
3416 2933
3417KERNEL VIRTUAL MACHINE (KVM) FOR AMD-V 2934KERNEL VIRTUAL MACHINE (KVM) FOR AMD-V
3418P: Joerg Roedel 2935M: Joerg Roedel <joerg.roedel@amd.com>
3419M: joerg.roedel@amd.com
3420L: kvm@vger.kernel.org 2936L: kvm@vger.kernel.org
3421W: http://kvm.qumranet.com 2937W: http://kvm.qumranet.com
3422S: Supported 2938S: Supported
@@ -3425,8 +2941,7 @@ F: arch/x86/kvm/kvm_svm.h
3425F: arch/x86/kvm/svm.c 2941F: arch/x86/kvm/svm.c
3426 2942
3427KERNEL VIRTUAL MACHINE (KVM) FOR POWERPC 2943KERNEL VIRTUAL MACHINE (KVM) FOR POWERPC
3428P: Hollis Blanchard 2944M: Hollis Blanchard <hollisb@us.ibm.com>
3429M: hollisb@us.ibm.com
3430L: kvm-ppc@vger.kernel.org 2945L: kvm-ppc@vger.kernel.org
3431W: http://kvm.qumranet.com 2946W: http://kvm.qumranet.com
3432S: Supported 2947S: Supported
@@ -3434,8 +2949,7 @@ F: arch/powerpc/include/asm/kvm*
3434F: arch/powerpc/kvm/ 2949F: arch/powerpc/kvm/
3435 2950
3436KERNEL VIRTUAL MACHINE For Itanium (KVM/IA64) 2951KERNEL VIRTUAL MACHINE For Itanium (KVM/IA64)
3437P: Xiantao Zhang 2952M: Xiantao Zhang <xiantao.zhang@intel.com>
3438M: xiantao.zhang@intel.com
3439L: kvm-ia64@vger.kernel.org 2953L: kvm-ia64@vger.kernel.org
3440W: http://kvm.qumranet.com 2954W: http://kvm.qumranet.com
3441S: Supported 2955S: Supported
@@ -3444,10 +2958,8 @@ F: arch/ia64/include/asm/kvm*
3444F: arch/ia64/kvm/ 2958F: arch/ia64/kvm/
3445 2959
3446KERNEL VIRTUAL MACHINE for s390 (KVM/s390) 2960KERNEL VIRTUAL MACHINE for s390 (KVM/s390)
3447P: Carsten Otte 2961M: Carsten Otte <cotte@de.ibm.com>
3448M: cotte@de.ibm.com 2962M: Christian Borntraeger <borntraeger@de.ibm.com>
3449P: Christian Borntraeger
3450M: borntraeger@de.ibm.com
3451M: linux390@de.ibm.com 2963M: linux390@de.ibm.com
3452L: linux-s390@vger.kernel.org 2964L: linux-s390@vger.kernel.org
3453W: http://www.ibm.com/developerworks/linux/linux390/ 2965W: http://www.ibm.com/developerworks/linux/linux390/
@@ -3457,8 +2969,7 @@ F: arch/s390/include/asm/kvm*
3457F: arch/s390/kvm/ 2969F: arch/s390/kvm/
3458 2970
3459KEXEC 2971KEXEC
3460P: Eric Biederman 2972M: Eric Biederman <ebiederm@xmission.com>
3461M: ebiederm@xmission.com
3462W: http://ftp.kernel.org/pub/linux/kernel/people/horms/kexec-tools/ 2973W: http://ftp.kernel.org/pub/linux/kernel/people/horms/kexec-tools/
3463L: kexec@lists.infradead.org 2974L: kexec@lists.infradead.org
3464S: Maintained 2975S: Maintained
@@ -3466,8 +2977,7 @@ F: include/linux/kexec.h
3466F: kernel/kexec.c 2977F: kernel/kexec.c
3467 2978
3468KGDB 2979KGDB
3469P: Jason Wessel 2980M: Jason Wessel <jason.wessel@windriver.com>
3470M: jason.wessel@windriver.com
3471L: kgdb-bugreport@lists.sourceforge.net 2981L: kgdb-bugreport@lists.sourceforge.net
3472S: Maintained 2982S: Maintained
3473F: Documentation/DocBook/kgdb.tmpl 2983F: Documentation/DocBook/kgdb.tmpl
@@ -3477,17 +2987,13 @@ F: include/linux/kgdb.h
3477F: kernel/kgdb.c 2987F: kernel/kgdb.c
3478 2988
3479KMEMCHECK 2989KMEMCHECK
3480P: Vegard Nossum 2990M: Vegard Nossum <vegardno@ifi.uio.no>
3481M: vegardno@ifi.uio.no
3482P Pekka Enberg 2991P Pekka Enberg
3483M: penberg@cs.helsinki.fi 2992M: penberg@cs.helsinki.fi
3484L: linux-kernel@vger.kernel.org
3485S: Maintained 2993S: Maintained
3486 2994
3487KMEMLEAK 2995KMEMLEAK
3488P: Catalin Marinas 2996M: Catalin Marinas <catalin.marinas@arm.com>
3489M: catalin.marinas@arm.com
3490L: linux-kernel@vger.kernel.org
3491S: Maintained 2997S: Maintained
3492F: Documentation/kmemleak.txt 2998F: Documentation/kmemleak.txt
3493F: include/linux/kmemleak.h 2999F: include/linux/kmemleak.h
@@ -3495,30 +3001,24 @@ F: mm/kmemleak.c
3495F: mm/kmemleak-test.c 3001F: mm/kmemleak-test.c
3496 3002
3497KMEMTRACE 3003KMEMTRACE
3498P: Eduard - Gabriel Munteanu 3004M: Eduard - Gabriel Munteanu <eduard.munteanu@linux360.ro>
3499M: eduard.munteanu@linux360.ro
3500S: Maintained 3005S: Maintained
3501F: Documentation/trace/kmemtrace.txt 3006F: Documentation/trace/kmemtrace.txt
3502F: include/linux/kmemtrace.h 3007F: include/linux/kmemtrace.h
3503F: kernel/trace/kmemtrace.c 3008F: kernel/trace/kmemtrace.c
3504 3009
3505KPROBES 3010KPROBES
3506P: Ananth N Mavinakayanahalli 3011M: Ananth N Mavinakayanahalli <ananth@in.ibm.com>
3507M: ananth@in.ibm.com 3012M: Anil S Keshavamurthy <anil.s.keshavamurthy@intel.com>
3508P: Anil S Keshavamurthy 3013M: "David S. Miller" <davem@davemloft.net>
3509M: anil.s.keshavamurthy@intel.com 3014M: Masami Hiramatsu <mhiramat@redhat.com>
3510P: David S. Miller
3511M: davem@davemloft.net
3512P: Masami Hiramatsu
3513M: mhiramat@redhat.com
3514S: Maintained 3015S: Maintained
3515F: Documentation/kprobes.txt 3016F: Documentation/kprobes.txt
3516F: include/linux/kprobes.h 3017F: include/linux/kprobes.h
3517F: kernel/kprobes.c 3018F: kernel/kprobes.c
3518 3019
3519KS0108 LCD CONTROLLER DRIVER 3020KS0108 LCD CONTROLLER DRIVER
3520P: Miguel Ojeda Sandonis 3021M: Miguel Ojeda Sandonis <miguel.ojeda.sandonis@gmail.com>
3521M: miguel.ojeda.sandonis@gmail.com
3522W: http://miguelojeda.es/auxdisplay.htm 3022W: http://miguelojeda.es/auxdisplay.htm
3523W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm 3023W: http://jair.lab.fi.uva.es/~migojed/auxdisplay.htm
3524S: Maintained 3024S: Maintained
@@ -3534,31 +3034,27 @@ F: include/*/lapb.h
3534F: net/lapb/ 3034F: net/lapb/
3535 3035
3536LASI 53c700 driver for PARISC 3036LASI 53c700 driver for PARISC
3537P: James E.J. Bottomley 3037M: "James E.J. Bottomley" <James.Bottomley@HansenPartnership.com>
3538M: James.Bottomley@HansenPartnership.com
3539L: linux-scsi@vger.kernel.org 3038L: linux-scsi@vger.kernel.org
3540S: Maintained 3039S: Maintained
3541F: Documentation/scsi/53c700.txt 3040F: Documentation/scsi/53c700.txt
3542F: drivers/scsi/53c700* 3041F: drivers/scsi/53c700*
3543 3042
3544LED SUBSYSTEM 3043LED SUBSYSTEM
3545P: Richard Purdie 3044M: Richard Purdie <rpurdie@rpsys.net>
3546M: rpurdie@rpsys.net
3547S: Maintained 3045S: Maintained
3548F: drivers/leds/ 3046F: drivers/leds/
3549F: include/linux/leds.h 3047F: include/linux/leds.h
3550 3048
3551LEGO USB Tower driver 3049LEGO USB Tower driver
3552P: Juergen Stuber 3050M: Juergen Stuber <starblue@users.sourceforge.net>
3553M: starblue@users.sourceforge.net
3554L: legousb-devel@lists.sourceforge.net 3051L: legousb-devel@lists.sourceforge.net
3555W: http://legousb.sourceforge.net/ 3052W: http://legousb.sourceforge.net/
3556S: Maintained 3053S: Maintained
3557F: drivers/usb/misc/legousbtower.c 3054F: drivers/usb/misc/legousbtower.c
3558 3055
3559LGUEST 3056LGUEST
3560P: Rusty Russell 3057M: Rusty Russell <rusty@rustcorp.com.au>
3561M: rusty@rustcorp.com.au
3562L: lguest@ozlabs.org 3058L: lguest@ozlabs.org
3563W: http://lguest.ozlabs.org/ 3059W: http://lguest.ozlabs.org/
3564S: Maintained 3060S: Maintained
@@ -3569,119 +3065,100 @@ F: include/linux/lguest*.h
3569F: arch/x86/include/asm/lguest*.h 3065F: arch/x86/include/asm/lguest*.h
3570 3066
3571LINUX FOR IBM pSERIES (RS/6000) 3067LINUX FOR IBM pSERIES (RS/6000)
3572P: Paul Mackerras 3068M: Paul Mackerras <paulus@au.ibm.com>
3573M: paulus@au.ibm.com
3574W: http://www.ibm.com/linux/ltc/projects/ppc 3069W: http://www.ibm.com/linux/ltc/projects/ppc
3575S: Supported 3070S: Supported
3576 3071
3577LINUX FOR POWERPC (32-BIT AND 64-BIT) 3072LINUX FOR POWERPC (32-BIT AND 64-BIT)
3578P: Benjamin Herrenschmidt 3073M: Benjamin Herrenschmidt <benh@kernel.crashing.org>
3579M: benh@kernel.crashing.org 3074M: Paul Mackerras <paulus@samba.org>
3580P: Paul Mackerras
3581M: paulus@samba.org
3582W: http://www.penguinppc.org/ 3075W: http://www.penguinppc.org/
3583L: linuxppc-dev@ozlabs.org 3076L: linuxppc-dev@ozlabs.org
3584T: git git://git.kernel.org/pub/scm/linux/kernel/git/benh/powerpc.git 3077T: git git://git.kernel.org/pub/scm/linux/kernel/git/benh/powerpc.git
3585S: Supported 3078S: Supported
3586 3079
3587LINUX FOR POWER MACINTOSH 3080LINUX FOR POWER MACINTOSH
3588P: Benjamin Herrenschmidt 3081M: Benjamin Herrenschmidt <benh@kernel.crashing.org>
3589M: benh@kernel.crashing.org
3590W: http://www.penguinppc.org/ 3082W: http://www.penguinppc.org/
3591L: linuxppc-dev@ozlabs.org 3083L: linuxppc-dev@ozlabs.org
3592S: Maintained 3084S: Maintained
3593 3085
3594LINUX FOR POWERPC EMBEDDED MPC5XXX 3086LINUX FOR POWERPC EMBEDDED MPC5XXX
3595P: Grant Likely 3087M: Grant Likely <grant.likely@secretlab.ca>
3596M: grant.likely@secretlab.ca
3597L: linuxppc-dev@ozlabs.org 3088L: linuxppc-dev@ozlabs.org
3598T: git git://git.secretlab.ca/git/linux-2.6.git 3089T: git git://git.secretlab.ca/git/linux-2.6.git
3599S: Maintained 3090S: Maintained
3600 3091
3601LINUX FOR POWERPC EMBEDDED PPC4XX 3092LINUX FOR POWERPC EMBEDDED PPC4XX
3602P: Josh Boyer 3093M: Josh Boyer <jwboyer@linux.vnet.ibm.com>
3603M: jwboyer@linux.vnet.ibm.com 3094M: Matt Porter <mporter@kernel.crashing.org>
3604P: Matt Porter
3605M: mporter@kernel.crashing.org
3606W: http://www.penguinppc.org/ 3095W: http://www.penguinppc.org/
3607L: linuxppc-dev@ozlabs.org 3096L: linuxppc-dev@ozlabs.org
3608T: git git://git.kernel.org/pub/scm/linux/kernel/git/jwboyer/powerpc-4xx.git 3097T: git git://git.kernel.org/pub/scm/linux/kernel/git/jwboyer/powerpc-4xx.git
3609S: Maintained 3098S: Maintained
3610 3099
3611LINUX FOR POWERPC EMBEDDED XILINX VIRTEX 3100LINUX FOR POWERPC EMBEDDED XILINX VIRTEX
3612P: Grant Likely 3101M: Grant Likely <grant.likely@secretlab.ca>
3613M: grant.likely@secretlab.ca
3614W: http://wiki.secretlab.ca/index.php/Linux_on_Xilinx_Virtex 3102W: http://wiki.secretlab.ca/index.php/Linux_on_Xilinx_Virtex
3615L: linuxppc-dev@ozlabs.org 3103L: linuxppc-dev@ozlabs.org
3616T: git git://git.secretlab.ca/git/linux-2.6.git 3104T: git git://git.secretlab.ca/git/linux-2.6.git
3617S: Maintained 3105S: Maintained
3618 3106
3619LINUX FOR POWERPC EMBEDDED PPC8XX 3107LINUX FOR POWERPC EMBEDDED PPC8XX
3620P: Vitaly Bordug 3108M: Vitaly Bordug <vitb@kernel.crashing.org>
3621M: vitb@kernel.crashing.org 3109M: Marcelo Tosatti <marcelo@kvack.org>
3622P: Marcelo Tosatti
3623M: marcelo@kvack.org
3624W: http://www.penguinppc.org/ 3110W: http://www.penguinppc.org/
3625L: linuxppc-dev@ozlabs.org 3111L: linuxppc-dev@ozlabs.org
3626S: Maintained 3112S: Maintained
3627 3113
3628LINUX FOR POWERPC EMBEDDED PPC83XX AND PPC85XX 3114LINUX FOR POWERPC EMBEDDED PPC83XX AND PPC85XX
3629P: Kumar Gala 3115M: Kumar Gala <galak@kernel.crashing.org>
3630M: galak@kernel.crashing.org
3631W: http://www.penguinppc.org/ 3116W: http://www.penguinppc.org/
3632L: linuxppc-dev@ozlabs.org 3117L: linuxppc-dev@ozlabs.org
3633S: Maintained 3118S: Maintained
3634 3119
3635LINUX FOR POWERPC PA SEMI PWRFICIENT 3120LINUX FOR POWERPC PA SEMI PWRFICIENT
3636P: Olof Johansson 3121M: Olof Johansson <olof@lixom.net>
3637M: olof@lixom.net
3638W: http://www.pasemi.com/ 3122W: http://www.pasemi.com/
3639L: linuxppc-dev@ozlabs.org 3123L: linuxppc-dev@ozlabs.org
3640S: Supported 3124S: Supported
3641 3125
3642LINUX SECURITY MODULE (LSM) FRAMEWORK 3126LINUX SECURITY MODULE (LSM) FRAMEWORK
3643P: Chris Wright 3127M: Chris Wright <chrisw@sous-sol.org>
3644M: chrisw@sous-sol.org
3645L: linux-security-module@vger.kernel.org 3128L: linux-security-module@vger.kernel.org
3646T: git git://git.kernel.org/pub/scm/linux/kernel/git/chrisw/lsm-2.6.git 3129T: git git://git.kernel.org/pub/scm/linux/kernel/git/chrisw/lsm-2.6.git
3647S: Supported 3130S: Supported
3648 3131
3649LLC (802.2) 3132LLC (802.2)
3650P: Arnaldo Carvalho de Melo 3133M: Arnaldo Carvalho de Melo <acme@ghostprotocols.net>
3651M: acme@ghostprotocols.net
3652S: Maintained 3134S: Maintained
3653F: include/linux/llc.h 3135F: include/linux/llc.h
3654F: include/net/llc* 3136F: include/net/llc*
3655F: net/llc/ 3137F: net/llc/
3656 3138
3657LIS3LV02D ACCELEROMETER DRIVER 3139LIS3LV02D ACCELEROMETER DRIVER
3658P: Eric Piel 3140M: Eric Piel <eric.piel@tremplin-utc.net>
3659M: eric.piel@tremplin-utc.net
3660S: Maintained 3141S: Maintained
3661F: Documentation/hwmon/lis3lv02d 3142F: Documentation/hwmon/lis3lv02d
3662F: drivers/hwmon/lis3lv02d.* 3143F: drivers/hwmon/lis3lv02d.*
3663 3144
3664LM83 HARDWARE MONITOR DRIVER 3145LM83 HARDWARE MONITOR DRIVER
3665P: Jean Delvare 3146M: Jean Delvare <khali@linux-fr.org>
3666M: khali@linux-fr.org
3667L: lm-sensors@lm-sensors.org 3147L: lm-sensors@lm-sensors.org
3668S: Maintained 3148S: Maintained
3669F: Documentation/hwmon/lm83 3149F: Documentation/hwmon/lm83
3670F: drivers/hwmon/lm83.c 3150F: drivers/hwmon/lm83.c
3671 3151
3672LM90 HARDWARE MONITOR DRIVER 3152LM90 HARDWARE MONITOR DRIVER
3673P: Jean Delvare 3153M: Jean Delvare <khali@linux-fr.org>
3674M: khali@linux-fr.org
3675L: lm-sensors@lm-sensors.org 3154L: lm-sensors@lm-sensors.org
3676S: Maintained 3155S: Maintained
3677F: Documentation/hwmon/lm90 3156F: Documentation/hwmon/lm90
3678F: drivers/hwmon/lm90.c 3157F: drivers/hwmon/lm90.c
3679 3158
3680LOCKDEP AND LOCKSTAT 3159LOCKDEP AND LOCKSTAT
3681P: Peter Zijlstra 3160M: Peter Zijlstra <peterz@infradead.org>
3682M: peterz@infradead.org 3161M: Ingo Molnar <mingo@redhat.com>
3683P: Ingo Molnar
3684M: mingo@redhat.com
3685T: git git://git.kernel.org/pub/scm/linux/kernel/git/peterz/linux-2.6-lockdep.git 3162T: git git://git.kernel.org/pub/scm/linux/kernel/git/peterz/linux-2.6-lockdep.git
3686S: Maintained 3163S: Maintained
3687F: Documentation/lockdep*.txt 3164F: Documentation/lockdep*.txt
@@ -3690,8 +3167,7 @@ F: include/linux/lockdep.h
3690F: kernel/lockdep* 3167F: kernel/lockdep*
3691 3168
3692LOGICAL DISK MANAGER SUPPORT (LDM, Windows 2000/XP/Vista Dynamic Disks) 3169LOGICAL DISK MANAGER SUPPORT (LDM, Windows 2000/XP/Vista Dynamic Disks)
3693P: Richard Russon (FlatCap) 3170M: "Richard Russon (FlatCap)" <ldm@flatcap.org>
3694M: ldm@flatcap.org
3695L: linux-ntfs-dev@lists.sourceforge.net 3171L: linux-ntfs-dev@lists.sourceforge.net
3696W: http://www.linux-ntfs.org/content/view/19/37/ 3172W: http://www.linux-ntfs.org/content/view/19/37/
3697S: Maintained 3173S: Maintained
@@ -3699,8 +3175,7 @@ F: Documentation/ldm.txt
3699F: fs/partitions/ldm.* 3175F: fs/partitions/ldm.*
3700 3176
3701LSILOGIC MPT FUSION DRIVERS (FC/SAS/SPI) 3177LSILOGIC MPT FUSION DRIVERS (FC/SAS/SPI)
3702P: Eric Moore 3178M: Eric Moore <Eric.Moore@lsi.com>
3703M: Eric.Moore@lsi.com
3704M: support@lsi.com 3179M: support@lsi.com
3705L: DL-MPTFusionLinux@lsi.com 3180L: DL-MPTFusionLinux@lsi.com
3706L: linux-scsi@vger.kernel.org 3181L: linux-scsi@vger.kernel.org
@@ -3709,25 +3184,21 @@ S: Supported
3709F: drivers/message/fusion/ 3184F: drivers/message/fusion/
3710 3185
3711LSILOGIC/SYMBIOS/NCR 53C8XX and 53C1010 PCI-SCSI drivers 3186LSILOGIC/SYMBIOS/NCR 53C8XX and 53C1010 PCI-SCSI drivers
3712P: Matthew Wilcox 3187M: Matthew Wilcox <matthew@wil.cx>
3713M: matthew@wil.cx
3714L: linux-scsi@vger.kernel.org 3188L: linux-scsi@vger.kernel.org
3715S: Maintained 3189S: Maintained
3716F: drivers/scsi/sym53c8xx_2/ 3190F: drivers/scsi/sym53c8xx_2/
3717 3191
3718LTP (Linux Test Project) 3192LTP (Linux Test Project)
3719P: Subrata Modak 3193M: Subrata Modak <subrata@linux.vnet.ibm.com>
3720M: subrata@linux.vnet.ibm.com 3194M: Mike Frysinger <vapier@gentoo.org>
3721P: Mike Frysinger
3722M: vapier@gentoo.org
3723L: ltp-list@lists.sourceforge.net (subscribers-only) 3195L: ltp-list@lists.sourceforge.net (subscribers-only)
3724W: http://ltp.sourceforge.net/ 3196W: http://ltp.sourceforge.net/
3725T: git git://git.kernel.org/pub/scm/linux/kernel/git/galak/ltp.git 3197T: git git://git.kernel.org/pub/scm/linux/kernel/git/galak/ltp.git
3726S: Maintained 3198S: Maintained
3727 3199
3728M32R ARCHITECTURE 3200M32R ARCHITECTURE
3729P: Hirokazu Takata 3201M: Hirokazu Takata <takata@linux-m32r.org>
3730M: takata@linux-m32r.org
3731L: linux-m32r@ml.linux-m32r.org 3202L: linux-m32r@ml.linux-m32r.org
3732L: linux-m32r-ja@ml.linux-m32r.org (in Japanese) 3203L: linux-m32r-ja@ml.linux-m32r.org (in Japanese)
3733W: http://www.linux-m32r.org/ 3204W: http://www.linux-m32r.org/
@@ -3735,10 +3206,8 @@ S: Maintained
3735F: arch/m32r/ 3206F: arch/m32r/
3736 3207
3737M68K ARCHITECTURE 3208M68K ARCHITECTURE
3738P: Geert Uytterhoeven 3209M: Geert Uytterhoeven <geert@linux-m68k.org>
3739M: geert@linux-m68k.org 3210M: Roman Zippel <zippel@linux-m68k.org>
3740P: Roman Zippel
3741M: zippel@linux-m68k.org
3742L: linux-m68k@lists.linux-m68k.org 3211L: linux-m68k@lists.linux-m68k.org
3743W: http://www.linux-m68k.org/ 3212W: http://www.linux-m68k.org/
3744T: git git://git.kernel.org/pub/scm/linux/kernel/git/geert/linux-m68k.git 3213T: git git://git.kernel.org/pub/scm/linux/kernel/git/geert/linux-m68k.git
@@ -3747,23 +3216,20 @@ F: arch/m68k/
3747F: drivers/zorro/ 3216F: drivers/zorro/
3748 3217
3749M68K ON APPLE MACINTOSH 3218M68K ON APPLE MACINTOSH
3750P: Joshua Thompson 3219M: Joshua Thompson <funaho@jurai.org>
3751M: funaho@jurai.org
3752W: http://www.mac.linux-m68k.org/ 3220W: http://www.mac.linux-m68k.org/
3753L: linux-m68k@lists.linux-m68k.org 3221L: linux-m68k@lists.linux-m68k.org
3754S: Maintained 3222S: Maintained
3755F: arch/m68k/mac/ 3223F: arch/m68k/mac/
3756 3224
3757M68K ON HP9000/300 3225M68K ON HP9000/300
3758P: Philip Blundell 3226M: Philip Blundell <philb@gnu.org>
3759M: philb@gnu.org
3760W: http://www.tazenda.demon.co.uk/phil/linux-hp 3227W: http://www.tazenda.demon.co.uk/phil/linux-hp
3761S: Maintained 3228S: Maintained
3762F: arch/m68k/hp300/ 3229F: arch/m68k/hp300/
3763 3230
3764MAC80211 3231MAC80211
3765P: Johannes Berg 3232M: Johannes Berg <johannes@sipsolutions.net>
3766M: johannes@sipsolutions.net
3767L: linux-wireless@vger.kernel.org 3233L: linux-wireless@vger.kernel.org
3768W: http://linuxwireless.org/ 3234W: http://linuxwireless.org/
3769T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6.git 3235T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6.git
@@ -3773,10 +3239,8 @@ F: include/net/mac80211.h
3773F: net/mac80211/ 3239F: net/mac80211/
3774 3240
3775MAC80211 PID RATE CONTROL 3241MAC80211 PID RATE CONTROL
3776P: Stefano Brivio 3242M: Stefano Brivio <stefano.brivio@polimi.it>
3777M: stefano.brivio@polimi.it 3243M: Mattias Nissler <mattias.nissler@gmx.de>
3778P: Mattias Nissler
3779M: mattias.nissler@gmx.de
3780L: linux-wireless@vger.kernel.org 3244L: linux-wireless@vger.kernel.org
3781W: http://linuxwireless.org/en/developers/Documentation/mac80211/RateControl/PID 3245W: http://linuxwireless.org/en/developers/Documentation/mac80211/RateControl/PID
3782T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6.git 3246T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6.git
@@ -3784,67 +3248,57 @@ S: Maintained
3784F: net/mac80211/rc80211_pid* 3248F: net/mac80211/rc80211_pid*
3785 3249
3786MACVLAN DRIVER 3250MACVLAN DRIVER
3787P: Patrick McHardy 3251M: Patrick McHardy <kaber@trash.net>
3788M: kaber@trash.net
3789L: netdev@vger.kernel.org 3252L: netdev@vger.kernel.org
3790S: Maintained 3253S: Maintained
3791F: drivers/net/macvlan.c 3254F: drivers/net/macvlan.c
3792F: include/linux/if_macvlan.h 3255F: include/linux/if_macvlan.h
3793 3256
3794MAN-PAGES: MANUAL PAGES FOR LINUX -- Sections 2, 3, 4, 5, and 7 3257MAN-PAGES: MANUAL PAGES FOR LINUX -- Sections 2, 3, 4, 5, and 7
3795P: Michael Kerrisk 3258M: Michael Kerrisk <mtk.manpages@gmail.com>
3796M: mtk.manpages@gmail.com
3797W: http://www.kernel.org/doc/man-pages 3259W: http://www.kernel.org/doc/man-pages
3798L: linux-man@vger.kernel.org 3260L: linux-man@vger.kernel.org
3799S: Maintained 3261S: Maintained
3800 3262
3801MARVELL LIBERTAS WIRELESS DRIVER 3263MARVELL LIBERTAS WIRELESS DRIVER
3802P: Dan Williams 3264M: Dan Williams <dcbw@redhat.com>
3803M: dcbw@redhat.com
3804L: libertas-dev@lists.infradead.org 3265L: libertas-dev@lists.infradead.org
3805S: Maintained 3266S: Maintained
3806F: drivers/net/wireless/libertas/ 3267F: drivers/net/wireless/libertas/
3807 3268
3808MARVELL MV643XX ETHERNET DRIVER 3269MARVELL MV643XX ETHERNET DRIVER
3809P: Lennert Buytenhek 3270M: Lennert Buytenhek <buytenh@marvell.com>
3810M: buytenh@marvell.com
3811L: netdev@vger.kernel.org 3271L: netdev@vger.kernel.org
3812S: Supported 3272S: Supported
3813F: drivers/net/mv643xx_eth.* 3273F: drivers/net/mv643xx_eth.*
3814F: include/linux/mv643xx.h 3274F: include/linux/mv643xx.h
3815 3275
3816MARVELL SOC MMC/SD/SDIO CONTROLLER DRIVER 3276MARVELL SOC MMC/SD/SDIO CONTROLLER DRIVER
3817P: Nicolas Pitre 3277M: Nicolas Pitre <nico@cam.org>
3818M: nico@cam.org
3819S: Maintained 3278S: Maintained
3820 3279
3821MARVELL YUKON / SYSKONNECT DRIVER 3280MARVELL YUKON / SYSKONNECT DRIVER
3822P: Mirko Lindner 3281M: Mirko Lindner <mlindner@syskonnect.de>
3823M: mlindner@syskonnect.de 3282M: Ralph Roesler <rroesler@syskonnect.de>
3824P: Ralph Roesler
3825M: rroesler@syskonnect.de
3826W: http://www.syskonnect.com 3283W: http://www.syskonnect.com
3827S: Supported 3284S: Supported
3828 3285
3829MATROX FRAMEBUFFER DRIVER 3286MATROX FRAMEBUFFER DRIVER
3830P: Petr Vandrovec 3287M: Petr Vandrovec <vandrove@vc.cvut.cz>
3831M: vandrove@vc.cvut.cz
3832L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) 3288L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers)
3833S: Maintained 3289S: Maintained
3834F: drivers/video/matrox/matroxfb_* 3290F: drivers/video/matrox/matroxfb_*
3835F: include/linux/matroxfb.h 3291F: include/linux/matroxfb.h
3836 3292
3837MAX6650 HARDWARE MONITOR AND FAN CONTROLLER DRIVER 3293MAX6650 HARDWARE MONITOR AND FAN CONTROLLER DRIVER
3838P: Hans J. Koch 3294M: "Hans J. Koch" <hjk@linutronix.de>
3839M: hjk@linutronix.de
3840L: lm-sensors@lm-sensors.org 3295L: lm-sensors@lm-sensors.org
3841S: Maintained 3296S: Maintained
3842F: Documentation/hwmon/max6650 3297F: Documentation/hwmon/max6650
3843F: drivers/hwmon/max6650.c 3298F: drivers/hwmon/max6650.c
3844 3299
3845MEDIA INPUT INFRASTRUCTURE (V4L/DVB) 3300MEDIA INPUT INFRASTRUCTURE (V4L/DVB)
3846P: Mauro Carvalho Chehab 3301M: Mauro Carvalho Chehab <mchehab@infradead.org>
3847M: mchehab@infradead.org
3848P: LinuxTV.org Project 3302P: LinuxTV.org Project
3849L: linux-media@vger.kernel.org 3303L: linux-media@vger.kernel.org
3850W: http://linuxtv.org 3304W: http://linuxtv.org
@@ -3858,8 +3312,7 @@ F: include/linux/dvb/
3858F: include/linux/videodev*.h 3312F: include/linux/videodev*.h
3859 3313
3860MEGARAID SCSI DRIVERS 3314MEGARAID SCSI DRIVERS
3861P: Neela Syam Kolli 3315M: Neela Syam Kolli <megaraidlinux@lsi.com>
3862M: megaraidlinux@lsi.com
3863L: linux-scsi@vger.kernel.org 3316L: linux-scsi@vger.kernel.org
3864W: http://megaraid.lsilogic.com 3317W: http://megaraid.lsilogic.com
3865S: Maintained 3318S: Maintained
@@ -3875,19 +3328,15 @@ F: include/linux/mm.h
3875F: mm/ 3328F: mm/
3876 3329
3877MEMORY RESOURCE CONTROLLER 3330MEMORY RESOURCE CONTROLLER
3878P: Balbir Singh 3331M: Balbir Singh <balbir@linux.vnet.ibm.com>
3879M: balbir@linux.vnet.ibm.com 3332M: Pavel Emelyanov <xemul@openvz.org>
3880P: Pavel Emelyanov 3333M: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
3881M: xemul@openvz.org
3882P: KAMEZAWA Hiroyuki
3883M: kamezawa.hiroyu@jp.fujitsu.com
3884L: linux-mm@kvack.org 3334L: linux-mm@kvack.org
3885S: Maintained 3335S: Maintained
3886F: mm/memcontrol.c 3336F: mm/memcontrol.c
3887 3337
3888MEMORY TECHNOLOGY DEVICES (MTD) 3338MEMORY TECHNOLOGY DEVICES (MTD)
3889P: David Woodhouse 3339M: David Woodhouse <dwmw2@infradead.org>
3890M: dwmw2@infradead.org
3891W: http://www.linux-mtd.infradead.org/ 3340W: http://www.linux-mtd.infradead.org/
3892L: linux-mtd@lists.infradead.org 3341L: linux-mtd@lists.infradead.org
3893T: git git://git.infradead.org/mtd-2.6.git 3342T: git git://git.infradead.org/mtd-2.6.git
@@ -3897,8 +3346,7 @@ F: include/linux/mtd/
3897F: include/mtd/ 3346F: include/mtd/
3898 3347
3899MICROBLAZE ARCHITECTURE 3348MICROBLAZE ARCHITECTURE
3900P: Michal Simek 3349M: Michal Simek <monstr@monstr.eu>
3901M: monstr@monstr.eu
3902L: microblaze-uclinux@itee.uq.edu.au 3350L: microblaze-uclinux@itee.uq.edu.au
3903W: http://www.monstr.eu/fdt/ 3351W: http://www.monstr.eu/fdt/
3904T: git git://git.monstr.eu/linux-2.6-microblaze.git 3352T: git git://git.monstr.eu/linux-2.6-microblaze.git
@@ -3906,14 +3354,12 @@ S: Supported
3906F: arch/microblaze/ 3354F: arch/microblaze/
3907 3355
3908MICROTEK X6 SCANNER 3356MICROTEK X6 SCANNER
3909P: Oliver Neukum 3357M: Oliver Neukum <oliver@neukum.name>
3910M: oliver@neukum.name
3911S: Maintained 3358S: Maintained
3912F: drivers/usb/image/microtek.* 3359F: drivers/usb/image/microtek.*
3913 3360
3914MIPS 3361MIPS
3915P: Ralf Baechle 3362M: Ralf Baechle <ralf@linux-mips.org>
3916M: ralf@linux-mips.org
3917W: http://www.linux-mips.org/ 3363W: http://www.linux-mips.org/
3918L: linux-mips@linux-mips.org 3364L: linux-mips@linux-mips.org
3919T: git git://git.linux-mips.org/pub/scm/linux.git 3365T: git git://git.linux-mips.org/pub/scm/linux.git
@@ -3922,8 +3368,7 @@ F: Documentation/mips/
3922F: arch/mips/ 3368F: arch/mips/
3923 3369
3924MISCELLANEOUS MCA-SUPPORT 3370MISCELLANEOUS MCA-SUPPORT
3925P: James Bottomley 3371M: James Bottomley <James.Bottomley@HansenPartnership.com>
3926M: James.Bottomley@HansenPartnership.com
3927S: Maintained 3372S: Maintained
3928F: Documentation/ia64/mca.txt 3373F: Documentation/ia64/mca.txt
3929F: Documentation/mca.txt 3374F: Documentation/mca.txt
@@ -3931,15 +3376,13 @@ F: drivers/mca/
3931F: include/linux/mca* 3376F: include/linux/mca*
3932 3377
3933MODULE SUPPORT 3378MODULE SUPPORT
3934P: Rusty Russell 3379M: Rusty Russell <rusty@rustcorp.com.au>
3935M: rusty@rustcorp.com.au
3936S: Maintained 3380S: Maintained
3937F: include/linux/module.h 3381F: include/linux/module.h
3938F: kernel/module.c 3382F: kernel/module.c
3939 3383
3940MOTION EYE VAIO PICTUREBOOK CAMERA DRIVER 3384MOTION EYE VAIO PICTUREBOOK CAMERA DRIVER
3941P: Stelian Pop 3385M: Stelian Pop <stelian@popies.net>
3942M: stelian@popies.net
3943W: http://popies.net/meye/ 3386W: http://popies.net/meye/
3944S: Maintained 3387S: Maintained
3945F: Documentation/video4linux/meye.txt 3388F: Documentation/video4linux/meye.txt
@@ -3947,135 +3390,112 @@ F: drivers/media/video/meye.*
3947F: include/linux/meye.h 3390F: include/linux/meye.h
3948 3391
3949MOTOROLA IMX MMC/SD HOST CONTROLLER INTERFACE DRIVER 3392MOTOROLA IMX MMC/SD HOST CONTROLLER INTERFACE DRIVER
3950P: Pavel Pisa 3393M: Pavel Pisa <ppisa@pikron.com>
3951M: ppisa@pikron.com
3952L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 3394L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
3953S: Maintained 3395S: Maintained
3954F: drivers/mmc/host/imxmmc.* 3396F: drivers/mmc/host/imxmmc.*
3955 3397
3956MOUSE AND MISC DEVICES [GENERAL] 3398MOUSE AND MISC DEVICES [GENERAL]
3957P: Alessandro Rubini 3399M: Alessandro Rubini <rubini@ipvvis.unipv.it>
3958M: rubini@ipvvis.unipv.it
3959S: Maintained 3400S: Maintained
3960F: drivers/input/mouse/ 3401F: drivers/input/mouse/
3961F: include/linux/gpio_mouse.h 3402F: include/linux/gpio_mouse.h
3962 3403
3963MOXA SMARTIO/INDUSTIO/INTELLIO SERIAL CARD 3404MOXA SMARTIO/INDUSTIO/INTELLIO SERIAL CARD
3964P: Jiri Slaby 3405M: Jiri Slaby <jirislaby@gmail.com>
3965M: jirislaby@gmail.com
3966S: Maintained 3406S: Maintained
3967F: Documentation/serial/moxa-smartio 3407F: Documentation/serial/moxa-smartio
3968F: drivers/char/mxser.* 3408F: drivers/char/mxser.*
3969 3409
3970MSI LAPTOP SUPPORT 3410MSI LAPTOP SUPPORT
3971P: Lennart Poettering 3411M: Lennart Poettering <mzxreary@0pointer.de>
3972M: mzxreary@0pointer.de
3973W: https://tango.0pointer.de/mailman/listinfo/s270-linux 3412W: https://tango.0pointer.de/mailman/listinfo/s270-linux
3974W: http://0pointer.de/lennart/tchibo.html 3413W: http://0pointer.de/lennart/tchibo.html
3975S: Maintained 3414S: Maintained
3976F: drivers/platform/x86/msi-laptop.c 3415F: drivers/platform/x86/msi-laptop.c
3977 3416
3978MULTIFUNCTION DEVICES (MFD) 3417MULTIFUNCTION DEVICES (MFD)
3979P: Samuel Ortiz 3418M: Samuel Ortiz <sameo@linux.intel.com>
3980M: sameo@linux.intel.com
3981T: git git://git.kernel.org/pub/scm/linux/kernel/git/sameo/mfd-2.6.git 3419T: git git://git.kernel.org/pub/scm/linux/kernel/git/sameo/mfd-2.6.git
3982S: Supported 3420S: Supported
3983F: drivers/mfd/ 3421F: drivers/mfd/
3984 3422
3985MULTIMEDIA CARD (MMC), SECURE DIGITAL (SD) AND SDIO SUBSYSTEM 3423MULTIMEDIA CARD (MMC), SECURE DIGITAL (SD) AND SDIO SUBSYSTEM
3986P: Pierre Ossman 3424M: Pierre Ossman <pierre@ossman.eu>
3987M: pierre@ossman.eu
3988S: Maintained 3425S: Maintained
3989F: drivers/mmc/ 3426F: drivers/mmc/
3990F: include/linux/mmc/ 3427F: include/linux/mmc/
3991 3428
3992MULTIMEDIA CARD (MMC) ETC. OVER SPI 3429MULTIMEDIA CARD (MMC) ETC. OVER SPI
3993P: David Brownell 3430M: David Brownell <dbrownell@users.sourceforge.net>
3994M: dbrownell@users.sourceforge.net
3995S: Odd Fixes 3431S: Odd Fixes
3996F: drivers/mmc/host/mmc_spi.c 3432F: drivers/mmc/host/mmc_spi.c
3997F: include/linux/spi/mmc_spi.h 3433F: include/linux/spi/mmc_spi.h
3998 3434
3999MULTISOUND SOUND DRIVER 3435MULTISOUND SOUND DRIVER
4000P: Andrew Veliath 3436M: Andrew Veliath <andrewtv@usa.net>
4001M: andrewtv@usa.net
4002S: Maintained 3437S: Maintained
4003F: Documentation/sound/oss/MultiSound 3438F: Documentation/sound/oss/MultiSound
4004F: sound/oss/msnd* 3439F: sound/oss/msnd*
4005 3440
4006MULTITECH MULTIPORT CARD (ISICOM) 3441MULTITECH MULTIPORT CARD (ISICOM)
4007P: Jiri Slaby 3442M: Jiri Slaby <jirislaby@gmail.com>
4008M: jirislaby@gmail.com
4009S: Maintained 3443S: Maintained
4010F: drivers/char/isicom.c 3444F: drivers/char/isicom.c
4011F: include/linux/isicom.h 3445F: include/linux/isicom.h
4012 3446
4013MUSB MULTIPOINT HIGH SPEED DUAL-ROLE CONTROLLER 3447MUSB MULTIPOINT HIGH SPEED DUAL-ROLE CONTROLLER
4014P: Felipe Balbi 3448M: Felipe Balbi <felipe.balbi@nokia.com>
4015M: felipe.balbi@nokia.com
4016L: linux-usb@vger.kernel.org 3449L: linux-usb@vger.kernel.org
4017T: git git://gitorious.org/musb/mainline.git 3450T: git git://gitorious.org/musb/mainline.git
4018S: Maintained 3451S: Maintained
4019F: drivers/usb/musb/ 3452F: drivers/usb/musb/
4020 3453
4021MYRICOM MYRI-10G 10GbE DRIVER (MYRI10GE) 3454MYRICOM MYRI-10G 10GbE DRIVER (MYRI10GE)
4022P: Andrew Gallatin 3455M: Andrew Gallatin <gallatin@myri.com>
4023M: gallatin@myri.com 3456M: Brice Goglin <brice@myri.com>
4024P: Brice Goglin
4025M: brice@myri.com
4026L: netdev@vger.kernel.org 3457L: netdev@vger.kernel.org
4027W: http://www.myri.com/scs/download-Myri10GE.html 3458W: http://www.myri.com/scs/download-Myri10GE.html
4028S: Supported 3459S: Supported
4029F: drivers/net/myri10ge/ 3460F: drivers/net/myri10ge/
4030 3461
4031NATSEMI ETHERNET DRIVER (DP8381x) 3462NATSEMI ETHERNET DRIVER (DP8381x)
4032P: Tim Hockin 3463M: Tim Hockin <thockin@hockin.org>
4033M: thockin@hockin.org
4034S: Maintained 3464S: Maintained
4035F: drivers/net/natsemi.c 3465F: drivers/net/natsemi.c
4036 3466
4037NCP FILESYSTEM 3467NCP FILESYSTEM
4038P: Petr Vandrovec 3468M: Petr Vandrovec <vandrove@vc.cvut.cz>
4039M: vandrove@vc.cvut.cz
4040L: linware@sh.cvut.cz 3469L: linware@sh.cvut.cz
4041S: Maintained 3470S: Maintained
4042F: fs/ncpfs/ 3471F: fs/ncpfs/
4043 3472
4044NCR DUAL 700 SCSI DRIVER (MICROCHANNEL) 3473NCR DUAL 700 SCSI DRIVER (MICROCHANNEL)
4045P: James E.J. Bottomley 3474M: "James E.J. Bottomley" <James.Bottomley@HansenPartnership.com>
4046M: James.Bottomley@HansenPartnership.com
4047L: linux-scsi@vger.kernel.org 3475L: linux-scsi@vger.kernel.org
4048S: Maintained 3476S: Maintained
4049F: drivers/scsi/NCR_D700.* 3477F: drivers/scsi/NCR_D700.*
4050 3478
4051NETEFFECT IWARP RNIC DRIVER (IW_NES) 3479NETEFFECT IWARP RNIC DRIVER (IW_NES)
4052P: Faisal Latif 3480M: Faisal Latif <faisal.latif@intel.com>
4053M: faisal.latif@intel.com 3481M: Chien Tung <chien.tin.tung@intel.com>
4054P: Chien Tung
4055M: chien.tin.tung@intel.com
4056L: general@lists.openfabrics.org 3482L: general@lists.openfabrics.org
4057W: http://www.neteffect.com 3483W: http://www.neteffect.com
4058S: Supported 3484S: Supported
4059F: drivers/infiniband/hw/nes/ 3485F: drivers/infiniband/hw/nes/
4060 3486
4061NETEM NETWORK EMULATOR 3487NETEM NETWORK EMULATOR
4062P: Stephen Hemminger 3488M: Stephen Hemminger <shemminger@linux-foundation.org>
4063M: shemminger@linux-foundation.org
4064L: netem@lists.linux-foundation.org 3489L: netem@lists.linux-foundation.org
4065S: Maintained 3490S: Maintained
4066F: net/sched/sch_netem.c 3491F: net/sched/sch_netem.c
4067 3492
4068NETERION (S2IO) 10GbE DRIVER (xframe/vxge) 3493NETERION (S2IO) 10GbE DRIVER (xframe/vxge)
4069P: Ramkrishna Vepa 3494M: Ramkrishna Vepa <ram.vepa@neterion.com>
4070M: ram.vepa@neterion.com 3495M: Rastapur Santosh <santosh.rastapur@neterion.com>
4071P: Rastapur Santosh 3496M: Sivakumar Subramani <sivakumar.subramani@neterion.com>
4072M: santosh.rastapur@neterion.com 3497M: Sreenivasa Honnur <sreenivasa.honnur@neterion.com>
4073P: Sivakumar Subramani 3498M: Anil Murthy <anil.murthy@neterion.com>
4074M: sivakumar.subramani@neterion.com
4075P: Sreenivasa Honnur
4076M: sreenivasa.honnur@neterion.com
4077P: Anil Murthy
4078M: anil.murthy@neterion.com
4079L: netdev@vger.kernel.org 3499L: netdev@vger.kernel.org
4080W: http://trac.neterion.com/cgi-bin/trac.cgi/wiki/Linux?Anonymous 3500W: http://trac.neterion.com/cgi-bin/trac.cgi/wiki/Linux?Anonymous
4081W: http://trac.neterion.com/cgi-bin/trac.cgi/wiki/X3100Linux?Anonymous 3501W: http://trac.neterion.com/cgi-bin/trac.cgi/wiki/X3100Linux?Anonymous
@@ -4089,8 +3509,7 @@ P: Marc Boucher
4089P: James Morris 3509P: James Morris
4090P: Harald Welte 3510P: Harald Welte
4091P: Jozsef Kadlecsik 3511P: Jozsef Kadlecsik
4092P: Patrick McHardy 3512M: Patrick McHardy <kaber@trash.net>
4093M: kaber@trash.net
4094L: netfilter-devel@vger.kernel.org 3513L: netfilter-devel@vger.kernel.org
4095L: netfilter@vger.kernel.org 3514L: netfilter@vger.kernel.org
4096L: coreteam@netfilter.org 3515L: coreteam@netfilter.org
@@ -4106,8 +3525,7 @@ F: net/*/netfilter/
4106F: net/netfilter/ 3525F: net/netfilter/
4107 3526
4108NETLABEL 3527NETLABEL
4109P: Paul Moore 3528M: Paul Moore <paul.moore@hp.com>
4110M: paul.moore@hp.com
4111W: http://netlabel.sf.net 3529W: http://netlabel.sf.net
4112L: netdev@vger.kernel.org 3530L: netdev@vger.kernel.org
4113S: Supported 3531S: Supported
@@ -4116,8 +3534,7 @@ F: include/net/netlabel.h
4116F: net/netlabel/ 3534F: net/netlabel/
4117 3535
4118NETROM NETWORK LAYER 3536NETROM NETWORK LAYER
4119P: Ralf Baechle 3537M: Ralf Baechle <ralf@linux-mips.org>
4120M: ralf@linux-mips.org
4121L: linux-hams@vger.kernel.org 3538L: linux-hams@vger.kernel.org
4122W: http://www.linux-ax25.org/ 3539W: http://www.linux-ax25.org/
4123S: Maintained 3540S: Maintained
@@ -4126,16 +3543,14 @@ F: include/net/netrom.h
4126F: net/netrom/ 3543F: net/netrom/
4127 3544
4128NETWORK BLOCK DEVICE (NBD) 3545NETWORK BLOCK DEVICE (NBD)
4129P: Paul Clements 3546M: Paul Clements <Paul.Clements@steeleye.com>
4130M: Paul.Clements@steeleye.com
4131S: Maintained 3547S: Maintained
4132F: Documentation/blockdev/nbd.txt 3548F: Documentation/blockdev/nbd.txt
4133F: drivers/block/nbd.c 3549F: drivers/block/nbd.c
4134F: include/linux/nbd.h 3550F: include/linux/nbd.h
4135 3551
4136NETWORKING [GENERAL] 3552NETWORKING [GENERAL]
4137P: David S. Miller 3553M: "David S. Miller" <davem@davemloft.net>
4138M: davem@davemloft.net
4139L: netdev@vger.kernel.org 3554L: netdev@vger.kernel.org
4140W: http://www.linuxfoundation.org/en/Net 3555W: http://www.linuxfoundation.org/en/Net
4141T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6.git 3556T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6.git
@@ -4144,18 +3559,12 @@ F: net/
4144F: include/net/ 3559F: include/net/
4145 3560
4146NETWORKING [IPv4/IPv6] 3561NETWORKING [IPv4/IPv6]
4147P: David S. Miller 3562M: "David S. Miller" <davem@davemloft.net>
4148M: davem@davemloft.net 3563M: Alexey Kuznetsov <kuznet@ms2.inr.ac.ru>
4149P: Alexey Kuznetsov 3564M: "Pekka Savola (ipv6)" <pekkas@netcore.fi>
4150M: kuznet@ms2.inr.ac.ru 3565M: James Morris <jmorris@namei.org>
4151P: Pekka Savola (ipv6) 3566M: Hideaki YOSHIFUJI <yoshfuji@linux-ipv6.org>
4152M: pekkas@netcore.fi 3567M: Patrick McHardy <kaber@trash.net>
4153P: James Morris
4154M: jmorris@namei.org
4155P: Hideaki YOSHIFUJI
4156M: yoshfuji@linux-ipv6.org
4157P: Patrick McHardy
4158M: kaber@trash.net
4159L: netdev@vger.kernel.org 3568L: netdev@vger.kernel.org
4160T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6.git 3569T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6.git
4161S: Maintained 3570S: Maintained
@@ -4164,14 +3573,12 @@ F: net/ipv6/
4164F: include/net/ip* 3573F: include/net/ip*
4165 3574
4166NETWORKING [LABELED] (NetLabel, CIPSO, Labeled IPsec, SECMARK) 3575NETWORKING [LABELED] (NetLabel, CIPSO, Labeled IPsec, SECMARK)
4167P: Paul Moore 3576M: Paul Moore <paul.moore@hp.com>
4168M: paul.moore@hp.com
4169L: netdev@vger.kernel.org 3577L: netdev@vger.kernel.org
4170S: Maintained 3578S: Maintained
4171 3579
4172NETWORKING [WIRELESS] 3580NETWORKING [WIRELESS]
4173P: John W. Linville 3581M: "John W. Linville" <linville@tuxdriver.com>
4174M: linville@tuxdriver.com
4175L: linux-wireless@vger.kernel.org 3582L: linux-wireless@vger.kernel.org
4176T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6.git 3583T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-2.6.git
4177S: Maintained 3584S: Maintained
@@ -4187,16 +3594,14 @@ S: Odd Fixes
4187F: drivers/net/ 3594F: drivers/net/
4188 3595
4189NETXEN (1/10) GbE SUPPORT 3596NETXEN (1/10) GbE SUPPORT
4190P: Dhananjay Phadke 3597M: Dhananjay Phadke <dhananjay@netxen.com>
4191M: dhananjay@netxen.com
4192L: netdev@vger.kernel.org 3598L: netdev@vger.kernel.org
4193W: http://www.netxen.com 3599W: http://www.netxen.com
4194S: Supported 3600S: Supported
4195F: drivers/net/netxen/ 3601F: drivers/net/netxen/
4196 3602
4197NFS, SUNRPC, AND LOCKD CLIENTS 3603NFS, SUNRPC, AND LOCKD CLIENTS
4198P: Trond Myklebust 3604M: Trond Myklebust <Trond.Myklebust@netapp.com>
4199M: Trond.Myklebust@netapp.com
4200L: linux-nfs@vger.kernel.org 3605L: linux-nfs@vger.kernel.org
4201W: http://client.linux-nfs.org 3606W: http://client.linux-nfs.org
4202T: git git://git.linux-nfs.org/pub/linux/nfs-2.6.git 3607T: git git://git.linux-nfs.org/pub/linux/nfs-2.6.git
@@ -4210,17 +3615,14 @@ F: include/linux/nfs*
4210F: include/linux/sunrpc/ 3615F: include/linux/sunrpc/
4211 3616
4212NI5010 NETWORK DRIVER 3617NI5010 NETWORK DRIVER
4213P: Jan-Pascal van Best 3618M: Jan-Pascal van Best <janpascal@vanbest.org>
4214M: janpascal@vanbest.org 3619M: Andreas Mohr <andi@lisas.de>
4215P: Andreas Mohr
4216M: andi@lisas.de
4217L: netdev@vger.kernel.org 3620L: netdev@vger.kernel.org
4218S: Maintained 3621S: Maintained
4219F: drivers/net/ni5010.* 3622F: drivers/net/ni5010.*
4220 3623
4221NILFS2 FILESYSTEM 3624NILFS2 FILESYSTEM
4222P: KONISHI Ryusuke 3625M: KONISHI Ryusuke <konishi.ryusuke@lab.ntt.co.jp>
4223M: konishi.ryusuke@lab.ntt.co.jp
4224L: users@nilfs.org 3626L: users@nilfs.org
4225W: http://www.nilfs.org/en/ 3627W: http://www.nilfs.org/en/
4226S: Supported 3628S: Supported
@@ -4229,26 +3631,22 @@ F: fs/nilfs2/
4229F: include/linux/nilfs2_fs.h 3631F: include/linux/nilfs2_fs.h
4230 3632
4231NINJA SCSI-3 / NINJA SCSI-32Bi (16bit/CardBus) PCMCIA SCSI HOST ADAPTER DRIVER 3633NINJA SCSI-3 / NINJA SCSI-32Bi (16bit/CardBus) PCMCIA SCSI HOST ADAPTER DRIVER
4232P: YOKOTA Hiroshi 3634M: YOKOTA Hiroshi <yokota@netlab.is.tsukuba.ac.jp>
4233M: yokota@netlab.is.tsukuba.ac.jp
4234W: http://www.netlab.is.tsukuba.ac.jp/~yokota/izumi/ninja/ 3635W: http://www.netlab.is.tsukuba.ac.jp/~yokota/izumi/ninja/
4235S: Maintained 3636S: Maintained
4236F: Documentation/scsi/NinjaSCSI.txt 3637F: Documentation/scsi/NinjaSCSI.txt
4237F: drivers/scsi/pcmcia/nsp_* 3638F: drivers/scsi/pcmcia/nsp_*
4238 3639
4239NINJA SCSI-32Bi/UDE PCI/CARDBUS SCSI HOST ADAPTER DRIVER 3640NINJA SCSI-32Bi/UDE PCI/CARDBUS SCSI HOST ADAPTER DRIVER
4240P: GOTO Masanori 3641M: GOTO Masanori <gotom@debian.or.jp>
4241M: gotom@debian.or.jp 3642M: YOKOTA Hiroshi <yokota@netlab.is.tsukuba.ac.jp>
4242P: YOKOTA Hiroshi
4243M: yokota@netlab.is.tsukuba.ac.jp
4244W: http://www.netlab.is.tsukuba.ac.jp/~yokota/izumi/ninja/ 3643W: http://www.netlab.is.tsukuba.ac.jp/~yokota/izumi/ninja/
4245S: Maintained 3644S: Maintained
4246F: Documentation/scsi/NinjaSCSI.txt 3645F: Documentation/scsi/NinjaSCSI.txt
4247F: drivers/scsi/nsp32* 3646F: drivers/scsi/nsp32*
4248 3647
4249NTFS FILESYSTEM 3648NTFS FILESYSTEM
4250P: Anton Altaparmakov 3649M: Anton Altaparmakov <aia21@cantab.net>
4251M: aia21@cantab.net
4252L: linux-ntfs-dev@lists.sourceforge.net 3650L: linux-ntfs-dev@lists.sourceforge.net
4253W: http://www.linux-ntfs.org/ 3651W: http://www.linux-ntfs.org/
4254T: git git://git.kernel.org/pub/scm/linux/kernel/git/aia21/ntfs-2.6.git 3652T: git git://git.kernel.org/pub/scm/linux/kernel/git/aia21/ntfs-2.6.git
@@ -4257,16 +3655,14 @@ F: Documentation/filesystems/ntfs.txt
4257F: fs/ntfs/ 3655F: fs/ntfs/
4258 3656
4259NVIDIA (rivafb and nvidiafb) FRAMEBUFFER DRIVER 3657NVIDIA (rivafb and nvidiafb) FRAMEBUFFER DRIVER
4260P: Antonino Daplas 3658M: Antonino Daplas <adaplas@gmail.com>
4261M: adaplas@gmail.com
4262L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) 3659L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers)
4263S: Maintained 3660S: Maintained
4264F: drivers/video/riva/ 3661F: drivers/video/riva/
4265F: drivers/video/nvidia/ 3662F: drivers/video/nvidia/
4266 3663
4267OMAP SUPPORT 3664OMAP SUPPORT
4268P: Tony Lindgren <tony@atomide.com> 3665M: "Tony Lindgren <tony@atomide.com>" <tony@atomide.com>
4269M: tony@atomide.com
4270L: linux-omap@vger.kernel.org 3666L: linux-omap@vger.kernel.org
4271W: http://www.muru.com/linux/omap/ 3667W: http://www.muru.com/linux/omap/
4272W: http://linux.omap.com/ 3668W: http://linux.omap.com/
@@ -4275,98 +3671,83 @@ S: Maintained
4275F: arch/arm/*omap* 3671F: arch/arm/*omap*
4276 3672
4277OMAP CLOCK FRAMEWORK SUPPORT 3673OMAP CLOCK FRAMEWORK SUPPORT
4278P: Paul Walmsley 3674M: Paul Walmsley <paul@pwsan.com>
4279M: paul@pwsan.com
4280L: linux-omap@vger.kernel.org 3675L: linux-omap@vger.kernel.org
4281S: Maintained 3676S: Maintained
4282F: arch/arm/*omap*/*clock* 3677F: arch/arm/*omap*/*clock*
4283 3678
4284OMAP POWER MANAGEMENT SUPPORT 3679OMAP POWER MANAGEMENT SUPPORT
4285P: Kevin Hilman 3680M: Kevin Hilman <khilman@deeprootsystems.com>
4286M: khilman@deeprootsystems.com
4287L: linux-omap@vger.kernel.org 3681L: linux-omap@vger.kernel.org
4288S: Maintained 3682S: Maintained
4289F: arch/arm/*omap*/*pm* 3683F: arch/arm/*omap*/*pm*
4290 3684
4291OMAP AUDIO SUPPORT 3685OMAP AUDIO SUPPORT
4292P: Jarkko Nikula 3686M: Jarkko Nikula <jhnikula@gmail.com>
4293M: jhnikula@gmail.com
4294L: alsa-devel@alsa-project.org (subscribers-only) 3687L: alsa-devel@alsa-project.org (subscribers-only)
4295L: linux-omap@vger.kernel.org 3688L: linux-omap@vger.kernel.org
4296S: Maintained 3689S: Maintained
4297F: sound/soc/omap/ 3690F: sound/soc/omap/
4298 3691
4299OMAP FRAMEBUFFER SUPPORT 3692OMAP FRAMEBUFFER SUPPORT
4300P: Imre Deak 3693M: Imre Deak <imre.deak@nokia.com>
4301M: imre.deak@nokia.com
4302L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) 3694L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers)
4303L: linux-omap@vger.kernel.org 3695L: linux-omap@vger.kernel.org
4304S: Maintained 3696S: Maintained
4305F: drivers/video/omap/ 3697F: drivers/video/omap/
4306 3698
4307OMAP MMC SUPPORT 3699OMAP MMC SUPPORT
4308P: Jarkko Lavinen 3700M: Jarkko Lavinen <jarkko.lavinen@nokia.com>
4309M: jarkko.lavinen@nokia.com
4310L: linux-kernel@vger.kernel.org
4311L: linux-omap@vger.kernel.org 3701L: linux-omap@vger.kernel.org
4312S: Maintained 3702S: Maintained
4313F: drivers/mmc/host/*omap* 3703F: drivers/mmc/host/*omap*
4314 3704
4315OMAP RANDOM NUMBER GENERATOR SUPPORT 3705OMAP RANDOM NUMBER GENERATOR SUPPORT
4316P: Deepak Saxena 3706M: Deepak Saxena <dsaxena@plexity.net>
4317M: dsaxena@plexity.net
4318S: Maintained 3707S: Maintained
4319F: drivers/char/hw_random/omap-rng.c 3708F: drivers/char/hw_random/omap-rng.c
4320 3709
4321OMAP USB SUPPORT 3710OMAP USB SUPPORT
4322P: Felipe Balbi 3711M: Felipe Balbi <felipe.balbi@nokia.com>
4323M: felipe.balbi@nokia.com 3712M: David Brownell <dbrownell@users.sourceforge.net>
4324P: David Brownell
4325M: dbrownell@users.sourceforge.net
4326L: linux-usb@vger.kernel.org 3713L: linux-usb@vger.kernel.org
4327L: linux-omap@vger.kernel.org 3714L: linux-omap@vger.kernel.org
4328S: Maintained 3715S: Maintained
4329 3716
4330OMFS FILESYSTEM 3717OMFS FILESYSTEM
4331P: Bob Copeland 3718M: Bob Copeland <me@bobcopeland.com>
4332M: me@bobcopeland.com
4333L: linux-karma-devel@lists.sourceforge.net 3719L: linux-karma-devel@lists.sourceforge.net
4334S: Maintained 3720S: Maintained
4335F: Documentation/filesystems/omfs.txt 3721F: Documentation/filesystems/omfs.txt
4336F: fs/omfs/ 3722F: fs/omfs/
4337 3723
4338OMNIKEY CARDMAN 4000 DRIVER 3724OMNIKEY CARDMAN 4000 DRIVER
4339P: Harald Welte 3725M: Harald Welte <laforge@gnumonks.org>
4340M: laforge@gnumonks.org
4341S: Maintained 3726S: Maintained
4342F: drivers/char/pcmcia/cm4000_cs.c 3727F: drivers/char/pcmcia/cm4000_cs.c
4343F: include/linux/cm4000_cs.h 3728F: include/linux/cm4000_cs.h
4344 3729
4345OMNIKEY CARDMAN 4040 DRIVER 3730OMNIKEY CARDMAN 4040 DRIVER
4346P: Harald Welte 3731M: Harald Welte <laforge@gnumonks.org>
4347M: laforge@gnumonks.org
4348S: Maintained 3732S: Maintained
4349F: drivers/char/pcmcia/cm4040_cs.* 3733F: drivers/char/pcmcia/cm4040_cs.*
4350 3734
4351OMNIVISION OV7670 SENSOR DRIVER 3735OMNIVISION OV7670 SENSOR DRIVER
4352P: Jonathan Corbet 3736M: Jonathan Corbet <corbet@lwn.net>
4353M: corbet@lwn.net
4354L: linux-media@vger.kernel.org 3737L: linux-media@vger.kernel.org
4355T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 3738T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
4356S: Maintained 3739S: Maintained
4357F: drivers/media/video/ov7670.c 3740F: drivers/media/video/ov7670.c
4358 3741
4359ONENAND FLASH DRIVER 3742ONENAND FLASH DRIVER
4360P: Kyungmin Park 3743M: Kyungmin Park <kyungmin.park@samsung.com>
4361M: kyungmin.park@samsung.com
4362L: linux-mtd@lists.infradead.org 3744L: linux-mtd@lists.infradead.org
4363S: Maintained 3745S: Maintained
4364F: drivers/mtd/onenand/ 3746F: drivers/mtd/onenand/
4365F: include/linux/mtd/onenand*.h 3747F: include/linux/mtd/onenand*.h
4366 3748
4367ONSTREAM SCSI TAPE DRIVER 3749ONSTREAM SCSI TAPE DRIVER
4368P: Willem Riede 3750M: Willem Riede <osst@riede.org>
4369M: osst@riede.org
4370L: osst-users@lists.sourceforge.net 3751L: osst-users@lists.sourceforge.net
4371L: linux-scsi@vger.kernel.org 3752L: linux-scsi@vger.kernel.org
4372S: Maintained 3753S: Maintained
@@ -4374,16 +3755,14 @@ F: drivers/scsi/osst*
4374F: drivers/scsi/st* 3755F: drivers/scsi/st*
4375 3756
4376OPENCORES I2C BUS DRIVER 3757OPENCORES I2C BUS DRIVER
4377P: Peter Korsgaard 3758M: Peter Korsgaard <jacmet@sunsite.dk>
4378M: jacmet@sunsite.dk
4379L: linux-i2c@vger.kernel.org 3759L: linux-i2c@vger.kernel.org
4380S: Maintained 3760S: Maintained
4381F: Documentation/i2c/busses/i2c-ocores 3761F: Documentation/i2c/busses/i2c-ocores
4382F: drivers/i2c/busses/i2c-ocores.c 3762F: drivers/i2c/busses/i2c-ocores.c
4383 3763
4384OPROFILE 3764OPROFILE
4385P: Robert Richter 3765M: Robert Richter <robert.richter@amd.com>
4386M: robert.richter@amd.com
4387L: oprofile-list@lists.sf.net 3766L: oprofile-list@lists.sf.net
4388S: Maintained 3767S: Maintained
4389F: arch/*/oprofile/ 3768F: arch/*/oprofile/
@@ -4391,10 +3770,8 @@ F: drivers/oprofile/
4391F: include/linux/oprofile.h 3770F: include/linux/oprofile.h
4392 3771
4393ORACLE CLUSTER FILESYSTEM 2 (OCFS2) 3772ORACLE CLUSTER FILESYSTEM 2 (OCFS2)
4394P: Mark Fasheh 3773M: Mark Fasheh <mfasheh@suse.com>
4395M: mfasheh@suse.com 3774M: Joel Becker <joel.becker@oracle.com>
4396P: Joel Becker
4397M: joel.becker@oracle.com
4398L: ocfs2-devel@oss.oracle.com (moderated for non-subscribers) 3775L: ocfs2-devel@oss.oracle.com (moderated for non-subscribers)
4399W: http://oss.oracle.com/projects/ocfs2/ 3776W: http://oss.oracle.com/projects/ocfs2/
4400T: git git://git.kernel.org/pub/scm/linux/kernel/git/jlbec/ocfs2.git 3777T: git git://git.kernel.org/pub/scm/linux/kernel/git/jlbec/ocfs2.git
@@ -4404,10 +3781,8 @@ F: Documentation/filesystems/dlmfs.txt
4404F: fs/ocfs2/ 3781F: fs/ocfs2/
4405 3782
4406ORINOCO DRIVER 3783ORINOCO DRIVER
4407P: Pavel Roskin 3784M: Pavel Roskin <proski@gnu.org>
4408M: proski@gnu.org 3785M: David Gibson <hermes@gibson.dropbear.id.au>
4409P: David Gibson
4410M: hermes@gibson.dropbear.id.au
4411L: linux-wireless@vger.kernel.org 3786L: linux-wireless@vger.kernel.org
4412L: orinoco-users@lists.sourceforge.net 3787L: orinoco-users@lists.sourceforge.net
4413L: orinoco-devel@lists.sourceforge.net 3788L: orinoco-devel@lists.sourceforge.net
@@ -4416,10 +3791,8 @@ S: Maintained
4416F: drivers/net/wireless/orinoco/ 3791F: drivers/net/wireless/orinoco/
4417 3792
4418OSD LIBRARY and FILESYSTEM 3793OSD LIBRARY and FILESYSTEM
4419P: Boaz Harrosh 3794M: Boaz Harrosh <bharrosh@panasas.com>
4420M: bharrosh@panasas.com 3795M: Benny Halevy <bhalevy@panasas.com>
4421P: Benny Halevy
4422M: bhalevy@panasas.com
4423L: osd-dev@open-osd.org 3796L: osd-dev@open-osd.org
4424W: http://open-osd.org 3797W: http://open-osd.org
4425T: git git://git.open-osd.org/open-osd.git 3798T: git git://git.open-osd.org/open-osd.git
@@ -4429,8 +3802,7 @@ F: drivers/include/scsi/osd_*
4429F: fs/exofs/ 3802F: fs/exofs/
4430 3803
4431P54 WIRELESS DRIVER 3804P54 WIRELESS DRIVER
4432P: Michael Wu 3805M: Michael Wu <flamingice@sourmilk.net>
4433M: flamingice@sourmilk.net
4434L: linux-wireless@vger.kernel.org 3806L: linux-wireless@vger.kernel.org
4435W: http://prism54.org 3807W: http://prism54.org
4436T: git git://git.kernel.org/pub/scm/linux/kernel/git/mwu/mac80211-drivers.git 3808T: git git://git.kernel.org/pub/scm/linux/kernel/git/mwu/mac80211-drivers.git
@@ -4438,30 +3810,25 @@ S: Maintained
4438F: drivers/net/wireless/p54/ 3810F: drivers/net/wireless/p54/
4439 3811
4440PA SEMI ETHERNET DRIVER 3812PA SEMI ETHERNET DRIVER
4441P: Olof Johansson 3813M: Olof Johansson <olof@lixom.net>
4442M: olof@lixom.net
4443L: netdev@vger.kernel.org 3814L: netdev@vger.kernel.org
4444S: Maintained 3815S: Maintained
4445F: drivers/net/pasemi_mac.* 3816F: drivers/net/pasemi_mac.*
4446 3817
4447PA SEMI SMBUS DRIVER 3818PA SEMI SMBUS DRIVER
4448P: Olof Johansson 3819M: Olof Johansson <olof@lixom.net>
4449M: olof@lixom.net
4450L: linux-i2c@vger.kernel.org 3820L: linux-i2c@vger.kernel.org
4451S: Maintained 3821S: Maintained
4452F: drivers/i2c/busses/i2c-pasemi.c 3822F: drivers/i2c/busses/i2c-pasemi.c
4453 3823
4454PANASONIC LAPTOP ACPI EXTRAS DRIVER 3824PANASONIC LAPTOP ACPI EXTRAS DRIVER
4455P: Harald Welte 3825M: Harald Welte <laforge@gnumonks.org>
4456M: laforge@gnumonks.org
4457S: Maintained 3826S: Maintained
4458F: drivers/platform/x86/panasonic-laptop.c 3827F: drivers/platform/x86/panasonic-laptop.c
4459 3828
4460PANASONIC MN10300/AM33 PORT 3829PANASONIC MN10300/AM33 PORT
4461P: David Howells 3830M: David Howells <dhowells@redhat.com>
4462M: dhowells@redhat.com 3831M: Koichi Yasutake <yasutake.koichi@jp.panasonic.com>
4463P: Koichi Yasutake
4464M: yasutake.koichi@jp.panasonic.com
4465L: linux-am33-list@redhat.com (moderated for non-subscribers) 3832L: linux-am33-list@redhat.com (moderated for non-subscribers)
4466W: ftp://ftp.redhat.com/pub/redhat/gnupro/AM33/ 3833W: ftp://ftp.redhat.com/pub/redhat/gnupro/AM33/
4467S: Maintained 3834S: Maintained
@@ -4477,14 +3844,10 @@ F: drivers/char/ppdev.c
4477F: include/linux/ppdev.h 3844F: include/linux/ppdev.h
4478 3845
4479PARAVIRT_OPS INTERFACE 3846PARAVIRT_OPS INTERFACE
4480P: Jeremy Fitzhardinge 3847M: Jeremy Fitzhardinge <jeremy@xensource.com>
4481M: jeremy@xensource.com 3848M: Chris Wright <chrisw@sous-sol.org>
4482P: Chris Wright 3849M: Alok Kataria <akataria@vmware.com>
4483M: chrisw@sous-sol.org 3850M: Rusty Russell <rusty@rustcorp.com.au>
4484P: Alok Kataria
4485M: akataria@vmware.com
4486P: Rusty Russell
4487M: rusty@rustcorp.com.au
4488L: virtualization@lists.osdl.org 3851L: virtualization@lists.osdl.org
4489S: Supported 3852S: Supported
4490F: Documentation/ia64/paravirt_ops.txt 3853F: Documentation/ia64/paravirt_ops.txt
@@ -4492,8 +3855,7 @@ F: arch/*/kernel/paravirt*
4492F: arch/*/include/asm/paravirt.h 3855F: arch/*/include/asm/paravirt.h
4493 3856
4494PARIDE DRIVERS FOR PARALLEL PORT IDE DEVICES 3857PARIDE DRIVERS FOR PARALLEL PORT IDE DEVICES
4495P: Tim Waugh 3858M: Tim Waugh <tim@cyberelk.net>
4496M: tim@cyberelk.net
4497L: linux-parport@lists.infradead.org (subscribers-only) 3859L: linux-parport@lists.infradead.org (subscribers-only)
4498W: http://www.torque.net/linux-pp.html 3860W: http://www.torque.net/linux-pp.html
4499S: Maintained 3861S: Maintained
@@ -4501,10 +3863,8 @@ F: Documentation/blockdev/paride.txt
4501F: drivers/block/paride/ 3863F: drivers/block/paride/
4502 3864
4503PARISC ARCHITECTURE 3865PARISC ARCHITECTURE
4504P: Kyle McMartin 3866M: Kyle McMartin <kyle@mcmartin.ca>
4505M: kyle@mcmartin.ca 3867M: Helge Deller <deller@gmx.de>
4506P: Helge Deller
4507M: deller@gmx.de
4508L: linux-parisc@vger.kernel.org 3868L: linux-parisc@vger.kernel.org
4509W: http://www.parisc-linux.org/ 3869W: http://www.parisc-linux.org/
4510T: git git://git.kernel.org/pub/scm/linux/kernel/git/kyle/parisc-2.6.git 3870T: git git://git.kernel.org/pub/scm/linux/kernel/git/kyle/parisc-2.6.git
@@ -4513,37 +3873,32 @@ F: arch/parisc/
4513F: drivers/parisc/ 3873F: drivers/parisc/
4514 3874
4515PC87360 HARDWARE MONITORING DRIVER 3875PC87360 HARDWARE MONITORING DRIVER
4516P: Jim Cromie 3876M: Jim Cromie <jim.cromie@gmail.com>
4517M: jim.cromie@gmail.com
4518L: lm-sensors@lm-sensors.org 3877L: lm-sensors@lm-sensors.org
4519S: Maintained 3878S: Maintained
4520F: Documentation/hwmon/pc87360 3879F: Documentation/hwmon/pc87360
4521F: drivers/hwmon/pc87360.c 3880F: drivers/hwmon/pc87360.c
4522 3881
4523PC8736x GPIO DRIVER 3882PC8736x GPIO DRIVER
4524P: Jim Cromie 3883M: Jim Cromie <jim.cromie@gmail.com>
4525M: jim.cromie@gmail.com
4526S: Maintained 3884S: Maintained
4527F: drivers/char/pc8736x_gpio.c 3885F: drivers/char/pc8736x_gpio.c
4528 3886
4529PCA9532 LED DRIVER 3887PCA9532 LED DRIVER
4530P: Riku Voipio 3888M: Riku Voipio <riku.voipio@iki.fi>
4531M: riku.voipio@iki.fi
4532S: Maintained 3889S: Maintained
4533F: drivers/leds/leds-pca9532.c 3890F: drivers/leds/leds-pca9532.c
4534F: include/linux/leds-pca9532.h 3891F: include/linux/leds-pca9532.h
4535 3892
4536PCI ERROR RECOVERY 3893PCI ERROR RECOVERY
4537P: Linas Vepstas 3894M: Linas Vepstas <linas@austin.ibm.com>
4538M: linas@austin.ibm.com
4539L: linux-pci@vger.kernel.org 3895L: linux-pci@vger.kernel.org
4540S: Supported 3896S: Supported
4541F: Documentation/PCI/pci-error-recovery.txt 3897F: Documentation/PCI/pci-error-recovery.txt
4542F: Documentation/powerpc/eeh-pci-error-recovery.txt 3898F: Documentation/powerpc/eeh-pci-error-recovery.txt
4543 3899
4544PCI SUBSYSTEM 3900PCI SUBSYSTEM
4545P: Jesse Barnes 3901M: Jesse Barnes <jbarnes@virtuousgeek.org>
4546M: jbarnes@virtuousgeek.org
4547L: linux-pci@vger.kernel.org 3902L: linux-pci@vger.kernel.org
4548T: git git://git.kernel.org/pub/scm/linux/kernel/git/jbarnes/pci-2.6.git 3903T: git git://git.kernel.org/pub/scm/linux/kernel/git/jbarnes/pci-2.6.git
4549S: Supported 3904S: Supported
@@ -4552,8 +3907,7 @@ F: drivers/pci/
4552F: include/linux/pci* 3907F: include/linux/pci*
4553 3908
4554PCIE HOTPLUG DRIVER 3909PCIE HOTPLUG DRIVER
4555P: Kristen Carlson Accardi 3910M: Kristen Carlson Accardi <kristen.c.accardi@intel.com>
4556M: kristen.c.accardi@intel.com
4557L: linux-pci@vger.kernel.org 3911L: linux-pci@vger.kernel.org
4558S: Supported 3912S: Supported
4559F: drivers/pci/pcie/ 3913F: drivers/pci/pcie/
@@ -4569,121 +3923,103 @@ F: drivers/pcmcia/
4569F: include/pcmcia/ 3923F: include/pcmcia/
4570 3924
4571PCNET32 NETWORK DRIVER 3925PCNET32 NETWORK DRIVER
4572P: Don Fry 3926M: Don Fry <pcnet32@verizon.net>
4573M: pcnet32@verizon.net
4574L: netdev@vger.kernel.org 3927L: netdev@vger.kernel.org
4575S: Maintained 3928S: Maintained
4576F: drivers/net/pcnet32.c 3929F: drivers/net/pcnet32.c
4577 3930
4578PER-TASK DELAY ACCOUNTING 3931PER-TASK DELAY ACCOUNTING
4579P: Balbir Singh 3932M: Balbir Singh <balbir@linux.vnet.ibm.com>
4580M: balbir@linux.vnet.ibm.com
4581S: Maintained 3933S: Maintained
4582F: include/linux/delayacct.h 3934F: include/linux/delayacct.h
4583F: kernel/delayacct.c 3935F: kernel/delayacct.c
4584 3936
4585PERFORMANCE COUNTER SUBSYSTEM 3937PERFORMANCE COUNTER SUBSYSTEM
4586P: Peter Zijlstra 3938M: Peter Zijlstra <a.p.zijlstra@chello.nl>
4587M: a.p.zijlstra@chello.nl 3939M: Paul Mackerras <paulus@samba.org>
4588P: Paul Mackerras 3940M: Ingo Molnar <mingo@elte.hu>
4589M: paulus@samba.org
4590P: Ingo Molnar
4591M: mingo@elte.hu
4592L: linux-kernel@vger.kernel.org
4593S: Supported 3941S: Supported
4594 3942
4595PERSONALITY HANDLING 3943PERSONALITY HANDLING
4596P: Christoph Hellwig 3944M: Christoph Hellwig <hch@infradead.org>
4597M: hch@infradead.org
4598L: linux-abi-devel@lists.sourceforge.net 3945L: linux-abi-devel@lists.sourceforge.net
4599S: Maintained 3946S: Maintained
4600F: include/linux/personality.h 3947F: include/linux/personality.h
4601 3948
4602PHRAM MTD DRIVER 3949PHRAM MTD DRIVER
4603P: Joern Engel 3950M: Joern Engel <joern@lazybastard.org>
4604M: joern@lazybastard.org
4605L: linux-mtd@lists.infradead.org 3951L: linux-mtd@lists.infradead.org
4606S: Maintained 3952S: Maintained
4607F: drivers/mtd/devices/phram.c 3953F: drivers/mtd/devices/phram.c
4608 3954
4609PKTCDVD DRIVER 3955PKTCDVD DRIVER
4610P: Peter Osterlund 3956M: Peter Osterlund <petero2@telia.com>
4611M: petero2@telia.com
4612S: Maintained 3957S: Maintained
4613F: drivers/block/pktcdvd.c 3958F: drivers/block/pktcdvd.c
4614F: include/linux/pktcdvd.h 3959F: include/linux/pktcdvd.h
4615 3960
4616POSIX CLOCKS and TIMERS 3961POSIX CLOCKS and TIMERS
4617P: Thomas Gleixner 3962M: Thomas Gleixner <tglx@linutronix.de>
4618M: tglx@linutronix.de
4619S: Supported 3963S: Supported
4620F: fs/timerfd.c 3964F: fs/timerfd.c
4621F: include/linux/timer* 3965F: include/linux/timer*
4622F: kernel/*timer* 3966F: kernel/*timer*
4623 3967
4624POWER SUPPLY CLASS/SUBSYSTEM and DRIVERS 3968POWER SUPPLY CLASS/SUBSYSTEM and DRIVERS
4625P: Anton Vorontsov 3969M: Anton Vorontsov <cbou@mail.ru>
4626M: cbou@mail.ru 3970M: David Woodhouse <dwmw2@infradead.org>
4627P: David Woodhouse
4628M: dwmw2@infradead.org
4629T: git git://git.infradead.org/battery-2.6.git 3971T: git git://git.infradead.org/battery-2.6.git
4630S: Maintained 3972S: Maintained
4631F: include/linux/power_supply.h 3973F: include/linux/power_supply.h
4632F: drivers/power/power_supply* 3974F: drivers/power/power_supply*
4633 3975
4634PNP SUPPORT 3976PNP SUPPORT
4635P: Adam Belay 3977M: Adam Belay <abelay@mit.edu>
4636M: abelay@mit.edu 3978M: Bjorn Helgaas <bjorn.helgaas@hp.com>
4637P: Bjorn Helgaas
4638M: bjorn.helgaas@hp.com
4639S: Maintained 3979S: Maintained
4640F: drivers/pnp/ 3980F: drivers/pnp/
4641 3981
4642PNXxxxx I2C DRIVER 3982PNXxxxx I2C DRIVER
4643P: Vitaly Wool 3983M: Vitaly Wool <vitalywool@gmail.com>
4644M: vitalywool@gmail.com
4645L: linux-i2c@vger.kernel.org 3984L: linux-i2c@vger.kernel.org
4646S: Maintained 3985S: Maintained
4647F: drivers/i2c/busses/i2c-pnx.c 3986F: drivers/i2c/busses/i2c-pnx.c
4648 3987
4649PPP PROTOCOL DRIVERS AND COMPRESSORS 3988PPP PROTOCOL DRIVERS AND COMPRESSORS
4650P: Paul Mackerras 3989M: Paul Mackerras <paulus@samba.org>
4651M: paulus@samba.org
4652L: linux-ppp@vger.kernel.org 3990L: linux-ppp@vger.kernel.org
4653S: Maintained 3991S: Maintained
4654F: drivers/net/ppp_* 3992F: drivers/net/ppp_*
4655 3993
4656PPP OVER ATM (RFC 2364) 3994PPP OVER ATM (RFC 2364)
4657P: Mitchell Blank Jr 3995M: Mitchell Blank Jr <mitch@sfgoth.com>
4658M: mitch@sfgoth.com
4659S: Maintained 3996S: Maintained
4660F: net/atm/pppoatm.c 3997F: net/atm/pppoatm.c
4661F: include/linux/atmppp.h 3998F: include/linux/atmppp.h
4662 3999
4663PPP OVER ETHERNET 4000PPP OVER ETHERNET
4664P: Michal Ostrowski 4001M: Michal Ostrowski <mostrows@earthlink.net>
4665M: mostrows@earthlink.net
4666S: Maintained 4002S: Maintained
4667F: drivers/net/pppoe.c 4003F: drivers/net/pppoe.c
4668F: drivers/net/pppox.c 4004F: drivers/net/pppox.c
4669 4005
4670PPP OVER L2TP 4006PPP OVER L2TP
4671P: James Chapman 4007M: James Chapman <jchapman@katalix.com>
4672M: jchapman@katalix.com
4673S: Maintained 4008S: Maintained
4674F: drivers/net/pppol2tp.c 4009F: drivers/net/pppol2tp.c
4675F: include/linux/if_pppol2tp.h 4010F: include/linux/if_pppol2tp.h
4676 4011
4677PPS SUPPORT 4012PPS SUPPORT
4678P: Rodolfo Giometti 4013M: Rodolfo Giometti <giometti@enneenne.com>
4679M: giometti@enneenne.com
4680W: http://wiki.enneenne.com/index.php/LinuxPPS_support 4014W: http://wiki.enneenne.com/index.php/LinuxPPS_support
4681L: linuxpps@ml.enneenne.com (subscribers-only) 4015L: linuxpps@ml.enneenne.com (subscribers-only)
4682S: Maintained 4016S: Maintained
4017F: Documentation/pps/
4018F: drivers/pps/
4019F: include/linux/pps*.h
4683 4020
4684PREEMPTIBLE KERNEL 4021PREEMPTIBLE KERNEL
4685P: Robert Love 4022M: Robert Love <rml@tech9.net>
4686M: rml@tech9.net
4687L: kpreempt-tech@lists.sourceforge.net 4023L: kpreempt-tech@lists.sourceforge.net
4688W: ftp://ftp.kernel.org/pub/linux/kernel/people/rml/preempt-kernel 4024W: ftp://ftp.kernel.org/pub/linux/kernel/people/rml/preempt-kernel
4689S: Supported 4025S: Supported
@@ -4691,37 +4027,32 @@ F: Documentation/preempt-locking.txt
4691F: include/linux/preempt.h 4027F: include/linux/preempt.h
4692 4028
4693PRISM54 WIRELESS DRIVER 4029PRISM54 WIRELESS DRIVER
4694P: Luis R. Rodriguez 4030M: "Luis R. Rodriguez" <mcgrof@gmail.com>
4695M: mcgrof@gmail.com
4696L: linux-wireless@vger.kernel.org 4031L: linux-wireless@vger.kernel.org
4697W: http://prism54.org 4032W: http://prism54.org
4698S: Maintained 4033S: Maintained
4699F: drivers/net/wireless/prism54/ 4034F: drivers/net/wireless/prism54/
4700 4035
4701PROMISE DC4030 CACHING DISK CONTROLLER DRIVER 4036PROMISE DC4030 CACHING DISK CONTROLLER DRIVER
4702P: Peter Denison 4037M: Peter Denison <promise@pnd-pc.demon.co.uk>
4703M: promise@pnd-pc.demon.co.uk
4704W: http://www.pnd-pc.demon.co.uk/promise/ 4038W: http://www.pnd-pc.demon.co.uk/promise/
4705S: Maintained 4039S: Maintained
4706 4040
4707PROMISE SATA TX2/TX4 CONTROLLER LIBATA DRIVER 4041PROMISE SATA TX2/TX4 CONTROLLER LIBATA DRIVER
4708P: Mikael Pettersson 4042M: Mikael Pettersson <mikpe@it.uu.se>
4709M: mikpe@it.uu.se
4710L: linux-ide@vger.kernel.org 4043L: linux-ide@vger.kernel.org
4711S: Maintained 4044S: Maintained
4712F: drivers/ata/sata_promise.* 4045F: drivers/ata/sata_promise.*
4713 4046
4714PS3 NETWORK SUPPORT 4047PS3 NETWORK SUPPORT
4715P: Geoff Levand 4048M: Geoff Levand <geoffrey.levand@am.sony.com>
4716M: geoffrey.levand@am.sony.com
4717L: netdev@vger.kernel.org 4049L: netdev@vger.kernel.org
4718L: cbe-oss-dev@ozlabs.org 4050L: cbe-oss-dev@ozlabs.org
4719S: Supported 4051S: Supported
4720F: drivers/net/ps3_gelic_net.* 4052F: drivers/net/ps3_gelic_net.*
4721 4053
4722PS3 PLATFORM SUPPORT 4054PS3 PLATFORM SUPPORT
4723P: Geoff Levand 4055M: Geoff Levand <geoffrey.levand@am.sony.com>
4724M: geoffrey.levand@am.sony.com
4725L: linuxppc-dev@ozlabs.org 4056L: linuxppc-dev@ozlabs.org
4726L: cbe-oss-dev@ozlabs.org 4057L: cbe-oss-dev@ozlabs.org
4727S: Supported 4058S: Supported
@@ -4736,16 +4067,13 @@ F: drivers/usb/host/*ps3.c
4736F: sound/ppc/snd_ps3* 4067F: sound/ppc/snd_ps3*
4737 4068
4738PS3VRAM DRIVER 4069PS3VRAM DRIVER
4739P: Jim Paris 4070M: Jim Paris <jim@jtan.com>
4740M: jim@jtan.com
4741L: cbe-oss-dev@ozlabs.org 4071L: cbe-oss-dev@ozlabs.org
4742S: Maintained 4072S: Maintained
4743 4073
4744PTRACE SUPPORT 4074PTRACE SUPPORT
4745P: Roland McGrath 4075M: Roland McGrath <roland@redhat.com>
4746M: roland@redhat.com 4076M: Oleg Nesterov <oleg@redhat.com>
4747P: Oleg Nesterov
4748M: oleg@redhat.com
4749S: Maintained 4077S: Maintained
4750F: include/asm-generic/syscall.h 4078F: include/asm-generic/syscall.h
4751F: include/linux/ptrace.h 4079F: include/linux/ptrace.h
@@ -4754,8 +4082,7 @@ F: include/linux/tracehook.h
4754F: kernel/ptrace.c 4082F: kernel/ptrace.c
4755 4083
4756PVRUSB2 VIDEO4LINUX DRIVER 4084PVRUSB2 VIDEO4LINUX DRIVER
4757P: Mike Isely 4085M: Mike Isely <isely@pobox.com>
4758M: isely@pobox.com
4759L: pvrusb2@isely.net (subscribers-only) 4086L: pvrusb2@isely.net (subscribers-only)
4760L: linux-media@vger.kernel.org 4087L: linux-media@vger.kernel.org
4761W: http://www.isely.net/pvrusb2/ 4088W: http://www.isely.net/pvrusb2/
@@ -4765,10 +4092,8 @@ F: Documentation/video4linux/README.pvrusb2
4765F: drivers/media/video/pvrusb2/ 4092F: drivers/media/video/pvrusb2/
4766 4093
4767PXA2xx/PXA3xx SUPPORT 4094PXA2xx/PXA3xx SUPPORT
4768P: Eric Miao 4095M: Eric Miao <eric.y.miao@gmail.com>
4769M: eric.y.miao@gmail.com 4096M: Russell King <linux@arm.linux.org.uk>
4770P: Russell King
4771M: linux@arm.linux.org.uk
4772L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 4097L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
4773S: Maintained 4098S: Maintained
4774F: arch/arm/mach-pxa/ 4099F: arch/arm/mach-pxa/
@@ -4780,17 +4105,14 @@ F: sound/arm/pxa*
4780F: sound/soc/pxa 4105F: sound/soc/pxa
4781 4106
4782PXA168 SUPPORT 4107PXA168 SUPPORT
4783P: Eric Miao 4108M: Eric Miao <eric.y.miao@gmail.com>
4784M: eric.y.miao@gmail.com 4109M: Jason Chagas <jason.chagas@marvell.com>
4785P: Jason Chagas
4786M: jason.chagas@marvell.com
4787L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 4110L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
4788T: git git://git.kernel.org/pub/scm/linux/kernel/git/ycmiao/pxa-linux-2.6.git 4111T: git git://git.kernel.org/pub/scm/linux/kernel/git/ycmiao/pxa-linux-2.6.git
4789S: Maintained 4112S: Maintained
4790 4113
4791PXA910 SUPPORT 4114PXA910 SUPPORT
4792P: Eric Miao 4115M: Eric Miao <eric.y.miao@gmail.com>
4793M: eric.y.miao@gmail.com
4794L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 4116L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
4795T: git git://git.kernel.org/pub/scm/linux/kernel/git/ycmiao/pxa-linux-2.6.git 4117T: git git://git.kernel.org/pub/scm/linux/kernel/git/ycmiao/pxa-linux-2.6.git
4796S: Maintained 4118S: Maintained
@@ -4799,13 +4121,12 @@ PXA MMCI DRIVER
4799S: Orphan 4121S: Orphan
4800 4122
4801PXA RTC DRIVER 4123PXA RTC DRIVER
4802P: Robert Jarzmik 4124M: Robert Jarzmik <robert.jarzmik@free.fr>
4803M: robert.jarzmik@free.fr
4804L: rtc-linux@googlegroups.com 4125L: rtc-linux@googlegroups.com
4805S: Maintained 4126S: Maintained
4806 4127
4807QLOGIC QLA2XXX FC-SCSI DRIVER 4128QLOGIC QLA2XXX FC-SCSI DRIVER
4808P: Andrew Vasquez 4129M: Andrew Vasquez <andrew.vasquez@qlogic.com>
4809M: linux-driver@qlogic.com 4130M: linux-driver@qlogic.com
4810L: linux-scsi@vger.kernel.org 4131L: linux-scsi@vger.kernel.org
4811S: Supported 4132S: Supported
@@ -4813,7 +4134,7 @@ F: Documentation/scsi/LICENSE.qla2xxx
4813F: drivers/scsi/qla2xxx/ 4134F: drivers/scsi/qla2xxx/
4814 4135
4815QLOGIC QLA3XXX NETWORK DRIVER 4136QLOGIC QLA3XXX NETWORK DRIVER
4816P: Ron Mercer 4137M: Ron Mercer <ron.mercer@qlogic.com>
4817M: linux-driver@qlogic.com 4138M: linux-driver@qlogic.com
4818L: netdev@vger.kernel.org 4139L: netdev@vger.kernel.org
4819S: Supported 4140S: Supported
@@ -4821,16 +4142,14 @@ F: Documentation/networking/LICENSE.qla3xxx
4821F: drivers/net/qla3xxx.* 4142F: drivers/net/qla3xxx.*
4822 4143
4823QLOGIC QLGE 10Gb ETHERNET DRIVER 4144QLOGIC QLGE 10Gb ETHERNET DRIVER
4824P: Ron Mercer 4145M: Ron Mercer <ron.mercer@qlogic.com>
4825M: linux-driver@qlogic.com 4146M: linux-driver@qlogic.com
4826M: ron.mercer@qlogic.com
4827L: netdev@vger.kernel.org 4147L: netdev@vger.kernel.org
4828S: Supported 4148S: Supported
4829F: drivers/net/qlge/ 4149F: drivers/net/qlge/
4830 4150
4831QNX4 FILESYSTEM 4151QNX4 FILESYSTEM
4832P: Anders Larsen 4152M: Anders Larsen <al@alarsen.net>
4833M: al@alarsen.net
4834W: http://www.alarsen.net/linux/qnx4fs/ 4153W: http://www.alarsen.net/linux/qnx4fs/
4835S: Maintained 4154S: Maintained
4836F: fs/qnx4/ 4155F: fs/qnx4/
@@ -4838,16 +4157,14 @@ F: include/linux/qnx4_fs.h
4838F: include/linux/qnxtypes.h 4157F: include/linux/qnxtypes.h
4839 4158
4840RADEON FRAMEBUFFER DISPLAY DRIVER 4159RADEON FRAMEBUFFER DISPLAY DRIVER
4841P: Benjamin Herrenschmidt 4160M: Benjamin Herrenschmidt <benh@kernel.crashing.org>
4842M: benh@kernel.crashing.org
4843L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) 4161L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers)
4844S: Maintained 4162S: Maintained
4845F: drivers/video/aty/radeon* 4163F: drivers/video/aty/radeon*
4846F: include/linux/radeonfb.h 4164F: include/linux/radeonfb.h
4847 4165
4848RAGE128 FRAMEBUFFER DISPLAY DRIVER 4166RAGE128 FRAMEBUFFER DISPLAY DRIVER
4849P: Paul Mackerras 4167M: Paul Mackerras <paulus@samba.org>
4850M: paulus@samba.org
4851L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) 4168L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers)
4852S: Maintained 4169S: Maintained
4853F: drivers/video/aty/aty128fb.c 4170F: drivers/video/aty/aty128fb.c
@@ -4862,64 +4179,53 @@ T: git git://git.kernel.org/pub/scm/linux/kernel/git/ivd/rt2x00.git
4862F: drivers/net/wireless/rt2x00/ 4179F: drivers/net/wireless/rt2x00/
4863 4180
4864RAMDISK RAM BLOCK DEVICE DRIVER 4181RAMDISK RAM BLOCK DEVICE DRIVER
4865P: Nick Piggin 4182M: Nick Piggin <npiggin@suse.de>
4866M: npiggin@suse.de
4867S: Maintained 4183S: Maintained
4868F: Documentation/blockdev/ramdisk.txt 4184F: Documentation/blockdev/ramdisk.txt
4869F: drivers/block/brd.c 4185F: drivers/block/brd.c
4870 4186
4871RANDOM NUMBER DRIVER 4187RANDOM NUMBER DRIVER
4872P: Matt Mackall 4188M: Matt Mackall <mpm@selenic.com>
4873M: mpm@selenic.com
4874S: Maintained 4189S: Maintained
4875F: drivers/char/random.c 4190F: drivers/char/random.c
4876 4191
4877RAPIDIO SUBSYSTEM 4192RAPIDIO SUBSYSTEM
4878P: Matt Porter 4193M: Matt Porter <mporter@kernel.crashing.org>
4879M: mporter@kernel.crashing.org
4880S: Maintained 4194S: Maintained
4881F: drivers/rapidio/ 4195F: drivers/rapidio/
4882 4196
4883RAYLINK/WEBGEAR 802.11 WIRELESS LAN DRIVER 4197RAYLINK/WEBGEAR 802.11 WIRELESS LAN DRIVER
4884P: Corey Thomas 4198M: Corey Thomas <coreythomas@charter.net>
4885M: coreythomas@charter.net
4886L: linux-wireless@vger.kernel.org 4199L: linux-wireless@vger.kernel.org
4887S: Maintained 4200S: Maintained
4888F: drivers/net/wireless/ray* 4201F: drivers/net/wireless/ray*
4889 4202
4890RCUTORTURE MODULE 4203RCUTORTURE MODULE
4891P: Josh Triplett 4204M: Josh Triplett <josh@freedesktop.org>
4892M: josh@freedesktop.org 4205M: "Paul E. McKenney" <paulmck@linux.vnet.ibm.com>
4893P: Paul E. McKenney
4894M: paulmck@linux.vnet.ibm.com
4895S: Maintained 4206S: Maintained
4896F: Documentation/RCU/torture.txt 4207F: Documentation/RCU/torture.txt
4897F: kernel/rcutorture.c 4208F: kernel/rcutorture.c
4898 4209
4899RDC R-321X SoC 4210RDC R-321X SoC
4900P: Florian Fainelli 4211M: Florian Fainelli <florian@openwrt.org>
4901M: florian@openwrt.org
4902S: Maintained 4212S: Maintained
4903 4213
4904RDC R6040 FAST ETHERNET DRIVER 4214RDC R6040 FAST ETHERNET DRIVER
4905P: Florian Fainelli 4215M: Florian Fainelli <florian@openwrt.org>
4906M: florian@openwrt.org
4907L: netdev@vger.kernel.org 4216L: netdev@vger.kernel.org
4908S: Maintained 4217S: Maintained
4909F: drivers/net/r6040.c 4218F: drivers/net/r6040.c
4910 4219
4911RDS - RELIABLE DATAGRAM SOCKETS 4220RDS - RELIABLE DATAGRAM SOCKETS
4912P: Andy Grover 4221M: Andy Grover <andy.grover@oracle.com>
4913M: andy.grover@oracle.com
4914L: rds-devel@oss.oracle.com (moderated for non-subscribers) 4222L: rds-devel@oss.oracle.com (moderated for non-subscribers)
4915S: Supported 4223S: Supported
4916F: net/rds/ 4224F: net/rds/
4917 4225
4918READ-COPY UPDATE (RCU) 4226READ-COPY UPDATE (RCU)
4919P: Dipankar Sarma 4227M: Dipankar Sarma <dipankar@in.ibm.com>
4920M: dipankar@in.ibm.com 4228M: "Paul E. McKenney" <paulmck@linux.vnet.ibm.com>
4921P: Paul E. McKenney
4922M: paulmck@linux.vnet.ibm.com
4923W: http://www.rdrop.com/users/paulmck/rclock/ 4229W: http://www.rdrop.com/users/paulmck/rclock/
4924S: Supported 4230S: Supported
4925F: Documentation/RCU/rcu.txt 4231F: Documentation/RCU/rcu.txt
@@ -4929,16 +4235,14 @@ F: include/linux/srcu.h
4929F: kernel/rcupdate.c 4235F: kernel/rcupdate.c
4930 4236
4931REAL TIME CLOCK DRIVER 4237REAL TIME CLOCK DRIVER
4932P: Paul Gortmaker 4238M: Paul Gortmaker <p_gortmaker@yahoo.com>
4933M: p_gortmaker@yahoo.com
4934S: Maintained 4239S: Maintained
4935F: Documentation/rtc.txt 4240F: Documentation/rtc.txt
4936F: drivers/rtc/ 4241F: drivers/rtc/
4937F: include/linux/rtc.h 4242F: include/linux/rtc.h
4938 4243
4939REAL TIME CLOCK (RTC) SUBSYSTEM 4244REAL TIME CLOCK (RTC) SUBSYSTEM
4940P: Alessandro Zummo 4245M: Alessandro Zummo <a.zummo@towertech.it>
4941M: a.zummo@towertech.it
4942L: rtc-linux@googlegroups.com 4246L: rtc-linux@googlegroups.com
4943S: Maintained 4247S: Maintained
4944F: Documentation/rtc.txt 4248F: Documentation/rtc.txt
@@ -4951,8 +4255,7 @@ S: Supported
4951F: fs/reiserfs/ 4255F: fs/reiserfs/
4952 4256
4953RFKILL 4257RFKILL
4954P: Johannes Berg 4258M: Johannes Berg <johannes@sipsolutions.net>
4955M: johannes@sipsolutions.net
4956L: linux-wireless@vger.kernel.org 4259L: linux-wireless@vger.kernel.org
4957S: Maintained 4260S: Maintained
4958F Documentation/rfkill.txt 4261F Documentation/rfkill.txt
@@ -4971,8 +4274,7 @@ F: Documentation/serial/rocket.txt
4971F: drivers/char/rocket* 4274F: drivers/char/rocket*
4972 4275
4973ROSE NETWORK LAYER 4276ROSE NETWORK LAYER
4974P: Ralf Baechle 4277M: Ralf Baechle <ralf@linux-mips.org>
4975M: ralf@linux-mips.org
4976L: linux-hams@vger.kernel.org 4278L: linux-hams@vger.kernel.org
4977W: http://www.linux-ax25.org/ 4279W: http://www.linux-ax25.org/
4978S: Maintained 4280S: Maintained
@@ -4981,8 +4283,7 @@ F: include/net/rose.h
4981F: net/rose/ 4283F: net/rose/
4982 4284
4983RTL8180 WIRELESS DRIVER 4285RTL8180 WIRELESS DRIVER
4984P: John W. Linville 4286M: "John W. Linville" <linville@tuxdriver.com>
4985M: linville@tuxdriver.com
4986L: linux-wireless@vger.kernel.org 4287L: linux-wireless@vger.kernel.org
4987W: http://linuxwireless.org/ 4288W: http://linuxwireless.org/
4988T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-testing.git 4289T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-testing.git
@@ -4990,12 +4291,9 @@ S: Maintained
4990F: drivers/net/wireless/rtl818* 4291F: drivers/net/wireless/rtl818*
4991 4292
4992RTL8187 WIRELESS DRIVER 4293RTL8187 WIRELESS DRIVER
4993P: Herton Ronaldo Krzesinski 4294M: Herton Ronaldo Krzesinski <herton@mandriva.com.br>
4994M: herton@mandriva.com.br 4295M: Hin-Tak Leung <htl10@users.sourceforge.net>
4995P: Hin-Tak Leung 4296M: Larry Finger <Larry.Finger@lwfinger.net>
4996M: htl10@users.sourceforge.net
4997P: Larry Finger
4998M: Larry.Finger@lwfinger.net
4999L: linux-wireless@vger.kernel.org 4297L: linux-wireless@vger.kernel.org
5000W: http://linuxwireless.org/ 4298W: http://linuxwireless.org/
5001T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-testing.git 4299T: git git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-testing.git
@@ -5003,17 +4301,14 @@ S: Maintained
5003F: drivers/net/wireless/rtl818x/rtl8187* 4301F: drivers/net/wireless/rtl818x/rtl8187*
5004 4302
5005S3 SAVAGE FRAMEBUFFER DRIVER 4303S3 SAVAGE FRAMEBUFFER DRIVER
5006P: Antonino Daplas 4304M: Antonino Daplas <adaplas@gmail.com>
5007M: adaplas@gmail.com
5008L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) 4305L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers)
5009S: Maintained 4306S: Maintained
5010F: drivers/video/savage/ 4307F: drivers/video/savage/
5011 4308
5012S390 4309S390
5013P: Martin Schwidefsky 4310M: Martin Schwidefsky <schwidefsky@de.ibm.com>
5014M: schwidefsky@de.ibm.com 4311M: Heiko Carstens <heiko.carstens@de.ibm.com>
5015P: Heiko Carstens
5016M: heiko.carstens@de.ibm.com
5017M: linux390@de.ibm.com 4312M: linux390@de.ibm.com
5018L: linux-s390@vger.kernel.org 4313L: linux-s390@vger.kernel.org
5019W: http://www.ibm.com/developerworks/linux/linux390/ 4314W: http://www.ibm.com/developerworks/linux/linux390/
@@ -5021,10 +4316,8 @@ S: Supported
5021F: arch/s390/ 4316F: arch/s390/
5022 4317
5023S390 NETWORK DRIVERS 4318S390 NETWORK DRIVERS
5024P: Ursula Braun 4319M: Ursula Braun <ursula.braun@de.ibm.com>
5025M: ursula.braun@de.ibm.com 4320M: Frank Blaschka <blaschka@linux.vnet.ibm.com>
5026P: Frank Blaschka
5027M: blaschka@linux.vnet.ibm.com
5028M: linux390@de.ibm.com 4321M: linux390@de.ibm.com
5029L: linux-s390@vger.kernel.org 4322L: linux-s390@vger.kernel.org
5030W: http://www.ibm.com/developerworks/linux/linux390/ 4323W: http://www.ibm.com/developerworks/linux/linux390/
@@ -5032,20 +4325,16 @@ S: Supported
5032F: drivers/s390/net/ 4325F: drivers/s390/net/
5033 4326
5034S390 ZCRYPT DRIVER 4327S390 ZCRYPT DRIVER
5035P: Felix Beck 4328M: Felix Beck <felix.beck@de.ibm.com>
5036M: felix.beck@de.ibm.com 4329M: Ralph Wuerthner <ralph.wuerthner@de.ibm.com>
5037P: Ralph Wuerthner
5038M: ralph.wuerthner@de.ibm.com
5039M: linux390@de.ibm.com 4330M: linux390@de.ibm.com
5040L: linux-s390@vger.kernel.org 4331L: linux-s390@vger.kernel.org
5041S: Supported 4332S: Supported
5042F: drivers/s390/crypto/ 4333F: drivers/s390/crypto/
5043 4334
5044S390 ZFCP DRIVER 4335S390 ZFCP DRIVER
5045P: Christof Schmitt 4336M: Christof Schmitt <christof.schmitt@de.ibm.com>
5046M: christof.schmitt@de.ibm.com 4337M: Martin Peschke <mp3@de.ibm.com>
5047P: Martin Peschke
5048M: mp3@de.ibm.com
5049M: linux390@de.ibm.com 4338M: linux390@de.ibm.com
5050L: linux-s390@vger.kernel.org 4339L: linux-s390@vger.kernel.org
5051W: http://www.ibm.com/developerworks/linux/linux390/ 4340W: http://www.ibm.com/developerworks/linux/linux390/
@@ -5054,8 +4343,7 @@ F: Documentation/s390/zfcpdump.txt
5054F: drivers/s390/scsi/zfcp_* 4343F: drivers/s390/scsi/zfcp_*
5055 4344
5056S390 IUCV NETWORK LAYER 4345S390 IUCV NETWORK LAYER
5057P: Ursula Braun 4346M: Ursula Braun <ursula.braun@de.ibm.com>
5058M: ursula.braun@de.ibm.com
5059M: linux390@de.ibm.com 4347M: linux390@de.ibm.com
5060L: linux-s390@vger.kernel.org 4348L: linux-s390@vger.kernel.org
5061W: http://www.ibm.com/developerworks/linux/linux390/ 4349W: http://www.ibm.com/developerworks/linux/linux390/
@@ -5065,15 +4353,13 @@ F: include/net/iucv/
5065F: net/iucv/ 4353F: net/iucv/
5066 4354
5067S3C24XX SD/MMC Driver 4355S3C24XX SD/MMC Driver
5068P: Ben Dooks 4356M: Ben Dooks <ben-linux@fluff.org>
5069M: ben-linux@fluff.org
5070L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 4357L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
5071S: Supported 4358S: Supported
5072F: drivers/mmc/host/s3cmci.* 4359F: drivers/mmc/host/s3cmci.*
5073 4360
5074SAA7146 VIDEO4LINUX-2 DRIVER 4361SAA7146 VIDEO4LINUX-2 DRIVER
5075P: Michael Hunold 4362M: Michael Hunold <michael@mihu.de>
5076M: michael@mihu.de
5077L: linux-media@vger.kernel.org 4363L: linux-media@vger.kernel.org
5078T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 4364T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
5079W: http://www.mihu.de/linux/saa7146 4365W: http://www.mihu.de/linux/saa7146
@@ -5083,31 +4369,26 @@ F: drivers/media/video/*7146*
5083F: include/media/*7146* 4369F: include/media/*7146*
5084 4370
5085SC1200 WDT DRIVER 4371SC1200 WDT DRIVER
5086P: Zwane Mwaikambo 4372M: Zwane Mwaikambo <zwane@arm.linux.org.uk>
5087M: zwane@arm.linux.org.uk
5088S: Maintained 4373S: Maintained
5089F: drivers/watchdog/sc1200wdt.c 4374F: drivers/watchdog/sc1200wdt.c
5090 4375
5091SCHEDULER 4376SCHEDULER
5092P: Ingo Molnar 4377M: Ingo Molnar <mingo@elte.hu>
5093M: mingo@elte.hu 4378M: Peter Zijlstra <peterz@infradead.org>
5094P: Peter Zijlstra
5095M: peterz@infradead.org
5096S: Maintained 4379S: Maintained
5097F: kernel/sched* 4380F: kernel/sched*
5098F: include/linux/sched.h 4381F: include/linux/sched.h
5099 4382
5100SCSI CDROM DRIVER 4383SCSI CDROM DRIVER
5101P: Jens Axboe 4384M: Jens Axboe <axboe@kernel.dk>
5102M: axboe@kernel.dk
5103L: linux-scsi@vger.kernel.org 4385L: linux-scsi@vger.kernel.org
5104W: http://www.kernel.dk 4386W: http://www.kernel.dk
5105S: Maintained 4387S: Maintained
5106F: drivers/scsi/sr* 4388F: drivers/scsi/sr*
5107 4389
5108SCSI SG DRIVER 4390SCSI SG DRIVER
5109P: Doug Gilbert 4391M: Doug Gilbert <dgilbert@interlog.com>
5110M: dgilbert@interlog.com
5111L: linux-scsi@vger.kernel.org 4392L: linux-scsi@vger.kernel.org
5112W: http://www.torque.net/sg 4393W: http://www.torque.net/sg
5113S: Maintained 4394S: Maintained
@@ -5115,8 +4396,7 @@ F: drivers/scsi/sg.c
5115F: include/scsi/sg.h 4396F: include/scsi/sg.h
5116 4397
5117SCSI SUBSYSTEM 4398SCSI SUBSYSTEM
5118P: James E.J. Bottomley 4399M: "James E.J. Bottomley" <James.Bottomley@HansenPartnership.com>
5119M: James.Bottomley@HansenPartnership.com
5120L: linux-scsi@vger.kernel.org 4400L: linux-scsi@vger.kernel.org
5121T: git git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-misc-2.6.git 4401T: git git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-misc-2.6.git
5122T: git git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-rc-fixes-2.6.git 4402T: git git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi-rc-fixes-2.6.git
@@ -5126,18 +4406,15 @@ F: drivers/scsi/
5126F: include/scsi/ 4406F: include/scsi/
5127 4407
5128SCSI TAPE DRIVER 4408SCSI TAPE DRIVER
5129P: Kai Mäkisara 4409M: Kai Mäkisara <Kai.Makisara@kolumbus.fi>
5130M: Kai.Makisara@kolumbus.fi
5131L: linux-scsi@vger.kernel.org 4410L: linux-scsi@vger.kernel.org
5132S: Maintained 4411S: Maintained
5133F: Documentation/scsi/st.txt 4412F: Documentation/scsi/st.txt
5134F: drivers/scsi/st* 4413F: drivers/scsi/st*
5135 4414
5136SCTP PROTOCOL 4415SCTP PROTOCOL
5137P: Vlad Yasevich 4416M: Vlad Yasevich <vladislav.yasevich@hp.com>
5138M: vladislav.yasevich@hp.com 4417M: Sridhar Samudrala <sri@us.ibm.com>
5139P: Sridhar Samudrala
5140M: sri@us.ibm.com
5141L: linux-sctp@vger.kernel.org 4418L: linux-sctp@vger.kernel.org
5142W: http://lksctp.sourceforge.net 4419W: http://lksctp.sourceforge.net
5143S: Supported 4420S: Supported
@@ -5147,8 +4424,7 @@ F: include/net/sctp/
5147F: net/sctp/ 4424F: net/sctp/
5148 4425
5149SCx200 CPU SUPPORT 4426SCx200 CPU SUPPORT
5150P: Jim Cromie 4427M: Jim Cromie <jim.cromie@gmail.com>
5151M: jim.cromie@gmail.com
5152S: Odd Fixes 4428S: Odd Fixes
5153F: Documentation/i2c/busses/scx200_acb 4429F: Documentation/i2c/busses/scx200_acb
5154F: arch/x86/kernel/scx200_32.c 4430F: arch/x86/kernel/scx200_32.c
@@ -5158,49 +4434,42 @@ F: drivers/mtd/maps/scx200_docflash.c
5158F: include/linux/scx200.h 4434F: include/linux/scx200.h
5159 4435
5160SCx200 GPIO DRIVER 4436SCx200 GPIO DRIVER
5161P: Jim Cromie 4437M: Jim Cromie <jim.cromie@gmail.com>
5162M: jim.cromie@gmail.com
5163S: Maintained 4438S: Maintained
5164F: drivers/char/scx200_gpio.c 4439F: drivers/char/scx200_gpio.c
5165F: include/linux/scx200_gpio.h 4440F: include/linux/scx200_gpio.h
5166 4441
5167SCx200 HRT CLOCKSOURCE DRIVER 4442SCx200 HRT CLOCKSOURCE DRIVER
5168P: Jim Cromie 4443M: Jim Cromie <jim.cromie@gmail.com>
5169M: jim.cromie@gmail.com
5170S: Maintained 4444S: Maintained
5171F: drivers/clocksource/scx200_hrt.c 4445F: drivers/clocksource/scx200_hrt.c
5172 4446
5173SDRICOH_CS MMC/SD HOST CONTROLLER INTERFACE DRIVER 4447SDRICOH_CS MMC/SD HOST CONTROLLER INTERFACE DRIVER
5174P: Sascha Sommer 4448M: Sascha Sommer <saschasommer@freenet.de>
5175M: saschasommer@freenet.de
5176L: sdricohcs-devel@lists.sourceforge.net (subscribers-only) 4449L: sdricohcs-devel@lists.sourceforge.net (subscribers-only)
5177S: Maintained 4450S: Maintained
5178F: drivers/mmc/host/sdricoh_cs.c 4451F: drivers/mmc/host/sdricoh_cs.c
5179 4452
5180SECURE DIGITAL HOST CONTROLLER INTERFACE (SDHCI) DRIVER 4453SECURE DIGITAL HOST CONTROLLER INTERFACE (SDHCI) DRIVER
5181P: Pierre Ossman 4454M: Pierre Ossman <pierre@ossman.eu>
5182M: pierre@ossman.eu
5183L: sdhci-devel@lists.ossman.eu 4455L: sdhci-devel@lists.ossman.eu
5184S: Maintained 4456S: Maintained
5185 4457
5186SECURE DIGITAL HOST CONTROLLER INTERFACE, OPEN FIRMWARE BINDINGS (SDHCI-OF) 4458SECURE DIGITAL HOST CONTROLLER INTERFACE, OPEN FIRMWARE BINDINGS (SDHCI-OF)
5187P: Anton Vorontsov 4459M: Anton Vorontsov <avorontsov@ru.mvista.com>
5188M: avorontsov@ru.mvista.com
5189L: linuxppc-dev@ozlabs.org 4460L: linuxppc-dev@ozlabs.org
5190L: sdhci-devel@lists.ossman.eu 4461L: sdhci-devel@lists.ossman.eu
5191S: Maintained 4462S: Maintained
5192F: drivers/mmc/host/sdhci.* 4463F: drivers/mmc/host/sdhci.*
5193 4464
5194SECURE DIGITAL HOST CONTROLLER INTERFACE (SDHCI) SAMSUNG DRIVER 4465SECURE DIGITAL HOST CONTROLLER INTERFACE (SDHCI) SAMSUNG DRIVER
5195P: Ben Dooks 4466M: Ben Dooks <ben-linux@fluff.org>
5196M: ben-linux@fluff.org
5197L: sdhci-devel@lists.ossman.eu 4467L: sdhci-devel@lists.ossman.eu
5198S: Maintained 4468S: Maintained
5199F: drivers/mmc/host/sdhci-s3c.c 4469F: drivers/mmc/host/sdhci-s3c.c
5200 4470
5201SECURITY SUBSYSTEM 4471SECURITY SUBSYSTEM
5202P: James Morris 4472M: James Morris <jmorris@namei.org>
5203M: jmorris@namei.org
5204L: linux-security-module@vger.kernel.org (suggested Cc:) 4473L: linux-security-module@vger.kernel.org (suggested Cc:)
5205T: git git://www.kernel.org/pub/scm/linux/kernel/git/jmorris/security-testing-2.6.git 4474T: git git://www.kernel.org/pub/scm/linux/kernel/git/jmorris/security-testing-2.6.git
5206W: http://security.wiki.kernel.org/ 4475W: http://security.wiki.kernel.org/
@@ -5208,17 +4477,13 @@ S: Supported
5208F: security/ 4477F: security/
5209 4478
5210SECURITY CONTACT 4479SECURITY CONTACT
5211P: Security Officers 4480M: Security Officers <security@kernel.org>
5212M: security@kernel.org
5213S: Supported 4481S: Supported
5214 4482
5215SELINUX SECURITY MODULE 4483SELINUX SECURITY MODULE
5216P: Stephen Smalley 4484M: Stephen Smalley <sds@tycho.nsa.gov>
5217M: sds@tycho.nsa.gov 4485M: James Morris <jmorris@namei.org>
5218P: James Morris 4486M: Eric Paris <eparis@parisplace.org>
5219M: jmorris@namei.org
5220P: Eric Paris
5221M: eparis@parisplace.org
5222L: selinux@tycho.nsa.gov (subscribers-only, general discussion) 4487L: selinux@tycho.nsa.gov (subscribers-only, general discussion)
5223W: http://selinuxproject.org 4488W: http://selinuxproject.org
5224T: git git://git.kernel.org/pub/scm/linux/kernel/git/jmorris/security-testing-2.6.git 4489T: git git://git.kernel.org/pub/scm/linux/kernel/git/jmorris/security-testing-2.6.git
@@ -5227,15 +4492,13 @@ F: include/linux/selinux*
5227F: security/selinux/ 4492F: security/selinux/
5228 4493
5229SENSABLE PHANTOM 4494SENSABLE PHANTOM
5230P: Jiri Slaby 4495M: Jiri Slaby <jirislaby@gmail.com>
5231M: jirislaby@gmail.com
5232S: Maintained 4496S: Maintained
5233F: drivers/misc/phantom.c 4497F: drivers/misc/phantom.c
5234F: include/linux/phantom.h 4498F: include/linux/phantom.h
5235 4499
5236SERIAL ATA (SATA) SUBSYSTEM 4500SERIAL ATA (SATA) SUBSYSTEM
5237P: Jeff Garzik 4501M: Jeff Garzik <jgarzik@pobox.com>
5238M: jgarzik@pobox.com
5239L: linux-ide@vger.kernel.org 4502L: linux-ide@vger.kernel.org
5240T: git git://git.kernel.org/pub/scm/linux/kernel/git/jgarzik/libata-dev.git 4503T: git git://git.kernel.org/pub/scm/linux/kernel/git/jgarzik/libata-dev.git
5241S: Supported 4504S: Supported
@@ -5244,10 +4507,8 @@ F: include/linux/ata.h
5244F: include/linux/libata.h 4507F: include/linux/libata.h
5245 4508
5246SERVER ENGINES 10Gbps NIC - BladeEngine 2 DRIVER 4509SERVER ENGINES 10Gbps NIC - BladeEngine 2 DRIVER
5247P: Sathya Perla 4510M: Sathya Perla <sathyap@serverengines.com>
5248M: sathyap@serverengines.com 4511M: Subbu Seetharaman <subbus@serverengines.com>
5249P: Subbu Seetharaman
5250M: subbus@serverengines.com
5251L: netdev@vger.kernel.org 4512L: netdev@vger.kernel.org
5252W: http://www.serverengines.com 4513W: http://www.serverengines.com
5253S: Supported 4514S: Supported
@@ -5256,20 +4517,17 @@ F: drivers/net/benet/
5256SFC NETWORK DRIVER 4517SFC NETWORK DRIVER
5257P: Steve Hodgson 4518P: Steve Hodgson
5258P: Ben Hutchings 4519P: Ben Hutchings
5259P: Robert Stonehouse 4520M: Robert Stonehouse <linux-net-drivers@solarflare.com>
5260M: linux-net-drivers@solarflare.com
5261S: Supported 4521S: Supported
5262F: drivers/net/sfc/ 4522F: drivers/net/sfc/
5263 4523
5264SGI GRU DRIVER 4524SGI GRU DRIVER
5265P: Jack Steiner 4525M: Jack Steiner <steiner@sgi.com>
5266M: steiner@sgi.com
5267S: Maintained 4526S: Maintained
5268F: drivers/misc/sgi-gru/ 4527F: drivers/misc/sgi-gru/
5269 4528
5270SGI SN-IA64 (Altix) SERIAL CONSOLE DRIVER 4529SGI SN-IA64 (Altix) SERIAL CONSOLE DRIVER
5271P: Pat Gefre 4530M: Pat Gefre <pfg@sgi.com>
5272M: pfg@sgi.com
5273L: linux-ia64@vger.kernel.org 4531L: linux-ia64@vger.kernel.org
5274S: Supported 4532S: Supported
5275F: Documentation/ia64/serial.txt 4533F: Documentation/ia64/serial.txt
@@ -5277,22 +4535,19 @@ F: drivers/serial/ioc?_serial.c
5277F: include/linux/ioc?.h 4535F: include/linux/ioc?.h
5278 4536
5279SGI VISUAL WORKSTATION 320 AND 540 4537SGI VISUAL WORKSTATION 320 AND 540
5280P: Andrey Panin 4538M: Andrey Panin <pazke@donpac.ru>
5281M: pazke@donpac.ru
5282L: linux-visws-devel@lists.sf.net 4539L: linux-visws-devel@lists.sf.net
5283W: http://linux-visws.sf.net 4540W: http://linux-visws.sf.net
5284S: Maintained for 2.6. 4541S: Maintained for 2.6.
5285F: Documentation/sgi-visws.txt 4542F: Documentation/sgi-visws.txt
5286 4543
5287SGI XP/XPC/XPNET DRIVER 4544SGI XP/XPC/XPNET DRIVER
5288P: Robin Holt 4545M: Robin Holt <holt@sgi.com>
5289M: holt@sgi.com
5290S: Maintained 4546S: Maintained
5291F: drivers/misc/sgi-xp/ 4547F: drivers/misc/sgi-xp/
5292 4548
5293SHARP LH SUPPORT (LH7952X & LH7A40X) 4549SHARP LH SUPPORT (LH7952X & LH7A40X)
5294P: Marc Singer 4550M: Marc Singer <elf@buici.com>
5295M: elf@buici.com
5296W: http://projects.buici.com/arm 4551W: http://projects.buici.com/arm
5297L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only) 4552L: linux-arm-kernel@lists.arm.linux.org.uk (subscribers-only)
5298S: Maintained 4553S: Maintained
@@ -5303,23 +4558,20 @@ F: drivers/usb/gadget/lh7a40*
5303F: drivers/usb/host/ohci-lh7a40* 4558F: drivers/usb/host/ohci-lh7a40*
5304 4559
5305SHPC HOTPLUG DRIVER 4560SHPC HOTPLUG DRIVER
5306P: Kristen Carlson Accardi 4561M: Kristen Carlson Accardi <kristen.c.accardi@intel.com>
5307M: kristen.c.accardi@intel.com
5308L: linux-pci@vger.kernel.org 4562L: linux-pci@vger.kernel.org
5309S: Supported 4563S: Supported
5310F: drivers/pci/hotplug/shpchp* 4564F: drivers/pci/hotplug/shpchp*
5311 4565
5312SIMTEC EB110ATX (Chalice CATS) 4566SIMTEC EB110ATX (Chalice CATS)
5313P: Ben Dooks 4567P: Ben Dooks
5314P: Vincent Sanders 4568M: Vincent Sanders <support@simtec.co.uk>
5315M: support@simtec.co.uk
5316W: http://www.simtec.co.uk/products/EB110ATX/ 4569W: http://www.simtec.co.uk/products/EB110ATX/
5317S: Supported 4570S: Supported
5318 4571
5319SIMTEC EB2410ITX (BAST) 4572SIMTEC EB2410ITX (BAST)
5320P: Ben Dooks 4573P: Ben Dooks
5321P: Vincent Sanders 4574M: Vincent Sanders <support@simtec.co.uk>
5322M: support@simtec.co.uk
5323W: http://www.simtec.co.uk/products/EB2410ITX/ 4575W: http://www.simtec.co.uk/products/EB2410ITX/
5324S: Supported 4576S: Supported
5325F: arch/arm/mach-s3c2410/ 4577F: arch/arm/mach-s3c2410/
@@ -5327,31 +4579,27 @@ F: drivers/*/*s3c2410*
5327F: drivers/*/*/*s3c2410* 4579F: drivers/*/*/*s3c2410*
5328 4580
5329SIS 190 ETHERNET DRIVER 4581SIS 190 ETHERNET DRIVER
5330P: Francois Romieu 4582M: Francois Romieu <romieu@fr.zoreil.com>
5331M: romieu@fr.zoreil.com
5332L: netdev@vger.kernel.org 4583L: netdev@vger.kernel.org
5333S: Maintained 4584S: Maintained
5334F: drivers/net/sis190.c 4585F: drivers/net/sis190.c
5335 4586
5336SIS 900/7016 FAST ETHERNET DRIVER 4587SIS 900/7016 FAST ETHERNET DRIVER
5337P: Daniele Venzano 4588M: Daniele Venzano <venza@brownhat.org>
5338M: venza@brownhat.org
5339W: http://www.brownhat.org/sis900.html 4589W: http://www.brownhat.org/sis900.html
5340L: netdev@vger.kernel.org 4590L: netdev@vger.kernel.org
5341S: Maintained 4591S: Maintained
5342F: drivers/net/sis900.* 4592F: drivers/net/sis900.*
5343 4593
5344SIS 96X I2C/SMBUS DRIVER 4594SIS 96X I2C/SMBUS DRIVER
5345P: Mark M. Hoffman 4595M: "Mark M. Hoffman" <mhoffman@lightlink.com>
5346M: mhoffman@lightlink.com
5347L: linux-i2c@vger.kernel.org 4596L: linux-i2c@vger.kernel.org
5348S: Maintained 4597S: Maintained
5349F: Documentation/i2c/busses/i2c-sis96x 4598F: Documentation/i2c/busses/i2c-sis96x
5350F: drivers/i2c/busses/i2c-sis96x.c 4599F: drivers/i2c/busses/i2c-sis96x.c
5351 4600
5352SIS FRAMEBUFFER DRIVER 4601SIS FRAMEBUFFER DRIVER
5353P: Thomas Winischhofer 4602M: Thomas Winischhofer <thomas@winischhofer.net>
5354M: thomas@winischhofer.net
5355W: http://www.winischhofer.net/linuxsisvga.shtml 4603W: http://www.winischhofer.net/linuxsisvga.shtml
5356S: Maintained 4604S: Maintained
5357F: Documentation/fb/sisfb.txt 4605F: Documentation/fb/sisfb.txt
@@ -5359,70 +4607,59 @@ F: drivers/video/sis/
5359F: include/video/sisfb.h 4607F: include/video/sisfb.h
5360 4608
5361SIS USB2VGA DRIVER 4609SIS USB2VGA DRIVER
5362P: Thomas Winischhofer 4610M: Thomas Winischhofer <thomas@winischhofer.net>
5363M: thomas@winischhofer.net
5364W: http://www.winischhofer.at/linuxsisusbvga.shtml 4611W: http://www.winischhofer.at/linuxsisusbvga.shtml
5365S: Maintained 4612S: Maintained
5366F: drivers/usb/misc/sisusbvga/ 4613F: drivers/usb/misc/sisusbvga/
5367 4614
5368SKGE, SKY2 10/100/1000 GIGABIT ETHERNET DRIVERS 4615SKGE, SKY2 10/100/1000 GIGABIT ETHERNET DRIVERS
5369P: Stephen Hemminger 4616M: Stephen Hemminger <shemminger@linux-foundation.org>
5370M: shemminger@linux-foundation.org
5371L: netdev@vger.kernel.org 4617L: netdev@vger.kernel.org
5372S: Maintained 4618S: Maintained
5373F: drivers/net/skge.* 4619F: drivers/net/skge.*
5374F: drivers/net/sky2.* 4620F: drivers/net/sky2.*
5375 4621
5376SLAB ALLOCATOR 4622SLAB ALLOCATOR
5377P: Christoph Lameter 4623M: Christoph Lameter <cl@linux-foundation.org>
5378M: cl@linux-foundation.org 4624M: Pekka Enberg <penberg@cs.helsinki.fi>
5379P: Pekka Enberg 4625M: Matt Mackall <mpm@selenic.com>
5380M: penberg@cs.helsinki.fi
5381P: Matt Mackall
5382M: mpm@selenic.com
5383L: linux-mm@kvack.org 4626L: linux-mm@kvack.org
5384S: Maintained 4627S: Maintained
5385F: include/linux/sl?b*.h 4628F: include/linux/sl?b*.h
5386F: mm/sl?b.c 4629F: mm/sl?b.c
5387 4630
5388SMC91x ETHERNET DRIVER 4631SMC91x ETHERNET DRIVER
5389P: Nicolas Pitre 4632M: Nicolas Pitre <nico@cam.org>
5390M: nico@cam.org
5391S: Maintained 4633S: Maintained
5392F: drivers/net/smc91x.* 4634F: drivers/net/smc91x.*
5393 4635
5394SMSC47B397 HARDWARE MONITOR DRIVER 4636SMSC47B397 HARDWARE MONITOR DRIVER
5395P: Mark M. Hoffman 4637M: "Mark M. Hoffman" <mhoffman@lightlink.com>
5396M: mhoffman@lightlink.com
5397L: lm-sensors@lm-sensors.org 4638L: lm-sensors@lm-sensors.org
5398S: Maintained 4639S: Maintained
5399F: Documentation/hwmon/smsc47b397 4640F: Documentation/hwmon/smsc47b397
5400F: drivers/hwmon/smsc47b397.c 4641F: drivers/hwmon/smsc47b397.c
5401 4642
5402SMSC911x ETHERNET DRIVER 4643SMSC911x ETHERNET DRIVER
5403P: Steve Glendinning 4644M: Steve Glendinning <steve.glendinning@smsc.com>
5404M: steve.glendinning@smsc.com
5405L: netdev@vger.kernel.org 4645L: netdev@vger.kernel.org
5406S: Supported 4646S: Supported
5407F: include/linux/smsc911x.h 4647F: include/linux/smsc911x.h
5408F: drivers/net/smsc911x.* 4648F: drivers/net/smsc911x.*
5409 4649
5410SMSC9420 PCI ETHERNET DRIVER 4650SMSC9420 PCI ETHERNET DRIVER
5411P: Steve Glendinning 4651M: Steve Glendinning <steve.glendinning@smsc.com>
5412M: steve.glendinning@smsc.com
5413L: netdev@vger.kernel.org 4652L: netdev@vger.kernel.org
5414S: Supported 4653S: Supported
5415F: drivers/net/smsc9420.* 4654F: drivers/net/smsc9420.*
5416 4655
5417SMX UIO Interface 4656SMX UIO Interface
5418P: Ben Nizette 4657M: Ben Nizette <bn@niasdigital.com>
5419M: bn@niasdigital.com
5420S: Maintained 4658S: Maintained
5421F: drivers/uio/uio_smx.c 4659F: drivers/uio/uio_smx.c
5422 4660
5423SN-IA64 (Itanium) SUB-PLATFORM 4661SN-IA64 (Itanium) SUB-PLATFORM
5424P: Jes Sorensen 4662M: Jes Sorensen <jes@sgi.com>
5425M: jes@sgi.com
5426L: linux-altix@sgi.com 4663L: linux-altix@sgi.com
5427L: linux-ia64@vger.kernel.org 4664L: linux-ia64@vger.kernel.org
5428W: http://www.sgi.com/altix 4665W: http://www.sgi.com/altix
@@ -5430,8 +4667,7 @@ S: Maintained
5430F: arch/ia64/sn/ 4667F: arch/ia64/sn/
5431 4668
5432SOC-CAMERA V4L2 SUBSYSTEM 4669SOC-CAMERA V4L2 SUBSYSTEM
5433P: Guennadi Liakhovetski 4670M: Guennadi Liakhovetski <g.liakhovetski@gmx.de>
5434M: g.liakhovetski@gmx.de
5435L: linux-media@vger.kernel.org 4671L: linux-media@vger.kernel.org
5436T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 4672T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
5437S: Maintained 4673S: Maintained
@@ -5439,37 +4675,32 @@ F: include/media/v4l2*
5439F: drivers/media/video/v4l2* 4675F: drivers/media/video/v4l2*
5440 4676
5441SOEKRIS NET48XX LED SUPPORT 4677SOEKRIS NET48XX LED SUPPORT
5442P: Chris Boot 4678M: Chris Boot <bootc@bootc.net>
5443M: bootc@bootc.net
5444S: Maintained 4679S: Maintained
5445F: drivers/leds/leds-net48xx.c 4680F: drivers/leds/leds-net48xx.c
5446 4681
5447SOFTWARE RAID (Multiple Disks) SUPPORT 4682SOFTWARE RAID (Multiple Disks) SUPPORT
5448P: Neil Brown 4683M: Neil Brown <neilb@suse.de>
5449M: neilb@suse.de
5450L: linux-raid@vger.kernel.org 4684L: linux-raid@vger.kernel.org
5451S: Supported 4685S: Supported
5452F: drivers/md/ 4686F: drivers/md/
5453F: include/linux/raid/ 4687F: include/linux/raid/
5454 4688
5455SONIC NETWORK DRIVER 4689SONIC NETWORK DRIVER
5456P: Thomas Bogendoerfer 4690M: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
5457M: tsbogend@alpha.franken.de
5458L: netdev@vger.kernel.org 4691L: netdev@vger.kernel.org
5459S: Maintained 4692S: Maintained
5460F: drivers/net/sonic.* 4693F: drivers/net/sonic.*
5461 4694
5462SONICS SILICON BACKPLANE DRIVER (SSB) 4695SONICS SILICON BACKPLANE DRIVER (SSB)
5463P: Michael Buesch 4696M: Michael Buesch <mb@bu3sch.de>
5464M: mb@bu3sch.de
5465L: netdev@vger.kernel.org 4697L: netdev@vger.kernel.org
5466S: Maintained 4698S: Maintained
5467F: drivers/ssb/ 4699F: drivers/ssb/
5468F: include/linux/ssb/ 4700F: include/linux/ssb/
5469 4701
5470SONY VAIO CONTROL DEVICE DRIVER 4702SONY VAIO CONTROL DEVICE DRIVER
5471P: Mattia Dongili 4703M: Mattia Dongili <malattia@linux.it>
5472M: malattia@linux.it
5473L: linux-acpi@vger.kernel.org 4704L: linux-acpi@vger.kernel.org
5474W: http://www.linux.it/~malattia/wiki/index.php/Sony_drivers 4705W: http://www.linux.it/~malattia/wiki/index.php/Sony_drivers
5475S: Maintained 4706S: Maintained
@@ -5479,17 +4710,14 @@ F: drivers/platform/x86/sony-laptop.c
5479F: include/linux/sony-laptop.h 4710F: include/linux/sony-laptop.h
5480 4711
5481SONY MEMORYSTICK CARD SUPPORT 4712SONY MEMORYSTICK CARD SUPPORT
5482P: Alex Dubov 4713M: Alex Dubov <oakad@yahoo.com>
5483M: oakad@yahoo.com
5484W: http://tifmxx.berlios.de/ 4714W: http://tifmxx.berlios.de/
5485S: Maintained 4715S: Maintained
5486F: drivers/memstick/host/tifm_ms.c 4716F: drivers/memstick/host/tifm_ms.c
5487 4717
5488SOUND 4718SOUND
5489P: Jaroslav Kysela 4719M: Jaroslav Kysela <perex@perex.cz>
5490M: perex@perex.cz 4720M: Takashi Iwai <tiwai@suse.de>
5491P: Takashi Iwai
5492M: tiwai@suse.de
5493L: alsa-devel@alsa-project.org (moderated for non-subscribers) 4721L: alsa-devel@alsa-project.org (moderated for non-subscribers)
5494W: http://www.alsa-project.org/ 4722W: http://www.alsa-project.org/
5495T: git git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound-2.6.git 4723T: git git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound-2.6.git
@@ -5500,10 +4728,8 @@ F: include/sound/
5500F: sound/ 4728F: sound/
5501 4729
5502SOUND - SOC LAYER / DYNAMIC AUDIO POWER MANAGEMENT (ASoC) 4730SOUND - SOC LAYER / DYNAMIC AUDIO POWER MANAGEMENT (ASoC)
5503P: Liam Girdwood 4731M: Liam Girdwood <lrg@slimlogic.co.uk>
5504M: lrg@slimlogic.co.uk 4732M: Mark Brown <broonie@opensource.wolfsonmicro.com>
5505P: Mark Brown
5506M: broonie@opensource.wolfsonmicro.com
5507T: git git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound-2.6.git 4733T: git git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound-2.6.git
5508L: alsa-devel@alsa-project.org (moderated for non-subscribers) 4734L: alsa-devel@alsa-project.org (moderated for non-subscribers)
5509W: http://alsa-project.org/main/index.php/ASoC 4735W: http://alsa-project.org/main/index.php/ASoC
@@ -5512,8 +4738,7 @@ F: sound/soc/
5512F: include/sound/soc* 4738F: include/sound/soc*
5513 4739
5514SPARC + UltraSPARC (sparc/sparc64) 4740SPARC + UltraSPARC (sparc/sparc64)
5515P: David S. Miller 4741M: "David S. Miller" <davem@davemloft.net>
5516M: davem@davemloft.net
5517L: sparclinux@vger.kernel.org 4742L: sparclinux@vger.kernel.org
5518T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-2.6.git 4743T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-2.6.git
5519T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-next-2.6.git 4744T: git git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc-next-2.6.git
@@ -5521,15 +4746,13 @@ S: Maintained
5521F: arch/sparc/ 4746F: arch/sparc/
5522 4747
5523SPECIALIX IO8+ MULTIPORT SERIAL CARD DRIVER 4748SPECIALIX IO8+ MULTIPORT SERIAL CARD DRIVER
5524P: Roger Wolff 4749M: Roger Wolff <R.E.Wolff@BitWizard.nl>
5525M: R.E.Wolff@BitWizard.nl
5526S: Supported 4750S: Supported
5527F: Documentation/serial/specialix.txt 4751F: Documentation/serial/specialix.txt
5528F: drivers/char/specialix* 4752F: drivers/char/specialix*
5529 4753
5530SPI SUBSYSTEM 4754SPI SUBSYSTEM
5531P: David Brownell 4755M: David Brownell <dbrownell@users.sourceforge.net>
5532M: dbrownell@users.sourceforge.net
5533L: spi-devel-general@lists.sourceforge.net 4756L: spi-devel-general@lists.sourceforge.net
5534S: Maintained 4757S: Maintained
5535F: Documentation/spi/ 4758F: Documentation/spi/
@@ -5537,18 +4760,15 @@ F: drivers/spi/
5537F: include/linux/spi/ 4760F: include/linux/spi/
5538 4761
5539SPIDERNET NETWORK DRIVER for CELL 4762SPIDERNET NETWORK DRIVER for CELL
5540P: Ishizaki Kou 4763M: Ishizaki Kou <kou.ishizaki@toshiba.co.jp>
5541M: kou.ishizaki@toshiba.co.jp 4764M: Jens Osterkamp <jens@de.ibm.com>
5542P: Jens Osterkamp
5543M: jens@de.ibm.com
5544L: netdev@vger.kernel.org 4765L: netdev@vger.kernel.org
5545S: Supported 4766S: Supported
5546F: Documentation/networking/spider_net.txt 4767F: Documentation/networking/spider_net.txt
5547F: drivers/net/spider_net* 4768F: drivers/net/spider_net*
5548 4769
5549SPU FILE SYSTEM 4770SPU FILE SYSTEM
5550P: Jeremy Kerr 4771M: Jeremy Kerr <jk@ozlabs.org>
5551M: jk@ozlabs.org
5552L: linuxppc-dev@ozlabs.org 4772L: linuxppc-dev@ozlabs.org
5553L: cbe-oss-dev@ozlabs.org 4773L: cbe-oss-dev@ozlabs.org
5554W: http://www.ibm.com/developerworks/power/cell/ 4774W: http://www.ibm.com/developerworks/power/cell/
@@ -5557,8 +4777,7 @@ F: Documentation/filesystems/spufs.txt
5557F: arch/powerpc/platforms/cell/spufs/ 4777F: arch/powerpc/platforms/cell/spufs/
5558 4778
5559SQUASHFS FILE SYSTEM 4779SQUASHFS FILE SYSTEM
5560P: Phillip Lougher 4780M: Phillip Lougher <phillip@lougher.demon.co.uk>
5561M: phillip@lougher.demon.co.uk
5562L: squashfs-devel@lists.sourceforge.net (subscribers-only) 4781L: squashfs-devel@lists.sourceforge.net (subscribers-only)
5563W: http://squashfs.org.uk 4782W: http://squashfs.org.uk
5564S: Maintained 4783S: Maintained
@@ -5566,30 +4785,25 @@ F: Documentation/filesystems/squashfs.txt
5566F: fs/squashfs/ 4785F: fs/squashfs/
5567 4786
5568SRM (Alpha) environment access 4787SRM (Alpha) environment access
5569P: Jan-Benedict Glaw 4788M: Jan-Benedict Glaw <jbglaw@lug-owl.de>
5570M: jbglaw@lug-owl.de
5571S: Maintained 4789S: Maintained
5572F: arch/alpha/kernel/srm_env.c 4790F: arch/alpha/kernel/srm_env.c
5573 4791
5574STABLE BRANCH 4792STABLE BRANCH
5575P: Greg Kroah-Hartman 4793M: Greg Kroah-Hartman <greg@kroah.com>
5576M: greg@kroah.com 4794M: Chris Wright <chrisw@sous-sol.org>
5577P: Chris Wright
5578M: chrisw@sous-sol.org
5579L: stable@kernel.org 4795L: stable@kernel.org
5580S: Maintained 4796S: Maintained
5581 4797
5582STAGING SUBSYSTEM 4798STAGING SUBSYSTEM
5583P: Greg Kroah-Hartman 4799M: Greg Kroah-Hartman <gregkh@suse.de>
5584M: gregkh@suse.de
5585T: quilt kernel.org/pub/linux/kernel/people/gregkh/gregkh-2.6/ 4800T: quilt kernel.org/pub/linux/kernel/people/gregkh/gregkh-2.6/
5586L: devel@driverdev.osuosl.org 4801L: devel@driverdev.osuosl.org
5587S: Maintained 4802S: Maintained
5588F: drivers/staging/ 4803F: drivers/staging/
5589 4804
5590STARFIRE/DURALAN NETWORK DRIVER 4805STARFIRE/DURALAN NETWORK DRIVER
5591P: Ion Badulescu 4806M: Ion Badulescu <ionut@badula.org>
5592M: ionut@badula.org
5593S: Odd Fixes 4807S: Odd Fixes
5594F: drivers/net/starfire* 4808F: drivers/net/starfire*
5595 4809
@@ -5599,15 +4813,13 @@ F: drivers/net/wireless/strip.c
5599F: include/linux/if_strip.h 4813F: include/linux/if_strip.h
5600 4814
5601STRADIS MPEG-2 DECODER DRIVER 4815STRADIS MPEG-2 DECODER DRIVER
5602P: Nathan Laredo 4816M: Nathan Laredo <laredo@gnu.org>
5603M: laredo@gnu.org
5604W: http://www.stradis.com/ 4817W: http://www.stradis.com/
5605S: Maintained 4818S: Maintained
5606F: drivers/media/video/stradis.c 4819F: drivers/media/video/stradis.c
5607 4820
5608SUN3/3X 4821SUN3/3X
5609P: Sam Creasey 4822M: Sam Creasey <sammy@sammy.net>
5610M: sammy@sammy.net
5611W: http://sammy.net/sun3/ 4823W: http://sammy.net/sun3/
5612S: Maintained 4824S: Maintained
5613F: arch/m68k/kernel/*sun3* 4825F: arch/m68k/kernel/*sun3*
@@ -5615,8 +4827,7 @@ F: arch/m68k/sun3*/
5615F: arch/m68k/include/asm/sun3* 4827F: arch/m68k/include/asm/sun3*
5616 4828
5617SUPERH 4829SUPERH
5618P: Paul Mundt 4830M: Paul Mundt <lethal@linux-sh.org>
5619M: lethal@linux-sh.org
5620L: linux-sh@vger.kernel.org 4831L: linux-sh@vger.kernel.org
5621W: http://www.linux-sh.org 4832W: http://www.linux-sh.org
5622T: git git://git.kernel.org/pub/scm/linux/kernel/git/lethal/sh-2.6.git 4833T: git git://git.kernel.org/pub/scm/linux/kernel/git/lethal/sh-2.6.git
@@ -5626,12 +4837,9 @@ F: arch/sh/
5626F: drivers/sh/ 4837F: drivers/sh/
5627 4838
5628SUSPEND TO RAM 4839SUSPEND TO RAM
5629P: Len Brown 4840M: Len Brown <len.brown@intel.com>
5630M: len.brown@intel.com 4841M: Pavel Machek <pavel@ucw.cz>
5631P: Pavel Machek 4842M: "Rafael J. Wysocki" <rjw@sisk.pl>
5632M: pavel@ucw.cz
5633P: Rafael J. Wysocki
5634M: rjw@sisk.pl
5635L: linux-pm@lists.linux-foundation.org 4843L: linux-pm@lists.linux-foundation.org
5636S: Supported 4844S: Supported
5637F: Documentation/power/ 4845F: Documentation/power/
@@ -5643,32 +4851,28 @@ F: include/linux/freezer.h
5643F: include/linux/pm.h 4851F: include/linux/pm.h
5644 4852
5645SVGA HANDLING 4853SVGA HANDLING
5646P: Martin Mares 4854M: Martin Mares <mj@ucw.cz>
5647M: mj@ucw.cz
5648L: linux-video@atrey.karlin.mff.cuni.cz 4855L: linux-video@atrey.karlin.mff.cuni.cz
5649S: Maintained 4856S: Maintained
5650F: Documentation/svga.txt 4857F: Documentation/svga.txt
5651F: arch/x86/boot/video* 4858F: arch/x86/boot/video*
5652 4859
5653SYSV FILESYSTEM 4860SYSV FILESYSTEM
5654P: Christoph Hellwig 4861M: Christoph Hellwig <hch@infradead.org>
5655M: hch@infradead.org
5656S: Maintained 4862S: Maintained
5657F: Documentation/filesystems/sysv-fs.txt 4863F: Documentation/filesystems/sysv-fs.txt
5658F: fs/sysv/ 4864F: fs/sysv/
5659F: include/linux/sysv_fs.h 4865F: include/linux/sysv_fs.h
5660 4866
5661TASKSTATS STATISTICS INTERFACE 4867TASKSTATS STATISTICS INTERFACE
5662P: Balbir Singh 4868M: Balbir Singh <balbir@linux.vnet.ibm.com>
5663M: balbir@linux.vnet.ibm.com
5664S: Maintained 4869S: Maintained
5665F: Documentation/accounting/taskstats* 4870F: Documentation/accounting/taskstats*
5666F: include/linux/taskstats* 4871F: include/linux/taskstats*
5667F: kernel/taskstats.c 4872F: kernel/taskstats.c
5668 4873
5669TC CLASSIFIER 4874TC CLASSIFIER
5670P: Jamal Hadi Salim 4875M: Jamal Hadi Salim <hadi@cyberus.ca>
5671M: hadi@cyberus.ca
5672L: netdev@vger.kernel.org 4876L: netdev@vger.kernel.org
5673S: Maintained 4877S: Maintained
5674F: include/linux/pkt_cls.h 4878F: include/linux/pkt_cls.h
@@ -5676,38 +4880,31 @@ F: include/net/pkt_cls.h
5676F: net/sched/ 4880F: net/sched/
5677 4881
5678TCP LOW PRIORITY MODULE 4882TCP LOW PRIORITY MODULE
5679P: Wong Hoi Sing, Edison 4883M: "Wong Hoi Sing, Edison" <hswong3i@gmail.com>
5680M: hswong3i@gmail.com 4884M: "Hung Hing Lun, Mike" <hlhung3i@gmail.com>
5681P: Hung Hing Lun, Mike
5682M: hlhung3i@gmail.com
5683W: http://tcp-lp-mod.sourceforge.net/ 4885W: http://tcp-lp-mod.sourceforge.net/
5684S: Maintained 4886S: Maintained
5685F: net/ipv4/tcp_lp.c 4887F: net/ipv4/tcp_lp.c
5686 4888
5687TEHUTI ETHERNET DRIVER 4889TEHUTI ETHERNET DRIVER
5688P: Alexander Indenbaum 4890M: Alexander Indenbaum <baum@tehutinetworks.net>
5689M: baum@tehutinetworks.net 4891M: Andy Gospodarek <andy@greyhouse.net>
5690P: Andy Gospodarek
5691M: andy@greyhouse.net
5692L: netdev@vger.kernel.org 4892L: netdev@vger.kernel.org
5693S: Supported 4893S: Supported
5694F: drivers/net/tehuti* 4894F: drivers/net/tehuti*
5695 4895
5696Telecom Clock Driver for MCPL0010 4896Telecom Clock Driver for MCPL0010
5697P: Mark Gross 4897M: Mark Gross <mark.gross@intel.com>
5698M: mark.gross@intel.com
5699S: Supported 4898S: Supported
5700F: drivers/char/tlclk.c 4899F: drivers/char/tlclk.c
5701 4900
5702TENSILICA XTENSA PORT (xtensa) 4901TENSILICA XTENSA PORT (xtensa)
5703P: Chris Zankel 4902M: Chris Zankel <chris@zankel.net>
5704M: chris@zankel.net
5705S: Maintained 4903S: Maintained
5706F: arch/xtensa/ 4904F: arch/xtensa/
5707 4905
5708THINKPAD ACPI EXTRAS DRIVER 4906THINKPAD ACPI EXTRAS DRIVER
5709P: Henrique de Moraes Holschuh 4907M: Henrique de Moraes Holschuh <ibm-acpi@hmh.eng.br>
5710M: ibm-acpi@hmh.eng.br
5711L: ibm-acpi-devel@lists.sourceforge.net 4908L: ibm-acpi-devel@lists.sourceforge.net
5712W: http://ibm-acpi.sourceforge.net 4909W: http://ibm-acpi.sourceforge.net
5713W: http://thinkwiki.org/wiki/Ibm-acpi 4910W: http://thinkwiki.org/wiki/Ibm-acpi
@@ -5716,27 +4913,22 @@ S: Maintained
5716F: drivers/platform/x86/thinkpad_acpi.c 4913F: drivers/platform/x86/thinkpad_acpi.c
5717 4914
5718TI FLASH MEDIA INTERFACE DRIVER 4915TI FLASH MEDIA INTERFACE DRIVER
5719P: Alex Dubov 4916M: Alex Dubov <oakad@yahoo.com>
5720M: oakad@yahoo.com
5721S: Maintained 4917S: Maintained
5722F: drivers/misc/tifm* 4918F: drivers/misc/tifm*
5723F: drivers/mmc/host/tifm_sd.c 4919F: drivers/mmc/host/tifm_sd.c
5724F: include/linux/tifm.h 4920F: include/linux/tifm.h
5725 4921
5726TI TWL4030 SERIES SOC CODEC DRIVER 4922TI TWL4030 SERIES SOC CODEC DRIVER
5727P: Peter Ujfalusi 4923M: Peter Ujfalusi <peter.ujfalusi@nokia.com>
5728M: peter.ujfalusi@nokia.com
5729L: alsa-devel@alsa-project.org (moderated for non-subscribers) 4924L: alsa-devel@alsa-project.org (moderated for non-subscribers)
5730S: Maintained 4925S: Maintained
5731F: sound/soc/codecs/twl4030* 4926F: sound/soc/codecs/twl4030*
5732 4927
5733TIPC NETWORK LAYER 4928TIPC NETWORK LAYER
5734P: Per Liden 4929M: Per Liden <per.liden@ericsson.com>
5735M: per.liden@ericsson.com 4930M: Jon Maloy <jon.maloy@ericsson.com>
5736P: Jon Maloy 4931M: Allan Stephens <allan.stephens@windriver.com>
5737M: jon.maloy@ericsson.com
5738P: Allan Stephens
5739M: allan.stephens@windriver.com
5740L: tipc-discussion@lists.sourceforge.net 4932L: tipc-discussion@lists.sourceforge.net
5741W: http://tipc.sourceforge.net/ 4933W: http://tipc.sourceforge.net/
5742W: http://tipc.cslab.ericsson.net/ 4934W: http://tipc.cslab.ericsson.net/
@@ -5747,8 +4939,7 @@ F: include/net/tipc/
5747F: net/tipc/ 4939F: net/tipc/
5748 4940
5749TLAN NETWORK DRIVER 4941TLAN NETWORK DRIVER
5750P: Samuel Chessman 4942M: Samuel Chessman <chessman@tux.org>
5751M: chessman@tux.org
5752L: tlan-devel@lists.sourceforge.net (subscribers-only) 4943L: tlan-devel@lists.sourceforge.net (subscribers-only)
5753W: http://sourceforge.net/projects/tlan/ 4944W: http://sourceforge.net/projects/tlan/
5754S: Maintained 4945S: Maintained
@@ -5756,10 +4947,8 @@ F: Documentation/networking/tlan.txt
5756F: drivers/net/tlan.* 4947F: drivers/net/tlan.*
5757 4948
5758TOMOYO SECURITY MODULE 4949TOMOYO SECURITY MODULE
5759P: Kentaro Takeda 4950M: Kentaro Takeda <takedakn@nttdata.co.jp>
5760M: takedakn@nttdata.co.jp 4951M: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp>
5761P: Tetsuo Handa
5762M: penguin-kernel@I-love.SAKURA.ne.jp
5763L: tomoyo-users-en@lists.sourceforge.jp (subscribers-only, for developers and users in English) 4952L: tomoyo-users-en@lists.sourceforge.jp (subscribers-only, for developers and users in English)
5764L: tomoyo-dev@lists.sourceforge.jp (subscribers-only, for developers in Japanese) 4953L: tomoyo-dev@lists.sourceforge.jp (subscribers-only, for developers in Japanese)
5765L: tomoyo-users@lists.sourceforge.jp (subscribers-only, for users in Japanese) 4954L: tomoyo-users@lists.sourceforge.jp (subscribers-only, for users in Japanese)
@@ -5773,8 +4962,7 @@ S: Orphan
5773F: drivers/platform/x86/toshiba_acpi.c 4962F: drivers/platform/x86/toshiba_acpi.c
5774 4963
5775TOSHIBA SMM DRIVER 4964TOSHIBA SMM DRIVER
5776P: Jonathan Buzzard 4965M: Jonathan Buzzard <jonathan@buzzard.org.uk>
5777M: jonathan@buzzard.org.uk
5778L: tlinux-users@tce.toshiba-dme.co.jp 4966L: tlinux-users@tce.toshiba-dme.co.jp
5779W: http://www.buzzard.org.uk/toshiba/ 4967W: http://www.buzzard.org.uk/toshiba/
5780S: Maintained 4968S: Maintained
@@ -5782,41 +4970,34 @@ F: drivers/char/toshiba.c
5782F: include/linux/toshiba.h 4970F: include/linux/toshiba.h
5783 4971
5784TMIO MMC DRIVER 4972TMIO MMC DRIVER
5785P: Ian Molton 4973M: Ian Molton <ian@mnementh.co.uk>
5786M: ian@mnementh.co.uk
5787S: Maintained 4974S: Maintained
5788F: drivers/mmc/host/tmio_mmc.* 4975F: drivers/mmc/host/tmio_mmc.*
5789 4976
5790TMPFS (SHMEM FILESYSTEM) 4977TMPFS (SHMEM FILESYSTEM)
5791P: Hugh Dickins 4978M: Hugh Dickins <hugh.dickins@tiscali.co.uk>
5792M: hugh.dickins@tiscali.co.uk
5793L: linux-mm@kvack.org 4979L: linux-mm@kvack.org
5794S: Maintained 4980S: Maintained
5795F: include/linux/shmem_fs.h 4981F: include/linux/shmem_fs.h
5796F: mm/shmem.c 4982F: mm/shmem.c
5797 4983
5798TPM DEVICE DRIVER 4984TPM DEVICE DRIVER
5799P: Debora Velarde 4985M: Debora Velarde <debora@linux.vnet.ibm.com>
5800M: debora@linux.vnet.ibm.com 4986M: Rajiv Andrade <srajiv@linux.vnet.ibm.com>
5801P: Rajiv Andrade
5802M: srajiv@linux.vnet.ibm.com
5803W: http://tpmdd.sourceforge.net 4987W: http://tpmdd.sourceforge.net
5804P: Marcel Selhorst 4988M: Marcel Selhorst <m.selhorst@sirrix.com>
5805M: m.selhorst@sirrix.com
5806W: http://www.sirrix.com 4989W: http://www.sirrix.com
5807L: tpmdd-devel@lists.sourceforge.net (moderated for non-subscribers) 4990L: tpmdd-devel@lists.sourceforge.net (moderated for non-subscribers)
5808S: Maintained 4991S: Maintained
5809F: drivers/char/tpm/ 4992F: drivers/char/tpm/
5810 4993
5811TRIVIAL PATCHES 4994TRIVIAL PATCHES
5812P: Jiri Kosina 4995M: Jiri Kosina <trivial@kernel.org>
5813M: trivial@kernel.org
5814T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/trivial.git 4996T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/trivial.git
5815S: Maintained 4997S: Maintained
5816 4998
5817TTY LAYER 4999TTY LAYER
5818P: Alan Cox 5000M: Alan Cox <alan@lxorguk.ukuu.org.uk>
5819M: alan@lxorguk.ukuu.org.uk
5820S: Maintained 5001S: Maintained
5821T: stgit http://zeniv.linux.org.uk/~alan/ttydev/ 5002T: stgit http://zeniv.linux.org.uk/~alan/ttydev/
5822F: drivers/char/tty_* 5003F: drivers/char/tty_*
@@ -5826,17 +5007,14 @@ F: include/linux/serial.h
5826F: include/linux/tty.h 5007F: include/linux/tty.h
5827 5008
5828TULIP NETWORK DRIVERS 5009TULIP NETWORK DRIVERS
5829P: Grant Grundler 5010M: Grant Grundler <grundler@parisc-linux.org>
5830M: grundler@parisc-linux.org 5011M: Kyle McMartin <kyle@mcmartin.ca>
5831P: Kyle McMartin
5832M: kyle@mcmartin.ca
5833L: netdev@vger.kernel.org 5012L: netdev@vger.kernel.org
5834S: Maintained 5013S: Maintained
5835F: drivers/net/tulip/ 5014F: drivers/net/tulip/
5836 5015
5837TUN/TAP driver 5016TUN/TAP driver
5838P: Maxim Krasnyansky 5017M: Maxim Krasnyansky <maxk@qualcomm.com>
5839M: maxk@qualcomm.com
5840L: vtun@office.satix.net 5018L: vtun@office.satix.net
5841W: http://vtun.sourceforge.net/tun 5019W: http://vtun.sourceforge.net/tun
5842S: Maintained 5020S: Maintained
@@ -5844,24 +5022,20 @@ F: Documentation/networking/tuntap.txt
5844F: arch/um/os-Linux/drivers/ 5022F: arch/um/os-Linux/drivers/
5845 5023
5846TURBOCHANNEL SUBSYSTEM 5024TURBOCHANNEL SUBSYSTEM
5847P: Maciej W. Rozycki 5025M: "Maciej W. Rozycki" <macro@linux-mips.org>
5848M: macro@linux-mips.org
5849S: Maintained 5026S: Maintained
5850F: drivers/tc/ 5027F: drivers/tc/
5851F: include/linux/tc.h 5028F: include/linux/tc.h
5852 5029
5853U14-34F SCSI DRIVER 5030U14-34F SCSI DRIVER
5854P: Dario Ballabio 5031M: Dario Ballabio <ballabio_dario@emc.com>
5855M: ballabio_dario@emc.com
5856L: linux-scsi@vger.kernel.org 5032L: linux-scsi@vger.kernel.org
5857S: Maintained 5033S: Maintained
5858F: drivers/scsi/u14-34f.c 5034F: drivers/scsi/u14-34f.c
5859 5035
5860UBI FILE SYSTEM (UBIFS) 5036UBI FILE SYSTEM (UBIFS)
5861P: Artem Bityutskiy 5037M: Artem Bityutskiy <dedekind@infradead.org>
5862M: dedekind@infradead.org 5038M: Adrian Hunter <adrian.hunter@nokia.com>
5863P: Adrian Hunter
5864M: adrian.hunter@nokia.com
5865L: linux-mtd@lists.infradead.org 5039L: linux-mtd@lists.infradead.org
5866T: git git://git.infradead.org/ubifs-2.6.git 5040T: git git://git.infradead.org/ubifs-2.6.git
5867W: http://www.linux-mtd.infradead.org/doc/ubifs.html 5041W: http://www.linux-mtd.infradead.org/doc/ubifs.html
@@ -5870,37 +5044,32 @@ F: Documentation/filesystems/ubifs.txt
5870F: fs/ubifs/ 5044F: fs/ubifs/
5871 5045
5872UCLINUX (AND M68KNOMMU) 5046UCLINUX (AND M68KNOMMU)
5873P: Greg Ungerer 5047M: Greg Ungerer <gerg@uclinux.org>
5874M: gerg@uclinux.org
5875W: http://www.uclinux.org/ 5048W: http://www.uclinux.org/
5876L: uclinux-dev@uclinux.org (subscribers-only) 5049L: uclinux-dev@uclinux.org (subscribers-only)
5877S: Maintained 5050S: Maintained
5878F: arch/m68knommu/ 5051F: arch/m68knommu/
5879 5052
5880UCLINUX FOR RENESAS H8/300 (H8300) 5053UCLINUX FOR RENESAS H8/300 (H8300)
5881P: Yoshinori Sato 5054M: Yoshinori Sato <ysato@users.sourceforge.jp>
5882M: ysato@users.sourceforge.jp
5883W: http://uclinux-h8.sourceforge.jp/ 5055W: http://uclinux-h8.sourceforge.jp/
5884S: Supported 5056S: Supported
5885 5057
5886UDF FILESYSTEM 5058UDF FILESYSTEM
5887P: Jan Kara 5059M: Jan Kara <jack@suse.cz>
5888M: jack@suse.cz
5889W: http://linux-udf.sourceforge.net 5060W: http://linux-udf.sourceforge.net
5890S: Maintained 5061S: Maintained
5891F: Documentation/filesystems/udf.txt 5062F: Documentation/filesystems/udf.txt
5892F: fs/udf/ 5063F: fs/udf/
5893 5064
5894UFS FILESYSTEM 5065UFS FILESYSTEM
5895P: Evgeniy Dushistov 5066M: Evgeniy Dushistov <dushistov@mail.ru>
5896M: dushistov@mail.ru
5897S: Maintained 5067S: Maintained
5898F: Documentation/filesystems/ufs.txt 5068F: Documentation/filesystems/ufs.txt
5899F: fs/ufs/ 5069F: fs/ufs/
5900 5070
5901ULTRA-WIDEBAND (UWB) SUBSYSTEM: 5071ULTRA-WIDEBAND (UWB) SUBSYSTEM:
5902P: David Vrabel 5072M: David Vrabel <david.vrabel@csr.com>
5903M: david.vrabel@csr.com
5904L: linux-usb@vger.kernel.org 5073L: linux-usb@vger.kernel.org
5905S: Supported 5074S: Supported
5906F: drivers/uwb/* 5075F: drivers/uwb/*
@@ -5908,8 +5077,7 @@ F: include/linux/uwb.h
5908F: include/linux/uwb/ 5077F: include/linux/uwb/
5909 5078
5910UNIFORM CDROM DRIVER 5079UNIFORM CDROM DRIVER
5911P: Jens Axboe 5080M: Jens Axboe <axboe@kernel.dk>
5912M: axboe@kernel.dk
5913W: http://www.kernel.dk 5081W: http://www.kernel.dk
5914S: Maintained 5082S: Maintained
5915F: Documentation/cdrom/ 5083F: Documentation/cdrom/
@@ -5917,8 +5085,7 @@ F: drivers/cdrom/cdrom.c
5917F: include/linux/cdrom.h 5085F: include/linux/cdrom.h
5918 5086
5919UNSORTED BLOCK IMAGES (UBI) 5087UNSORTED BLOCK IMAGES (UBI)
5920P: Artem Bityutskiy 5088M: Artem Bityutskiy <dedekind@infradead.org>
5921M: dedekind@infradead.org
5922W: http://www.linux-mtd.infradead.org/ 5089W: http://www.linux-mtd.infradead.org/
5923L: linux-mtd@lists.infradead.org 5090L: linux-mtd@lists.infradead.org
5924T: git git://git.infradead.org/ubi-2.6.git 5091T: git git://git.infradead.org/ubi-2.6.git
@@ -5928,23 +5095,20 @@ F: include/linux/mtd/ubi.h
5928F: include/mtd/ubi-user.h 5095F: include/mtd/ubi-user.h
5929 5096
5930USB ACM DRIVER 5097USB ACM DRIVER
5931P: Oliver Neukum 5098M: Oliver Neukum <oliver@neukum.name>
5932M: oliver@neukum.name
5933L: linux-usb@vger.kernel.org 5099L: linux-usb@vger.kernel.org
5934S: Maintained 5100S: Maintained
5935F: Documentation/usb/acm.txt 5101F: Documentation/usb/acm.txt
5936F: drivers/usb/class/cdc-acm.* 5102F: drivers/usb/class/cdc-acm.*
5937 5103
5938USB BLOCK DRIVER (UB ub) 5104USB BLOCK DRIVER (UB ub)
5939P: Pete Zaitcev 5105M: Pete Zaitcev <zaitcev@redhat.com>
5940M: zaitcev@redhat.com
5941L: linux-usb@vger.kernel.org 5106L: linux-usb@vger.kernel.org
5942S: Supported 5107S: Supported
5943F: drivers/block/ub.c 5108F: drivers/block/ub.c
5944 5109
5945USB CDC ETHERNET DRIVER 5110USB CDC ETHERNET DRIVER
5946P: Greg Kroah-Hartman 5111M: Greg Kroah-Hartman <greg@kroah.com>
5947M: greg@kroah.com
5948L: linux-usb@vger.kernel.org 5112L: linux-usb@vger.kernel.org
5949S: Maintained 5113S: Maintained
5950W: http://www.kroah.com/linux-usb/ 5114W: http://www.kroah.com/linux-usb/
@@ -5952,39 +5116,34 @@ F: drivers/net/usb/cdc_*.c
5952F: include/linux/usb/cdc.h 5116F: include/linux/usb/cdc.h
5953 5117
5954USB CYPRESS C67X00 DRIVER 5118USB CYPRESS C67X00 DRIVER
5955P: Peter Korsgaard 5119M: Peter Korsgaard <jacmet@sunsite.dk>
5956M: jacmet@sunsite.dk
5957L: linux-usb@vger.kernel.org 5120L: linux-usb@vger.kernel.org
5958S: Maintained 5121S: Maintained
5959F: drivers/usb/c67x00/ 5122F: drivers/usb/c67x00/
5960 5123
5961USB DAVICOM DM9601 DRIVER 5124USB DAVICOM DM9601 DRIVER
5962P: Peter Korsgaard 5125M: Peter Korsgaard <jacmet@sunsite.dk>
5963M: jacmet@sunsite.dk
5964L: netdev@vger.kernel.org 5126L: netdev@vger.kernel.org
5965W: http://www.linux-usb.org/usbnet 5127W: http://www.linux-usb.org/usbnet
5966S: Maintained 5128S: Maintained
5967F: drivers/net/usb/dm9601.c 5129F: drivers/net/usb/dm9601.c
5968 5130
5969USB DIAMOND RIO500 DRIVER 5131USB DIAMOND RIO500 DRIVER
5970P: Cesar Miquel 5132M: Cesar Miquel <miquel@df.uba.ar>
5971M: miquel@df.uba.ar
5972L: rio500-users@lists.sourceforge.net 5133L: rio500-users@lists.sourceforge.net
5973W: http://rio500.sourceforge.net 5134W: http://rio500.sourceforge.net
5974S: Maintained 5135S: Maintained
5975F: drivers/usb/misc/rio500* 5136F: drivers/usb/misc/rio500*
5976 5137
5977USB EHCI DRIVER 5138USB EHCI DRIVER
5978P: David Brownell 5139M: David Brownell <dbrownell@users.sourceforge.net>
5979M: dbrownell@users.sourceforge.net
5980L: linux-usb@vger.kernel.org 5140L: linux-usb@vger.kernel.org
5981S: Odd Fixes 5141S: Odd Fixes
5982F: Documentation/usb/ehci.txt 5142F: Documentation/usb/ehci.txt
5983F: drivers/usb/host/ehci* 5143F: drivers/usb/host/ehci*
5984 5144
5985USB ET61X[12]51 DRIVER 5145USB ET61X[12]51 DRIVER
5986P: Luca Risolia 5146M: Luca Risolia <luca.risolia@studio.unibo.it>
5987M: luca.risolia@studio.unibo.it
5988L: linux-usb@vger.kernel.org 5147L: linux-usb@vger.kernel.org
5989L: linux-media@vger.kernel.org 5148L: linux-media@vger.kernel.org
5990T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 5149T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
@@ -5993,8 +5152,7 @@ S: Maintained
5993F: drivers/media/video/et61x251/ 5152F: drivers/media/video/et61x251/
5994 5153
5995USB GADGET/PERIPHERAL SUBSYSTEM 5154USB GADGET/PERIPHERAL SUBSYSTEM
5996P: David Brownell 5155M: David Brownell <dbrownell@users.sourceforge.net>
5997M: dbrownell@users.sourceforge.net
5998L: linux-usb@vger.kernel.org 5156L: linux-usb@vger.kernel.org
5999W: http://www.linux-usb.org/gadget 5157W: http://www.linux-usb.org/gadget
6000S: Maintained 5158S: Maintained
@@ -6002,8 +5160,7 @@ F: drivers/usb/gadget/
6002F: include/linux/usb/gadget* 5160F: include/linux/usb/gadget*
6003 5161
6004USB HID/HIDBP DRIVERS (USB KEYBOARDS, MICE, REMOTE CONTROLS, ...) 5162USB HID/HIDBP DRIVERS (USB KEYBOARDS, MICE, REMOTE CONTROLS, ...)
6005P: Jiri Kosina 5163M: Jiri Kosina <jkosina@suse.cz>
6006M: jkosina@suse.cz
6007L: linux-usb@vger.kernel.org 5164L: linux-usb@vger.kernel.org
6008T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/hid.git 5165T: git git://git.kernel.org/pub/scm/linux/kernel/git/jikos/hid.git
6009S: Maintained 5166S: Maintained
@@ -6011,23 +5168,20 @@ F: Documentation/usb/hiddev.txt
6011F: drivers/hid/usbhid/ 5168F: drivers/hid/usbhid/
6012 5169
6013USB ISP116X DRIVER 5170USB ISP116X DRIVER
6014P: Olav Kongas 5171M: Olav Kongas <ok@artecdesign.ee>
6015M: ok@artecdesign.ee
6016L: linux-usb@vger.kernel.org 5172L: linux-usb@vger.kernel.org
6017S: Maintained 5173S: Maintained
6018F: drivers/usb/host/isp116x* 5174F: drivers/usb/host/isp116x*
6019F: include/linux/usb/isp116x.h 5175F: include/linux/usb/isp116x.h
6020 5176
6021USB KAWASAKI LSI DRIVER 5177USB KAWASAKI LSI DRIVER
6022P: Oliver Neukum 5178M: Oliver Neukum <oliver@neukum.name>
6023M: oliver@neukum.name
6024L: linux-usb@vger.kernel.org 5179L: linux-usb@vger.kernel.org
6025S: Maintained 5180S: Maintained
6026F: drivers/usb/serial/kl5kusb105.* 5181F: drivers/usb/serial/kl5kusb105.*
6027 5182
6028USB MASS STORAGE DRIVER 5183USB MASS STORAGE DRIVER
6029P: Matthew Dharm 5184M: Matthew Dharm <mdharm-usb@one-eyed-alien.net>
6030M: mdharm-usb@one-eyed-alien.net
6031L: linux-usb@vger.kernel.org 5185L: linux-usb@vger.kernel.org
6032L: usb-storage@lists.one-eyed-alien.net 5186L: usb-storage@lists.one-eyed-alien.net
6033S: Maintained 5187S: Maintained
@@ -6035,31 +5189,27 @@ W: http://www.one-eyed-alien.net/~mdharm/linux-usb/
6035F: drivers/usb/storage/ 5189F: drivers/usb/storage/
6036 5190
6037USB OHCI DRIVER 5191USB OHCI DRIVER
6038P: David Brownell 5192M: David Brownell <dbrownell@users.sourceforge.net>
6039M: dbrownell@users.sourceforge.net
6040L: linux-usb@vger.kernel.org 5193L: linux-usb@vger.kernel.org
6041S: Odd Fixes 5194S: Odd Fixes
6042F: Documentation/usb/ohci.txt 5195F: Documentation/usb/ohci.txt
6043F: drivers/usb/host/ohci* 5196F: drivers/usb/host/ohci*
6044 5197
6045USB OPTION-CARD DRIVER 5198USB OPTION-CARD DRIVER
6046P: Matthias Urlichs 5199M: Matthias Urlichs <smurf@smurf.noris.de>
6047M: smurf@smurf.noris.de
6048L: linux-usb@vger.kernel.org 5200L: linux-usb@vger.kernel.org
6049S: Maintained 5201S: Maintained
6050F: drivers/usb/serial/option.c 5202F: drivers/usb/serial/option.c
6051 5203
6052USB OV511 DRIVER 5204USB OV511 DRIVER
6053P: Mark McClelland 5205M: Mark McClelland <mmcclell@bigfoot.com>
6054M: mmcclell@bigfoot.com
6055L: linux-usb@vger.kernel.org 5206L: linux-usb@vger.kernel.org
6056W: http://alpha.dyndns.org/ov511/ 5207W: http://alpha.dyndns.org/ov511/
6057S: Maintained 5208S: Maintained
6058F: drivers/media/video/ov511.* 5209F: drivers/media/video/ov511.*
6059 5210
6060USB PEGASUS DRIVER 5211USB PEGASUS DRIVER
6061P: Petko Manolov 5212M: Petko Manolov <petkan@users.sourceforge.net>
6062M: petkan@users.sourceforge.net
6063L: linux-usb@vger.kernel.org 5213L: linux-usb@vger.kernel.org
6064L: netdev@vger.kernel.org 5214L: netdev@vger.kernel.org
6065W: http://pegasus2.sourceforge.net/ 5215W: http://pegasus2.sourceforge.net/
@@ -6067,15 +5217,13 @@ S: Maintained
6067F: drivers/net/usb/pegasus.* 5217F: drivers/net/usb/pegasus.*
6068 5218
6069USB PRINTER DRIVER (usblp) 5219USB PRINTER DRIVER (usblp)
6070P: Pete Zaitcev 5220M: Pete Zaitcev <zaitcev@redhat.com>
6071M: zaitcev@redhat.com
6072L: linux-usb@vger.kernel.org 5221L: linux-usb@vger.kernel.org
6073S: Supported 5222S: Supported
6074F: drivers/usb/class/usblp.c 5223F: drivers/usb/class/usblp.c
6075 5224
6076USB RTL8150 DRIVER 5225USB RTL8150 DRIVER
6077P: Petko Manolov 5226M: Petko Manolov <petkan@users.sourceforge.net>
6078M: petkan@users.sourceforge.net
6079L: linux-usb@vger.kernel.org 5227L: linux-usb@vger.kernel.org
6080L: netdev@vger.kernel.org 5228L: netdev@vger.kernel.org
6081W: http://pegasus2.sourceforge.net/ 5229W: http://pegasus2.sourceforge.net/
@@ -6083,8 +5231,7 @@ S: Maintained
6083F: drivers/net/usb/rtl8150.c 5231F: drivers/net/usb/rtl8150.c
6084 5232
6085USB SE401 DRIVER 5233USB SE401 DRIVER
6086P: Jeroen Vreeken 5234M: Jeroen Vreeken <pe1rxq@amsat.org>
6087M: pe1rxq@amsat.org
6088L: linux-usb@vger.kernel.org 5235L: linux-usb@vger.kernel.org
6089W: http://www.chello.nl/~j.vreeken/se401/ 5236W: http://www.chello.nl/~j.vreeken/se401/
6090S: Maintained 5237S: Maintained
@@ -6092,15 +5239,13 @@ F: Documentation/video4linux/se401.txt
6092F: drivers/media/video/se401.* 5239F: drivers/media/video/se401.*
6093 5240
6094USB SERIAL BELKIN F5U103 DRIVER 5241USB SERIAL BELKIN F5U103 DRIVER
6095P: William Greathouse 5242M: William Greathouse <wgreathouse@smva.com>
6096M: wgreathouse@smva.com
6097L: linux-usb@vger.kernel.org 5243L: linux-usb@vger.kernel.org
6098S: Maintained 5244S: Maintained
6099F: drivers/usb/serial/belkin_sa.* 5245F: drivers/usb/serial/belkin_sa.*
6100 5246
6101USB SERIAL CYPRESS M8 DRIVER 5247USB SERIAL CYPRESS M8 DRIVER
6102P: Lonnie Mendez 5248M: Lonnie Mendez <dignome@gmail.com>
6103M: dignome@gmail.com
6104L: linux-usb@vger.kernel.org 5249L: linux-usb@vger.kernel.org
6105S: Maintained 5250S: Maintained
6106W: http://geocities.com/i0xox0i 5251W: http://geocities.com/i0xox0i
@@ -6108,23 +5253,20 @@ W: http://firstlight.net/cvs
6108F: drivers/usb/serial/cypress_m8.* 5253F: drivers/usb/serial/cypress_m8.*
6109 5254
6110USB SERIAL CYBERJACK DRIVER 5255USB SERIAL CYBERJACK DRIVER
6111P: Matthias Bruestle and Harald Welte 5256M: Matthias Bruestle and Harald Welte <support@reiner-sct.com>
6112M: support@reiner-sct.com
6113W: http://www.reiner-sct.de/support/treiber_cyberjack.php 5257W: http://www.reiner-sct.de/support/treiber_cyberjack.php
6114S: Maintained 5258S: Maintained
6115F: drivers/usb/serial/cyberjack.c 5259F: drivers/usb/serial/cyberjack.c
6116 5260
6117USB SERIAL DIGI ACCELEPORT DRIVER 5261USB SERIAL DIGI ACCELEPORT DRIVER
6118P: Peter Berger and Al Borchers 5262M: Peter Berger <pberger@brimson.com>
6119M: pberger@brimson.com 5263M: Al Borchers <alborchers@steinerpoint.com>
6120M: alborchers@steinerpoint.com
6121L: linux-usb@vger.kernel.org 5264L: linux-usb@vger.kernel.org
6122S: Maintained 5265S: Maintained
6123F: drivers/usb/serial/digi_acceleport.c 5266F: drivers/usb/serial/digi_acceleport.c
6124 5267
6125USB SERIAL DRIVER 5268USB SERIAL DRIVER
6126P: Greg Kroah-Hartman 5269M: Greg Kroah-Hartman <gregkh@suse.de>
6127M: gregkh@suse.de
6128L: linux-usb@vger.kernel.org 5270L: linux-usb@vger.kernel.org
6129S: Supported 5271S: Supported
6130F: Documentation/usb/usb-serial.txt 5272F: Documentation/usb/usb-serial.txt
@@ -6133,38 +5275,33 @@ F: drivers/usb/serial/usb-serial.c
6133F: include/linux/usb/serial.h 5275F: include/linux/usb/serial.h
6134 5276
6135USB SERIAL EMPEG EMPEG-CAR MARK I/II DRIVER 5277USB SERIAL EMPEG EMPEG-CAR MARK I/II DRIVER
6136P: Gary Brubaker 5278M: Gary Brubaker <xavyer@ix.netcom.com>
6137M: xavyer@ix.netcom.com
6138L: linux-usb@vger.kernel.org 5279L: linux-usb@vger.kernel.org
6139S: Maintained 5280S: Maintained
6140F: drivers/usb/serial/empeg.c 5281F: drivers/usb/serial/empeg.c
6141 5282
6142USB SERIAL KEYSPAN DRIVER 5283USB SERIAL KEYSPAN DRIVER
6143P: Greg Kroah-Hartman 5284M: Greg Kroah-Hartman <greg@kroah.com>
6144M: greg@kroah.com
6145L: linux-usb@vger.kernel.org 5285L: linux-usb@vger.kernel.org
6146W: http://www.kroah.com/linux/ 5286W: http://www.kroah.com/linux/
6147S: Maintained 5287S: Maintained
6148F: drivers/usb/serial/*keyspan* 5288F: drivers/usb/serial/*keyspan*
6149 5289
6150USB SERIAL WHITEHEAT DRIVER 5290USB SERIAL WHITEHEAT DRIVER
6151P: Support Department 5291M: Support Department <support@connecttech.com>
6152M: support@connecttech.com
6153L: linux-usb@vger.kernel.org 5292L: linux-usb@vger.kernel.org
6154W: http://www.connecttech.com 5293W: http://www.connecttech.com
6155S: Supported 5294S: Supported
6156F: drivers/usb/serial/whiteheat* 5295F: drivers/usb/serial/whiteheat*
6157 5296
6158USB SMSC95XX ETHERNET DRIVER 5297USB SMSC95XX ETHERNET DRIVER
6159P: Steve Glendinning 5298M: Steve Glendinning <steve.glendinning@smsc.com>
6160M: steve.glendinning@smsc.com
6161L: netdev@vger.kernel.org 5299L: netdev@vger.kernel.org
6162S: Supported 5300S: Supported
6163F: drivers/net/usb/smsc95xx.* 5301F: drivers/net/usb/smsc95xx.*
6164 5302
6165USB SN9C1xx DRIVER 5303USB SN9C1xx DRIVER
6166P: Luca Risolia 5304M: Luca Risolia <luca.risolia@studio.unibo.it>
6167M: luca.risolia@studio.unibo.it
6168L: linux-usb@vger.kernel.org 5305L: linux-usb@vger.kernel.org
6169L: linux-media@vger.kernel.org 5306L: linux-media@vger.kernel.org
6170T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 5307T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
@@ -6174,8 +5311,7 @@ F: Documentation/video4linux/sn9c102.txt
6174F: drivers/media/video/sn9c102/ 5311F: drivers/media/video/sn9c102/
6175 5312
6176USB SUBSYSTEM 5313USB SUBSYSTEM
6177P: Greg Kroah-Hartman 5314M: Greg Kroah-Hartman <gregkh@suse.de>
6178M: gregkh@suse.de
6179L: linux-usb@vger.kernel.org 5315L: linux-usb@vger.kernel.org
6180W: http://www.linux-usb.org 5316W: http://www.linux-usb.org
6181T: quilt kernel.org/pub/linux/kernel/people/gregkh/gregkh-2.6/ 5317T: quilt kernel.org/pub/linux/kernel/people/gregkh/gregkh-2.6/
@@ -6187,15 +5323,13 @@ F: include/linux/usb.h
6187F: include/linux/usb/ 5323F: include/linux/usb/
6188 5324
6189USB UHCI DRIVER 5325USB UHCI DRIVER
6190P: Alan Stern 5326M: Alan Stern <stern@rowland.harvard.edu>
6191M: stern@rowland.harvard.edu
6192L: linux-usb@vger.kernel.org 5327L: linux-usb@vger.kernel.org
6193S: Maintained 5328S: Maintained
6194F: drivers/usb/host/uhci* 5329F: drivers/usb/host/uhci*
6195 5330
6196USB "USBNET" DRIVER FRAMEWORK 5331USB "USBNET" DRIVER FRAMEWORK
6197P: David Brownell 5332M: David Brownell <dbrownell@users.sourceforge.net>
6198M: dbrownell@users.sourceforge.net
6199L: netdev@vger.kernel.org 5333L: netdev@vger.kernel.org
6200W: http://www.linux-usb.org/usbnet 5334W: http://www.linux-usb.org/usbnet
6201S: Maintained 5335S: Maintained
@@ -6203,8 +5337,7 @@ F: drivers/net/usb/usbnet.c
6203F: include/linux/usb/usbnet.h 5337F: include/linux/usb/usbnet.h
6204 5338
6205USB VIDEO CLASS 5339USB VIDEO CLASS
6206P: Laurent Pinchart 5340M: Laurent Pinchart <laurent.pinchart@skynet.be>
6207M: laurent.pinchart@skynet.be
6208L: linux-uvc-devel@lists.berlios.de (subscribers-only) 5341L: linux-uvc-devel@lists.berlios.de (subscribers-only)
6209L: linux-media@vger.kernel.org 5342L: linux-media@vger.kernel.org
6210T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 5343T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
@@ -6213,8 +5346,7 @@ S: Maintained
6213F: drivers/media/video/uvc/ 5346F: drivers/media/video/uvc/
6214 5347
6215USB W996[87]CF DRIVER 5348USB W996[87]CF DRIVER
6216P: Luca Risolia 5349M: Luca Risolia <luca.risolia@studio.unibo.it>
6217M: luca.risolia@studio.unibo.it
6218L: linux-usb@vger.kernel.org 5350L: linux-usb@vger.kernel.org
6219L: linux-media@vger.kernel.org 5351L: linux-media@vger.kernel.org
6220T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 5352T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
@@ -6224,21 +5356,18 @@ F: Documentation/video4linux/w9968cf.txt
6224F: drivers/media/video/w996* 5356F: drivers/media/video/w996*
6225 5357
6226USB WIRELESS RNDIS DRIVER (rndis_wlan) 5358USB WIRELESS RNDIS DRIVER (rndis_wlan)
6227P: Jussi Kivilinna 5359M: Jussi Kivilinna <jussi.kivilinna@mbnet.fi>
6228M: jussi.kivilinna@mbnet.fi
6229L: linux-wireless@vger.kernel.org 5360L: linux-wireless@vger.kernel.org
6230S: Maintained 5361S: Maintained
6231F: drivers/net/wireless/rndis_wlan.c 5362F: drivers/net/wireless/rndis_wlan.c
6232 5363
6233USB XHCI DRIVER 5364USB XHCI DRIVER
6234P: Sarah Sharp 5365M: Sarah Sharp <sarah.a.sharp@intel.com>
6235M: sarah.a.sharp@intel.com
6236L: linux-usb@vger.kernel.org 5366L: linux-usb@vger.kernel.org
6237S: Supported 5367S: Supported
6238 5368
6239USB ZC0301 DRIVER 5369USB ZC0301 DRIVER
6240P: Luca Risolia 5370M: Luca Risolia <luca.risolia@studio.unibo.it>
6241M: luca.risolia@studio.unibo.it
6242L: linux-usb@vger.kernel.org 5371L: linux-usb@vger.kernel.org
6243L: linux-media@vger.kernel.org 5372L: linux-media@vger.kernel.org
6244T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 5373T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
@@ -6248,16 +5377,14 @@ F: Documentation/video4linux/zc0301.txt
6248F: drivers/media/video/zc0301/ 5377F: drivers/media/video/zc0301/
6249 5378
6250USB ZD1201 DRIVER 5379USB ZD1201 DRIVER
6251P: Jeroen Vreeken 5380M: Jeroen Vreeken <pe1rxq@amsat.org>
6252M: pe1rxq@amsat.org
6253L: linux-usb@vger.kernel.org 5381L: linux-usb@vger.kernel.org
6254W: http://linux-lc100020.sourceforge.net 5382W: http://linux-lc100020.sourceforge.net
6255S: Maintained 5383S: Maintained
6256F: drivers/net/wireless/zd1201.* 5384F: drivers/net/wireless/zd1201.*
6257 5385
6258USB ZR364XX DRIVER 5386USB ZR364XX DRIVER
6259P: Antoine Jacquet 5387M: Antoine Jacquet <royale@zerezo.com>
6260M: royale@zerezo.com
6261L: linux-usb@vger.kernel.org 5388L: linux-usb@vger.kernel.org
6262L: linux-media@vger.kernel.org 5389L: linux-media@vger.kernel.org
6263T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git 5390T: git git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-2.6.git
@@ -6267,8 +5394,7 @@ F: Documentation/video4linux/zr364xx.txt
6267F: drivers/media/video/zr364xx.c 5394F: drivers/media/video/zr364xx.c
6268 5395
6269USER-MODE LINUX (UML) 5396USER-MODE LINUX (UML)
6270P: Jeff Dike 5397M: Jeff Dike <jdike@addtoit.com>
6271M: jdike@addtoit.com
6272L: user-mode-linux-devel@lists.sourceforge.net 5398L: user-mode-linux-devel@lists.sourceforge.net
6273L: user-mode-linux-user@lists.sourceforge.net 5399L: user-mode-linux-user@lists.sourceforge.net
6274W: http://user-mode-linux.sourceforge.net 5400W: http://user-mode-linux.sourceforge.net
@@ -6279,26 +5405,22 @@ F: fs/hostfs/
6279F: fs/hppfs/ 5405F: fs/hppfs/
6280 5406
6281USERSPACE I/O (UIO) 5407USERSPACE I/O (UIO)
6282P: Hans J. Koch 5408M: "Hans J. Koch" <hjk@linutronix.de>
6283M: hjk@linutronix.de 5409M: Greg Kroah-Hartman <gregkh@suse.de>
6284P: Greg Kroah-Hartman
6285M: gregkh@suse.de
6286S: Maintained 5410S: Maintained
6287F: Documentation/DocBook/uio-howto.tmpl 5411F: Documentation/DocBook/uio-howto.tmpl
6288F: drivers/uio/ 5412F: drivers/uio/
6289F: include/linux/uio*.h 5413F: include/linux/uio*.h
6290 5414
6291UTIL-LINUX-NG PACKAGE 5415UTIL-LINUX-NG PACKAGE
6292P: Karel Zak 5416M: Karel Zak <kzak@redhat.com>
6293M: kzak@redhat.com
6294L: util-linux-ng@vger.kernel.org 5417L: util-linux-ng@vger.kernel.org
6295W: http://kernel.org/~kzak/util-linux-ng/ 5418W: http://kernel.org/~kzak/util-linux-ng/
6296T: git git://git.kernel.org/pub/scm/utils/util-linux-ng/util-linux-ng.git 5419T: git git://git.kernel.org/pub/scm/utils/util-linux-ng/util-linux-ng.git
6297S: Maintained 5420S: Maintained
6298 5421
6299UVESAFB DRIVER 5422UVESAFB DRIVER
6300P: Michal Januszewski 5423M: Michal Januszewski <spock@gentoo.org>
6301M: spock@gentoo.org
6302L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) 5424L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers)
6303W: http://dev.gentoo.org/~spock/projects/uvesafb/ 5425W: http://dev.gentoo.org/~spock/projects/uvesafb/
6304S: Maintained 5426S: Maintained
@@ -6306,53 +5428,44 @@ F: Documentation/fb/uvesafb.txt
6306F: drivers/video/uvesafb.* 5428F: drivers/video/uvesafb.*
6307 5429
6308VFAT/FAT/MSDOS FILESYSTEM 5430VFAT/FAT/MSDOS FILESYSTEM
6309P: OGAWA Hirofumi 5431M: OGAWA Hirofumi <hirofumi@mail.parknet.co.jp>
6310M: hirofumi@mail.parknet.co.jp
6311S: Maintained 5432S: Maintained
6312F: Documentation/filesystems/vfat.txt 5433F: Documentation/filesystems/vfat.txt
6313F: fs/fat/ 5434F: fs/fat/
6314 5435
6315VIA RHINE NETWORK DRIVER 5436VIA RHINE NETWORK DRIVER
6316P: Roger Luethi 5437M: Roger Luethi <rl@hellgate.ch>
6317M: rl@hellgate.ch
6318S: Maintained 5438S: Maintained
6319F: drivers/net/via-rhine.c 5439F: drivers/net/via-rhine.c
6320 5440
6321VIAPRO SMBUS DRIVER 5441VIAPRO SMBUS DRIVER
6322P: Jean Delvare 5442M: Jean Delvare <khali@linux-fr.org>
6323M: khali@linux-fr.org
6324L: linux-i2c@vger.kernel.org 5443L: linux-i2c@vger.kernel.org
6325S: Maintained 5444S: Maintained
6326F: Documentation/i2c/busses/i2c-viapro 5445F: Documentation/i2c/busses/i2c-viapro
6327F: drivers/i2c/busses/i2c-viapro.c 5446F: drivers/i2c/busses/i2c-viapro.c
6328 5447
6329VIA SD/MMC CARD CONTROLLER DRIVER 5448VIA SD/MMC CARD CONTROLLER DRIVER
6330P: Joseph Chan 5449M: Joseph Chan <JosephChan@via.com.tw>
6331M: JosephChan@via.com.tw 5450M: Harald Welte <HaraldWelte@viatech.com>
6332P: Harald Welte
6333M: HaraldWelte@viatech.com
6334S: Maintained 5451S: Maintained
6335F: drivers/mmc/host/via-sdmmc.c 5452F: drivers/mmc/host/via-sdmmc.c
6336 5453
6337VIA UNICHROME(PRO)/CHROME9 FRAMEBUFFER DRIVER 5454VIA UNICHROME(PRO)/CHROME9 FRAMEBUFFER DRIVER
6338P: Joseph Chan 5455M: Joseph Chan <JosephChan@via.com.tw>
6339M: JosephChan@via.com.tw 5456M: Scott Fang <ScottFang@viatech.com.cn>
6340P: Scott Fang
6341M: ScottFang@viatech.com.cn
6342L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers) 5457L: linux-fbdev-devel@lists.sourceforge.net (moderated for non-subscribers)
6343S: Maintained 5458S: Maintained
6344F: drivers/video/via/ 5459F: drivers/video/via/
6345 5460
6346VIA VELOCITY NETWORK DRIVER 5461VIA VELOCITY NETWORK DRIVER
6347P: Francois Romieu 5462M: Francois Romieu <romieu@fr.zoreil.com>
6348M: romieu@fr.zoreil.com
6349L: netdev@vger.kernel.org 5463L: netdev@vger.kernel.org
6350S: Maintained 5464S: Maintained
6351F: drivers/net/via-velocity.* 5465F: drivers/net/via-velocity.*
6352 5466
6353VLAN (802.1Q) 5467VLAN (802.1Q)
6354P: Patrick McHardy 5468M: Patrick McHardy <kaber@trash.net>
6355M: kaber@trash.net
6356L: netdev@vger.kernel.org 5469L: netdev@vger.kernel.org
6357S: Maintained 5470S: Maintained
6358F: drivers/net/macvlan.c 5471F: drivers/net/macvlan.c
@@ -6360,18 +5473,15 @@ F: include/linux/if_*vlan.h
6360F: net/8021q/ 5473F: net/8021q/
6361 5474
6362VLYNQ BUS 5475VLYNQ BUS
6363P: Florian Fainelli 5476M: Florian Fainelli <florian@openwrt.org>
6364M: florian@openwrt.org
6365L: openwrt-devel@lists.openwrt.org 5477L: openwrt-devel@lists.openwrt.org
6366S: Maintained 5478S: Maintained
6367F: drivers/vlynq/vlynq.c 5479F: drivers/vlynq/vlynq.c
6368F: include/linux/vlynq.h 5480F: include/linux/vlynq.h
6369 5481
6370VOLTAGE AND CURRENT REGULATOR FRAMEWORK 5482VOLTAGE AND CURRENT REGULATOR FRAMEWORK
6371P: Liam Girdwood 5483M: Liam Girdwood <lrg@slimlogic.co.uk>
6372M: lrg@slimlogic.co.uk 5484M: Mark Brown <broonie@opensource.wolfsonmicro.com>
6373P: Mark Brown
6374M: broonie@opensource.wolfsonmicro.com
6375W: http://opensource.wolfsonmicro.com/node/15 5485W: http://opensource.wolfsonmicro.com/node/15
6376W: http://www.slimlogic.co.uk/?p=48 5486W: http://www.slimlogic.co.uk/?p=48
6377T: git git://git.kernel.org/pub/scm/linux/kernel/git/lrg/voltage-2.6.git 5487T: git git://git.kernel.org/pub/scm/linux/kernel/git/lrg/voltage-2.6.git
@@ -6380,52 +5490,45 @@ F: drivers/regulator/
6380F: include/linux/regulator/ 5490F: include/linux/regulator/
6381 5491
6382VT1211 HARDWARE MONITOR DRIVER 5492VT1211 HARDWARE MONITOR DRIVER
6383P: Juerg Haefliger 5493M: Juerg Haefliger <juergh@gmail.com>
6384M: juergh@gmail.com
6385L: lm-sensors@lm-sensors.org 5494L: lm-sensors@lm-sensors.org
6386S: Maintained 5495S: Maintained
6387F: Documentation/hwmon/vt1211 5496F: Documentation/hwmon/vt1211
6388F: drivers/hwmon/vt1211.c 5497F: drivers/hwmon/vt1211.c
6389 5498
6390VT8231 HARDWARE MONITOR DRIVER 5499VT8231 HARDWARE MONITOR DRIVER
6391P: Roger Lucas 5500M: Roger Lucas <vt8231@hiddenengine.co.uk>
6392M: vt8231@hiddenengine.co.uk
6393L: lm-sensors@lm-sensors.org 5501L: lm-sensors@lm-sensors.org
6394S: Maintained 5502S: Maintained
6395F: drivers/hwmon/vt8231.c 5503F: drivers/hwmon/vt8231.c
6396 5504
6397W1 DALLAS'S 1-WIRE BUS 5505W1 DALLAS'S 1-WIRE BUS
6398P: Evgeniy Polyakov 5506M: Evgeniy Polyakov <johnpol@2ka.mipt.ru>
6399M: johnpol@2ka.mipt.ru
6400S: Maintained 5507S: Maintained
6401F: Documentation/w1/ 5508F: Documentation/w1/
6402F: drivers/w1/ 5509F: drivers/w1/
6403 5510
6404W83791D HARDWARE MONITORING DRIVER 5511W83791D HARDWARE MONITORING DRIVER
6405P: Marc Hulsman 5512M: Marc Hulsman <m.hulsman@tudelft.nl>
6406M: m.hulsman@tudelft.nl
6407L: lm-sensors@lm-sensors.org 5513L: lm-sensors@lm-sensors.org
6408S: Maintained 5514S: Maintained
6409F: Documentation/hwmon/w83791d 5515F: Documentation/hwmon/w83791d
6410F: drivers/hwmon/w83791d.c 5516F: drivers/hwmon/w83791d.c
6411 5517
6412W83793 HARDWARE MONITORING DRIVER 5518W83793 HARDWARE MONITORING DRIVER
6413P: Rudolf Marek 5519M: Rudolf Marek <r.marek@assembler.cz>
6414M: r.marek@assembler.cz
6415L: lm-sensors@lm-sensors.org 5520L: lm-sensors@lm-sensors.org
6416S: Maintained 5521S: Maintained
6417F: Documentation/hwmon/w83793 5522F: Documentation/hwmon/w83793
6418F: drivers/hwmon/w83793.c 5523F: drivers/hwmon/w83793.c
6419 5524
6420W83L51xD SD/MMC CARD INTERFACE DRIVER 5525W83L51xD SD/MMC CARD INTERFACE DRIVER
6421P: Pierre Ossman 5526M: Pierre Ossman <pierre@ossman.eu>
6422M: pierre@ossman.eu
6423S: Maintained 5527S: Maintained
6424F: drivers/mmc/host/wbsd.* 5528F: drivers/mmc/host/wbsd.*
6425 5529
6426WATCHDOG DEVICE DRIVERS 5530WATCHDOG DEVICE DRIVERS
6427P: Wim Van Sebroeck 5531M: Wim Van Sebroeck <wim@iguana.be>
6428M: wim@iguana.be
6429T: git git://git.kernel.org/pub/scm/linux/kernel/git/wim/linux-2.6-watchdog.git 5532T: git git://git.kernel.org/pub/scm/linux/kernel/git/wim/linux-2.6-watchdog.git
6430S: Maintained 5533S: Maintained
6431F: Documentation/watchdog/ 5534F: Documentation/watchdog/
@@ -6433,8 +5536,7 @@ F: drivers/watchdog/
6433F: include/linux/watchdog.h 5536F: include/linux/watchdog.h
6434 5537
6435WAVELAN NETWORK DRIVER & WIRELESS EXTENSIONS 5538WAVELAN NETWORK DRIVER & WIRELESS EXTENSIONS
6436P: Jean Tourrilhes 5539M: Jean Tourrilhes <jt@hpl.hp.com>
6437M: jt@hpl.hp.com
6438L: linux-wireless@vger.kernel.org 5540L: linux-wireless@vger.kernel.org
6439W: http://www.hpl.hp.com/personal/Jean_Tourrilhes/Linux/ 5541W: http://www.hpl.hp.com/personal/Jean_Tourrilhes/Linux/
6440S: Maintained 5542S: Maintained
@@ -6442,46 +5544,39 @@ F: Documentation/networking/wavelan.txt
6442F: drivers/net/wireless/wavelan* 5544F: drivers/net/wireless/wavelan*
6443 5545
6444WD7000 SCSI DRIVER 5546WD7000 SCSI DRIVER
6445P: Miroslav Zagorac 5547M: Miroslav Zagorac <zaga@fly.cc.fer.hr>
6446M: zaga@fly.cc.fer.hr
6447L: linux-scsi@vger.kernel.org 5548L: linux-scsi@vger.kernel.org
6448S: Maintained 5549S: Maintained
6449F: drivers/scsi/wd7000.c 5550F: drivers/scsi/wd7000.c
6450 5551
6451WIMAX STACK 5552WIMAX STACK
6452P: Inaky Perez-Gonzalez 5553M: Inaky Perez-Gonzalez <inaky.perez-gonzalez@intel.com>
6453M: inaky.perez-gonzalez@intel.com
6454M: linux-wimax@intel.com 5554M: linux-wimax@intel.com
6455L: wimax@linuxwimax.org 5555L: wimax@linuxwimax.org
6456S: Supported 5556S: Supported
6457W: http://linuxwimax.org 5557W: http://linuxwimax.org
6458 5558
6459WIMEDIA LLC PROTOCOL (WLP) SUBSYSTEM 5559WIMEDIA LLC PROTOCOL (WLP) SUBSYSTEM
6460P: David Vrabel 5560M: David Vrabel <david.vrabel@csr.com>
6461M: david.vrabel@csr.com
6462S: Maintained 5561S: Maintained
6463F: include/linux/wlp.h 5562F: include/linux/wlp.h
6464F: drivers/uwb/wlp/ 5563F: drivers/uwb/wlp/
6465 5564
6466WISTRON LAPTOP BUTTON DRIVER 5565WISTRON LAPTOP BUTTON DRIVER
6467P: Miloslav Trmac 5566M: Miloslav Trmac <mitr@volny.cz>
6468M: mitr@volny.cz
6469S: Maintained 5567S: Maintained
6470F: drivers/input/misc/wistron_btns.c 5568F: drivers/input/misc/wistron_btns.c
6471 5569
6472WL3501 WIRELESS PCMCIA CARD DRIVER 5570WL3501 WIRELESS PCMCIA CARD DRIVER
6473P: Arnaldo Carvalho de Melo 5571M: Arnaldo Carvalho de Melo <acme@ghostprotocols.net>
6474M: acme@ghostprotocols.net
6475L: linux-wireless@vger.kernel.org 5572L: linux-wireless@vger.kernel.org
6476W: http://oops.ghostprotocols.net:81/blog 5573W: http://oops.ghostprotocols.net:81/blog
6477S: Maintained 5574S: Maintained
6478F: drivers/net/wireless/wl3501* 5575F: drivers/net/wireless/wl3501*
6479 5576
6480WM97XX TOUCHSCREEN DRIVERS 5577WM97XX TOUCHSCREEN DRIVERS
6481P: Mark Brown 5578M: Mark Brown <broonie@opensource.wolfsonmicro.com>
6482M: broonie@opensource.wolfsonmicro.com 5579M: Liam Girdwood <lrg@slimlogic.co.uk>
6483P: Liam Girdwood
6484M: lrg@slimlogic.co.uk
6485L: linux-input@vger.kernel.org 5580L: linux-input@vger.kernel.org
6486T: git git://opensource.wolfsonmicro.com/linux-2.6-touch 5581T: git git://opensource.wolfsonmicro.com/linux-2.6-touch
6487W: http://opensource.wolfsonmicro.com/node/7 5582W: http://opensource.wolfsonmicro.com/node/7
@@ -6490,8 +5585,7 @@ F: drivers/input/touchscreen/*wm97*
6490F: include/linux/wm97xx.h 5585F: include/linux/wm97xx.h
6491 5586
6492X.25 NETWORK LAYER 5587X.25 NETWORK LAYER
6493P: Henner Eisen 5588M: Henner Eisen <eis@baty.hanse.de>
6494M: eis@baty.hanse.de
6495L: linux-x25@vger.kernel.org 5589L: linux-x25@vger.kernel.org
6496S: Maintained 5590S: Maintained
6497F: Documentation/networking/x25* 5591F: Documentation/networking/x25*
@@ -6499,12 +5593,9 @@ F: include/net/x25*
6499F: net/x25/ 5593F: net/x25/
6500 5594
6501X86 ARCHITECTURE (32-BIT AND 64-BIT) 5595X86 ARCHITECTURE (32-BIT AND 64-BIT)
6502P: Thomas Gleixner 5596M: Thomas Gleixner <tglx@linutronix.de>
6503M: tglx@linutronix.de 5597M: Ingo Molnar <mingo@redhat.com>
6504P: Ingo Molnar 5598M: "H. Peter Anvin" <hpa@zytor.com>
6505M: mingo@redhat.com
6506P: H. Peter Anvin
6507M: hpa@zytor.com
6508M: x86@kernel.org 5599M: x86@kernel.org
6509T: git git://git.kernel.org/pub/scm/linux/kernel/git/x86/linux-2.6-x86.git 5600T: git git://git.kernel.org/pub/scm/linux/kernel/git/x86/linux-2.6-x86.git
6510S: Maintained 5601S: Maintained
@@ -6512,10 +5603,8 @@ F: Documentation/x86/
6512F: arch/x86/ 5603F: arch/x86/
6513 5604
6514XEN HYPERVISOR INTERFACE 5605XEN HYPERVISOR INTERFACE
6515P: Jeremy Fitzhardinge 5606M: Jeremy Fitzhardinge <jeremy@xensource.com>
6516M: jeremy@xensource.com 5607M: Chris Wright <chrisw@sous-sol.org>
6517P: Chris Wright
6518M: chrisw@sous-sol.org
6519L: virtualization@lists.osdl.org 5608L: virtualization@lists.osdl.org
6520L: xen-devel@lists.xensource.com 5609L: xen-devel@lists.xensource.com
6521S: Supported 5610S: Supported
@@ -6527,8 +5616,7 @@ F: include/xen/
6527 5616
6528XFS FILESYSTEM 5617XFS FILESYSTEM
6529P: Silicon Graphics Inc 5618P: Silicon Graphics Inc
6530P: Felix Blyakher 5619M: Felix Blyakher <felixb@sgi.com>
6531M: felixb@sgi.com
6532M: xfs-masters@oss.sgi.com 5620M: xfs-masters@oss.sgi.com
6533L: xfs@oss.sgi.com 5621L: xfs@oss.sgi.com
6534W: http://oss.sgi.com/projects/xfs 5622W: http://oss.sgi.com/projects/xfs
@@ -6538,38 +5626,33 @@ F: Documentation/filesystems/xfs.txt
6538F: fs/xfs/ 5626F: fs/xfs/
6539 5627
6540XILINX SYSTEMACE DRIVER 5628XILINX SYSTEMACE DRIVER
6541P: Grant Likely 5629M: Grant Likely <grant.likely@secretlab.ca>
6542M: grant.likely@secretlab.ca
6543W: http://www.secretlab.ca/ 5630W: http://www.secretlab.ca/
6544S: Maintained 5631S: Maintained
6545F: drivers/block/xsysace.c 5632F: drivers/block/xsysace.c
6546 5633
6547XILINX UARTLITE SERIAL DRIVER 5634XILINX UARTLITE SERIAL DRIVER
6548P: Peter Korsgaard 5635M: Peter Korsgaard <jacmet@sunsite.dk>
6549M: jacmet@sunsite.dk
6550L: linux-serial@vger.kernel.org 5636L: linux-serial@vger.kernel.org
6551S: Maintained 5637S: Maintained
6552F: drivers/serial/uartlite.c 5638F: drivers/serial/uartlite.c
6553 5639
6554YAM DRIVER FOR AX.25 5640YAM DRIVER FOR AX.25
6555P: Jean-Paul Roubelat 5641M: Jean-Paul Roubelat <jpr@f6fbb.org>
6556M: jpr@f6fbb.org
6557L: linux-hams@vger.kernel.org 5642L: linux-hams@vger.kernel.org
6558S: Maintained 5643S: Maintained
6559F: drivers/net/hamradio/yam* 5644F: drivers/net/hamradio/yam*
6560F: include/linux/yam.h 5645F: include/linux/yam.h
6561 5646
6562YEALINK PHONE DRIVER 5647YEALINK PHONE DRIVER
6563P: Henk Vergonet 5648M: Henk Vergonet <Henk.Vergonet@gmail.com>
6564M: Henk.Vergonet@gmail.com
6565L: usbb2k-api-dev@nongnu.org 5649L: usbb2k-api-dev@nongnu.org
6566S: Maintained 5650S: Maintained
6567F: Documentation/input/yealink.txt 5651F: Documentation/input/yealink.txt
6568F: drivers/input/misc/yealink.* 5652F: drivers/input/misc/yealink.*
6569 5653
6570Z8530 DRIVER FOR AX.25 5654Z8530 DRIVER FOR AX.25
6571P: Joerg Reuter 5655M: Joerg Reuter <jreuter@yaina.de>
6572M: jreuter@yaina.de
6573W: http://yaina.de/jreuter/ 5656W: http://yaina.de/jreuter/
6574W: http://www.qsl.net/dl1bke/ 5657W: http://www.qsl.net/dl1bke/
6575L: linux-hams@vger.kernel.org 5658L: linux-hams@vger.kernel.org
@@ -6579,10 +5662,8 @@ F: drivers/net/hamradio/*scc.c
6579F: drivers/net/hamradio/z8530.h 5662F: drivers/net/hamradio/z8530.h
6580 5663
6581ZD1211RW WIRELESS DRIVER 5664ZD1211RW WIRELESS DRIVER
6582P: Daniel Drake 5665M: Daniel Drake <dsd@gentoo.org>
6583M: dsd@gentoo.org 5666M: Ulrich Kunitz <kune@deine-taler.de>
6584P: Ulrich Kunitz
6585M: kune@deine-taler.de
6586W: http://zd1211.ath.cx/wiki/DriverRewrite 5667W: http://zd1211.ath.cx/wiki/DriverRewrite
6587L: linux-wireless@vger.kernel.org 5668L: linux-wireless@vger.kernel.org
6588L: zd1211-devs@lists.sourceforge.net (subscribers-only) 5669L: zd1211-devs@lists.sourceforge.net (subscribers-only)
@@ -6598,14 +5679,12 @@ S: Odd Fixes
6598F: drivers/media/video/zoran/ 5679F: drivers/media/video/zoran/
6599 5680
6600ZS DECSTATION Z85C30 SERIAL DRIVER 5681ZS DECSTATION Z85C30 SERIAL DRIVER
6601P: Maciej W. Rozycki 5682M: "Maciej W. Rozycki" <macro@linux-mips.org>
6602M: macro@linux-mips.org
6603S: Maintained 5683S: Maintained
6604F: drivers/serial/zs.* 5684F: drivers/serial/zs.*
6605 5685
6606THE REST 5686THE REST
6607P: Linus Torvalds 5687M: Linus Torvalds <torvalds@linux-foundation.org>
6608M: torvalds@linux-foundation.org
6609L: linux-kernel@vger.kernel.org 5688L: linux-kernel@vger.kernel.org
6610T: git git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git 5689T: git git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git
6611S: Buried alive in reporters 5690S: Buried alive in reporters
diff --git a/arch/x86/mm/highmem_32.c b/arch/x86/mm/highmem_32.c
index 58f621e81919..2112ed55e7ea 100644
--- a/arch/x86/mm/highmem_32.c
+++ b/arch/x86/mm/highmem_32.c
@@ -103,6 +103,7 @@ EXPORT_SYMBOL(kmap);
103EXPORT_SYMBOL(kunmap); 103EXPORT_SYMBOL(kunmap);
104EXPORT_SYMBOL(kmap_atomic); 104EXPORT_SYMBOL(kmap_atomic);
105EXPORT_SYMBOL(kunmap_atomic); 105EXPORT_SYMBOL(kunmap_atomic);
106EXPORT_SYMBOL(kmap_atomic_prot);
106 107
107void __init set_highmem_pages_init(void) 108void __init set_highmem_pages_init(void)
108{ 109{
diff --git a/drivers/acpi/sleep.c b/drivers/acpi/sleep.c
index 01574a066534..42159a28f433 100644
--- a/drivers/acpi/sleep.c
+++ b/drivers/acpi/sleep.c
@@ -397,6 +397,14 @@ static struct dmi_system_id __initdata acpisleep_dmi_table[] = {
397 }, 397 },
398 }, 398 },
399 { 399 {
400 .callback = init_set_sci_en_on_resume,
401 .ident = "Hewlett-Packard HP G7000 Notebook PC",
402 .matches = {
403 DMI_MATCH(DMI_SYS_VENDOR, "Hewlett-Packard"),
404 DMI_MATCH(DMI_PRODUCT_NAME, "HP G7000 Notebook PC"),
405 },
406 },
407 {
400 .callback = init_old_suspend_ordering, 408 .callback = init_old_suspend_ordering,
401 .ident = "Panasonic CF51-2L", 409 .ident = "Panasonic CF51-2L",
402 .matches = { 410 .matches = {
diff --git a/drivers/ata/ahci.c b/drivers/ata/ahci.c
index 336eb1ed73cc..958c1fa41900 100644
--- a/drivers/ata/ahci.c
+++ b/drivers/ata/ahci.c
@@ -515,10 +515,14 @@ static const struct pci_device_id ahci_pci_tbl[] = {
515 { PCI_VDEVICE(INTEL, 0x3a05), board_ahci }, /* ICH10 */ 515 { PCI_VDEVICE(INTEL, 0x3a05), board_ahci }, /* ICH10 */
516 { PCI_VDEVICE(INTEL, 0x3a22), board_ahci }, /* ICH10 */ 516 { PCI_VDEVICE(INTEL, 0x3a22), board_ahci }, /* ICH10 */
517 { PCI_VDEVICE(INTEL, 0x3a25), board_ahci }, /* ICH10 */ 517 { PCI_VDEVICE(INTEL, 0x3a25), board_ahci }, /* ICH10 */
518 { PCI_VDEVICE(INTEL, 0x3b22), board_ahci }, /* PCH AHCI */
519 { PCI_VDEVICE(INTEL, 0x3b23), board_ahci }, /* PCH AHCI */
518 { PCI_VDEVICE(INTEL, 0x3b24), board_ahci }, /* PCH RAID */ 520 { PCI_VDEVICE(INTEL, 0x3b24), board_ahci }, /* PCH RAID */
519 { PCI_VDEVICE(INTEL, 0x3b25), board_ahci }, /* PCH RAID */ 521 { PCI_VDEVICE(INTEL, 0x3b25), board_ahci }, /* PCH RAID */
522 { PCI_VDEVICE(INTEL, 0x3b29), board_ahci }, /* PCH AHCI */
520 { PCI_VDEVICE(INTEL, 0x3b2b), board_ahci }, /* PCH RAID */ 523 { PCI_VDEVICE(INTEL, 0x3b2b), board_ahci }, /* PCH RAID */
521 { PCI_VDEVICE(INTEL, 0x3b2c), board_ahci }, /* PCH RAID */ 524 { PCI_VDEVICE(INTEL, 0x3b2c), board_ahci }, /* PCH RAID */
525 { PCI_VDEVICE(INTEL, 0x3b2f), board_ahci }, /* PCH AHCI */
522 526
523 /* JMicron 360/1/3/5/6, match class to avoid IDE function */ 527 /* JMicron 360/1/3/5/6, match class to avoid IDE function */
524 { PCI_VENDOR_ID_JMICRON, PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID, 528 { PCI_VENDOR_ID_JMICRON, PCI_ANY_ID, PCI_ANY_ID, PCI_ANY_ID,
diff --git a/drivers/ata/ata_piix.c b/drivers/ata/ata_piix.c
index d0a14cf2bd74..56b8a3ff1286 100644
--- a/drivers/ata/ata_piix.c
+++ b/drivers/ata/ata_piix.c
@@ -596,9 +596,12 @@ static const struct ich_laptop ich_laptop[] = {
596 { 0x27DF, 0x0005, 0x0280 }, /* ICH7 on Acer 5602WLMi */ 596 { 0x27DF, 0x0005, 0x0280 }, /* ICH7 on Acer 5602WLMi */
597 { 0x27DF, 0x1025, 0x0102 }, /* ICH7 on Acer 5602aWLMi */ 597 { 0x27DF, 0x1025, 0x0102 }, /* ICH7 on Acer 5602aWLMi */
598 { 0x27DF, 0x1025, 0x0110 }, /* ICH7 on Acer 3682WLMi */ 598 { 0x27DF, 0x1025, 0x0110 }, /* ICH7 on Acer 3682WLMi */
599 { 0x27DF, 0x1028, 0x02b0 }, /* ICH7 on unknown Dell */
599 { 0x27DF, 0x1043, 0x1267 }, /* ICH7 on Asus W5F */ 600 { 0x27DF, 0x1043, 0x1267 }, /* ICH7 on Asus W5F */
600 { 0x27DF, 0x103C, 0x30A1 }, /* ICH7 on HP Compaq nc2400 */ 601 { 0x27DF, 0x103C, 0x30A1 }, /* ICH7 on HP Compaq nc2400 */
602 { 0x27DF, 0x103C, 0x361a }, /* ICH7 on unkown HP */
601 { 0x27DF, 0x1071, 0xD221 }, /* ICH7 on Hercules EC-900 */ 603 { 0x27DF, 0x1071, 0xD221 }, /* ICH7 on Hercules EC-900 */
604 { 0x27DF, 0x152D, 0x0778 }, /* ICH7 on unknown Intel */
602 { 0x24CA, 0x1025, 0x0061 }, /* ICH4 on ACER Aspire 2023WLMi */ 605 { 0x24CA, 0x1025, 0x0061 }, /* ICH4 on ACER Aspire 2023WLMi */
603 { 0x24CA, 0x1025, 0x003d }, /* ICH4 on ACER TM290 */ 606 { 0x24CA, 0x1025, 0x003d }, /* ICH4 on ACER TM290 */
604 { 0x266F, 0x1025, 0x0066 }, /* ICH6 on ACER Aspire 1694WLMi */ 607 { 0x266F, 0x1025, 0x0066 }, /* ICH6 on ACER Aspire 1694WLMi */
diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c
index 2c6aedaef718..8ac98ff16d7d 100644
--- a/drivers/ata/libata-core.c
+++ b/drivers/ata/libata-core.c
@@ -1515,6 +1515,7 @@ static int ata_hpa_resize(struct ata_device *dev)
1515 1515
1516 return rc; 1516 return rc;
1517 } 1517 }
1518 dev->n_native_sectors = native_sectors;
1518 1519
1519 /* nothing to do? */ 1520 /* nothing to do? */
1520 if (native_sectors <= sectors || !ata_ignore_hpa) { 1521 if (native_sectors <= sectors || !ata_ignore_hpa) {
@@ -4099,6 +4100,7 @@ int ata_dev_revalidate(struct ata_device *dev, unsigned int new_class,
4099 unsigned int readid_flags) 4100 unsigned int readid_flags)
4100{ 4101{
4101 u64 n_sectors = dev->n_sectors; 4102 u64 n_sectors = dev->n_sectors;
4103 u64 n_native_sectors = dev->n_native_sectors;
4102 int rc; 4104 int rc;
4103 4105
4104 if (!ata_dev_enabled(dev)) 4106 if (!ata_dev_enabled(dev))
@@ -4128,16 +4130,30 @@ int ata_dev_revalidate(struct ata_device *dev, unsigned int new_class,
4128 /* verify n_sectors hasn't changed */ 4130 /* verify n_sectors hasn't changed */
4129 if (dev->class == ATA_DEV_ATA && n_sectors && 4131 if (dev->class == ATA_DEV_ATA && n_sectors &&
4130 dev->n_sectors != n_sectors) { 4132 dev->n_sectors != n_sectors) {
4131 ata_dev_printk(dev, KERN_INFO, "n_sectors mismatch " 4133 ata_dev_printk(dev, KERN_WARNING, "n_sectors mismatch "
4132 "%llu != %llu\n", 4134 "%llu != %llu\n",
4133 (unsigned long long)n_sectors, 4135 (unsigned long long)n_sectors,
4134 (unsigned long long)dev->n_sectors); 4136 (unsigned long long)dev->n_sectors);
4135 4137 /*
4136 /* restore original n_sectors */ 4138 * Something could have caused HPA to be unlocked
4137 dev->n_sectors = n_sectors; 4139 * involuntarily. If n_native_sectors hasn't changed
4138 4140 * and the new size matches it, keep the device.
4139 rc = -ENODEV; 4141 */
4140 goto fail; 4142 if (dev->n_native_sectors == n_native_sectors &&
4143 dev->n_sectors > n_sectors &&
4144 dev->n_sectors == n_native_sectors) {
4145 ata_dev_printk(dev, KERN_WARNING,
4146 "new n_sectors matches native, probably "
4147 "late HPA unlock, continuing\n");
4148 /* keep using the old n_sectors */
4149 dev->n_sectors = n_sectors;
4150 } else {
4151 /* restore original n_[native]_sectors and fail */
4152 dev->n_native_sectors = n_native_sectors;
4153 dev->n_sectors = n_sectors;
4154 rc = -ENODEV;
4155 goto fail;
4156 }
4141 } 4157 }
4142 4158
4143 return 0; 4159 return 0;
diff --git a/drivers/ata/libata-eh.c b/drivers/ata/libata-eh.c
index 1a07c061f644..79711b64054b 100644
--- a/drivers/ata/libata-eh.c
+++ b/drivers/ata/libata-eh.c
@@ -2327,7 +2327,7 @@ int ata_eh_reset(struct ata_link *link, int classify,
2327 struct ata_port *ap = link->ap; 2327 struct ata_port *ap = link->ap;
2328 struct ata_link *slave = ap->slave_link; 2328 struct ata_link *slave = ap->slave_link;
2329 struct ata_eh_context *ehc = &link->eh_context; 2329 struct ata_eh_context *ehc = &link->eh_context;
2330 struct ata_eh_context *sehc = &slave->eh_context; 2330 struct ata_eh_context *sehc = slave ? &slave->eh_context : NULL;
2331 unsigned int *classes = ehc->classes; 2331 unsigned int *classes = ehc->classes;
2332 unsigned int lflags = link->flags; 2332 unsigned int lflags = link->flags;
2333 int verbose = !(ehc->i.flags & ATA_EHI_QUIET); 2333 int verbose = !(ehc->i.flags & ATA_EHI_QUIET);
diff --git a/drivers/ata/pata_at91.c b/drivers/ata/pata_at91.c
index 8561a9f195c1..5702affcb325 100644
--- a/drivers/ata/pata_at91.c
+++ b/drivers/ata/pata_at91.c
@@ -26,9 +26,7 @@
26#include <linux/platform_device.h> 26#include <linux/platform_device.h>
27#include <linux/ata_platform.h> 27#include <linux/ata_platform.h>
28 28
29#include <mach/at91sam9260_matrix.h>
30#include <mach/at91sam9_smc.h> 29#include <mach/at91sam9_smc.h>
31#include <mach/at91sam9260.h>
32#include <mach/board.h> 30#include <mach/board.h>
33#include <mach/gpio.h> 31#include <mach/gpio.h>
34 32
@@ -44,65 +42,62 @@ struct at91_ide_info {
44 unsigned long mode; 42 unsigned long mode;
45 unsigned int cs; 43 unsigned int cs;
46 44
45 struct clk *mck;
46
47 void __iomem *ide_addr; 47 void __iomem *ide_addr;
48 void __iomem *alt_addr; 48 void __iomem *alt_addr;
49}; 49};
50 50
51const struct ata_timing initial_timing = 51static const struct ata_timing initial_timing =
52 {XFER_PIO_0, 70, 290, 240, 600, 165, 150, 600, 0}; 52 {XFER_PIO_0, 70, 290, 240, 600, 165, 150, 600, 0};
53 53
54static unsigned int calc_mck_cycles(unsigned int ns, unsigned int mck_hz) 54static unsigned long calc_mck_cycles(unsigned long ns, unsigned long mck_hz)
55{ 55{
56 unsigned long mul; 56 unsigned long mul;
57 57
58 /* 58 /*
59 * cycles = x [nsec] * f [Hz] / 10^9 [ns in sec] = 59 * cycles = x [nsec] * f [Hz] / 10^9 [ns in sec] =
60 * x * (f / 1_000_000_000) = 60 * x * (f / 1_000_000_000) =
61 * x * ((f * 65536) / 1_000_000_000) / 65536 = 61 * x * ((f * 65536) / 1_000_000_000) / 65536 =
62 * x * (((f / 10_000) * 65536) / 100_000) / 65536 = 62 * x * (((f / 10_000) * 65536) / 100_000) / 65536 =
63 */ 63 */
64 64
65 mul = (mck_hz / 10000) << 16; 65 mul = (mck_hz / 10000) << 16;
66 mul /= 100000; 66 mul /= 100000;
67 67
68 return (ns * mul + 65536) >> 16; /* rounding */ 68 return (ns * mul + 65536) >> 16; /* rounding */
69} 69}
70 70
71static void set_smc_mode(struct at91_ide_info *info) 71static void set_smc_mode(struct at91_ide_info *info)
72{ 72{
73 at91_sys_write(AT91_SMC_MODE(info->cs), info->mode); 73 at91_sys_write(AT91_SMC_MODE(info->cs), info->mode);
74 return; 74 return;
75} 75}
76 76
77static void set_smc_timing(struct device *dev, 77static void set_smc_timing(struct device *dev,
78 struct at91_ide_info *info, const struct ata_timing *ata) 78 struct at91_ide_info *info, const struct ata_timing *ata)
79{ 79{
80 int read_cycle, write_cycle, active, recover; 80 unsigned long read_cycle, write_cycle, active, recover;
81 int nrd_setup, nrd_pulse, nrd_recover; 81 unsigned long nrd_setup, nrd_pulse, nrd_recover;
82 int nwe_setup, nwe_pulse; 82 unsigned long nwe_setup, nwe_pulse;
83 83
84 int ncs_write_setup, ncs_write_pulse; 84 unsigned long ncs_write_setup, ncs_write_pulse;
85 int ncs_read_setup, ncs_read_pulse; 85 unsigned long ncs_read_setup, ncs_read_pulse;
86 86
87 unsigned int mck_hz; 87 unsigned long mck_hz;
88 struct clk *mck;
89 88
90 read_cycle = ata->cyc8b; 89 read_cycle = ata->cyc8b;
91 nrd_setup = ata->setup; 90 nrd_setup = ata->setup;
92 nrd_pulse = ata->act8b; 91 nrd_pulse = ata->act8b;
93 nrd_recover = ata->rec8b; 92 nrd_recover = ata->rec8b;
94 93
95 mck = clk_get(NULL, "mck"); 94 mck_hz = clk_get_rate(info->mck);
96 BUG_ON(IS_ERR(mck));
97 mck_hz = clk_get_rate(mck);
98 95
99 read_cycle = calc_mck_cycles(read_cycle, mck_hz); 96 read_cycle = calc_mck_cycles(read_cycle, mck_hz);
100 nrd_setup = calc_mck_cycles(nrd_setup, mck_hz); 97 nrd_setup = calc_mck_cycles(nrd_setup, mck_hz);
101 nrd_pulse = calc_mck_cycles(nrd_pulse, mck_hz); 98 nrd_pulse = calc_mck_cycles(nrd_pulse, mck_hz);
102 nrd_recover = calc_mck_cycles(nrd_recover, mck_hz); 99 nrd_recover = calc_mck_cycles(nrd_recover, mck_hz);
103 100
104 clk_put(mck);
105
106 active = nrd_setup + nrd_pulse; 101 active = nrd_setup + nrd_pulse;
107 recover = read_cycle - active; 102 recover = read_cycle - active;
108 103
@@ -121,13 +116,13 @@ static void set_smc_timing(struct device *dev,
121 ncs_write_setup = ncs_read_setup; 116 ncs_write_setup = ncs_read_setup;
122 ncs_write_pulse = ncs_read_pulse; 117 ncs_write_pulse = ncs_read_pulse;
123 118
124 dev_dbg(dev, "ATA timings: nrd_setup = %d nrd_pulse = %d nrd_cycle = %d\n", 119 dev_dbg(dev, "ATA timings: nrd_setup = %lu nrd_pulse = %lu nrd_cycle = %lu\n",
125 nrd_setup, nrd_pulse, read_cycle); 120 nrd_setup, nrd_pulse, read_cycle);
126 dev_dbg(dev, "ATA timings: nwe_setup = %d nwe_pulse = %d nwe_cycle = %d\n", 121 dev_dbg(dev, "ATA timings: nwe_setup = %lu nwe_pulse = %lu nwe_cycle = %lu\n",
127 nwe_setup, nwe_pulse, write_cycle); 122 nwe_setup, nwe_pulse, write_cycle);
128 dev_dbg(dev, "ATA timings: ncs_read_setup = %d ncs_read_pulse = %d\n", 123 dev_dbg(dev, "ATA timings: ncs_read_setup = %lu ncs_read_pulse = %lu\n",
129 ncs_read_setup, ncs_read_pulse); 124 ncs_read_setup, ncs_read_pulse);
130 dev_dbg(dev, "ATA timings: ncs_write_setup = %d ncs_write_pulse = %d\n", 125 dev_dbg(dev, "ATA timings: ncs_write_setup = %lu ncs_write_pulse = %lu\n",
131 ncs_write_setup, ncs_write_pulse); 126 ncs_write_setup, ncs_write_pulse);
132 127
133 at91_sys_write(AT91_SMC_SETUP(info->cs), 128 at91_sys_write(AT91_SMC_SETUP(info->cs),
@@ -217,6 +212,7 @@ static int __devinit pata_at91_probe(struct platform_device *pdev)
217 struct resource *mem_res; 212 struct resource *mem_res;
218 struct ata_host *host; 213 struct ata_host *host;
219 struct ata_port *ap; 214 struct ata_port *ap;
215
220 int irq_flags = 0; 216 int irq_flags = 0;
221 int irq = 0; 217 int irq = 0;
222 int ret; 218 int ret;
@@ -261,6 +257,13 @@ static int __devinit pata_at91_probe(struct platform_device *pdev)
261 return -ENOMEM; 257 return -ENOMEM;
262 } 258 }
263 259
260 info->mck = clk_get(NULL, "mck");
261
262 if (IS_ERR(info->mck)) {
263 dev_err(dev, "failed to get access to mck clock\n");
264 return -ENODEV;
265 }
266
264 info->cs = board->chipselect; 267 info->cs = board->chipselect;
265 info->mode = AT91_SMC_READMODE | AT91_SMC_WRITEMODE | 268 info->mode = AT91_SMC_READMODE | AT91_SMC_WRITEMODE |
266 AT91_SMC_EXNWMODE_READY | AT91_SMC_BAT_SELECT | 269 AT91_SMC_EXNWMODE_READY | AT91_SMC_BAT_SELECT |
@@ -304,6 +307,7 @@ err_alt_ioremap:
304 devm_iounmap(dev, info->ide_addr); 307 devm_iounmap(dev, info->ide_addr);
305 308
306err_ide_ioremap: 309err_ide_ioremap:
310 clk_put(info->mck);
307 kfree(info); 311 kfree(info);
308 312
309 return ret; 313 return ret;
@@ -326,6 +330,7 @@ static int __devexit pata_at91_remove(struct platform_device *pdev)
326 330
327 devm_iounmap(dev, info->ide_addr); 331 devm_iounmap(dev, info->ide_addr);
328 devm_iounmap(dev, info->alt_addr); 332 devm_iounmap(dev, info->alt_addr);
333 clk_put(info->mck);
329 334
330 kfree(info); 335 kfree(info);
331 return 0; 336 return 0;
diff --git a/drivers/ata/pata_octeon_cf.c b/drivers/ata/pata_octeon_cf.c
index 8d9343accf3c..abdd19fe990a 100644
--- a/drivers/ata/pata_octeon_cf.c
+++ b/drivers/ata/pata_octeon_cf.c
@@ -653,7 +653,8 @@ static irqreturn_t octeon_cf_interrupt(int irq, void *dev_instance)
653 653
654 ap = host->ports[i]; 654 ap = host->ports[i];
655 ocd = ap->dev->platform_data; 655 ocd = ap->dev->platform_data;
656 if (!ap || (ap->flags & ATA_FLAG_DISABLED)) 656
657 if (ap->flags & ATA_FLAG_DISABLED)
657 continue; 658 continue;
658 659
659 ocd = ap->dev->platform_data; 660 ocd = ap->dev->platform_data;
diff --git a/drivers/ata/pata_pcmcia.c b/drivers/ata/pata_pcmcia.c
index f4d009ed50ac..dc99e26f8e5b 100644
--- a/drivers/ata/pata_pcmcia.c
+++ b/drivers/ata/pata_pcmcia.c
@@ -411,6 +411,7 @@ static struct pcmcia_device_id pcmcia_devices[] = {
411 PCMCIA_DEVICE_PROD_ID123("PCMCIA", "IDE CARD", "F1", 0x281f1c5d, 0x1907960c, 0xf7fde8b9), 411 PCMCIA_DEVICE_PROD_ID123("PCMCIA", "IDE CARD", "F1", 0x281f1c5d, 0x1907960c, 0xf7fde8b9),
412 PCMCIA_DEVICE_PROD_ID12("ARGOSY", "CD-ROM", 0x78f308dc, 0x66536591), 412 PCMCIA_DEVICE_PROD_ID12("ARGOSY", "CD-ROM", 0x78f308dc, 0x66536591),
413 PCMCIA_DEVICE_PROD_ID12("ARGOSY", "PnPIDE", 0x78f308dc, 0x0c694728), 413 PCMCIA_DEVICE_PROD_ID12("ARGOSY", "PnPIDE", 0x78f308dc, 0x0c694728),
414 PCMCIA_DEVICE_PROD_ID12("CNF ", "CD-ROM", 0x46d7db81, 0x66536591),
414 PCMCIA_DEVICE_PROD_ID12("CNF CD-M", "CD-ROM", 0x7d93b852, 0x66536591), 415 PCMCIA_DEVICE_PROD_ID12("CNF CD-M", "CD-ROM", 0x7d93b852, 0x66536591),
415 PCMCIA_DEVICE_PROD_ID12("Creative Technology Ltd.", "PCMCIA CD-ROM Interface Card", 0xff8c8a45, 0xfe8020c4), 416 PCMCIA_DEVICE_PROD_ID12("Creative Technology Ltd.", "PCMCIA CD-ROM Interface Card", 0xff8c8a45, 0xfe8020c4),
416 PCMCIA_DEVICE_PROD_ID12("Digital Equipment Corporation.", "Digital Mobile Media CD-ROM", 0x17692a66, 0xef1dcbde), 417 PCMCIA_DEVICE_PROD_ID12("Digital Equipment Corporation.", "Digital Mobile Media CD-ROM", 0x17692a66, 0xef1dcbde),
diff --git a/drivers/ata/sata_mv.c b/drivers/ata/sata_mv.c
index 23714aefb825..c19417e02208 100644
--- a/drivers/ata/sata_mv.c
+++ b/drivers/ata/sata_mv.c
@@ -2514,7 +2514,7 @@ static void mv_unexpected_intr(struct ata_port *ap, int edma_was_enabled)
2514 char *when = "idle"; 2514 char *when = "idle";
2515 2515
2516 ata_ehi_clear_desc(ehi); 2516 ata_ehi_clear_desc(ehi);
2517 if (!ap || (ap->flags & ATA_FLAG_DISABLED)) { 2517 if (ap->flags & ATA_FLAG_DISABLED) {
2518 when = "disabled"; 2518 when = "disabled";
2519 } else if (edma_was_enabled) { 2519 } else if (edma_was_enabled) {
2520 when = "EDMA enabled"; 2520 when = "EDMA enabled";
diff --git a/drivers/ata/sata_sil.c b/drivers/ata/sata_sil.c
index 030ec079b184..35bd5cc7f285 100644
--- a/drivers/ata/sata_sil.c
+++ b/drivers/ata/sata_sil.c
@@ -532,7 +532,7 @@ static irqreturn_t sil_interrupt(int irq, void *dev_instance)
532 struct ata_port *ap = host->ports[i]; 532 struct ata_port *ap = host->ports[i];
533 u32 bmdma2 = readl(mmio_base + sil_port[ap->port_no].bmdma2); 533 u32 bmdma2 = readl(mmio_base + sil_port[ap->port_no].bmdma2);
534 534
535 if (unlikely(!ap || ap->flags & ATA_FLAG_DISABLED)) 535 if (unlikely(ap->flags & ATA_FLAG_DISABLED))
536 continue; 536 continue;
537 537
538 /* turn off SATA_IRQ if not supported */ 538 /* turn off SATA_IRQ if not supported */
diff --git a/drivers/base/firmware_class.c b/drivers/base/firmware_class.c
index f285f441fab9..7376367bcb80 100644
--- a/drivers/base/firmware_class.c
+++ b/drivers/base/firmware_class.c
@@ -180,7 +180,6 @@ static ssize_t firmware_loading_store(struct device *dev,
180 goto err; 180 goto err;
181 } 181 }
182 /* Pages will be freed by vfree() */ 182 /* Pages will be freed by vfree() */
183 fw_priv->pages = NULL;
184 fw_priv->page_array_size = 0; 183 fw_priv->page_array_size = 0;
185 fw_priv->nr_pages = 0; 184 fw_priv->nr_pages = 0;
186 complete(&fw_priv->completion); 185 complete(&fw_priv->completion);
diff --git a/drivers/base/sys.c b/drivers/base/sys.c
index 79a9ae5238ac..0d903909af7e 100644
--- a/drivers/base/sys.c
+++ b/drivers/base/sys.c
@@ -275,9 +275,9 @@ int sysdev_register(struct sys_device *sysdev)
275 drv->add(sysdev); 275 drv->add(sysdev);
276 } 276 }
277 mutex_unlock(&sysdev_drivers_lock); 277 mutex_unlock(&sysdev_drivers_lock);
278 kobject_uevent(&sysdev->kobj, KOBJ_ADD);
278 } 279 }
279 280
280 kobject_uevent(&sysdev->kobj, KOBJ_ADD);
281 return error; 281 return error;
282} 282}
283 283
diff --git a/drivers/char/n_tty.c b/drivers/char/n_tty.c
index ff47907ff1bf..973be2f44195 100644
--- a/drivers/char/n_tty.c
+++ b/drivers/char/n_tty.c
@@ -1583,6 +1583,7 @@ static int n_tty_open(struct tty_struct *tty)
1583 1583
1584static inline int input_available_p(struct tty_struct *tty, int amt) 1584static inline int input_available_p(struct tty_struct *tty, int amt)
1585{ 1585{
1586 tty_flush_to_ldisc(tty);
1586 if (tty->icanon) { 1587 if (tty->icanon) {
1587 if (tty->canon_data) 1588 if (tty->canon_data)
1588 return 1; 1589 return 1;
diff --git a/drivers/char/pty.c b/drivers/char/pty.c
index 3850a68f265a..6e6942c45f5b 100644
--- a/drivers/char/pty.c
+++ b/drivers/char/pty.c
@@ -52,7 +52,6 @@ static void pty_close(struct tty_struct *tty, struct file *filp)
52 return; 52 return;
53 tty->link->packet = 0; 53 tty->link->packet = 0;
54 set_bit(TTY_OTHER_CLOSED, &tty->link->flags); 54 set_bit(TTY_OTHER_CLOSED, &tty->link->flags);
55 tty_flip_buffer_push(tty->link);
56 wake_up_interruptible(&tty->link->read_wait); 55 wake_up_interruptible(&tty->link->read_wait);
57 wake_up_interruptible(&tty->link->write_wait); 56 wake_up_interruptible(&tty->link->write_wait);
58 if (tty->driver->subtype == PTY_TYPE_MASTER) { 57 if (tty->driver->subtype == PTY_TYPE_MASTER) {
@@ -208,7 +207,6 @@ static int pty_open(struct tty_struct *tty, struct file *filp)
208 clear_bit(TTY_OTHER_CLOSED, &tty->link->flags); 207 clear_bit(TTY_OTHER_CLOSED, &tty->link->flags);
209 set_bit(TTY_THROTTLED, &tty->flags); 208 set_bit(TTY_THROTTLED, &tty->flags);
210 retval = 0; 209 retval = 0;
211 tty->low_latency = 1;
212out: 210out:
213 return retval; 211 return retval;
214} 212}
diff --git a/drivers/char/sysrq.c b/drivers/char/sysrq.c
index 0db35857e4d8..5d7a02f63e1c 100644
--- a/drivers/char/sysrq.c
+++ b/drivers/char/sysrq.c
@@ -35,7 +35,6 @@
35#include <linux/spinlock.h> 35#include <linux/spinlock.h>
36#include <linux/vt_kern.h> 36#include <linux/vt_kern.h>
37#include <linux/workqueue.h> 37#include <linux/workqueue.h>
38#include <linux/kexec.h>
39#include <linux/hrtimer.h> 38#include <linux/hrtimer.h>
40#include <linux/oom.h> 39#include <linux/oom.h>
41 40
@@ -124,9 +123,12 @@ static struct sysrq_key_op sysrq_unraw_op = {
124static void sysrq_handle_crash(int key, struct tty_struct *tty) 123static void sysrq_handle_crash(int key, struct tty_struct *tty)
125{ 124{
126 char *killer = NULL; 125 char *killer = NULL;
126
127 panic_on_oops = 1; /* force panic */
128 wmb();
127 *killer = 1; 129 *killer = 1;
128} 130}
129static struct sysrq_key_op sysrq_crashdump_op = { 131static struct sysrq_key_op sysrq_crash_op = {
130 .handler = sysrq_handle_crash, 132 .handler = sysrq_handle_crash,
131 .help_msg = "Crash", 133 .help_msg = "Crash",
132 .action_msg = "Trigger a crash", 134 .action_msg = "Trigger a crash",
@@ -401,7 +403,7 @@ static struct sysrq_key_op *sysrq_key_table[36] = {
401 */ 403 */
402 NULL, /* a */ 404 NULL, /* a */
403 &sysrq_reboot_op, /* b */ 405 &sysrq_reboot_op, /* b */
404 &sysrq_crashdump_op, /* c & ibm_emac driver debug */ 406 &sysrq_crash_op, /* c & ibm_emac driver debug */
405 &sysrq_showlocks_op, /* d */ 407 &sysrq_showlocks_op, /* d */
406 &sysrq_term_op, /* e */ 408 &sysrq_term_op, /* e */
407 &sysrq_moom_op, /* f */ 409 &sysrq_moom_op, /* f */
diff --git a/drivers/char/tty_buffer.c b/drivers/char/tty_buffer.c
index 810ee25d66a4..3108991c5c8b 100644
--- a/drivers/char/tty_buffer.c
+++ b/drivers/char/tty_buffer.c
@@ -462,6 +462,19 @@ static void flush_to_ldisc(struct work_struct *work)
462} 462}
463 463
464/** 464/**
465 * tty_flush_to_ldisc
466 * @tty: tty to push
467 *
468 * Push the terminal flip buffers to the line discipline.
469 *
470 * Must not be called from IRQ context.
471 */
472void tty_flush_to_ldisc(struct tty_struct *tty)
473{
474 flush_to_ldisc(&tty->buf.work.work);
475}
476
477/**
465 * tty_flip_buffer_push - terminal 478 * tty_flip_buffer_push - terminal
466 * @tty: tty to push 479 * @tty: tty to push
467 * 480 *
diff --git a/drivers/char/vr41xx_giu.c b/drivers/char/vr41xx_giu.c
deleted file mode 100644
index e69de29bb2d1..000000000000
--- a/drivers/char/vr41xx_giu.c
+++ /dev/null
diff --git a/drivers/edac/x38_edac.c b/drivers/edac/x38_edac.c
index 2406c2ce2844..d4ec60593176 100644
--- a/drivers/edac/x38_edac.c
+++ b/drivers/edac/x38_edac.c
@@ -30,7 +30,7 @@
30/* Intel X38 register addresses - device 0 function 0 - DRAM Controller */ 30/* Intel X38 register addresses - device 0 function 0 - DRAM Controller */
31 31
32#define X38_MCHBAR_LOW 0x48 /* MCH Memory Mapped Register BAR */ 32#define X38_MCHBAR_LOW 0x48 /* MCH Memory Mapped Register BAR */
33#define X38_MCHBAR_HIGH 0x4b 33#define X38_MCHBAR_HIGH 0x4c
34#define X38_MCHBAR_MASK 0xfffffc000ULL /* bits 35:14 */ 34#define X38_MCHBAR_MASK 0xfffffc000ULL /* bits 35:14 */
35#define X38_MMR_WINDOW_SIZE 16384 35#define X38_MMR_WINDOW_SIZE 16384
36 36
diff --git a/drivers/gpu/drm/radeon/Makefile b/drivers/gpu/drm/radeon/Makefile
index 5fae1e074b4b..013d38059943 100644
--- a/drivers/gpu/drm/radeon/Makefile
+++ b/drivers/gpu/drm/radeon/Makefile
@@ -13,7 +13,8 @@ radeon-$(CONFIG_DRM_RADEON_KMS) += radeon_device.o radeon_kms.o \
13 radeon_encoders.o radeon_display.o radeon_cursor.o radeon_i2c.o \ 13 radeon_encoders.o radeon_display.o radeon_cursor.o radeon_i2c.o \
14 radeon_clocks.o radeon_fb.o radeon_gem.o radeon_ring.o radeon_irq_kms.o \ 14 radeon_clocks.o radeon_fb.o radeon_gem.o radeon_ring.o radeon_irq_kms.o \
15 radeon_cs.o radeon_bios.o radeon_benchmark.o r100.o r300.o r420.o \ 15 radeon_cs.o radeon_bios.o radeon_benchmark.o r100.o r300.o r420.o \
16 rs400.o rs600.o rs690.o rv515.o r520.o r600.o rs780.o rv770.o 16 rs400.o rs600.o rs690.o rv515.o r520.o r600.o rs780.o rv770.o \
17 radeon_test.o
17 18
18radeon-$(CONFIG_COMPAT) += radeon_ioc32.o 19radeon-$(CONFIG_COMPAT) += radeon_ioc32.o
19 20
diff --git a/drivers/gpu/drm/radeon/atombios_crtc.c b/drivers/gpu/drm/radeon/atombios_crtc.c
index c0080cc9bf8d..74d034f77c6b 100644
--- a/drivers/gpu/drm/radeon/atombios_crtc.c
+++ b/drivers/gpu/drm/radeon/atombios_crtc.c
@@ -31,6 +31,132 @@
31#include "atom.h" 31#include "atom.h"
32#include "atom-bits.h" 32#include "atom-bits.h"
33 33
34static void atombios_overscan_setup(struct drm_crtc *crtc,
35 struct drm_display_mode *mode,
36 struct drm_display_mode *adjusted_mode)
37{
38 struct drm_device *dev = crtc->dev;
39 struct radeon_device *rdev = dev->dev_private;
40 struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc);
41 SET_CRTC_OVERSCAN_PS_ALLOCATION args;
42 int index = GetIndexIntoMasterTable(COMMAND, SetCRTC_OverScan);
43 int a1, a2;
44
45 memset(&args, 0, sizeof(args));
46
47 args.usOverscanRight = 0;
48 args.usOverscanLeft = 0;
49 args.usOverscanBottom = 0;
50 args.usOverscanTop = 0;
51 args.ucCRTC = radeon_crtc->crtc_id;
52
53 switch (radeon_crtc->rmx_type) {
54 case RMX_CENTER:
55 args.usOverscanTop = (adjusted_mode->crtc_vdisplay - mode->crtc_vdisplay) / 2;
56 args.usOverscanBottom = (adjusted_mode->crtc_vdisplay - mode->crtc_vdisplay) / 2;
57 args.usOverscanLeft = (adjusted_mode->crtc_hdisplay - mode->crtc_hdisplay) / 2;
58 args.usOverscanRight = (adjusted_mode->crtc_hdisplay - mode->crtc_hdisplay) / 2;
59 atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args);
60 break;
61 case RMX_ASPECT:
62 a1 = mode->crtc_vdisplay * adjusted_mode->crtc_hdisplay;
63 a2 = adjusted_mode->crtc_vdisplay * mode->crtc_hdisplay;
64
65 if (a1 > a2) {
66 args.usOverscanLeft = (adjusted_mode->crtc_hdisplay - (a2 / mode->crtc_vdisplay)) / 2;
67 args.usOverscanRight = (adjusted_mode->crtc_hdisplay - (a2 / mode->crtc_vdisplay)) / 2;
68 } else if (a2 > a1) {
69 args.usOverscanLeft = (adjusted_mode->crtc_vdisplay - (a1 / mode->crtc_hdisplay)) / 2;
70 args.usOverscanRight = (adjusted_mode->crtc_vdisplay - (a1 / mode->crtc_hdisplay)) / 2;
71 }
72 atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args);
73 break;
74 case RMX_FULL:
75 default:
76 args.usOverscanRight = 0;
77 args.usOverscanLeft = 0;
78 args.usOverscanBottom = 0;
79 args.usOverscanTop = 0;
80 atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args);
81 break;
82 }
83}
84
85static void atombios_scaler_setup(struct drm_crtc *crtc)
86{
87 struct drm_device *dev = crtc->dev;
88 struct radeon_device *rdev = dev->dev_private;
89 struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc);
90 ENABLE_SCALER_PS_ALLOCATION args;
91 int index = GetIndexIntoMasterTable(COMMAND, EnableScaler);
92 /* fixme - fill in enc_priv for atom dac */
93 enum radeon_tv_std tv_std = TV_STD_NTSC;
94
95 if (!ASIC_IS_AVIVO(rdev) && radeon_crtc->crtc_id)
96 return;
97
98 memset(&args, 0, sizeof(args));
99
100 args.ucScaler = radeon_crtc->crtc_id;
101
102 if (radeon_crtc->devices & (ATOM_DEVICE_TV_SUPPORT)) {
103 switch (tv_std) {
104 case TV_STD_NTSC:
105 default:
106 args.ucTVStandard = ATOM_TV_NTSC;
107 break;
108 case TV_STD_PAL:
109 args.ucTVStandard = ATOM_TV_PAL;
110 break;
111 case TV_STD_PAL_M:
112 args.ucTVStandard = ATOM_TV_PALM;
113 break;
114 case TV_STD_PAL_60:
115 args.ucTVStandard = ATOM_TV_PAL60;
116 break;
117 case TV_STD_NTSC_J:
118 args.ucTVStandard = ATOM_TV_NTSCJ;
119 break;
120 case TV_STD_SCART_PAL:
121 args.ucTVStandard = ATOM_TV_PAL; /* ??? */
122 break;
123 case TV_STD_SECAM:
124 args.ucTVStandard = ATOM_TV_SECAM;
125 break;
126 case TV_STD_PAL_CN:
127 args.ucTVStandard = ATOM_TV_PALCN;
128 break;
129 }
130 args.ucEnable = SCALER_ENABLE_MULTITAP_MODE;
131 } else if (radeon_crtc->devices & (ATOM_DEVICE_CV_SUPPORT)) {
132 args.ucTVStandard = ATOM_TV_CV;
133 args.ucEnable = SCALER_ENABLE_MULTITAP_MODE;
134 } else {
135 switch (radeon_crtc->rmx_type) {
136 case RMX_FULL:
137 args.ucEnable = ATOM_SCALER_EXPANSION;
138 break;
139 case RMX_CENTER:
140 args.ucEnable = ATOM_SCALER_CENTER;
141 break;
142 case RMX_ASPECT:
143 args.ucEnable = ATOM_SCALER_EXPANSION;
144 break;
145 default:
146 if (ASIC_IS_AVIVO(rdev))
147 args.ucEnable = ATOM_SCALER_DISABLE;
148 else
149 args.ucEnable = ATOM_SCALER_CENTER;
150 break;
151 }
152 }
153 atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args);
154 if (radeon_crtc->devices & (ATOM_DEVICE_CV_SUPPORT | ATOM_DEVICE_TV_SUPPORT)
155 && rdev->family >= CHIP_RV515 && rdev->family <= CHIP_RV570) {
156 atom_rv515_force_tv_scaler(rdev);
157 }
158}
159
34static void atombios_lock_crtc(struct drm_crtc *crtc, int lock) 160static void atombios_lock_crtc(struct drm_crtc *crtc, int lock)
35{ 161{
36 struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc); 162 struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc);
@@ -203,6 +329,12 @@ void atombios_crtc_set_pll(struct drm_crtc *crtc, struct drm_display_mode *mode)
203 if (ASIC_IS_AVIVO(rdev)) { 329 if (ASIC_IS_AVIVO(rdev)) {
204 uint32_t ss_cntl; 330 uint32_t ss_cntl;
205 331
332 if ((rdev->family == CHIP_RS600) ||
333 (rdev->family == CHIP_RS690) ||
334 (rdev->family == CHIP_RS740))
335 pll_flags |= (RADEON_PLL_USE_FRAC_FB_DIV |
336 RADEON_PLL_PREFER_CLOSEST_LOWER);
337
206 if (ASIC_IS_DCE32(rdev) && mode->clock > 200000) /* range limits??? */ 338 if (ASIC_IS_DCE32(rdev) && mode->clock > 200000) /* range limits??? */
207 pll_flags |= RADEON_PLL_PREFER_HIGH_FB_DIV; 339 pll_flags |= RADEON_PLL_PREFER_HIGH_FB_DIV;
208 else 340 else
@@ -321,7 +453,7 @@ int atombios_crtc_set_base(struct drm_crtc *crtc, int x, int y,
321 struct drm_gem_object *obj; 453 struct drm_gem_object *obj;
322 struct drm_radeon_gem_object *obj_priv; 454 struct drm_radeon_gem_object *obj_priv;
323 uint64_t fb_location; 455 uint64_t fb_location;
324 uint32_t fb_format, fb_pitch_pixels; 456 uint32_t fb_format, fb_pitch_pixels, tiling_flags;
325 457
326 if (!crtc->fb) 458 if (!crtc->fb)
327 return -EINVAL; 459 return -EINVAL;
@@ -358,7 +490,14 @@ int atombios_crtc_set_base(struct drm_crtc *crtc, int x, int y,
358 return -EINVAL; 490 return -EINVAL;
359 } 491 }
360 492
361 /* TODO tiling */ 493 radeon_object_get_tiling_flags(obj->driver_private,
494 &tiling_flags, NULL);
495 if (tiling_flags & RADEON_TILING_MACRO)
496 fb_format |= AVIVO_D1GRPH_MACRO_ADDRESS_MODE;
497
498 if (tiling_flags & RADEON_TILING_MICRO)
499 fb_format |= AVIVO_D1GRPH_TILED;
500
362 if (radeon_crtc->crtc_id == 0) 501 if (radeon_crtc->crtc_id == 0)
363 WREG32(AVIVO_D1VGA_CONTROL, 0); 502 WREG32(AVIVO_D1VGA_CONTROL, 0);
364 else 503 else
@@ -509,6 +648,9 @@ int atombios_crtc_mode_set(struct drm_crtc *crtc,
509 radeon_crtc_set_base(crtc, x, y, old_fb); 648 radeon_crtc_set_base(crtc, x, y, old_fb);
510 radeon_legacy_atom_set_surface(crtc); 649 radeon_legacy_atom_set_surface(crtc);
511 } 650 }
651 atombios_overscan_setup(crtc, mode, adjusted_mode);
652 atombios_scaler_setup(crtc);
653 radeon_bandwidth_update(rdev);
512 return 0; 654 return 0;
513} 655}
514 656
@@ -516,6 +658,8 @@ static bool atombios_crtc_mode_fixup(struct drm_crtc *crtc,
516 struct drm_display_mode *mode, 658 struct drm_display_mode *mode,
517 struct drm_display_mode *adjusted_mode) 659 struct drm_display_mode *adjusted_mode)
518{ 660{
661 if (!radeon_crtc_scaling_mode_fixup(crtc, mode, adjusted_mode))
662 return false;
519 return true; 663 return true;
520} 664}
521 665
@@ -548,148 +692,3 @@ void radeon_atombios_init_crtc(struct drm_device *dev,
548 AVIVO_D2CRTC_H_TOTAL - AVIVO_D1CRTC_H_TOTAL; 692 AVIVO_D2CRTC_H_TOTAL - AVIVO_D1CRTC_H_TOTAL;
549 drm_crtc_helper_add(&radeon_crtc->base, &atombios_helper_funcs); 693 drm_crtc_helper_add(&radeon_crtc->base, &atombios_helper_funcs);
550} 694}
551
552void radeon_init_disp_bw_avivo(struct drm_device *dev,
553 struct drm_display_mode *mode1,
554 uint32_t pixel_bytes1,
555 struct drm_display_mode *mode2,
556 uint32_t pixel_bytes2)
557{
558 struct radeon_device *rdev = dev->dev_private;
559 fixed20_12 min_mem_eff;
560 fixed20_12 peak_disp_bw, mem_bw, pix_clk, pix_clk2, temp_ff;
561 fixed20_12 sclk_ff, mclk_ff;
562 uint32_t dc_lb_memory_split, temp;
563
564 min_mem_eff.full = rfixed_const_8(0);
565 if (rdev->disp_priority == 2) {
566 uint32_t mc_init_misc_lat_timer = 0;
567 if (rdev->family == CHIP_RV515)
568 mc_init_misc_lat_timer =
569 RREG32_MC(RV515_MC_INIT_MISC_LAT_TIMER);
570 else if (rdev->family == CHIP_RS690)
571 mc_init_misc_lat_timer =
572 RREG32_MC(RS690_MC_INIT_MISC_LAT_TIMER);
573
574 mc_init_misc_lat_timer &=
575 ~(R300_MC_DISP1R_INIT_LAT_MASK <<
576 R300_MC_DISP1R_INIT_LAT_SHIFT);
577 mc_init_misc_lat_timer &=
578 ~(R300_MC_DISP0R_INIT_LAT_MASK <<
579 R300_MC_DISP0R_INIT_LAT_SHIFT);
580
581 if (mode2)
582 mc_init_misc_lat_timer |=
583 (1 << R300_MC_DISP1R_INIT_LAT_SHIFT);
584 if (mode1)
585 mc_init_misc_lat_timer |=
586 (1 << R300_MC_DISP0R_INIT_LAT_SHIFT);
587
588 if (rdev->family == CHIP_RV515)
589 WREG32_MC(RV515_MC_INIT_MISC_LAT_TIMER,
590 mc_init_misc_lat_timer);
591 else if (rdev->family == CHIP_RS690)
592 WREG32_MC(RS690_MC_INIT_MISC_LAT_TIMER,
593 mc_init_misc_lat_timer);
594 }
595
596 /*
597 * determine is there is enough bw for current mode
598 */
599 temp_ff.full = rfixed_const(100);
600 mclk_ff.full = rfixed_const(rdev->clock.default_mclk);
601 mclk_ff.full = rfixed_div(mclk_ff, temp_ff);
602 sclk_ff.full = rfixed_const(rdev->clock.default_sclk);
603 sclk_ff.full = rfixed_div(sclk_ff, temp_ff);
604
605 temp = (rdev->mc.vram_width / 8) * (rdev->mc.vram_is_ddr ? 2 : 1);
606 temp_ff.full = rfixed_const(temp);
607 mem_bw.full = rfixed_mul(mclk_ff, temp_ff);
608 mem_bw.full = rfixed_mul(mem_bw, min_mem_eff);
609
610 pix_clk.full = 0;
611 pix_clk2.full = 0;
612 peak_disp_bw.full = 0;
613 if (mode1) {
614 temp_ff.full = rfixed_const(1000);
615 pix_clk.full = rfixed_const(mode1->clock); /* convert to fixed point */
616 pix_clk.full = rfixed_div(pix_clk, temp_ff);
617 temp_ff.full = rfixed_const(pixel_bytes1);
618 peak_disp_bw.full += rfixed_mul(pix_clk, temp_ff);
619 }
620 if (mode2) {
621 temp_ff.full = rfixed_const(1000);
622 pix_clk2.full = rfixed_const(mode2->clock); /* convert to fixed point */
623 pix_clk2.full = rfixed_div(pix_clk2, temp_ff);
624 temp_ff.full = rfixed_const(pixel_bytes2);
625 peak_disp_bw.full += rfixed_mul(pix_clk2, temp_ff);
626 }
627
628 if (peak_disp_bw.full >= mem_bw.full) {
629 DRM_ERROR
630 ("You may not have enough display bandwidth for current mode\n"
631 "If you have flickering problem, try to lower resolution, refresh rate, or color depth\n");
632 printk("peak disp bw %d, mem_bw %d\n",
633 rfixed_trunc(peak_disp_bw), rfixed_trunc(mem_bw));
634 }
635
636 /*
637 * Line Buffer Setup
638 * There is a single line buffer shared by both display controllers.
639 * DC_LB_MEMORY_SPLIT controls how that line buffer is shared between the display
640 * controllers. The paritioning can either be done manually or via one of four
641 * preset allocations specified in bits 1:0:
642 * 0 - line buffer is divided in half and shared between each display controller
643 * 1 - D1 gets 3/4 of the line buffer, D2 gets 1/4
644 * 2 - D1 gets the whole buffer
645 * 3 - D1 gets 1/4 of the line buffer, D2 gets 3/4
646 * Setting bit 2 of DC_LB_MEMORY_SPLIT controls switches to manual allocation mode.
647 * In manual allocation mode, D1 always starts at 0, D1 end/2 is specified in bits
648 * 14:4; D2 allocation follows D1.
649 */
650
651 /* is auto or manual better ? */
652 dc_lb_memory_split =
653 RREG32(AVIVO_DC_LB_MEMORY_SPLIT) & ~AVIVO_DC_LB_MEMORY_SPLIT_MASK;
654 dc_lb_memory_split &= ~AVIVO_DC_LB_MEMORY_SPLIT_SHIFT_MODE;
655#if 1
656 /* auto */
657 if (mode1 && mode2) {
658 if (mode1->hdisplay > mode2->hdisplay) {
659 if (mode1->hdisplay > 2560)
660 dc_lb_memory_split |=
661 AVIVO_DC_LB_MEMORY_SPLIT_D1_3Q_D2_1Q;
662 else
663 dc_lb_memory_split |=
664 AVIVO_DC_LB_MEMORY_SPLIT_D1HALF_D2HALF;
665 } else if (mode2->hdisplay > mode1->hdisplay) {
666 if (mode2->hdisplay > 2560)
667 dc_lb_memory_split |=
668 AVIVO_DC_LB_MEMORY_SPLIT_D1_1Q_D2_3Q;
669 else
670 dc_lb_memory_split |=
671 AVIVO_DC_LB_MEMORY_SPLIT_D1HALF_D2HALF;
672 } else
673 dc_lb_memory_split |=
674 AVIVO_DC_LB_MEMORY_SPLIT_D1HALF_D2HALF;
675 } else if (mode1) {
676 dc_lb_memory_split |= AVIVO_DC_LB_MEMORY_SPLIT_D1_ONLY;
677 } else if (mode2) {
678 dc_lb_memory_split |= AVIVO_DC_LB_MEMORY_SPLIT_D1_1Q_D2_3Q;
679 }
680#else
681 /* manual */
682 dc_lb_memory_split |= AVIVO_DC_LB_MEMORY_SPLIT_SHIFT_MODE;
683 dc_lb_memory_split &=
684 ~(AVIVO_DC_LB_DISP1_END_ADR_MASK <<
685 AVIVO_DC_LB_DISP1_END_ADR_SHIFT);
686 if (mode1) {
687 dc_lb_memory_split |=
688 ((((mode1->hdisplay / 2) + 64) & AVIVO_DC_LB_DISP1_END_ADR_MASK)
689 << AVIVO_DC_LB_DISP1_END_ADR_SHIFT);
690 } else if (mode2) {
691 dc_lb_memory_split |= (0 << AVIVO_DC_LB_DISP1_END_ADR_SHIFT);
692 }
693#endif
694 WREG32(AVIVO_DC_LB_MEMORY_SPLIT, dc_lb_memory_split);
695}
diff --git a/drivers/gpu/drm/radeon/r100.c b/drivers/gpu/drm/radeon/r100.c
index c550932a108f..05a44896dffb 100644
--- a/drivers/gpu/drm/radeon/r100.c
+++ b/drivers/gpu/drm/radeon/r100.c
@@ -110,7 +110,7 @@ int r100_pci_gart_set_page(struct radeon_device *rdev, int i, uint64_t addr)
110 if (i < 0 || i > rdev->gart.num_gpu_pages) { 110 if (i < 0 || i > rdev->gart.num_gpu_pages) {
111 return -EINVAL; 111 return -EINVAL;
112 } 112 }
113 rdev->gart.table.ram.ptr[i] = cpu_to_le32((uint32_t)addr); 113 rdev->gart.table.ram.ptr[i] = cpu_to_le32(lower_32_bits(addr));
114 return 0; 114 return 0;
115} 115}
116 116
@@ -173,8 +173,12 @@ void r100_mc_setup(struct radeon_device *rdev)
173 DRM_ERROR("Failed to register debugfs file for R100 MC !\n"); 173 DRM_ERROR("Failed to register debugfs file for R100 MC !\n");
174 } 174 }
175 /* Write VRAM size in case we are limiting it */ 175 /* Write VRAM size in case we are limiting it */
176 WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.vram_size); 176 WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.real_vram_size);
177 tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; 177 /* Novell bug 204882 for RN50/M6/M7 with 8/16/32MB VRAM,
178 * if the aperture is 64MB but we have 32MB VRAM
179 * we report only 32MB VRAM but we have to set MC_FB_LOCATION
180 * to 64MB, otherwise the gpu accidentially dies */
181 tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1;
178 tmp = REG_SET(RADEON_MC_FB_TOP, tmp >> 16); 182 tmp = REG_SET(RADEON_MC_FB_TOP, tmp >> 16);
179 tmp |= REG_SET(RADEON_MC_FB_START, rdev->mc.vram_location >> 16); 183 tmp |= REG_SET(RADEON_MC_FB_START, rdev->mc.vram_location >> 16);
180 WREG32(RADEON_MC_FB_LOCATION, tmp); 184 WREG32(RADEON_MC_FB_LOCATION, tmp);
@@ -215,7 +219,6 @@ int r100_mc_init(struct radeon_device *rdev)
215 r100_pci_gart_disable(rdev); 219 r100_pci_gart_disable(rdev);
216 220
217 /* Setup GPU memory space */ 221 /* Setup GPU memory space */
218 rdev->mc.vram_location = 0xFFFFFFFFUL;
219 rdev->mc.gtt_location = 0xFFFFFFFFUL; 222 rdev->mc.gtt_location = 0xFFFFFFFFUL;
220 if (rdev->flags & RADEON_IS_AGP) { 223 if (rdev->flags & RADEON_IS_AGP) {
221 r = radeon_agp_init(rdev); 224 r = radeon_agp_init(rdev);
@@ -753,6 +756,102 @@ int r100_cs_packet_parse(struct radeon_cs_parser *p,
753} 756}
754 757
755/** 758/**
759 * r100_cs_packet_next_vline() - parse userspace VLINE packet
760 * @parser: parser structure holding parsing context.
761 *
762 * Userspace sends a special sequence for VLINE waits.
763 * PACKET0 - VLINE_START_END + value
764 * PACKET0 - WAIT_UNTIL +_value
765 * RELOC (P3) - crtc_id in reloc.
766 *
767 * This function parses this and relocates the VLINE START END
768 * and WAIT UNTIL packets to the correct crtc.
769 * It also detects a switched off crtc and nulls out the
770 * wait in that case.
771 */
772int r100_cs_packet_parse_vline(struct radeon_cs_parser *p)
773{
774 struct radeon_cs_chunk *ib_chunk;
775 struct drm_mode_object *obj;
776 struct drm_crtc *crtc;
777 struct radeon_crtc *radeon_crtc;
778 struct radeon_cs_packet p3reloc, waitreloc;
779 int crtc_id;
780 int r;
781 uint32_t header, h_idx, reg;
782
783 ib_chunk = &p->chunks[p->chunk_ib_idx];
784
785 /* parse the wait until */
786 r = r100_cs_packet_parse(p, &waitreloc, p->idx);
787 if (r)
788 return r;
789
790 /* check its a wait until and only 1 count */
791 if (waitreloc.reg != RADEON_WAIT_UNTIL ||
792 waitreloc.count != 0) {
793 DRM_ERROR("vline wait had illegal wait until segment\n");
794 r = -EINVAL;
795 return r;
796 }
797
798 if (ib_chunk->kdata[waitreloc.idx + 1] != RADEON_WAIT_CRTC_VLINE) {
799 DRM_ERROR("vline wait had illegal wait until\n");
800 r = -EINVAL;
801 return r;
802 }
803
804 /* jump over the NOP */
805 r = r100_cs_packet_parse(p, &p3reloc, p->idx);
806 if (r)
807 return r;
808
809 h_idx = p->idx - 2;
810 p->idx += waitreloc.count;
811 p->idx += p3reloc.count;
812
813 header = ib_chunk->kdata[h_idx];
814 crtc_id = ib_chunk->kdata[h_idx + 5];
815 reg = ib_chunk->kdata[h_idx] >> 2;
816 mutex_lock(&p->rdev->ddev->mode_config.mutex);
817 obj = drm_mode_object_find(p->rdev->ddev, crtc_id, DRM_MODE_OBJECT_CRTC);
818 if (!obj) {
819 DRM_ERROR("cannot find crtc %d\n", crtc_id);
820 r = -EINVAL;
821 goto out;
822 }
823 crtc = obj_to_crtc(obj);
824 radeon_crtc = to_radeon_crtc(crtc);
825 crtc_id = radeon_crtc->crtc_id;
826
827 if (!crtc->enabled) {
828 /* if the CRTC isn't enabled - we need to nop out the wait until */
829 ib_chunk->kdata[h_idx + 2] = PACKET2(0);
830 ib_chunk->kdata[h_idx + 3] = PACKET2(0);
831 } else if (crtc_id == 1) {
832 switch (reg) {
833 case AVIVO_D1MODE_VLINE_START_END:
834 header &= R300_CP_PACKET0_REG_MASK;
835 header |= AVIVO_D2MODE_VLINE_START_END >> 2;
836 break;
837 case RADEON_CRTC_GUI_TRIG_VLINE:
838 header &= R300_CP_PACKET0_REG_MASK;
839 header |= RADEON_CRTC2_GUI_TRIG_VLINE >> 2;
840 break;
841 default:
842 DRM_ERROR("unknown crtc reloc\n");
843 r = -EINVAL;
844 goto out;
845 }
846 ib_chunk->kdata[h_idx] = header;
847 ib_chunk->kdata[h_idx + 3] |= RADEON_ENG_DISPLAY_SELECT_CRTC1;
848 }
849out:
850 mutex_unlock(&p->rdev->ddev->mode_config.mutex);
851 return r;
852}
853
854/**
756 * r100_cs_packet_next_reloc() - parse next packet which should be reloc packet3 855 * r100_cs_packet_next_reloc() - parse next packet which should be reloc packet3
757 * @parser: parser structure holding parsing context. 856 * @parser: parser structure holding parsing context.
758 * @data: pointer to relocation data 857 * @data: pointer to relocation data
@@ -814,6 +913,7 @@ static int r100_packet0_check(struct radeon_cs_parser *p,
814 unsigned idx; 913 unsigned idx;
815 bool onereg; 914 bool onereg;
816 int r; 915 int r;
916 u32 tile_flags = 0;
817 917
818 ib = p->ib->ptr; 918 ib = p->ib->ptr;
819 ib_chunk = &p->chunks[p->chunk_ib_idx]; 919 ib_chunk = &p->chunks[p->chunk_ib_idx];
@@ -825,6 +925,15 @@ static int r100_packet0_check(struct radeon_cs_parser *p,
825 } 925 }
826 for (i = 0; i <= pkt->count; i++, idx++, reg += 4) { 926 for (i = 0; i <= pkt->count; i++, idx++, reg += 4) {
827 switch (reg) { 927 switch (reg) {
928 case RADEON_CRTC_GUI_TRIG_VLINE:
929 r = r100_cs_packet_parse_vline(p);
930 if (r) {
931 DRM_ERROR("No reloc for ib[%d]=0x%04X\n",
932 idx, reg);
933 r100_cs_dump_packet(p, pkt);
934 return r;
935 }
936 break;
828 /* FIXME: only allow PACKET3 blit? easier to check for out of 937 /* FIXME: only allow PACKET3 blit? easier to check for out of
829 * range access */ 938 * range access */
830 case RADEON_DST_PITCH_OFFSET: 939 case RADEON_DST_PITCH_OFFSET:
@@ -838,7 +947,20 @@ static int r100_packet0_check(struct radeon_cs_parser *p,
838 } 947 }
839 tmp = ib_chunk->kdata[idx] & 0x003fffff; 948 tmp = ib_chunk->kdata[idx] & 0x003fffff;
840 tmp += (((u32)reloc->lobj.gpu_offset) >> 10); 949 tmp += (((u32)reloc->lobj.gpu_offset) >> 10);
841 ib[idx] = (ib_chunk->kdata[idx] & 0xffc00000) | tmp; 950
951 if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO)
952 tile_flags |= RADEON_DST_TILE_MACRO;
953 if (reloc->lobj.tiling_flags & RADEON_TILING_MICRO) {
954 if (reg == RADEON_SRC_PITCH_OFFSET) {
955 DRM_ERROR("Cannot src blit from microtiled surface\n");
956 r100_cs_dump_packet(p, pkt);
957 return -EINVAL;
958 }
959 tile_flags |= RADEON_DST_TILE_MICRO;
960 }
961
962 tmp |= tile_flags;
963 ib[idx] = (ib_chunk->kdata[idx] & 0x3fc00000) | tmp;
842 break; 964 break;
843 case RADEON_RB3D_DEPTHOFFSET: 965 case RADEON_RB3D_DEPTHOFFSET:
844 case RADEON_RB3D_COLOROFFSET: 966 case RADEON_RB3D_COLOROFFSET:
@@ -869,6 +991,11 @@ static int r100_packet0_check(struct radeon_cs_parser *p,
869 case R300_TX_OFFSET_0+52: 991 case R300_TX_OFFSET_0+52:
870 case R300_TX_OFFSET_0+56: 992 case R300_TX_OFFSET_0+56:
871 case R300_TX_OFFSET_0+60: 993 case R300_TX_OFFSET_0+60:
994 /* rn50 has no 3D engine so fail on any 3d setup */
995 if (ASIC_IS_RN50(p->rdev)) {
996 DRM_ERROR("attempt to use RN50 3D engine failed\n");
997 return -EINVAL;
998 }
872 r = r100_cs_packet_next_reloc(p, &reloc); 999 r = r100_cs_packet_next_reloc(p, &reloc);
873 if (r) { 1000 if (r) {
874 DRM_ERROR("No reloc for ib[%d]=0x%04X\n", 1001 DRM_ERROR("No reloc for ib[%d]=0x%04X\n",
@@ -878,6 +1005,25 @@ static int r100_packet0_check(struct radeon_cs_parser *p,
878 } 1005 }
879 ib[idx] = ib_chunk->kdata[idx] + ((u32)reloc->lobj.gpu_offset); 1006 ib[idx] = ib_chunk->kdata[idx] + ((u32)reloc->lobj.gpu_offset);
880 break; 1007 break;
1008 case R300_RB3D_COLORPITCH0:
1009 case RADEON_RB3D_COLORPITCH:
1010 r = r100_cs_packet_next_reloc(p, &reloc);
1011 if (r) {
1012 DRM_ERROR("No reloc for ib[%d]=0x%04X\n",
1013 idx, reg);
1014 r100_cs_dump_packet(p, pkt);
1015 return r;
1016 }
1017
1018 if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO)
1019 tile_flags |= RADEON_COLOR_TILE_ENABLE;
1020 if (reloc->lobj.tiling_flags & RADEON_TILING_MICRO)
1021 tile_flags |= RADEON_COLOR_MICROTILE_ENABLE;
1022
1023 tmp = ib_chunk->kdata[idx] & ~(0x7 << 16);
1024 tmp |= tile_flags;
1025 ib[idx] = tmp;
1026 break;
881 default: 1027 default:
882 /* FIXME: we don't want to allow anyothers packet */ 1028 /* FIXME: we don't want to allow anyothers packet */
883 break; 1029 break;
@@ -1256,29 +1402,100 @@ static void r100_vram_get_type(struct radeon_device *rdev)
1256 } 1402 }
1257} 1403}
1258 1404
1259void r100_vram_info(struct radeon_device *rdev) 1405static u32 r100_get_accessible_vram(struct radeon_device *rdev)
1260{ 1406{
1261 r100_vram_get_type(rdev); 1407 u32 aper_size;
1408 u8 byte;
1409
1410 aper_size = RREG32(RADEON_CONFIG_APER_SIZE);
1411
1412 /* Set HDP_APER_CNTL only on cards that are known not to be broken,
1413 * that is has the 2nd generation multifunction PCI interface
1414 */
1415 if (rdev->family == CHIP_RV280 ||
1416 rdev->family >= CHIP_RV350) {
1417 WREG32_P(RADEON_HOST_PATH_CNTL, RADEON_HDP_APER_CNTL,
1418 ~RADEON_HDP_APER_CNTL);
1419 DRM_INFO("Generation 2 PCI interface, using max accessible memory\n");
1420 return aper_size * 2;
1421 }
1422
1423 /* Older cards have all sorts of funny issues to deal with. First
1424 * check if it's a multifunction card by reading the PCI config
1425 * header type... Limit those to one aperture size
1426 */
1427 pci_read_config_byte(rdev->pdev, 0xe, &byte);
1428 if (byte & 0x80) {
1429 DRM_INFO("Generation 1 PCI interface in multifunction mode\n");
1430 DRM_INFO("Limiting VRAM to one aperture\n");
1431 return aper_size;
1432 }
1433
1434 /* Single function older card. We read HDP_APER_CNTL to see how the BIOS
1435 * have set it up. We don't write this as it's broken on some ASICs but
1436 * we expect the BIOS to have done the right thing (might be too optimistic...)
1437 */
1438 if (RREG32(RADEON_HOST_PATH_CNTL) & RADEON_HDP_APER_CNTL)
1439 return aper_size * 2;
1440 return aper_size;
1441}
1442
1443void r100_vram_init_sizes(struct radeon_device *rdev)
1444{
1445 u64 config_aper_size;
1446 u32 accessible;
1447
1448 config_aper_size = RREG32(RADEON_CONFIG_APER_SIZE);
1262 1449
1263 if (rdev->flags & RADEON_IS_IGP) { 1450 if (rdev->flags & RADEON_IS_IGP) {
1264 uint32_t tom; 1451 uint32_t tom;
1265 /* read NB_TOM to get the amount of ram stolen for the GPU */ 1452 /* read NB_TOM to get the amount of ram stolen for the GPU */
1266 tom = RREG32(RADEON_NB_TOM); 1453 tom = RREG32(RADEON_NB_TOM);
1267 rdev->mc.vram_size = (((tom >> 16) - (tom & 0xffff) + 1) << 16); 1454 rdev->mc.real_vram_size = (((tom >> 16) - (tom & 0xffff) + 1) << 16);
1268 WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.vram_size); 1455 /* for IGPs we need to keep VRAM where it was put by the BIOS */
1456 rdev->mc.vram_location = (tom & 0xffff) << 16;
1457 WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.real_vram_size);
1458 rdev->mc.mc_vram_size = rdev->mc.real_vram_size;
1269 } else { 1459 } else {
1270 rdev->mc.vram_size = RREG32(RADEON_CONFIG_MEMSIZE); 1460 rdev->mc.real_vram_size = RREG32(RADEON_CONFIG_MEMSIZE);
1271 /* Some production boards of m6 will report 0 1461 /* Some production boards of m6 will report 0
1272 * if it's 8 MB 1462 * if it's 8 MB
1273 */ 1463 */
1274 if (rdev->mc.vram_size == 0) { 1464 if (rdev->mc.real_vram_size == 0) {
1275 rdev->mc.vram_size = 8192 * 1024; 1465 rdev->mc.real_vram_size = 8192 * 1024;
1276 WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.vram_size); 1466 WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.real_vram_size);
1277 } 1467 }
1468 /* let driver place VRAM */
1469 rdev->mc.vram_location = 0xFFFFFFFFUL;
1470 /* Fix for RN50, M6, M7 with 8/16/32(??) MBs of VRAM -
1471 * Novell bug 204882 + along with lots of ubuntu ones */
1472 if (config_aper_size > rdev->mc.real_vram_size)
1473 rdev->mc.mc_vram_size = config_aper_size;
1474 else
1475 rdev->mc.mc_vram_size = rdev->mc.real_vram_size;
1278 } 1476 }
1279 1477
1478 /* work out accessible VRAM */
1479 accessible = r100_get_accessible_vram(rdev);
1480
1280 rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); 1481 rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0);
1281 rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0); 1482 rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0);
1483
1484 if (accessible > rdev->mc.aper_size)
1485 accessible = rdev->mc.aper_size;
1486
1487 if (rdev->mc.mc_vram_size > rdev->mc.aper_size)
1488 rdev->mc.mc_vram_size = rdev->mc.aper_size;
1489
1490 if (rdev->mc.real_vram_size > rdev->mc.aper_size)
1491 rdev->mc.real_vram_size = rdev->mc.aper_size;
1492}
1493
1494void r100_vram_info(struct radeon_device *rdev)
1495{
1496 r100_vram_get_type(rdev);
1497
1498 r100_vram_init_sizes(rdev);
1282} 1499}
1283 1500
1284 1501
@@ -1533,3 +1750,530 @@ int r100_debugfs_mc_info_init(struct radeon_device *rdev)
1533 return 0; 1750 return 0;
1534#endif 1751#endif
1535} 1752}
1753
1754int r100_set_surface_reg(struct radeon_device *rdev, int reg,
1755 uint32_t tiling_flags, uint32_t pitch,
1756 uint32_t offset, uint32_t obj_size)
1757{
1758 int surf_index = reg * 16;
1759 int flags = 0;
1760
1761 /* r100/r200 divide by 16 */
1762 if (rdev->family < CHIP_R300)
1763 flags = pitch / 16;
1764 else
1765 flags = pitch / 8;
1766
1767 if (rdev->family <= CHIP_RS200) {
1768 if ((tiling_flags & (RADEON_TILING_MACRO|RADEON_TILING_MICRO))
1769 == (RADEON_TILING_MACRO|RADEON_TILING_MICRO))
1770 flags |= RADEON_SURF_TILE_COLOR_BOTH;
1771 if (tiling_flags & RADEON_TILING_MACRO)
1772 flags |= RADEON_SURF_TILE_COLOR_MACRO;
1773 } else if (rdev->family <= CHIP_RV280) {
1774 if (tiling_flags & (RADEON_TILING_MACRO))
1775 flags |= R200_SURF_TILE_COLOR_MACRO;
1776 if (tiling_flags & RADEON_TILING_MICRO)
1777 flags |= R200_SURF_TILE_COLOR_MICRO;
1778 } else {
1779 if (tiling_flags & RADEON_TILING_MACRO)
1780 flags |= R300_SURF_TILE_MACRO;
1781 if (tiling_flags & RADEON_TILING_MICRO)
1782 flags |= R300_SURF_TILE_MICRO;
1783 }
1784
1785 DRM_DEBUG("writing surface %d %d %x %x\n", reg, flags, offset, offset+obj_size-1);
1786 WREG32(RADEON_SURFACE0_INFO + surf_index, flags);
1787 WREG32(RADEON_SURFACE0_LOWER_BOUND + surf_index, offset);
1788 WREG32(RADEON_SURFACE0_UPPER_BOUND + surf_index, offset + obj_size - 1);
1789 return 0;
1790}
1791
1792void r100_clear_surface_reg(struct radeon_device *rdev, int reg)
1793{
1794 int surf_index = reg * 16;
1795 WREG32(RADEON_SURFACE0_INFO + surf_index, 0);
1796}
1797
1798void r100_bandwidth_update(struct radeon_device *rdev)
1799{
1800 fixed20_12 trcd_ff, trp_ff, tras_ff, trbs_ff, tcas_ff;
1801 fixed20_12 sclk_ff, mclk_ff, sclk_eff_ff, sclk_delay_ff;
1802 fixed20_12 peak_disp_bw, mem_bw, pix_clk, pix_clk2, temp_ff, crit_point_ff;
1803 uint32_t temp, data, mem_trcd, mem_trp, mem_tras;
1804 fixed20_12 memtcas_ff[8] = {
1805 fixed_init(1),
1806 fixed_init(2),
1807 fixed_init(3),
1808 fixed_init(0),
1809 fixed_init_half(1),
1810 fixed_init_half(2),
1811 fixed_init(0),
1812 };
1813 fixed20_12 memtcas_rs480_ff[8] = {
1814 fixed_init(0),
1815 fixed_init(1),
1816 fixed_init(2),
1817 fixed_init(3),
1818 fixed_init(0),
1819 fixed_init_half(1),
1820 fixed_init_half(2),
1821 fixed_init_half(3),
1822 };
1823 fixed20_12 memtcas2_ff[8] = {
1824 fixed_init(0),
1825 fixed_init(1),
1826 fixed_init(2),
1827 fixed_init(3),
1828 fixed_init(4),
1829 fixed_init(5),
1830 fixed_init(6),
1831 fixed_init(7),
1832 };
1833 fixed20_12 memtrbs[8] = {
1834 fixed_init(1),
1835 fixed_init_half(1),
1836 fixed_init(2),
1837 fixed_init_half(2),
1838 fixed_init(3),
1839 fixed_init_half(3),
1840 fixed_init(4),
1841 fixed_init_half(4)
1842 };
1843 fixed20_12 memtrbs_r4xx[8] = {
1844 fixed_init(4),
1845 fixed_init(5),
1846 fixed_init(6),
1847 fixed_init(7),
1848 fixed_init(8),
1849 fixed_init(9),
1850 fixed_init(10),
1851 fixed_init(11)
1852 };
1853 fixed20_12 min_mem_eff;
1854 fixed20_12 mc_latency_sclk, mc_latency_mclk, k1;
1855 fixed20_12 cur_latency_mclk, cur_latency_sclk;
1856 fixed20_12 disp_latency, disp_latency_overhead, disp_drain_rate,
1857 disp_drain_rate2, read_return_rate;
1858 fixed20_12 time_disp1_drop_priority;
1859 int c;
1860 int cur_size = 16; /* in octawords */
1861 int critical_point = 0, critical_point2;
1862/* uint32_t read_return_rate, time_disp1_drop_priority; */
1863 int stop_req, max_stop_req;
1864 struct drm_display_mode *mode1 = NULL;
1865 struct drm_display_mode *mode2 = NULL;
1866 uint32_t pixel_bytes1 = 0;
1867 uint32_t pixel_bytes2 = 0;
1868
1869 if (rdev->mode_info.crtcs[0]->base.enabled) {
1870 mode1 = &rdev->mode_info.crtcs[0]->base.mode;
1871 pixel_bytes1 = rdev->mode_info.crtcs[0]->base.fb->bits_per_pixel / 8;
1872 }
1873 if (rdev->mode_info.crtcs[1]->base.enabled) {
1874 mode2 = &rdev->mode_info.crtcs[1]->base.mode;
1875 pixel_bytes2 = rdev->mode_info.crtcs[1]->base.fb->bits_per_pixel / 8;
1876 }
1877
1878 min_mem_eff.full = rfixed_const_8(0);
1879 /* get modes */
1880 if ((rdev->disp_priority == 2) && ASIC_IS_R300(rdev)) {
1881 uint32_t mc_init_misc_lat_timer = RREG32(R300_MC_INIT_MISC_LAT_TIMER);
1882 mc_init_misc_lat_timer &= ~(R300_MC_DISP1R_INIT_LAT_MASK << R300_MC_DISP1R_INIT_LAT_SHIFT);
1883 mc_init_misc_lat_timer &= ~(R300_MC_DISP0R_INIT_LAT_MASK << R300_MC_DISP0R_INIT_LAT_SHIFT);
1884 /* check crtc enables */
1885 if (mode2)
1886 mc_init_misc_lat_timer |= (1 << R300_MC_DISP1R_INIT_LAT_SHIFT);
1887 if (mode1)
1888 mc_init_misc_lat_timer |= (1 << R300_MC_DISP0R_INIT_LAT_SHIFT);
1889 WREG32(R300_MC_INIT_MISC_LAT_TIMER, mc_init_misc_lat_timer);
1890 }
1891
1892 /*
1893 * determine is there is enough bw for current mode
1894 */
1895 mclk_ff.full = rfixed_const(rdev->clock.default_mclk);
1896 temp_ff.full = rfixed_const(100);
1897 mclk_ff.full = rfixed_div(mclk_ff, temp_ff);
1898 sclk_ff.full = rfixed_const(rdev->clock.default_sclk);
1899 sclk_ff.full = rfixed_div(sclk_ff, temp_ff);
1900
1901 temp = (rdev->mc.vram_width / 8) * (rdev->mc.vram_is_ddr ? 2 : 1);
1902 temp_ff.full = rfixed_const(temp);
1903 mem_bw.full = rfixed_mul(mclk_ff, temp_ff);
1904
1905 pix_clk.full = 0;
1906 pix_clk2.full = 0;
1907 peak_disp_bw.full = 0;
1908 if (mode1) {
1909 temp_ff.full = rfixed_const(1000);
1910 pix_clk.full = rfixed_const(mode1->clock); /* convert to fixed point */
1911 pix_clk.full = rfixed_div(pix_clk, temp_ff);
1912 temp_ff.full = rfixed_const(pixel_bytes1);
1913 peak_disp_bw.full += rfixed_mul(pix_clk, temp_ff);
1914 }
1915 if (mode2) {
1916 temp_ff.full = rfixed_const(1000);
1917 pix_clk2.full = rfixed_const(mode2->clock); /* convert to fixed point */
1918 pix_clk2.full = rfixed_div(pix_clk2, temp_ff);
1919 temp_ff.full = rfixed_const(pixel_bytes2);
1920 peak_disp_bw.full += rfixed_mul(pix_clk2, temp_ff);
1921 }
1922
1923 mem_bw.full = rfixed_mul(mem_bw, min_mem_eff);
1924 if (peak_disp_bw.full >= mem_bw.full) {
1925 DRM_ERROR("You may not have enough display bandwidth for current mode\n"
1926 "If you have flickering problem, try to lower resolution, refresh rate, or color depth\n");
1927 }
1928
1929 /* Get values from the EXT_MEM_CNTL register...converting its contents. */
1930 temp = RREG32(RADEON_MEM_TIMING_CNTL);
1931 if ((rdev->family == CHIP_RV100) || (rdev->flags & RADEON_IS_IGP)) { /* RV100, M6, IGPs */
1932 mem_trcd = ((temp >> 2) & 0x3) + 1;
1933 mem_trp = ((temp & 0x3)) + 1;
1934 mem_tras = ((temp & 0x70) >> 4) + 1;
1935 } else if (rdev->family == CHIP_R300 ||
1936 rdev->family == CHIP_R350) { /* r300, r350 */
1937 mem_trcd = (temp & 0x7) + 1;
1938 mem_trp = ((temp >> 8) & 0x7) + 1;
1939 mem_tras = ((temp >> 11) & 0xf) + 4;
1940 } else if (rdev->family == CHIP_RV350 ||
1941 rdev->family <= CHIP_RV380) {
1942 /* rv3x0 */
1943 mem_trcd = (temp & 0x7) + 3;
1944 mem_trp = ((temp >> 8) & 0x7) + 3;
1945 mem_tras = ((temp >> 11) & 0xf) + 6;
1946 } else if (rdev->family == CHIP_R420 ||
1947 rdev->family == CHIP_R423 ||
1948 rdev->family == CHIP_RV410) {
1949 /* r4xx */
1950 mem_trcd = (temp & 0xf) + 3;
1951 if (mem_trcd > 15)
1952 mem_trcd = 15;
1953 mem_trp = ((temp >> 8) & 0xf) + 3;
1954 if (mem_trp > 15)
1955 mem_trp = 15;
1956 mem_tras = ((temp >> 12) & 0x1f) + 6;
1957 if (mem_tras > 31)
1958 mem_tras = 31;
1959 } else { /* RV200, R200 */
1960 mem_trcd = (temp & 0x7) + 1;
1961 mem_trp = ((temp >> 8) & 0x7) + 1;
1962 mem_tras = ((temp >> 12) & 0xf) + 4;
1963 }
1964 /* convert to FF */
1965 trcd_ff.full = rfixed_const(mem_trcd);
1966 trp_ff.full = rfixed_const(mem_trp);
1967 tras_ff.full = rfixed_const(mem_tras);
1968
1969 /* Get values from the MEM_SDRAM_MODE_REG register...converting its */
1970 temp = RREG32(RADEON_MEM_SDRAM_MODE_REG);
1971 data = (temp & (7 << 20)) >> 20;
1972 if ((rdev->family == CHIP_RV100) || rdev->flags & RADEON_IS_IGP) {
1973 if (rdev->family == CHIP_RS480) /* don't think rs400 */
1974 tcas_ff = memtcas_rs480_ff[data];
1975 else
1976 tcas_ff = memtcas_ff[data];
1977 } else
1978 tcas_ff = memtcas2_ff[data];
1979
1980 if (rdev->family == CHIP_RS400 ||
1981 rdev->family == CHIP_RS480) {
1982 /* extra cas latency stored in bits 23-25 0-4 clocks */
1983 data = (temp >> 23) & 0x7;
1984 if (data < 5)
1985 tcas_ff.full += rfixed_const(data);
1986 }
1987
1988 if (ASIC_IS_R300(rdev) && !(rdev->flags & RADEON_IS_IGP)) {
1989 /* on the R300, Tcas is included in Trbs.
1990 */
1991 temp = RREG32(RADEON_MEM_CNTL);
1992 data = (R300_MEM_NUM_CHANNELS_MASK & temp);
1993 if (data == 1) {
1994 if (R300_MEM_USE_CD_CH_ONLY & temp) {
1995 temp = RREG32(R300_MC_IND_INDEX);
1996 temp &= ~R300_MC_IND_ADDR_MASK;
1997 temp |= R300_MC_READ_CNTL_CD_mcind;
1998 WREG32(R300_MC_IND_INDEX, temp);
1999 temp = RREG32(R300_MC_IND_DATA);
2000 data = (R300_MEM_RBS_POSITION_C_MASK & temp);
2001 } else {
2002 temp = RREG32(R300_MC_READ_CNTL_AB);
2003 data = (R300_MEM_RBS_POSITION_A_MASK & temp);
2004 }
2005 } else {
2006 temp = RREG32(R300_MC_READ_CNTL_AB);
2007 data = (R300_MEM_RBS_POSITION_A_MASK & temp);
2008 }
2009 if (rdev->family == CHIP_RV410 ||
2010 rdev->family == CHIP_R420 ||
2011 rdev->family == CHIP_R423)
2012 trbs_ff = memtrbs_r4xx[data];
2013 else
2014 trbs_ff = memtrbs[data];
2015 tcas_ff.full += trbs_ff.full;
2016 }
2017
2018 sclk_eff_ff.full = sclk_ff.full;
2019
2020 if (rdev->flags & RADEON_IS_AGP) {
2021 fixed20_12 agpmode_ff;
2022 agpmode_ff.full = rfixed_const(radeon_agpmode);
2023 temp_ff.full = rfixed_const_666(16);
2024 sclk_eff_ff.full -= rfixed_mul(agpmode_ff, temp_ff);
2025 }
2026 /* TODO PCIE lanes may affect this - agpmode == 16?? */
2027
2028 if (ASIC_IS_R300(rdev)) {
2029 sclk_delay_ff.full = rfixed_const(250);
2030 } else {
2031 if ((rdev->family == CHIP_RV100) ||
2032 rdev->flags & RADEON_IS_IGP) {
2033 if (rdev->mc.vram_is_ddr)
2034 sclk_delay_ff.full = rfixed_const(41);
2035 else
2036 sclk_delay_ff.full = rfixed_const(33);
2037 } else {
2038 if (rdev->mc.vram_width == 128)
2039 sclk_delay_ff.full = rfixed_const(57);
2040 else
2041 sclk_delay_ff.full = rfixed_const(41);
2042 }
2043 }
2044
2045 mc_latency_sclk.full = rfixed_div(sclk_delay_ff, sclk_eff_ff);
2046
2047 if (rdev->mc.vram_is_ddr) {
2048 if (rdev->mc.vram_width == 32) {
2049 k1.full = rfixed_const(40);
2050 c = 3;
2051 } else {
2052 k1.full = rfixed_const(20);
2053 c = 1;
2054 }
2055 } else {
2056 k1.full = rfixed_const(40);
2057 c = 3;
2058 }
2059
2060 temp_ff.full = rfixed_const(2);
2061 mc_latency_mclk.full = rfixed_mul(trcd_ff, temp_ff);
2062 temp_ff.full = rfixed_const(c);
2063 mc_latency_mclk.full += rfixed_mul(tcas_ff, temp_ff);
2064 temp_ff.full = rfixed_const(4);
2065 mc_latency_mclk.full += rfixed_mul(tras_ff, temp_ff);
2066 mc_latency_mclk.full += rfixed_mul(trp_ff, temp_ff);
2067 mc_latency_mclk.full += k1.full;
2068
2069 mc_latency_mclk.full = rfixed_div(mc_latency_mclk, mclk_ff);
2070 mc_latency_mclk.full += rfixed_div(temp_ff, sclk_eff_ff);
2071
2072 /*
2073 HW cursor time assuming worst case of full size colour cursor.
2074 */
2075 temp_ff.full = rfixed_const((2 * (cur_size - (rdev->mc.vram_is_ddr + 1))));
2076 temp_ff.full += trcd_ff.full;
2077 if (temp_ff.full < tras_ff.full)
2078 temp_ff.full = tras_ff.full;
2079 cur_latency_mclk.full = rfixed_div(temp_ff, mclk_ff);
2080
2081 temp_ff.full = rfixed_const(cur_size);
2082 cur_latency_sclk.full = rfixed_div(temp_ff, sclk_eff_ff);
2083 /*
2084 Find the total latency for the display data.
2085 */
2086 disp_latency_overhead.full = rfixed_const(80);
2087 disp_latency_overhead.full = rfixed_div(disp_latency_overhead, sclk_ff);
2088 mc_latency_mclk.full += disp_latency_overhead.full + cur_latency_mclk.full;
2089 mc_latency_sclk.full += disp_latency_overhead.full + cur_latency_sclk.full;
2090
2091 if (mc_latency_mclk.full > mc_latency_sclk.full)
2092 disp_latency.full = mc_latency_mclk.full;
2093 else
2094 disp_latency.full = mc_latency_sclk.full;
2095
2096 /* setup Max GRPH_STOP_REQ default value */
2097 if (ASIC_IS_RV100(rdev))
2098 max_stop_req = 0x5c;
2099 else
2100 max_stop_req = 0x7c;
2101
2102 if (mode1) {
2103 /* CRTC1
2104 Set GRPH_BUFFER_CNTL register using h/w defined optimal values.
2105 GRPH_STOP_REQ <= MIN[ 0x7C, (CRTC_H_DISP + 1) * (bit depth) / 0x10 ]
2106 */
2107 stop_req = mode1->hdisplay * pixel_bytes1 / 16;
2108
2109 if (stop_req > max_stop_req)
2110 stop_req = max_stop_req;
2111
2112 /*
2113 Find the drain rate of the display buffer.
2114 */
2115 temp_ff.full = rfixed_const((16/pixel_bytes1));
2116 disp_drain_rate.full = rfixed_div(pix_clk, temp_ff);
2117
2118 /*
2119 Find the critical point of the display buffer.
2120 */
2121 crit_point_ff.full = rfixed_mul(disp_drain_rate, disp_latency);
2122 crit_point_ff.full += rfixed_const_half(0);
2123
2124 critical_point = rfixed_trunc(crit_point_ff);
2125
2126 if (rdev->disp_priority == 2) {
2127 critical_point = 0;
2128 }
2129
2130 /*
2131 The critical point should never be above max_stop_req-4. Setting
2132 GRPH_CRITICAL_CNTL = 0 will thus force high priority all the time.
2133 */
2134 if (max_stop_req - critical_point < 4)
2135 critical_point = 0;
2136
2137 if (critical_point == 0 && mode2 && rdev->family == CHIP_R300) {
2138 /* some R300 cards have problem with this set to 0, when CRTC2 is enabled.*/
2139 critical_point = 0x10;
2140 }
2141
2142 temp = RREG32(RADEON_GRPH_BUFFER_CNTL);
2143 temp &= ~(RADEON_GRPH_STOP_REQ_MASK);
2144 temp |= (stop_req << RADEON_GRPH_STOP_REQ_SHIFT);
2145 temp &= ~(RADEON_GRPH_START_REQ_MASK);
2146 if ((rdev->family == CHIP_R350) &&
2147 (stop_req > 0x15)) {
2148 stop_req -= 0x10;
2149 }
2150 temp |= (stop_req << RADEON_GRPH_START_REQ_SHIFT);
2151 temp |= RADEON_GRPH_BUFFER_SIZE;
2152 temp &= ~(RADEON_GRPH_CRITICAL_CNTL |
2153 RADEON_GRPH_CRITICAL_AT_SOF |
2154 RADEON_GRPH_STOP_CNTL);
2155 /*
2156 Write the result into the register.
2157 */
2158 WREG32(RADEON_GRPH_BUFFER_CNTL, ((temp & ~RADEON_GRPH_CRITICAL_POINT_MASK) |
2159 (critical_point << RADEON_GRPH_CRITICAL_POINT_SHIFT)));
2160
2161#if 0
2162 if ((rdev->family == CHIP_RS400) ||
2163 (rdev->family == CHIP_RS480)) {
2164 /* attempt to program RS400 disp regs correctly ??? */
2165 temp = RREG32(RS400_DISP1_REG_CNTL);
2166 temp &= ~(RS400_DISP1_START_REQ_LEVEL_MASK |
2167 RS400_DISP1_STOP_REQ_LEVEL_MASK);
2168 WREG32(RS400_DISP1_REQ_CNTL1, (temp |
2169 (critical_point << RS400_DISP1_START_REQ_LEVEL_SHIFT) |
2170 (critical_point << RS400_DISP1_STOP_REQ_LEVEL_SHIFT)));
2171 temp = RREG32(RS400_DMIF_MEM_CNTL1);
2172 temp &= ~(RS400_DISP1_CRITICAL_POINT_START_MASK |
2173 RS400_DISP1_CRITICAL_POINT_STOP_MASK);
2174 WREG32(RS400_DMIF_MEM_CNTL1, (temp |
2175 (critical_point << RS400_DISP1_CRITICAL_POINT_START_SHIFT) |
2176 (critical_point << RS400_DISP1_CRITICAL_POINT_STOP_SHIFT)));
2177 }
2178#endif
2179
2180 DRM_DEBUG("GRPH_BUFFER_CNTL from to %x\n",
2181 /* (unsigned int)info->SavedReg->grph_buffer_cntl, */
2182 (unsigned int)RREG32(RADEON_GRPH_BUFFER_CNTL));
2183 }
2184
2185 if (mode2) {
2186 u32 grph2_cntl;
2187 stop_req = mode2->hdisplay * pixel_bytes2 / 16;
2188
2189 if (stop_req > max_stop_req)
2190 stop_req = max_stop_req;
2191
2192 /*
2193 Find the drain rate of the display buffer.
2194 */
2195 temp_ff.full = rfixed_const((16/pixel_bytes2));
2196 disp_drain_rate2.full = rfixed_div(pix_clk2, temp_ff);
2197
2198 grph2_cntl = RREG32(RADEON_GRPH2_BUFFER_CNTL);
2199 grph2_cntl &= ~(RADEON_GRPH_STOP_REQ_MASK);
2200 grph2_cntl |= (stop_req << RADEON_GRPH_STOP_REQ_SHIFT);
2201 grph2_cntl &= ~(RADEON_GRPH_START_REQ_MASK);
2202 if ((rdev->family == CHIP_R350) &&
2203 (stop_req > 0x15)) {
2204 stop_req -= 0x10;
2205 }
2206 grph2_cntl |= (stop_req << RADEON_GRPH_START_REQ_SHIFT);
2207 grph2_cntl |= RADEON_GRPH_BUFFER_SIZE;
2208 grph2_cntl &= ~(RADEON_GRPH_CRITICAL_CNTL |
2209 RADEON_GRPH_CRITICAL_AT_SOF |
2210 RADEON_GRPH_STOP_CNTL);
2211
2212 if ((rdev->family == CHIP_RS100) ||
2213 (rdev->family == CHIP_RS200))
2214 critical_point2 = 0;
2215 else {
2216 temp = (rdev->mc.vram_width * rdev->mc.vram_is_ddr + 1)/128;
2217 temp_ff.full = rfixed_const(temp);
2218 temp_ff.full = rfixed_mul(mclk_ff, temp_ff);
2219 if (sclk_ff.full < temp_ff.full)
2220 temp_ff.full = sclk_ff.full;
2221
2222 read_return_rate.full = temp_ff.full;
2223
2224 if (mode1) {
2225 temp_ff.full = read_return_rate.full - disp_drain_rate.full;
2226 time_disp1_drop_priority.full = rfixed_div(crit_point_ff, temp_ff);
2227 } else {
2228 time_disp1_drop_priority.full = 0;
2229 }
2230 crit_point_ff.full = disp_latency.full + time_disp1_drop_priority.full + disp_latency.full;
2231 crit_point_ff.full = rfixed_mul(crit_point_ff, disp_drain_rate2);
2232 crit_point_ff.full += rfixed_const_half(0);
2233
2234 critical_point2 = rfixed_trunc(crit_point_ff);
2235
2236 if (rdev->disp_priority == 2) {
2237 critical_point2 = 0;
2238 }
2239
2240 if (max_stop_req - critical_point2 < 4)
2241 critical_point2 = 0;
2242
2243 }
2244
2245 if (critical_point2 == 0 && rdev->family == CHIP_R300) {
2246 /* some R300 cards have problem with this set to 0 */
2247 critical_point2 = 0x10;
2248 }
2249
2250 WREG32(RADEON_GRPH2_BUFFER_CNTL, ((grph2_cntl & ~RADEON_GRPH_CRITICAL_POINT_MASK) |
2251 (critical_point2 << RADEON_GRPH_CRITICAL_POINT_SHIFT)));
2252
2253 if ((rdev->family == CHIP_RS400) ||
2254 (rdev->family == CHIP_RS480)) {
2255#if 0
2256 /* attempt to program RS400 disp2 regs correctly ??? */
2257 temp = RREG32(RS400_DISP2_REQ_CNTL1);
2258 temp &= ~(RS400_DISP2_START_REQ_LEVEL_MASK |
2259 RS400_DISP2_STOP_REQ_LEVEL_MASK);
2260 WREG32(RS400_DISP2_REQ_CNTL1, (temp |
2261 (critical_point2 << RS400_DISP1_START_REQ_LEVEL_SHIFT) |
2262 (critical_point2 << RS400_DISP1_STOP_REQ_LEVEL_SHIFT)));
2263 temp = RREG32(RS400_DISP2_REQ_CNTL2);
2264 temp &= ~(RS400_DISP2_CRITICAL_POINT_START_MASK |
2265 RS400_DISP2_CRITICAL_POINT_STOP_MASK);
2266 WREG32(RS400_DISP2_REQ_CNTL2, (temp |
2267 (critical_point2 << RS400_DISP2_CRITICAL_POINT_START_SHIFT) |
2268 (critical_point2 << RS400_DISP2_CRITICAL_POINT_STOP_SHIFT)));
2269#endif
2270 WREG32(RS400_DISP2_REQ_CNTL1, 0x105DC1CC);
2271 WREG32(RS400_DISP2_REQ_CNTL2, 0x2749D000);
2272 WREG32(RS400_DMIF_MEM_CNTL1, 0x29CA71DC);
2273 WREG32(RS400_DISP1_REQ_CNTL1, 0x28FBC3AC);
2274 }
2275
2276 DRM_DEBUG("GRPH2_BUFFER_CNTL from to %x\n",
2277 (unsigned int)RREG32(RADEON_GRPH2_BUFFER_CNTL));
2278 }
2279}
diff --git a/drivers/gpu/drm/radeon/r300.c b/drivers/gpu/drm/radeon/r300.c
index e2ed5bc08170..9c8d41534a5d 100644
--- a/drivers/gpu/drm/radeon/r300.c
+++ b/drivers/gpu/drm/radeon/r300.c
@@ -30,6 +30,8 @@
30#include "drm.h" 30#include "drm.h"
31#include "radeon_reg.h" 31#include "radeon_reg.h"
32#include "radeon.h" 32#include "radeon.h"
33#include "radeon_drm.h"
34#include "radeon_share.h"
33 35
34/* r300,r350,rv350,rv370,rv380 depends on : */ 36/* r300,r350,rv350,rv370,rv380 depends on : */
35void r100_hdp_reset(struct radeon_device *rdev); 37void r100_hdp_reset(struct radeon_device *rdev);
@@ -44,6 +46,7 @@ int r100_gui_wait_for_idle(struct radeon_device *rdev);
44int r100_cs_packet_parse(struct radeon_cs_parser *p, 46int r100_cs_packet_parse(struct radeon_cs_parser *p,
45 struct radeon_cs_packet *pkt, 47 struct radeon_cs_packet *pkt,
46 unsigned idx); 48 unsigned idx);
49int r100_cs_packet_parse_vline(struct radeon_cs_parser *p);
47int r100_cs_packet_next_reloc(struct radeon_cs_parser *p, 50int r100_cs_packet_next_reloc(struct radeon_cs_parser *p,
48 struct radeon_cs_reloc **cs_reloc); 51 struct radeon_cs_reloc **cs_reloc);
49int r100_cs_parse_packet0(struct radeon_cs_parser *p, 52int r100_cs_parse_packet0(struct radeon_cs_parser *p,
@@ -150,8 +153,13 @@ int rv370_pcie_gart_set_page(struct radeon_device *rdev, int i, uint64_t addr)
150 if (i < 0 || i > rdev->gart.num_gpu_pages) { 153 if (i < 0 || i > rdev->gart.num_gpu_pages) {
151 return -EINVAL; 154 return -EINVAL;
152 } 155 }
153 addr = (((u32)addr) >> 8) | ((upper_32_bits(addr) & 0xff) << 4) | 0xC; 156 addr = (lower_32_bits(addr) >> 8) |
154 writel(cpu_to_le32(addr), ((void __iomem *)ptr) + (i * 4)); 157 ((upper_32_bits(addr) & 0xff) << 24) |
158 0xc;
159 /* on x86 we want this to be CPU endian, on powerpc
160 * on powerpc without HW swappers, it'll get swapped on way
161 * into VRAM - so no need for cpu_to_le32 on VRAM tables */
162 writel(addr, ((void __iomem *)ptr) + (i * 4));
155 return 0; 163 return 0;
156} 164}
157 165
@@ -579,10 +587,8 @@ void r300_vram_info(struct radeon_device *rdev)
579 } else { 587 } else {
580 rdev->mc.vram_width = 64; 588 rdev->mc.vram_width = 64;
581 } 589 }
582 rdev->mc.vram_size = RREG32(RADEON_CONFIG_MEMSIZE);
583 590
584 rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); 591 r100_vram_init_sizes(rdev);
585 rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0);
586} 592}
587 593
588 594
@@ -970,7 +976,7 @@ static inline void r300_cs_track_clear(struct r300_cs_track *track)
970 976
971static const unsigned r300_reg_safe_bm[159] = { 977static const unsigned r300_reg_safe_bm[159] = {
972 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 978 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
973 0xFFFFFFBF, 0xFFFFFFFF, 0xFFFFFFBF, 0xFFFFFFFF, 979 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
974 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 980 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
975 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 981 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
976 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 982 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
@@ -1019,7 +1025,7 @@ static int r300_packet0_check(struct radeon_cs_parser *p,
1019 struct radeon_cs_reloc *reloc; 1025 struct radeon_cs_reloc *reloc;
1020 struct r300_cs_track *track; 1026 struct r300_cs_track *track;
1021 volatile uint32_t *ib; 1027 volatile uint32_t *ib;
1022 uint32_t tmp; 1028 uint32_t tmp, tile_flags = 0;
1023 unsigned i; 1029 unsigned i;
1024 int r; 1030 int r;
1025 1031
@@ -1027,6 +1033,16 @@ static int r300_packet0_check(struct radeon_cs_parser *p,
1027 ib_chunk = &p->chunks[p->chunk_ib_idx]; 1033 ib_chunk = &p->chunks[p->chunk_ib_idx];
1028 track = (struct r300_cs_track*)p->track; 1034 track = (struct r300_cs_track*)p->track;
1029 switch(reg) { 1035 switch(reg) {
1036 case AVIVO_D1MODE_VLINE_START_END:
1037 case RADEON_CRTC_GUI_TRIG_VLINE:
1038 r = r100_cs_packet_parse_vline(p);
1039 if (r) {
1040 DRM_ERROR("No reloc for ib[%d]=0x%04X\n",
1041 idx, reg);
1042 r100_cs_dump_packet(p, pkt);
1043 return r;
1044 }
1045 break;
1030 case RADEON_DST_PITCH_OFFSET: 1046 case RADEON_DST_PITCH_OFFSET:
1031 case RADEON_SRC_PITCH_OFFSET: 1047 case RADEON_SRC_PITCH_OFFSET:
1032 r = r100_cs_packet_next_reloc(p, &reloc); 1048 r = r100_cs_packet_next_reloc(p, &reloc);
@@ -1038,7 +1054,19 @@ static int r300_packet0_check(struct radeon_cs_parser *p,
1038 } 1054 }
1039 tmp = ib_chunk->kdata[idx] & 0x003fffff; 1055 tmp = ib_chunk->kdata[idx] & 0x003fffff;
1040 tmp += (((u32)reloc->lobj.gpu_offset) >> 10); 1056 tmp += (((u32)reloc->lobj.gpu_offset) >> 10);
1041 ib[idx] = (ib_chunk->kdata[idx] & 0xffc00000) | tmp; 1057
1058 if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO)
1059 tile_flags |= RADEON_DST_TILE_MACRO;
1060 if (reloc->lobj.tiling_flags & RADEON_TILING_MICRO) {
1061 if (reg == RADEON_SRC_PITCH_OFFSET) {
1062 DRM_ERROR("Cannot src blit from microtiled surface\n");
1063 r100_cs_dump_packet(p, pkt);
1064 return -EINVAL;
1065 }
1066 tile_flags |= RADEON_DST_TILE_MICRO;
1067 }
1068 tmp |= tile_flags;
1069 ib[idx] = (ib_chunk->kdata[idx] & 0x3fc00000) | tmp;
1042 break; 1070 break;
1043 case R300_RB3D_COLOROFFSET0: 1071 case R300_RB3D_COLOROFFSET0:
1044 case R300_RB3D_COLOROFFSET1: 1072 case R300_RB3D_COLOROFFSET1:
@@ -1127,6 +1155,23 @@ static int r300_packet0_check(struct radeon_cs_parser *p,
1127 /* RB3D_COLORPITCH1 */ 1155 /* RB3D_COLORPITCH1 */
1128 /* RB3D_COLORPITCH2 */ 1156 /* RB3D_COLORPITCH2 */
1129 /* RB3D_COLORPITCH3 */ 1157 /* RB3D_COLORPITCH3 */
1158 r = r100_cs_packet_next_reloc(p, &reloc);
1159 if (r) {
1160 DRM_ERROR("No reloc for ib[%d]=0x%04X\n",
1161 idx, reg);
1162 r100_cs_dump_packet(p, pkt);
1163 return r;
1164 }
1165
1166 if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO)
1167 tile_flags |= R300_COLOR_TILE_ENABLE;
1168 if (reloc->lobj.tiling_flags & RADEON_TILING_MICRO)
1169 tile_flags |= R300_COLOR_MICROTILE_ENABLE;
1170
1171 tmp = ib_chunk->kdata[idx] & ~(0x7 << 16);
1172 tmp |= tile_flags;
1173 ib[idx] = tmp;
1174
1130 i = (reg - 0x4E38) >> 2; 1175 i = (reg - 0x4E38) >> 2;
1131 track->cb[i].pitch = ib_chunk->kdata[idx] & 0x3FFE; 1176 track->cb[i].pitch = ib_chunk->kdata[idx] & 0x3FFE;
1132 switch (((ib_chunk->kdata[idx] >> 21) & 0xF)) { 1177 switch (((ib_chunk->kdata[idx] >> 21) & 0xF)) {
@@ -1182,6 +1227,23 @@ static int r300_packet0_check(struct radeon_cs_parser *p,
1182 break; 1227 break;
1183 case 0x4F24: 1228 case 0x4F24:
1184 /* ZB_DEPTHPITCH */ 1229 /* ZB_DEPTHPITCH */
1230 r = r100_cs_packet_next_reloc(p, &reloc);
1231 if (r) {
1232 DRM_ERROR("No reloc for ib[%d]=0x%04X\n",
1233 idx, reg);
1234 r100_cs_dump_packet(p, pkt);
1235 return r;
1236 }
1237
1238 if (reloc->lobj.tiling_flags & RADEON_TILING_MACRO)
1239 tile_flags |= R300_DEPTHMACROTILE_ENABLE;
1240 if (reloc->lobj.tiling_flags & RADEON_TILING_MICRO)
1241 tile_flags |= R300_DEPTHMICROTILE_TILED;;
1242
1243 tmp = ib_chunk->kdata[idx] & ~(0x7 << 16);
1244 tmp |= tile_flags;
1245 ib[idx] = tmp;
1246
1185 track->zb.pitch = ib_chunk->kdata[idx] & 0x3FFC; 1247 track->zb.pitch = ib_chunk->kdata[idx] & 0x3FFC;
1186 break; 1248 break;
1187 case 0x4104: 1249 case 0x4104:
diff --git a/drivers/gpu/drm/radeon/r300_reg.h b/drivers/gpu/drm/radeon/r300_reg.h
index 70f48609515e..4b7afef35a65 100644
--- a/drivers/gpu/drm/radeon/r300_reg.h
+++ b/drivers/gpu/drm/radeon/r300_reg.h
@@ -27,7 +27,9 @@
27#ifndef _R300_REG_H_ 27#ifndef _R300_REG_H_
28#define _R300_REG_H_ 28#define _R300_REG_H_
29 29
30 30#define R300_SURF_TILE_MACRO (1<<16)
31#define R300_SURF_TILE_MICRO (2<<16)
32#define R300_SURF_TILE_BOTH (3<<16)
31 33
32 34
33#define R300_MC_INIT_MISC_LAT_TIMER 0x180 35#define R300_MC_INIT_MISC_LAT_TIMER 0x180
diff --git a/drivers/gpu/drm/radeon/r500_reg.h b/drivers/gpu/drm/radeon/r500_reg.h
index 9070a1c2ce23..036691b38cb7 100644
--- a/drivers/gpu/drm/radeon/r500_reg.h
+++ b/drivers/gpu/drm/radeon/r500_reg.h
@@ -445,6 +445,7 @@
445#define AVIVO_D1MODE_DATA_FORMAT 0x6528 445#define AVIVO_D1MODE_DATA_FORMAT 0x6528
446# define AVIVO_D1MODE_INTERLEAVE_EN (1 << 0) 446# define AVIVO_D1MODE_INTERLEAVE_EN (1 << 0)
447#define AVIVO_D1MODE_DESKTOP_HEIGHT 0x652C 447#define AVIVO_D1MODE_DESKTOP_HEIGHT 0x652C
448#define AVIVO_D1MODE_VLINE_START_END 0x6538
448#define AVIVO_D1MODE_VIEWPORT_START 0x6580 449#define AVIVO_D1MODE_VIEWPORT_START 0x6580
449#define AVIVO_D1MODE_VIEWPORT_SIZE 0x6584 450#define AVIVO_D1MODE_VIEWPORT_SIZE 0x6584
450#define AVIVO_D1MODE_EXT_OVERSCAN_LEFT_RIGHT 0x6588 451#define AVIVO_D1MODE_EXT_OVERSCAN_LEFT_RIGHT 0x6588
@@ -496,6 +497,7 @@
496#define AVIVO_D2CUR_SIZE 0x6c10 497#define AVIVO_D2CUR_SIZE 0x6c10
497#define AVIVO_D2CUR_POSITION 0x6c14 498#define AVIVO_D2CUR_POSITION 0x6c14
498 499
500#define AVIVO_D2MODE_VLINE_START_END 0x6d38
499#define AVIVO_D2MODE_VIEWPORT_START 0x6d80 501#define AVIVO_D2MODE_VIEWPORT_START 0x6d80
500#define AVIVO_D2MODE_VIEWPORT_SIZE 0x6d84 502#define AVIVO_D2MODE_VIEWPORT_SIZE 0x6d84
501#define AVIVO_D2MODE_EXT_OVERSCAN_LEFT_RIGHT 0x6d88 503#define AVIVO_D2MODE_EXT_OVERSCAN_LEFT_RIGHT 0x6d88
diff --git a/drivers/gpu/drm/radeon/r520.c b/drivers/gpu/drm/radeon/r520.c
index 570a244bd88b..09fb0b6ec7dd 100644
--- a/drivers/gpu/drm/radeon/r520.c
+++ b/drivers/gpu/drm/radeon/r520.c
@@ -28,6 +28,7 @@
28#include "drmP.h" 28#include "drmP.h"
29#include "radeon_reg.h" 29#include "radeon_reg.h"
30#include "radeon.h" 30#include "radeon.h"
31#include "radeon_share.h"
31 32
32/* r520,rv530,rv560,rv570,r580 depends on : */ 33/* r520,rv530,rv560,rv570,r580 depends on : */
33void r100_hdp_reset(struct radeon_device *rdev); 34void r100_hdp_reset(struct radeon_device *rdev);
@@ -94,8 +95,8 @@ int r520_mc_init(struct radeon_device *rdev)
94 "programming pipes. Bad things might happen.\n"); 95 "programming pipes. Bad things might happen.\n");
95 } 96 }
96 /* Write VRAM size in case we are limiting it */ 97 /* Write VRAM size in case we are limiting it */
97 WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.vram_size); 98 WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.real_vram_size);
98 tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; 99 tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1;
99 tmp = REG_SET(R520_MC_FB_TOP, tmp >> 16); 100 tmp = REG_SET(R520_MC_FB_TOP, tmp >> 16);
100 tmp |= REG_SET(R520_MC_FB_START, rdev->mc.vram_location >> 16); 101 tmp |= REG_SET(R520_MC_FB_START, rdev->mc.vram_location >> 16);
101 WREG32_MC(R520_MC_FB_LOCATION, tmp); 102 WREG32_MC(R520_MC_FB_LOCATION, tmp);
@@ -226,9 +227,20 @@ static void r520_vram_get_type(struct radeon_device *rdev)
226 227
227void r520_vram_info(struct radeon_device *rdev) 228void r520_vram_info(struct radeon_device *rdev)
228{ 229{
230 fixed20_12 a;
231
229 r520_vram_get_type(rdev); 232 r520_vram_get_type(rdev);
230 rdev->mc.vram_size = RREG32(RADEON_CONFIG_MEMSIZE);
231 233
232 rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); 234 r100_vram_init_sizes(rdev);
233 rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0); 235 /* FIXME: we should enforce default clock in case GPU is not in
236 * default setup
237 */
238 a.full = rfixed_const(100);
239 rdev->pm.sclk.full = rfixed_const(rdev->clock.default_sclk);
240 rdev->pm.sclk.full = rfixed_div(rdev->pm.sclk, a);
241}
242
243void r520_bandwidth_update(struct radeon_device *rdev)
244{
245 rv515_bandwidth_avivo_update(rdev);
234} 246}
diff --git a/drivers/gpu/drm/radeon/r600.c b/drivers/gpu/drm/radeon/r600.c
index c45559fc97fd..538cd907df69 100644
--- a/drivers/gpu/drm/radeon/r600.c
+++ b/drivers/gpu/drm/radeon/r600.c
@@ -67,7 +67,7 @@ int r600_mc_init(struct radeon_device *rdev)
67 "programming pipes. Bad things might happen.\n"); 67 "programming pipes. Bad things might happen.\n");
68 } 68 }
69 69
70 tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; 70 tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1;
71 tmp = REG_SET(R600_MC_FB_TOP, tmp >> 24); 71 tmp = REG_SET(R600_MC_FB_TOP, tmp >> 24);
72 tmp |= REG_SET(R600_MC_FB_BASE, rdev->mc.vram_location >> 24); 72 tmp |= REG_SET(R600_MC_FB_BASE, rdev->mc.vram_location >> 24);
73 WREG32(R600_MC_VM_FB_LOCATION, tmp); 73 WREG32(R600_MC_VM_FB_LOCATION, tmp);
@@ -140,7 +140,8 @@ void r600_vram_get_type(struct radeon_device *rdev)
140void r600_vram_info(struct radeon_device *rdev) 140void r600_vram_info(struct radeon_device *rdev)
141{ 141{
142 r600_vram_get_type(rdev); 142 r600_vram_get_type(rdev);
143 rdev->mc.vram_size = RREG32(R600_CONFIG_MEMSIZE); 143 rdev->mc.real_vram_size = RREG32(R600_CONFIG_MEMSIZE);
144 rdev->mc.mc_vram_size = rdev->mc.real_vram_size;
144 145
145 /* Could aper size report 0 ? */ 146 /* Could aper size report 0 ? */
146 rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); 147 rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0);
diff --git a/drivers/gpu/drm/radeon/radeon.h b/drivers/gpu/drm/radeon/radeon.h
index d61f2fc61df5..b1d945b8ed6c 100644
--- a/drivers/gpu/drm/radeon/radeon.h
+++ b/drivers/gpu/drm/radeon/radeon.h
@@ -64,6 +64,7 @@ extern int radeon_agpmode;
64extern int radeon_vram_limit; 64extern int radeon_vram_limit;
65extern int radeon_gart_size; 65extern int radeon_gart_size;
66extern int radeon_benchmarking; 66extern int radeon_benchmarking;
67extern int radeon_testing;
67extern int radeon_connector_table; 68extern int radeon_connector_table;
68 69
69/* 70/*
@@ -113,6 +114,7 @@ enum radeon_family {
113 CHIP_RV770, 114 CHIP_RV770,
114 CHIP_RV730, 115 CHIP_RV730,
115 CHIP_RV710, 116 CHIP_RV710,
117 CHIP_RS880,
116 CHIP_LAST, 118 CHIP_LAST,
117}; 119};
118 120
@@ -201,6 +203,14 @@ int radeon_fence_wait_last(struct radeon_device *rdev);
201struct radeon_fence *radeon_fence_ref(struct radeon_fence *fence); 203struct radeon_fence *radeon_fence_ref(struct radeon_fence *fence);
202void radeon_fence_unref(struct radeon_fence **fence); 204void radeon_fence_unref(struct radeon_fence **fence);
203 205
206/*
207 * Tiling registers
208 */
209struct radeon_surface_reg {
210 struct radeon_object *robj;
211};
212
213#define RADEON_GEM_MAX_SURFACES 8
204 214
205/* 215/*
206 * Radeon buffer. 216 * Radeon buffer.
@@ -213,6 +223,7 @@ struct radeon_object_list {
213 uint64_t gpu_offset; 223 uint64_t gpu_offset;
214 unsigned rdomain; 224 unsigned rdomain;
215 unsigned wdomain; 225 unsigned wdomain;
226 uint32_t tiling_flags;
216}; 227};
217 228
218int radeon_object_init(struct radeon_device *rdev); 229int radeon_object_init(struct radeon_device *rdev);
@@ -242,8 +253,15 @@ void radeon_object_list_clean(struct list_head *head);
242int radeon_object_fbdev_mmap(struct radeon_object *robj, 253int radeon_object_fbdev_mmap(struct radeon_object *robj,
243 struct vm_area_struct *vma); 254 struct vm_area_struct *vma);
244unsigned long radeon_object_size(struct radeon_object *robj); 255unsigned long radeon_object_size(struct radeon_object *robj);
245 256void radeon_object_clear_surface_reg(struct radeon_object *robj);
246 257int radeon_object_check_tiling(struct radeon_object *robj, bool has_moved,
258 bool force_drop);
259void radeon_object_set_tiling_flags(struct radeon_object *robj,
260 uint32_t tiling_flags, uint32_t pitch);
261void radeon_object_get_tiling_flags(struct radeon_object *robj, uint32_t *tiling_flags, uint32_t *pitch);
262void radeon_bo_move_notify(struct ttm_buffer_object *bo,
263 struct ttm_mem_reg *mem);
264void radeon_bo_fault_reserve_notify(struct ttm_buffer_object *bo);
247/* 265/*
248 * GEM objects. 266 * GEM objects.
249 */ 267 */
@@ -315,8 +333,11 @@ struct radeon_mc {
315 unsigned gtt_location; 333 unsigned gtt_location;
316 unsigned gtt_size; 334 unsigned gtt_size;
317 unsigned vram_location; 335 unsigned vram_location;
318 unsigned vram_size; 336 /* for some chips with <= 32MB we need to lie
337 * about vram size near mc fb location */
338 unsigned mc_vram_size;
319 unsigned vram_width; 339 unsigned vram_width;
340 unsigned real_vram_size;
320 int vram_mtrr; 341 int vram_mtrr;
321 bool vram_is_ddr; 342 bool vram_is_ddr;
322}; 343};
@@ -474,6 +495,39 @@ struct radeon_wb {
474 uint64_t gpu_addr; 495 uint64_t gpu_addr;
475}; 496};
476 497
498/**
499 * struct radeon_pm - power management datas
500 * @max_bandwidth: maximum bandwidth the gpu has (MByte/s)
501 * @igp_sideport_mclk: sideport memory clock Mhz (rs690,rs740,rs780,rs880)
502 * @igp_system_mclk: system clock Mhz (rs690,rs740,rs780,rs880)
503 * @igp_ht_link_clk: ht link clock Mhz (rs690,rs740,rs780,rs880)
504 * @igp_ht_link_width: ht link width in bits (rs690,rs740,rs780,rs880)
505 * @k8_bandwidth: k8 bandwidth the gpu has (MByte/s) (IGP)
506 * @sideport_bandwidth: sideport bandwidth the gpu has (MByte/s) (IGP)
507 * @ht_bandwidth: ht bandwidth the gpu has (MByte/s) (IGP)
508 * @core_bandwidth: core GPU bandwidth the gpu has (MByte/s) (IGP)
509 * @sclk: GPU clock Mhz (core bandwith depends of this clock)
510 * @needed_bandwidth: current bandwidth needs
511 *
512 * It keeps track of various data needed to take powermanagement decision.
513 * Bandwith need is used to determine minimun clock of the GPU and memory.
514 * Equation between gpu/memory clock and available bandwidth is hw dependent
515 * (type of memory, bus size, efficiency, ...)
516 */
517struct radeon_pm {
518 fixed20_12 max_bandwidth;
519 fixed20_12 igp_sideport_mclk;
520 fixed20_12 igp_system_mclk;
521 fixed20_12 igp_ht_link_clk;
522 fixed20_12 igp_ht_link_width;
523 fixed20_12 k8_bandwidth;
524 fixed20_12 sideport_bandwidth;
525 fixed20_12 ht_bandwidth;
526 fixed20_12 core_bandwidth;
527 fixed20_12 sclk;
528 fixed20_12 needed_bandwidth;
529};
530
477 531
478/* 532/*
479 * Benchmarking 533 * Benchmarking
@@ -482,6 +536,12 @@ void radeon_benchmark(struct radeon_device *rdev);
482 536
483 537
484/* 538/*
539 * Testing
540 */
541void radeon_test_moves(struct radeon_device *rdev);
542
543
544/*
485 * Debugfs 545 * Debugfs
486 */ 546 */
487int radeon_debugfs_add_files(struct radeon_device *rdev, 547int radeon_debugfs_add_files(struct radeon_device *rdev,
@@ -535,6 +595,11 @@ struct radeon_asic {
535 void (*set_memory_clock)(struct radeon_device *rdev, uint32_t mem_clock); 595 void (*set_memory_clock)(struct radeon_device *rdev, uint32_t mem_clock);
536 void (*set_pcie_lanes)(struct radeon_device *rdev, int lanes); 596 void (*set_pcie_lanes)(struct radeon_device *rdev, int lanes);
537 void (*set_clock_gating)(struct radeon_device *rdev, int enable); 597 void (*set_clock_gating)(struct radeon_device *rdev, int enable);
598 int (*set_surface_reg)(struct radeon_device *rdev, int reg,
599 uint32_t tiling_flags, uint32_t pitch,
600 uint32_t offset, uint32_t obj_size);
601 int (*clear_surface_reg)(struct radeon_device *rdev, int reg);
602 void (*bandwidth_update)(struct radeon_device *rdev);
538}; 603};
539 604
540union radeon_asic_config { 605union radeon_asic_config {
@@ -566,6 +631,10 @@ int radeon_gem_busy_ioctl(struct drm_device *dev, void *data,
566int radeon_gem_wait_idle_ioctl(struct drm_device *dev, void *data, 631int radeon_gem_wait_idle_ioctl(struct drm_device *dev, void *data,
567 struct drm_file *filp); 632 struct drm_file *filp);
568int radeon_cs_ioctl(struct drm_device *dev, void *data, struct drm_file *filp); 633int radeon_cs_ioctl(struct drm_device *dev, void *data, struct drm_file *filp);
634int radeon_gem_set_tiling_ioctl(struct drm_device *dev, void *data,
635 struct drm_file *filp);
636int radeon_gem_get_tiling_ioctl(struct drm_device *dev, void *data,
637 struct drm_file *filp);
569 638
570 639
571/* 640/*
@@ -594,8 +663,8 @@ struct radeon_device {
594 struct radeon_object *fbdev_robj; 663 struct radeon_object *fbdev_robj;
595 struct radeon_framebuffer *fbdev_rfb; 664 struct radeon_framebuffer *fbdev_rfb;
596 /* Register mmio */ 665 /* Register mmio */
597 unsigned long rmmio_base; 666 resource_size_t rmmio_base;
598 unsigned long rmmio_size; 667 resource_size_t rmmio_size;
599 void *rmmio; 668 void *rmmio;
600 radeon_rreg_t mm_rreg; 669 radeon_rreg_t mm_rreg;
601 radeon_wreg_t mm_wreg; 670 radeon_wreg_t mm_wreg;
@@ -619,11 +688,14 @@ struct radeon_device {
619 struct radeon_irq irq; 688 struct radeon_irq irq;
620 struct radeon_asic *asic; 689 struct radeon_asic *asic;
621 struct radeon_gem gem; 690 struct radeon_gem gem;
691 struct radeon_pm pm;
622 struct mutex cs_mutex; 692 struct mutex cs_mutex;
623 struct radeon_wb wb; 693 struct radeon_wb wb;
624 bool gpu_lockup; 694 bool gpu_lockup;
625 bool shutdown; 695 bool shutdown;
626 bool suspend; 696 bool suspend;
697 bool need_dma32;
698 struct radeon_surface_reg surface_regs[RADEON_GEM_MAX_SURFACES];
627}; 699};
628 700
629int radeon_device_init(struct radeon_device *rdev, 701int radeon_device_init(struct radeon_device *rdev,
@@ -670,6 +742,8 @@ void r100_pll_errata_after_index(struct radeon_device *rdev);
670/* 742/*
671 * ASICs helpers. 743 * ASICs helpers.
672 */ 744 */
745#define ASIC_IS_RN50(rdev) ((rdev->pdev->device == 0x515e) || \
746 (rdev->pdev->device == 0x5969))
673#define ASIC_IS_RV100(rdev) ((rdev->family == CHIP_RV100) || \ 747#define ASIC_IS_RV100(rdev) ((rdev->family == CHIP_RV100) || \
674 (rdev->family == CHIP_RV200) || \ 748 (rdev->family == CHIP_RV200) || \
675 (rdev->family == CHIP_RS100) || \ 749 (rdev->family == CHIP_RS100) || \
@@ -796,5 +870,8 @@ static inline void radeon_ring_write(struct radeon_device *rdev, uint32_t v)
796#define radeon_set_memory_clock(rdev, e) (rdev)->asic->set_engine_clock((rdev), (e)) 870#define radeon_set_memory_clock(rdev, e) (rdev)->asic->set_engine_clock((rdev), (e))
797#define radeon_set_pcie_lanes(rdev, l) (rdev)->asic->set_pcie_lanes((rdev), (l)) 871#define radeon_set_pcie_lanes(rdev, l) (rdev)->asic->set_pcie_lanes((rdev), (l))
798#define radeon_set_clock_gating(rdev, e) (rdev)->asic->set_clock_gating((rdev), (e)) 872#define radeon_set_clock_gating(rdev, e) (rdev)->asic->set_clock_gating((rdev), (e))
873#define radeon_set_surface_reg(rdev, r, f, p, o, s) ((rdev)->asic->set_surface_reg((rdev), (r), (f), (p), (o), (s)))
874#define radeon_clear_surface_reg(rdev, r) ((rdev)->asic->clear_surface_reg((rdev), (r)))
875#define radeon_bandwidth_update(rdev) (rdev)->asic->bandwidth_update((rdev))
799 876
800#endif 877#endif
diff --git a/drivers/gpu/drm/radeon/radeon_asic.h b/drivers/gpu/drm/radeon/radeon_asic.h
index e2e567395df8..9a75876e0c3b 100644
--- a/drivers/gpu/drm/radeon/radeon_asic.h
+++ b/drivers/gpu/drm/radeon/radeon_asic.h
@@ -71,6 +71,11 @@ int r100_copy_blit(struct radeon_device *rdev,
71 uint64_t dst_offset, 71 uint64_t dst_offset,
72 unsigned num_pages, 72 unsigned num_pages,
73 struct radeon_fence *fence); 73 struct radeon_fence *fence);
74int r100_set_surface_reg(struct radeon_device *rdev, int reg,
75 uint32_t tiling_flags, uint32_t pitch,
76 uint32_t offset, uint32_t obj_size);
77int r100_clear_surface_reg(struct radeon_device *rdev, int reg);
78void r100_bandwidth_update(struct radeon_device *rdev);
74 79
75static struct radeon_asic r100_asic = { 80static struct radeon_asic r100_asic = {
76 .init = &r100_init, 81 .init = &r100_init,
@@ -100,6 +105,9 @@ static struct radeon_asic r100_asic = {
100 .set_memory_clock = NULL, 105 .set_memory_clock = NULL,
101 .set_pcie_lanes = NULL, 106 .set_pcie_lanes = NULL,
102 .set_clock_gating = &radeon_legacy_set_clock_gating, 107 .set_clock_gating = &radeon_legacy_set_clock_gating,
108 .set_surface_reg = r100_set_surface_reg,
109 .clear_surface_reg = r100_clear_surface_reg,
110 .bandwidth_update = &r100_bandwidth_update,
103}; 111};
104 112
105 113
@@ -128,6 +136,7 @@ int r300_copy_dma(struct radeon_device *rdev,
128 uint64_t dst_offset, 136 uint64_t dst_offset,
129 unsigned num_pages, 137 unsigned num_pages,
130 struct radeon_fence *fence); 138 struct radeon_fence *fence);
139
131static struct radeon_asic r300_asic = { 140static struct radeon_asic r300_asic = {
132 .init = &r300_init, 141 .init = &r300_init,
133 .errata = &r300_errata, 142 .errata = &r300_errata,
@@ -156,6 +165,9 @@ static struct radeon_asic r300_asic = {
156 .set_memory_clock = NULL, 165 .set_memory_clock = NULL,
157 .set_pcie_lanes = &rv370_set_pcie_lanes, 166 .set_pcie_lanes = &rv370_set_pcie_lanes,
158 .set_clock_gating = &radeon_legacy_set_clock_gating, 167 .set_clock_gating = &radeon_legacy_set_clock_gating,
168 .set_surface_reg = r100_set_surface_reg,
169 .clear_surface_reg = r100_clear_surface_reg,
170 .bandwidth_update = &r100_bandwidth_update,
159}; 171};
160 172
161/* 173/*
@@ -193,6 +205,9 @@ static struct radeon_asic r420_asic = {
193 .set_memory_clock = &radeon_atom_set_memory_clock, 205 .set_memory_clock = &radeon_atom_set_memory_clock,
194 .set_pcie_lanes = &rv370_set_pcie_lanes, 206 .set_pcie_lanes = &rv370_set_pcie_lanes,
195 .set_clock_gating = &radeon_atom_set_clock_gating, 207 .set_clock_gating = &radeon_atom_set_clock_gating,
208 .set_surface_reg = r100_set_surface_reg,
209 .clear_surface_reg = r100_clear_surface_reg,
210 .bandwidth_update = &r100_bandwidth_update,
196}; 211};
197 212
198 213
@@ -237,6 +252,9 @@ static struct radeon_asic rs400_asic = {
237 .set_memory_clock = NULL, 252 .set_memory_clock = NULL,
238 .set_pcie_lanes = NULL, 253 .set_pcie_lanes = NULL,
239 .set_clock_gating = &radeon_legacy_set_clock_gating, 254 .set_clock_gating = &radeon_legacy_set_clock_gating,
255 .set_surface_reg = r100_set_surface_reg,
256 .clear_surface_reg = r100_clear_surface_reg,
257 .bandwidth_update = &r100_bandwidth_update,
240}; 258};
241 259
242 260
@@ -254,6 +272,7 @@ void rs600_gart_tlb_flush(struct radeon_device *rdev);
254int rs600_gart_set_page(struct radeon_device *rdev, int i, uint64_t addr); 272int rs600_gart_set_page(struct radeon_device *rdev, int i, uint64_t addr);
255uint32_t rs600_mc_rreg(struct radeon_device *rdev, uint32_t reg); 273uint32_t rs600_mc_rreg(struct radeon_device *rdev, uint32_t reg);
256void rs600_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v); 274void rs600_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v);
275void rs600_bandwidth_update(struct radeon_device *rdev);
257static struct radeon_asic rs600_asic = { 276static struct radeon_asic rs600_asic = {
258 .init = &r300_init, 277 .init = &r300_init,
259 .errata = &rs600_errata, 278 .errata = &rs600_errata,
@@ -282,6 +301,7 @@ static struct radeon_asic rs600_asic = {
282 .set_memory_clock = &radeon_atom_set_memory_clock, 301 .set_memory_clock = &radeon_atom_set_memory_clock,
283 .set_pcie_lanes = NULL, 302 .set_pcie_lanes = NULL,
284 .set_clock_gating = &radeon_atom_set_clock_gating, 303 .set_clock_gating = &radeon_atom_set_clock_gating,
304 .bandwidth_update = &rs600_bandwidth_update,
285}; 305};
286 306
287 307
@@ -294,6 +314,7 @@ int rs690_mc_init(struct radeon_device *rdev);
294void rs690_mc_fini(struct radeon_device *rdev); 314void rs690_mc_fini(struct radeon_device *rdev);
295uint32_t rs690_mc_rreg(struct radeon_device *rdev, uint32_t reg); 315uint32_t rs690_mc_rreg(struct radeon_device *rdev, uint32_t reg);
296void rs690_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v); 316void rs690_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v);
317void rs690_bandwidth_update(struct radeon_device *rdev);
297static struct radeon_asic rs690_asic = { 318static struct radeon_asic rs690_asic = {
298 .init = &r300_init, 319 .init = &r300_init,
299 .errata = &rs690_errata, 320 .errata = &rs690_errata,
@@ -322,6 +343,9 @@ static struct radeon_asic rs690_asic = {
322 .set_memory_clock = &radeon_atom_set_memory_clock, 343 .set_memory_clock = &radeon_atom_set_memory_clock,
323 .set_pcie_lanes = NULL, 344 .set_pcie_lanes = NULL,
324 .set_clock_gating = &radeon_atom_set_clock_gating, 345 .set_clock_gating = &radeon_atom_set_clock_gating,
346 .set_surface_reg = r100_set_surface_reg,
347 .clear_surface_reg = r100_clear_surface_reg,
348 .bandwidth_update = &rs690_bandwidth_update,
325}; 349};
326 350
327 351
@@ -339,6 +363,7 @@ void rv515_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v);
339void rv515_ring_start(struct radeon_device *rdev); 363void rv515_ring_start(struct radeon_device *rdev);
340uint32_t rv515_pcie_rreg(struct radeon_device *rdev, uint32_t reg); 364uint32_t rv515_pcie_rreg(struct radeon_device *rdev, uint32_t reg);
341void rv515_pcie_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v); 365void rv515_pcie_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v);
366void rv515_bandwidth_update(struct radeon_device *rdev);
342static struct radeon_asic rv515_asic = { 367static struct radeon_asic rv515_asic = {
343 .init = &rv515_init, 368 .init = &rv515_init,
344 .errata = &rv515_errata, 369 .errata = &rv515_errata,
@@ -367,6 +392,9 @@ static struct radeon_asic rv515_asic = {
367 .set_memory_clock = &radeon_atom_set_memory_clock, 392 .set_memory_clock = &radeon_atom_set_memory_clock,
368 .set_pcie_lanes = &rv370_set_pcie_lanes, 393 .set_pcie_lanes = &rv370_set_pcie_lanes,
369 .set_clock_gating = &radeon_atom_set_clock_gating, 394 .set_clock_gating = &radeon_atom_set_clock_gating,
395 .set_surface_reg = r100_set_surface_reg,
396 .clear_surface_reg = r100_clear_surface_reg,
397 .bandwidth_update = &rv515_bandwidth_update,
370}; 398};
371 399
372 400
@@ -377,6 +405,7 @@ void r520_errata(struct radeon_device *rdev);
377void r520_vram_info(struct radeon_device *rdev); 405void r520_vram_info(struct radeon_device *rdev);
378int r520_mc_init(struct radeon_device *rdev); 406int r520_mc_init(struct radeon_device *rdev);
379void r520_mc_fini(struct radeon_device *rdev); 407void r520_mc_fini(struct radeon_device *rdev);
408void r520_bandwidth_update(struct radeon_device *rdev);
380static struct radeon_asic r520_asic = { 409static struct radeon_asic r520_asic = {
381 .init = &rv515_init, 410 .init = &rv515_init,
382 .errata = &r520_errata, 411 .errata = &r520_errata,
@@ -405,6 +434,9 @@ static struct radeon_asic r520_asic = {
405 .set_memory_clock = &radeon_atom_set_memory_clock, 434 .set_memory_clock = &radeon_atom_set_memory_clock,
406 .set_pcie_lanes = &rv370_set_pcie_lanes, 435 .set_pcie_lanes = &rv370_set_pcie_lanes,
407 .set_clock_gating = &radeon_atom_set_clock_gating, 436 .set_clock_gating = &radeon_atom_set_clock_gating,
437 .set_surface_reg = r100_set_surface_reg,
438 .clear_surface_reg = r100_clear_surface_reg,
439 .bandwidth_update = &r520_bandwidth_update,
408}; 440};
409 441
410/* 442/*
diff --git a/drivers/gpu/drm/radeon/radeon_atombios.c b/drivers/gpu/drm/radeon/radeon_atombios.c
index 1f5a1a490984..fcfe5c02d744 100644
--- a/drivers/gpu/drm/radeon/radeon_atombios.c
+++ b/drivers/gpu/drm/radeon/radeon_atombios.c
@@ -103,7 +103,8 @@ static inline struct radeon_i2c_bus_rec radeon_lookup_gpio(struct drm_device
103static bool radeon_atom_apply_quirks(struct drm_device *dev, 103static bool radeon_atom_apply_quirks(struct drm_device *dev,
104 uint32_t supported_device, 104 uint32_t supported_device,
105 int *connector_type, 105 int *connector_type,
106 struct radeon_i2c_bus_rec *i2c_bus) 106 struct radeon_i2c_bus_rec *i2c_bus,
107 uint8_t *line_mux)
107{ 108{
108 109
109 /* Asus M2A-VM HDMI board lists the DVI port as HDMI */ 110 /* Asus M2A-VM HDMI board lists the DVI port as HDMI */
@@ -127,8 +128,10 @@ static bool radeon_atom_apply_quirks(struct drm_device *dev,
127 if ((dev->pdev->device == 0x5653) && 128 if ((dev->pdev->device == 0x5653) &&
128 (dev->pdev->subsystem_vendor == 0x1462) && 129 (dev->pdev->subsystem_vendor == 0x1462) &&
129 (dev->pdev->subsystem_device == 0x0291)) { 130 (dev->pdev->subsystem_device == 0x0291)) {
130 if (*connector_type == DRM_MODE_CONNECTOR_LVDS) 131 if (*connector_type == DRM_MODE_CONNECTOR_LVDS) {
131 i2c_bus->valid = false; 132 i2c_bus->valid = false;
133 *line_mux = 53;
134 }
132 } 135 }
133 136
134 /* Funky macbooks */ 137 /* Funky macbooks */
@@ -526,7 +529,7 @@ bool radeon_get_atom_connector_info_from_supported_devices_table(struct
526 529
527 if (!radeon_atom_apply_quirks 530 if (!radeon_atom_apply_quirks
528 (dev, (1 << i), &bios_connectors[i].connector_type, 531 (dev, (1 << i), &bios_connectors[i].connector_type,
529 &bios_connectors[i].ddc_bus)) 532 &bios_connectors[i].ddc_bus, &bios_connectors[i].line_mux))
530 continue; 533 continue;
531 534
532 bios_connectors[i].valid = true; 535 bios_connectors[i].valid = true;
diff --git a/drivers/gpu/drm/radeon/radeon_benchmark.c b/drivers/gpu/drm/radeon/radeon_benchmark.c
index c44403a2ca76..2e938f7496fb 100644
--- a/drivers/gpu/drm/radeon/radeon_benchmark.c
+++ b/drivers/gpu/drm/radeon/radeon_benchmark.c
@@ -63,7 +63,7 @@ void radeon_benchmark_move(struct radeon_device *rdev, unsigned bsize,
63 if (r) { 63 if (r) {
64 goto out_cleanup; 64 goto out_cleanup;
65 } 65 }
66 r = radeon_copy_dma(rdev, saddr, daddr, size >> 14, fence); 66 r = radeon_copy_dma(rdev, saddr, daddr, size / 4096, fence);
67 if (r) { 67 if (r) {
68 goto out_cleanup; 68 goto out_cleanup;
69 } 69 }
@@ -88,7 +88,7 @@ void radeon_benchmark_move(struct radeon_device *rdev, unsigned bsize,
88 if (r) { 88 if (r) {
89 goto out_cleanup; 89 goto out_cleanup;
90 } 90 }
91 r = radeon_copy_blit(rdev, saddr, daddr, size >> 14, fence); 91 r = radeon_copy_blit(rdev, saddr, daddr, size / 4096, fence);
92 if (r) { 92 if (r) {
93 goto out_cleanup; 93 goto out_cleanup;
94 } 94 }
diff --git a/drivers/gpu/drm/radeon/radeon_cs.c b/drivers/gpu/drm/radeon/radeon_cs.c
index b843f9bdfb14..a169067efc4e 100644
--- a/drivers/gpu/drm/radeon/radeon_cs.c
+++ b/drivers/gpu/drm/radeon/radeon_cs.c
@@ -127,17 +127,23 @@ int radeon_cs_parser_init(struct radeon_cs_parser *p, void *data)
127 sizeof(struct drm_radeon_cs_chunk))) { 127 sizeof(struct drm_radeon_cs_chunk))) {
128 return -EFAULT; 128 return -EFAULT;
129 } 129 }
130 p->chunks[i].length_dw = user_chunk.length_dw;
131 p->chunks[i].kdata = NULL;
130 p->chunks[i].chunk_id = user_chunk.chunk_id; 132 p->chunks[i].chunk_id = user_chunk.chunk_id;
133
131 if (p->chunks[i].chunk_id == RADEON_CHUNK_ID_RELOCS) { 134 if (p->chunks[i].chunk_id == RADEON_CHUNK_ID_RELOCS) {
132 p->chunk_relocs_idx = i; 135 p->chunk_relocs_idx = i;
133 } 136 }
134 if (p->chunks[i].chunk_id == RADEON_CHUNK_ID_IB) { 137 if (p->chunks[i].chunk_id == RADEON_CHUNK_ID_IB) {
135 p->chunk_ib_idx = i; 138 p->chunk_ib_idx = i;
139 /* zero length IB isn't useful */
140 if (p->chunks[i].length_dw == 0)
141 return -EINVAL;
136 } 142 }
143
137 p->chunks[i].length_dw = user_chunk.length_dw; 144 p->chunks[i].length_dw = user_chunk.length_dw;
138 cdata = (uint32_t *)(unsigned long)user_chunk.chunk_data; 145 cdata = (uint32_t *)(unsigned long)user_chunk.chunk_data;
139 146
140 p->chunks[i].kdata = NULL;
141 size = p->chunks[i].length_dw * sizeof(uint32_t); 147 size = p->chunks[i].length_dw * sizeof(uint32_t);
142 p->chunks[i].kdata = kzalloc(size, GFP_KERNEL); 148 p->chunks[i].kdata = kzalloc(size, GFP_KERNEL);
143 if (p->chunks[i].kdata == NULL) { 149 if (p->chunks[i].kdata == NULL) {
diff --git a/drivers/gpu/drm/radeon/radeon_cursor.c b/drivers/gpu/drm/radeon/radeon_cursor.c
index 5232441f119b..b13c79e38bc0 100644
--- a/drivers/gpu/drm/radeon/radeon_cursor.c
+++ b/drivers/gpu/drm/radeon/radeon_cursor.c
@@ -111,9 +111,11 @@ static void radeon_set_cursor(struct drm_crtc *crtc, struct drm_gem_object *obj,
111 111
112 if (ASIC_IS_AVIVO(rdev)) 112 if (ASIC_IS_AVIVO(rdev))
113 WREG32(AVIVO_D1CUR_SURFACE_ADDRESS + radeon_crtc->crtc_offset, gpu_addr); 113 WREG32(AVIVO_D1CUR_SURFACE_ADDRESS + radeon_crtc->crtc_offset, gpu_addr);
114 else 114 else {
115 radeon_crtc->legacy_cursor_offset = gpu_addr - radeon_crtc->legacy_display_base_addr;
115 /* offset is from DISP(2)_BASE_ADDRESS */ 116 /* offset is from DISP(2)_BASE_ADDRESS */
116 WREG32(RADEON_CUR_OFFSET + radeon_crtc->crtc_offset, gpu_addr); 117 WREG32(RADEON_CUR_OFFSET + radeon_crtc->crtc_offset, radeon_crtc->legacy_cursor_offset);
118 }
117} 119}
118 120
119int radeon_crtc_cursor_set(struct drm_crtc *crtc, 121int radeon_crtc_cursor_set(struct drm_crtc *crtc,
@@ -245,6 +247,9 @@ int radeon_crtc_cursor_move(struct drm_crtc *crtc,
245 (RADEON_CUR_LOCK 247 (RADEON_CUR_LOCK
246 | ((xorigin ? 0 : x) << 16) 248 | ((xorigin ? 0 : x) << 16)
247 | (yorigin ? 0 : y))); 249 | (yorigin ? 0 : y)));
250 /* offset is from DISP(2)_BASE_ADDRESS */
251 WREG32(RADEON_CUR_OFFSET + radeon_crtc->crtc_offset, (radeon_crtc->legacy_cursor_offset +
252 (yorigin * 256)));
248 } 253 }
249 radeon_lock_cursor(crtc, false); 254 radeon_lock_cursor(crtc, false);
250 255
diff --git a/drivers/gpu/drm/radeon/radeon_device.c b/drivers/gpu/drm/radeon/radeon_device.c
index f97563db4e59..a162ade74b7f 100644
--- a/drivers/gpu/drm/radeon/radeon_device.c
+++ b/drivers/gpu/drm/radeon/radeon_device.c
@@ -48,6 +48,8 @@ static void radeon_surface_init(struct radeon_device *rdev)
48 i * (RADEON_SURFACE1_INFO - RADEON_SURFACE0_INFO), 48 i * (RADEON_SURFACE1_INFO - RADEON_SURFACE0_INFO),
49 0); 49 0);
50 } 50 }
51 /* enable surfaces */
52 WREG32(RADEON_SURFACE_CNTL, 0);
51 } 53 }
52} 54}
53 55
@@ -119,7 +121,7 @@ int radeon_mc_setup(struct radeon_device *rdev)
119 if (rdev->mc.vram_location != 0xFFFFFFFFUL) { 121 if (rdev->mc.vram_location != 0xFFFFFFFFUL) {
120 /* vram location was already setup try to put gtt after 122 /* vram location was already setup try to put gtt after
121 * if it fits */ 123 * if it fits */
122 tmp = rdev->mc.vram_location + rdev->mc.vram_size; 124 tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size;
123 tmp = (tmp + rdev->mc.gtt_size - 1) & ~(rdev->mc.gtt_size - 1); 125 tmp = (tmp + rdev->mc.gtt_size - 1) & ~(rdev->mc.gtt_size - 1);
124 if ((0xFFFFFFFFUL - tmp) >= rdev->mc.gtt_size) { 126 if ((0xFFFFFFFFUL - tmp) >= rdev->mc.gtt_size) {
125 rdev->mc.gtt_location = tmp; 127 rdev->mc.gtt_location = tmp;
@@ -134,13 +136,13 @@ int radeon_mc_setup(struct radeon_device *rdev)
134 } else if (rdev->mc.gtt_location != 0xFFFFFFFFUL) { 136 } else if (rdev->mc.gtt_location != 0xFFFFFFFFUL) {
135 /* gtt location was already setup try to put vram before 137 /* gtt location was already setup try to put vram before
136 * if it fits */ 138 * if it fits */
137 if (rdev->mc.vram_size < rdev->mc.gtt_location) { 139 if (rdev->mc.mc_vram_size < rdev->mc.gtt_location) {
138 rdev->mc.vram_location = 0; 140 rdev->mc.vram_location = 0;
139 } else { 141 } else {
140 tmp = rdev->mc.gtt_location + rdev->mc.gtt_size; 142 tmp = rdev->mc.gtt_location + rdev->mc.gtt_size;
141 tmp += (rdev->mc.vram_size - 1); 143 tmp += (rdev->mc.mc_vram_size - 1);
142 tmp &= ~(rdev->mc.vram_size - 1); 144 tmp &= ~(rdev->mc.mc_vram_size - 1);
143 if ((0xFFFFFFFFUL - tmp) >= rdev->mc.vram_size) { 145 if ((0xFFFFFFFFUL - tmp) >= rdev->mc.mc_vram_size) {
144 rdev->mc.vram_location = tmp; 146 rdev->mc.vram_location = tmp;
145 } else { 147 } else {
146 printk(KERN_ERR "[drm] vram too big to fit " 148 printk(KERN_ERR "[drm] vram too big to fit "
@@ -150,12 +152,14 @@ int radeon_mc_setup(struct radeon_device *rdev)
150 } 152 }
151 } else { 153 } else {
152 rdev->mc.vram_location = 0; 154 rdev->mc.vram_location = 0;
153 rdev->mc.gtt_location = rdev->mc.vram_size; 155 rdev->mc.gtt_location = rdev->mc.mc_vram_size;
154 } 156 }
155 DRM_INFO("radeon: VRAM %uM\n", rdev->mc.vram_size >> 20); 157 DRM_INFO("radeon: VRAM %uM\n", rdev->mc.real_vram_size >> 20);
156 DRM_INFO("radeon: VRAM from 0x%08X to 0x%08X\n", 158 DRM_INFO("radeon: VRAM from 0x%08X to 0x%08X\n",
157 rdev->mc.vram_location, 159 rdev->mc.vram_location,
158 rdev->mc.vram_location + rdev->mc.vram_size - 1); 160 rdev->mc.vram_location + rdev->mc.mc_vram_size - 1);
161 if (rdev->mc.real_vram_size != rdev->mc.mc_vram_size)
162 DRM_INFO("radeon: VRAM less than aperture workaround enabled\n");
159 DRM_INFO("radeon: GTT %uM\n", rdev->mc.gtt_size >> 20); 163 DRM_INFO("radeon: GTT %uM\n", rdev->mc.gtt_size >> 20);
160 DRM_INFO("radeon: GTT from 0x%08X to 0x%08X\n", 164 DRM_INFO("radeon: GTT from 0x%08X to 0x%08X\n",
161 rdev->mc.gtt_location, 165 rdev->mc.gtt_location,
@@ -450,6 +454,7 @@ int radeon_device_init(struct radeon_device *rdev,
450 uint32_t flags) 454 uint32_t flags)
451{ 455{
452 int r, ret; 456 int r, ret;
457 int dma_bits;
453 458
454 DRM_INFO("radeon: Initializing kernel modesetting.\n"); 459 DRM_INFO("radeon: Initializing kernel modesetting.\n");
455 rdev->shutdown = false; 460 rdev->shutdown = false;
@@ -492,8 +497,20 @@ int radeon_device_init(struct radeon_device *rdev,
492 return r; 497 return r;
493 } 498 }
494 499
495 /* Report DMA addressing limitation */ 500 /* set DMA mask + need_dma32 flags.
496 r = pci_set_dma_mask(rdev->pdev, DMA_BIT_MASK(32)); 501 * PCIE - can handle 40-bits.
502 * IGP - can handle 40-bits (in theory)
503 * AGP - generally dma32 is safest
504 * PCI - only dma32
505 */
506 rdev->need_dma32 = false;
507 if (rdev->flags & RADEON_IS_AGP)
508 rdev->need_dma32 = true;
509 if (rdev->flags & RADEON_IS_PCI)
510 rdev->need_dma32 = true;
511
512 dma_bits = rdev->need_dma32 ? 32 : 40;
513 r = pci_set_dma_mask(rdev->pdev, DMA_BIT_MASK(dma_bits));
497 if (r) { 514 if (r) {
498 printk(KERN_WARNING "radeon: No suitable DMA available.\n"); 515 printk(KERN_WARNING "radeon: No suitable DMA available.\n");
499 } 516 }
@@ -546,27 +563,22 @@ int radeon_device_init(struct radeon_device *rdev,
546 radeon_combios_asic_init(rdev->ddev); 563 radeon_combios_asic_init(rdev->ddev);
547 } 564 }
548 } 565 }
566 /* Initialize clocks */
567 r = radeon_clocks_init(rdev);
568 if (r) {
569 return r;
570 }
549 /* Get vram informations */ 571 /* Get vram informations */
550 radeon_vram_info(rdev); 572 radeon_vram_info(rdev);
551 /* Device is severly broken if aper size > vram size. 573
552 * for RN50/M6/M7 - Novell bug 204882 ?
553 */
554 if (rdev->mc.vram_size < rdev->mc.aper_size) {
555 rdev->mc.aper_size = rdev->mc.vram_size;
556 }
557 /* Add an MTRR for the VRAM */ 574 /* Add an MTRR for the VRAM */
558 rdev->mc.vram_mtrr = mtrr_add(rdev->mc.aper_base, rdev->mc.aper_size, 575 rdev->mc.vram_mtrr = mtrr_add(rdev->mc.aper_base, rdev->mc.aper_size,
559 MTRR_TYPE_WRCOMB, 1); 576 MTRR_TYPE_WRCOMB, 1);
560 DRM_INFO("Detected VRAM RAM=%uM, BAR=%uM\n", 577 DRM_INFO("Detected VRAM RAM=%uM, BAR=%uM\n",
561 rdev->mc.vram_size >> 20, 578 rdev->mc.real_vram_size >> 20,
562 (unsigned)rdev->mc.aper_size >> 20); 579 (unsigned)rdev->mc.aper_size >> 20);
563 DRM_INFO("RAM width %dbits %cDR\n", 580 DRM_INFO("RAM width %dbits %cDR\n",
564 rdev->mc.vram_width, rdev->mc.vram_is_ddr ? 'D' : 'S'); 581 rdev->mc.vram_width, rdev->mc.vram_is_ddr ? 'D' : 'S');
565 /* Initialize clocks */
566 r = radeon_clocks_init(rdev);
567 if (r) {
568 return r;
569 }
570 /* Initialize memory controller (also test AGP) */ 582 /* Initialize memory controller (also test AGP) */
571 r = radeon_mc_init(rdev); 583 r = radeon_mc_init(rdev);
572 if (r) { 584 if (r) {
@@ -626,6 +638,9 @@ int radeon_device_init(struct radeon_device *rdev,
626 if (!ret) { 638 if (!ret) {
627 DRM_INFO("radeon: kernel modesetting successfully initialized.\n"); 639 DRM_INFO("radeon: kernel modesetting successfully initialized.\n");
628 } 640 }
641 if (radeon_testing) {
642 radeon_test_moves(rdev);
643 }
629 if (radeon_benchmarking) { 644 if (radeon_benchmarking) {
630 radeon_benchmark(rdev); 645 radeon_benchmark(rdev);
631 } 646 }
diff --git a/drivers/gpu/drm/radeon/radeon_display.c b/drivers/gpu/drm/radeon/radeon_display.c
index 3efcf1a526be..a8fa1bb84cf7 100644
--- a/drivers/gpu/drm/radeon/radeon_display.c
+++ b/drivers/gpu/drm/radeon/radeon_display.c
@@ -187,6 +187,7 @@ static void radeon_crtc_init(struct drm_device *dev, int index)
187 187
188 drm_mode_crtc_set_gamma_size(&radeon_crtc->base, 256); 188 drm_mode_crtc_set_gamma_size(&radeon_crtc->base, 256);
189 radeon_crtc->crtc_id = index; 189 radeon_crtc->crtc_id = index;
190 rdev->mode_info.crtcs[index] = radeon_crtc;
190 191
191 radeon_crtc->mode_set.crtc = &radeon_crtc->base; 192 radeon_crtc->mode_set.crtc = &radeon_crtc->base;
192 radeon_crtc->mode_set.connectors = (struct drm_connector **)(radeon_crtc + 1); 193 radeon_crtc->mode_set.connectors = (struct drm_connector **)(radeon_crtc + 1);
@@ -491,7 +492,11 @@ void radeon_compute_pll(struct radeon_pll *pll,
491 tmp += (uint64_t)pll->reference_freq * 1000 * frac_feedback_div; 492 tmp += (uint64_t)pll->reference_freq * 1000 * frac_feedback_div;
492 current_freq = radeon_div(tmp, ref_div * post_div); 493 current_freq = radeon_div(tmp, ref_div * post_div);
493 494
494 error = abs(current_freq - freq); 495 if (flags & RADEON_PLL_PREFER_CLOSEST_LOWER) {
496 error = freq - current_freq;
497 error = error < 0 ? 0xffffffff : error;
498 } else
499 error = abs(current_freq - freq);
495 vco_diff = abs(vco - best_vco); 500 vco_diff = abs(vco - best_vco);
496 501
497 if ((best_vco == 0 && error < best_error) || 502 if ((best_vco == 0 && error < best_error) ||
@@ -657,36 +662,51 @@ void radeon_modeset_fini(struct radeon_device *rdev)
657 } 662 }
658} 663}
659 664
660void radeon_init_disp_bandwidth(struct drm_device *dev) 665bool radeon_crtc_scaling_mode_fixup(struct drm_crtc *crtc,
666 struct drm_display_mode *mode,
667 struct drm_display_mode *adjusted_mode)
661{ 668{
662 struct radeon_device *rdev = dev->dev_private; 669 struct drm_device *dev = crtc->dev;
663 struct drm_display_mode *modes[2]; 670 struct drm_encoder *encoder;
664 int pixel_bytes[2]; 671 struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc);
665 struct drm_crtc *crtc; 672 struct radeon_encoder *radeon_encoder;
666 673 bool first = true;
667 pixel_bytes[0] = pixel_bytes[1] = 0;
668 modes[0] = modes[1] = NULL;
669
670 list_for_each_entry(crtc, &dev->mode_config.crtc_list, head) {
671 struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc);
672 674
673 if (crtc->enabled && crtc->fb) { 675 list_for_each_entry(encoder, &dev->mode_config.encoder_list, head) {
674 modes[radeon_crtc->crtc_id] = &crtc->mode; 676 radeon_encoder = to_radeon_encoder(encoder);
675 pixel_bytes[radeon_crtc->crtc_id] = crtc->fb->bits_per_pixel / 8; 677 if (encoder->crtc != crtc)
678 continue;
679 if (first) {
680 radeon_crtc->rmx_type = radeon_encoder->rmx_type;
681 radeon_crtc->devices = radeon_encoder->devices;
682 memcpy(&radeon_crtc->native_mode,
683 &radeon_encoder->native_mode,
684 sizeof(struct radeon_native_mode));
685 first = false;
686 } else {
687 if (radeon_crtc->rmx_type != radeon_encoder->rmx_type) {
688 /* WARNING: Right now this can't happen but
689 * in the future we need to check that scaling
690 * are consistent accross different encoder
691 * (ie all encoder can work with the same
692 * scaling).
693 */
694 DRM_ERROR("Scaling not consistent accross encoder.\n");
695 return false;
696 }
676 } 697 }
677 } 698 }
678 699 if (radeon_crtc->rmx_type != RMX_OFF) {
679 if (ASIC_IS_AVIVO(rdev)) { 700 fixed20_12 a, b;
680 radeon_init_disp_bw_avivo(dev, 701 a.full = rfixed_const(crtc->mode.vdisplay);
681 modes[0], 702 b.full = rfixed_const(radeon_crtc->native_mode.panel_xres);
682 pixel_bytes[0], 703 radeon_crtc->vsc.full = rfixed_div(a, b);
683 modes[1], 704 a.full = rfixed_const(crtc->mode.hdisplay);
684 pixel_bytes[1]); 705 b.full = rfixed_const(radeon_crtc->native_mode.panel_yres);
706 radeon_crtc->hsc.full = rfixed_div(a, b);
685 } else { 707 } else {
686 radeon_init_disp_bw_legacy(dev, 708 radeon_crtc->vsc.full = rfixed_const(1);
687 modes[0], 709 radeon_crtc->hsc.full = rfixed_const(1);
688 pixel_bytes[0],
689 modes[1],
690 pixel_bytes[1]);
691 } 710 }
711 return true;
692} 712}
diff --git a/drivers/gpu/drm/radeon/radeon_drv.c b/drivers/gpu/drm/radeon/radeon_drv.c
index 84ba69f48784..3cfcee17dc56 100644
--- a/drivers/gpu/drm/radeon/radeon_drv.c
+++ b/drivers/gpu/drm/radeon/radeon_drv.c
@@ -89,6 +89,7 @@ int radeon_agpmode = 0;
89int radeon_vram_limit = 0; 89int radeon_vram_limit = 0;
90int radeon_gart_size = 512; /* default gart size */ 90int radeon_gart_size = 512; /* default gart size */
91int radeon_benchmarking = 0; 91int radeon_benchmarking = 0;
92int radeon_testing = 0;
92int radeon_connector_table = 0; 93int radeon_connector_table = 0;
93#endif 94#endif
94 95
@@ -117,6 +118,9 @@ module_param_named(gartsize, radeon_gart_size, int, 0600);
117MODULE_PARM_DESC(benchmark, "Run benchmark"); 118MODULE_PARM_DESC(benchmark, "Run benchmark");
118module_param_named(benchmark, radeon_benchmarking, int, 0444); 119module_param_named(benchmark, radeon_benchmarking, int, 0444);
119 120
121MODULE_PARM_DESC(test, "Run tests");
122module_param_named(test, radeon_testing, int, 0444);
123
120MODULE_PARM_DESC(connector_table, "Force connector table"); 124MODULE_PARM_DESC(connector_table, "Force connector table");
121module_param_named(connector_table, radeon_connector_table, int, 0444); 125module_param_named(connector_table, radeon_connector_table, int, 0444);
122#endif 126#endif
diff --git a/drivers/gpu/drm/radeon/radeon_encoders.c b/drivers/gpu/drm/radeon/radeon_encoders.c
index c8ef0d14ffab..0a92706eac19 100644
--- a/drivers/gpu/drm/radeon/radeon_encoders.c
+++ b/drivers/gpu/drm/radeon/radeon_encoders.c
@@ -154,7 +154,6 @@ void radeon_rmx_mode_fixup(struct drm_encoder *encoder,
154 154
155 if (mode->hdisplay < native_mode->panel_xres || 155 if (mode->hdisplay < native_mode->panel_xres ||
156 mode->vdisplay < native_mode->panel_yres) { 156 mode->vdisplay < native_mode->panel_yres) {
157 radeon_encoder->flags |= RADEON_USE_RMX;
158 if (ASIC_IS_AVIVO(rdev)) { 157 if (ASIC_IS_AVIVO(rdev)) {
159 adjusted_mode->hdisplay = native_mode->panel_xres; 158 adjusted_mode->hdisplay = native_mode->panel_xres;
160 adjusted_mode->vdisplay = native_mode->panel_yres; 159 adjusted_mode->vdisplay = native_mode->panel_yres;
@@ -197,15 +196,13 @@ void radeon_rmx_mode_fixup(struct drm_encoder *encoder,
197 } 196 }
198} 197}
199 198
199
200static bool radeon_atom_mode_fixup(struct drm_encoder *encoder, 200static bool radeon_atom_mode_fixup(struct drm_encoder *encoder,
201 struct drm_display_mode *mode, 201 struct drm_display_mode *mode,
202 struct drm_display_mode *adjusted_mode) 202 struct drm_display_mode *adjusted_mode)
203{ 203{
204
205 struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder); 204 struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder);
206 205
207 radeon_encoder->flags &= ~RADEON_USE_RMX;
208
209 drm_mode_set_crtcinfo(adjusted_mode, 0); 206 drm_mode_set_crtcinfo(adjusted_mode, 0);
210 207
211 if (radeon_encoder->rmx_type != RMX_OFF) 208 if (radeon_encoder->rmx_type != RMX_OFF)
@@ -808,234 +805,6 @@ atombios_dig_transmitter_setup(struct drm_encoder *encoder, int action)
808 805
809} 806}
810 807
811static void atom_rv515_force_tv_scaler(struct radeon_device *rdev)
812{
813
814 WREG32(0x659C, 0x0);
815 WREG32(0x6594, 0x705);
816 WREG32(0x65A4, 0x10001);
817 WREG32(0x65D8, 0x0);
818 WREG32(0x65B0, 0x0);
819 WREG32(0x65C0, 0x0);
820 WREG32(0x65D4, 0x0);
821 WREG32(0x6578, 0x0);
822 WREG32(0x657C, 0x841880A8);
823 WREG32(0x6578, 0x1);
824 WREG32(0x657C, 0x84208680);
825 WREG32(0x6578, 0x2);
826 WREG32(0x657C, 0xBFF880B0);
827 WREG32(0x6578, 0x100);
828 WREG32(0x657C, 0x83D88088);
829 WREG32(0x6578, 0x101);
830 WREG32(0x657C, 0x84608680);
831 WREG32(0x6578, 0x102);
832 WREG32(0x657C, 0xBFF080D0);
833 WREG32(0x6578, 0x200);
834 WREG32(0x657C, 0x83988068);
835 WREG32(0x6578, 0x201);
836 WREG32(0x657C, 0x84A08680);
837 WREG32(0x6578, 0x202);
838 WREG32(0x657C, 0xBFF080F8);
839 WREG32(0x6578, 0x300);
840 WREG32(0x657C, 0x83588058);
841 WREG32(0x6578, 0x301);
842 WREG32(0x657C, 0x84E08660);
843 WREG32(0x6578, 0x302);
844 WREG32(0x657C, 0xBFF88120);
845 WREG32(0x6578, 0x400);
846 WREG32(0x657C, 0x83188040);
847 WREG32(0x6578, 0x401);
848 WREG32(0x657C, 0x85008660);
849 WREG32(0x6578, 0x402);
850 WREG32(0x657C, 0xBFF88150);
851 WREG32(0x6578, 0x500);
852 WREG32(0x657C, 0x82D88030);
853 WREG32(0x6578, 0x501);
854 WREG32(0x657C, 0x85408640);
855 WREG32(0x6578, 0x502);
856 WREG32(0x657C, 0xBFF88180);
857 WREG32(0x6578, 0x600);
858 WREG32(0x657C, 0x82A08018);
859 WREG32(0x6578, 0x601);
860 WREG32(0x657C, 0x85808620);
861 WREG32(0x6578, 0x602);
862 WREG32(0x657C, 0xBFF081B8);
863 WREG32(0x6578, 0x700);
864 WREG32(0x657C, 0x82608010);
865 WREG32(0x6578, 0x701);
866 WREG32(0x657C, 0x85A08600);
867 WREG32(0x6578, 0x702);
868 WREG32(0x657C, 0x800081F0);
869 WREG32(0x6578, 0x800);
870 WREG32(0x657C, 0x8228BFF8);
871 WREG32(0x6578, 0x801);
872 WREG32(0x657C, 0x85E085E0);
873 WREG32(0x6578, 0x802);
874 WREG32(0x657C, 0xBFF88228);
875 WREG32(0x6578, 0x10000);
876 WREG32(0x657C, 0x82A8BF00);
877 WREG32(0x6578, 0x10001);
878 WREG32(0x657C, 0x82A08CC0);
879 WREG32(0x6578, 0x10002);
880 WREG32(0x657C, 0x8008BEF8);
881 WREG32(0x6578, 0x10100);
882 WREG32(0x657C, 0x81F0BF28);
883 WREG32(0x6578, 0x10101);
884 WREG32(0x657C, 0x83608CA0);
885 WREG32(0x6578, 0x10102);
886 WREG32(0x657C, 0x8018BED0);
887 WREG32(0x6578, 0x10200);
888 WREG32(0x657C, 0x8148BF38);
889 WREG32(0x6578, 0x10201);
890 WREG32(0x657C, 0x84408C80);
891 WREG32(0x6578, 0x10202);
892 WREG32(0x657C, 0x8008BEB8);
893 WREG32(0x6578, 0x10300);
894 WREG32(0x657C, 0x80B0BF78);
895 WREG32(0x6578, 0x10301);
896 WREG32(0x657C, 0x85008C20);
897 WREG32(0x6578, 0x10302);
898 WREG32(0x657C, 0x8020BEA0);
899 WREG32(0x6578, 0x10400);
900 WREG32(0x657C, 0x8028BF90);
901 WREG32(0x6578, 0x10401);
902 WREG32(0x657C, 0x85E08BC0);
903 WREG32(0x6578, 0x10402);
904 WREG32(0x657C, 0x8018BE90);
905 WREG32(0x6578, 0x10500);
906 WREG32(0x657C, 0xBFB8BFB0);
907 WREG32(0x6578, 0x10501);
908 WREG32(0x657C, 0x86C08B40);
909 WREG32(0x6578, 0x10502);
910 WREG32(0x657C, 0x8010BE90);
911 WREG32(0x6578, 0x10600);
912 WREG32(0x657C, 0xBF58BFC8);
913 WREG32(0x6578, 0x10601);
914 WREG32(0x657C, 0x87A08AA0);
915 WREG32(0x6578, 0x10602);
916 WREG32(0x657C, 0x8010BE98);
917 WREG32(0x6578, 0x10700);
918 WREG32(0x657C, 0xBF10BFF0);
919 WREG32(0x6578, 0x10701);
920 WREG32(0x657C, 0x886089E0);
921 WREG32(0x6578, 0x10702);
922 WREG32(0x657C, 0x8018BEB0);
923 WREG32(0x6578, 0x10800);
924 WREG32(0x657C, 0xBED8BFE8);
925 WREG32(0x6578, 0x10801);
926 WREG32(0x657C, 0x89408940);
927 WREG32(0x6578, 0x10802);
928 WREG32(0x657C, 0xBFE8BED8);
929 WREG32(0x6578, 0x20000);
930 WREG32(0x657C, 0x80008000);
931 WREG32(0x6578, 0x20001);
932 WREG32(0x657C, 0x90008000);
933 WREG32(0x6578, 0x20002);
934 WREG32(0x657C, 0x80008000);
935 WREG32(0x6578, 0x20003);
936 WREG32(0x657C, 0x80008000);
937 WREG32(0x6578, 0x20100);
938 WREG32(0x657C, 0x80108000);
939 WREG32(0x6578, 0x20101);
940 WREG32(0x657C, 0x8FE0BF70);
941 WREG32(0x6578, 0x20102);
942 WREG32(0x657C, 0xBFE880C0);
943 WREG32(0x6578, 0x20103);
944 WREG32(0x657C, 0x80008000);
945 WREG32(0x6578, 0x20200);
946 WREG32(0x657C, 0x8018BFF8);
947 WREG32(0x6578, 0x20201);
948 WREG32(0x657C, 0x8F80BF08);
949 WREG32(0x6578, 0x20202);
950 WREG32(0x657C, 0xBFD081A0);
951 WREG32(0x6578, 0x20203);
952 WREG32(0x657C, 0xBFF88000);
953 WREG32(0x6578, 0x20300);
954 WREG32(0x657C, 0x80188000);
955 WREG32(0x6578, 0x20301);
956 WREG32(0x657C, 0x8EE0BEC0);
957 WREG32(0x6578, 0x20302);
958 WREG32(0x657C, 0xBFB082A0);
959 WREG32(0x6578, 0x20303);
960 WREG32(0x657C, 0x80008000);
961 WREG32(0x6578, 0x20400);
962 WREG32(0x657C, 0x80188000);
963 WREG32(0x6578, 0x20401);
964 WREG32(0x657C, 0x8E00BEA0);
965 WREG32(0x6578, 0x20402);
966 WREG32(0x657C, 0xBF8883C0);
967 WREG32(0x6578, 0x20403);
968 WREG32(0x657C, 0x80008000);
969 WREG32(0x6578, 0x20500);
970 WREG32(0x657C, 0x80188000);
971 WREG32(0x6578, 0x20501);
972 WREG32(0x657C, 0x8D00BE90);
973 WREG32(0x6578, 0x20502);
974 WREG32(0x657C, 0xBF588500);
975 WREG32(0x6578, 0x20503);
976 WREG32(0x657C, 0x80008008);
977 WREG32(0x6578, 0x20600);
978 WREG32(0x657C, 0x80188000);
979 WREG32(0x6578, 0x20601);
980 WREG32(0x657C, 0x8BC0BE98);
981 WREG32(0x6578, 0x20602);
982 WREG32(0x657C, 0xBF308660);
983 WREG32(0x6578, 0x20603);
984 WREG32(0x657C, 0x80008008);
985 WREG32(0x6578, 0x20700);
986 WREG32(0x657C, 0x80108000);
987 WREG32(0x6578, 0x20701);
988 WREG32(0x657C, 0x8A80BEB0);
989 WREG32(0x6578, 0x20702);
990 WREG32(0x657C, 0xBF0087C0);
991 WREG32(0x6578, 0x20703);
992 WREG32(0x657C, 0x80008008);
993 WREG32(0x6578, 0x20800);
994 WREG32(0x657C, 0x80108000);
995 WREG32(0x6578, 0x20801);
996 WREG32(0x657C, 0x8920BED0);
997 WREG32(0x6578, 0x20802);
998 WREG32(0x657C, 0xBED08920);
999 WREG32(0x6578, 0x20803);
1000 WREG32(0x657C, 0x80008010);
1001 WREG32(0x6578, 0x30000);
1002 WREG32(0x657C, 0x90008000);
1003 WREG32(0x6578, 0x30001);
1004 WREG32(0x657C, 0x80008000);
1005 WREG32(0x6578, 0x30100);
1006 WREG32(0x657C, 0x8FE0BF90);
1007 WREG32(0x6578, 0x30101);
1008 WREG32(0x657C, 0xBFF880A0);
1009 WREG32(0x6578, 0x30200);
1010 WREG32(0x657C, 0x8F60BF40);
1011 WREG32(0x6578, 0x30201);
1012 WREG32(0x657C, 0xBFE88180);
1013 WREG32(0x6578, 0x30300);
1014 WREG32(0x657C, 0x8EC0BF00);
1015 WREG32(0x6578, 0x30301);
1016 WREG32(0x657C, 0xBFC88280);
1017 WREG32(0x6578, 0x30400);
1018 WREG32(0x657C, 0x8DE0BEE0);
1019 WREG32(0x6578, 0x30401);
1020 WREG32(0x657C, 0xBFA083A0);
1021 WREG32(0x6578, 0x30500);
1022 WREG32(0x657C, 0x8CE0BED0);
1023 WREG32(0x6578, 0x30501);
1024 WREG32(0x657C, 0xBF7884E0);
1025 WREG32(0x6578, 0x30600);
1026 WREG32(0x657C, 0x8BA0BED8);
1027 WREG32(0x6578, 0x30601);
1028 WREG32(0x657C, 0xBF508640);
1029 WREG32(0x6578, 0x30700);
1030 WREG32(0x657C, 0x8A60BEE8);
1031 WREG32(0x6578, 0x30701);
1032 WREG32(0x657C, 0xBF2087A0);
1033 WREG32(0x6578, 0x30800);
1034 WREG32(0x657C, 0x8900BF00);
1035 WREG32(0x6578, 0x30801);
1036 WREG32(0x657C, 0xBF008900);
1037}
1038
1039static void 808static void
1040atombios_yuv_setup(struct drm_encoder *encoder, bool enable) 809atombios_yuv_setup(struct drm_encoder *encoder, bool enable)
1041{ 810{
@@ -1074,129 +843,6 @@ atombios_yuv_setup(struct drm_encoder *encoder, bool enable)
1074} 843}
1075 844
1076static void 845static void
1077atombios_overscan_setup(struct drm_encoder *encoder,
1078 struct drm_display_mode *mode,
1079 struct drm_display_mode *adjusted_mode)
1080{
1081 struct drm_device *dev = encoder->dev;
1082 struct radeon_device *rdev = dev->dev_private;
1083 struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder);
1084 struct radeon_crtc *radeon_crtc = to_radeon_crtc(encoder->crtc);
1085 SET_CRTC_OVERSCAN_PS_ALLOCATION args;
1086 int index = GetIndexIntoMasterTable(COMMAND, SetCRTC_OverScan);
1087
1088 memset(&args, 0, sizeof(args));
1089
1090 args.usOverscanRight = 0;
1091 args.usOverscanLeft = 0;
1092 args.usOverscanBottom = 0;
1093 args.usOverscanTop = 0;
1094 args.ucCRTC = radeon_crtc->crtc_id;
1095
1096 if (radeon_encoder->flags & RADEON_USE_RMX) {
1097 if (radeon_encoder->rmx_type == RMX_FULL) {
1098 args.usOverscanRight = 0;
1099 args.usOverscanLeft = 0;
1100 args.usOverscanBottom = 0;
1101 args.usOverscanTop = 0;
1102 } else if (radeon_encoder->rmx_type == RMX_CENTER) {
1103 args.usOverscanTop = (adjusted_mode->crtc_vdisplay - mode->crtc_vdisplay) / 2;
1104 args.usOverscanBottom = (adjusted_mode->crtc_vdisplay - mode->crtc_vdisplay) / 2;
1105 args.usOverscanLeft = (adjusted_mode->crtc_hdisplay - mode->crtc_hdisplay) / 2;
1106 args.usOverscanRight = (adjusted_mode->crtc_hdisplay - mode->crtc_hdisplay) / 2;
1107 } else if (radeon_encoder->rmx_type == RMX_ASPECT) {
1108 int a1 = mode->crtc_vdisplay * adjusted_mode->crtc_hdisplay;
1109 int a2 = adjusted_mode->crtc_vdisplay * mode->crtc_hdisplay;
1110
1111 if (a1 > a2) {
1112 args.usOverscanLeft = (adjusted_mode->crtc_hdisplay - (a2 / mode->crtc_vdisplay)) / 2;
1113 args.usOverscanRight = (adjusted_mode->crtc_hdisplay - (a2 / mode->crtc_vdisplay)) / 2;
1114 } else if (a2 > a1) {
1115 args.usOverscanLeft = (adjusted_mode->crtc_vdisplay - (a1 / mode->crtc_hdisplay)) / 2;
1116 args.usOverscanRight = (adjusted_mode->crtc_vdisplay - (a1 / mode->crtc_hdisplay)) / 2;
1117 }
1118 }
1119 }
1120
1121 atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args);
1122
1123}
1124
1125static void
1126atombios_scaler_setup(struct drm_encoder *encoder)
1127{
1128 struct drm_device *dev = encoder->dev;
1129 struct radeon_device *rdev = dev->dev_private;
1130 struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder);
1131 struct radeon_crtc *radeon_crtc = to_radeon_crtc(encoder->crtc);
1132 ENABLE_SCALER_PS_ALLOCATION args;
1133 int index = GetIndexIntoMasterTable(COMMAND, EnableScaler);
1134 /* fixme - fill in enc_priv for atom dac */
1135 enum radeon_tv_std tv_std = TV_STD_NTSC;
1136
1137 if (!ASIC_IS_AVIVO(rdev) && radeon_crtc->crtc_id)
1138 return;
1139
1140 memset(&args, 0, sizeof(args));
1141
1142 args.ucScaler = radeon_crtc->crtc_id;
1143
1144 if (radeon_encoder->devices & (ATOM_DEVICE_TV_SUPPORT)) {
1145 switch (tv_std) {
1146 case TV_STD_NTSC:
1147 default:
1148 args.ucTVStandard = ATOM_TV_NTSC;
1149 break;
1150 case TV_STD_PAL:
1151 args.ucTVStandard = ATOM_TV_PAL;
1152 break;
1153 case TV_STD_PAL_M:
1154 args.ucTVStandard = ATOM_TV_PALM;
1155 break;
1156 case TV_STD_PAL_60:
1157 args.ucTVStandard = ATOM_TV_PAL60;
1158 break;
1159 case TV_STD_NTSC_J:
1160 args.ucTVStandard = ATOM_TV_NTSCJ;
1161 break;
1162 case TV_STD_SCART_PAL:
1163 args.ucTVStandard = ATOM_TV_PAL; /* ??? */
1164 break;
1165 case TV_STD_SECAM:
1166 args.ucTVStandard = ATOM_TV_SECAM;
1167 break;
1168 case TV_STD_PAL_CN:
1169 args.ucTVStandard = ATOM_TV_PALCN;
1170 break;
1171 }
1172 args.ucEnable = SCALER_ENABLE_MULTITAP_MODE;
1173 } else if (radeon_encoder->devices & (ATOM_DEVICE_CV_SUPPORT)) {
1174 args.ucTVStandard = ATOM_TV_CV;
1175 args.ucEnable = SCALER_ENABLE_MULTITAP_MODE;
1176 } else if (radeon_encoder->flags & RADEON_USE_RMX) {
1177 if (radeon_encoder->rmx_type == RMX_FULL)
1178 args.ucEnable = ATOM_SCALER_EXPANSION;
1179 else if (radeon_encoder->rmx_type == RMX_CENTER)
1180 args.ucEnable = ATOM_SCALER_CENTER;
1181 else if (radeon_encoder->rmx_type == RMX_ASPECT)
1182 args.ucEnable = ATOM_SCALER_EXPANSION;
1183 } else {
1184 if (ASIC_IS_AVIVO(rdev))
1185 args.ucEnable = ATOM_SCALER_DISABLE;
1186 else
1187 args.ucEnable = ATOM_SCALER_CENTER;
1188 }
1189
1190 atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args);
1191
1192 if (radeon_encoder->devices & (ATOM_DEVICE_CV_SUPPORT | ATOM_DEVICE_TV_SUPPORT)
1193 && rdev->family >= CHIP_RV515 && rdev->family <= CHIP_RV570) {
1194 atom_rv515_force_tv_scaler(rdev);
1195 }
1196
1197}
1198
1199static void
1200radeon_atom_encoder_dpms(struct drm_encoder *encoder, int mode) 846radeon_atom_encoder_dpms(struct drm_encoder *encoder, int mode)
1201{ 847{
1202 struct drm_device *dev = encoder->dev; 848 struct drm_device *dev = encoder->dev;
@@ -1448,8 +1094,6 @@ radeon_atom_encoder_mode_set(struct drm_encoder *encoder,
1448 radeon_encoder->pixel_clock = adjusted_mode->clock; 1094 radeon_encoder->pixel_clock = adjusted_mode->clock;
1449 1095
1450 radeon_atombios_encoder_crtc_scratch_regs(encoder, radeon_crtc->crtc_id); 1096 radeon_atombios_encoder_crtc_scratch_regs(encoder, radeon_crtc->crtc_id);
1451 atombios_overscan_setup(encoder, mode, adjusted_mode);
1452 atombios_scaler_setup(encoder);
1453 atombios_set_encoder_crtc_source(encoder); 1097 atombios_set_encoder_crtc_source(encoder);
1454 1098
1455 if (ASIC_IS_AVIVO(rdev)) { 1099 if (ASIC_IS_AVIVO(rdev)) {
@@ -1667,6 +1311,7 @@ radeon_add_atom_encoder(struct drm_device *dev, uint32_t encoder_id, uint32_t su
1667 1311
1668 radeon_encoder->encoder_id = encoder_id; 1312 radeon_encoder->encoder_id = encoder_id;
1669 radeon_encoder->devices = supported_device; 1313 radeon_encoder->devices = supported_device;
1314 radeon_encoder->rmx_type = RMX_OFF;
1670 1315
1671 switch (radeon_encoder->encoder_id) { 1316 switch (radeon_encoder->encoder_id) {
1672 case ENCODER_OBJECT_ID_INTERNAL_LVDS: 1317 case ENCODER_OBJECT_ID_INTERNAL_LVDS:
diff --git a/drivers/gpu/drm/radeon/radeon_fb.c b/drivers/gpu/drm/radeon/radeon_fb.c
index 9e8f191eb64a..3206c0ad7b6c 100644
--- a/drivers/gpu/drm/radeon/radeon_fb.c
+++ b/drivers/gpu/drm/radeon/radeon_fb.c
@@ -101,9 +101,10 @@ static int radeonfb_setcolreg(unsigned regno,
101 break; 101 break;
102 case 24: 102 case 24:
103 case 32: 103 case 32:
104 fb->pseudo_palette[regno] = ((red & 0xff00) << 8) | 104 fb->pseudo_palette[regno] =
105 (green & 0xff00) | 105 (((red >> 8) & 0xff) << info->var.red.offset) |
106 ((blue & 0xff00) >> 8); 106 (((green >> 8) & 0xff) << info->var.green.offset) |
107 (((blue >> 8) & 0xff) << info->var.blue.offset);
107 break; 108 break;
108 } 109 }
109 } 110 }
@@ -154,6 +155,7 @@ static int radeonfb_check_var(struct fb_var_screeninfo *var,
154 var->transp.length = 0; 155 var->transp.length = 0;
155 var->transp.offset = 0; 156 var->transp.offset = 0;
156 break; 157 break;
158#ifdef __LITTLE_ENDIAN
157 case 15: 159 case 15:
158 var->red.offset = 10; 160 var->red.offset = 10;
159 var->green.offset = 5; 161 var->green.offset = 5;
@@ -194,6 +196,28 @@ static int radeonfb_check_var(struct fb_var_screeninfo *var,
194 var->transp.length = 8; 196 var->transp.length = 8;
195 var->transp.offset = 24; 197 var->transp.offset = 24;
196 break; 198 break;
199#else
200 case 24:
201 var->red.offset = 8;
202 var->green.offset = 16;
203 var->blue.offset = 24;
204 var->red.length = 8;
205 var->green.length = 8;
206 var->blue.length = 8;
207 var->transp.length = 0;
208 var->transp.offset = 0;
209 break;
210 case 32:
211 var->red.offset = 8;
212 var->green.offset = 16;
213 var->blue.offset = 24;
214 var->red.length = 8;
215 var->green.length = 8;
216 var->blue.length = 8;
217 var->transp.length = 8;
218 var->transp.offset = 0;
219 break;
220#endif
197 default: 221 default:
198 return -EINVAL; 222 return -EINVAL;
199 } 223 }
@@ -447,10 +471,10 @@ static struct notifier_block paniced = {
447 .notifier_call = radeonfb_panic, 471 .notifier_call = radeonfb_panic,
448}; 472};
449 473
450static int radeon_align_pitch(struct radeon_device *rdev, int width, int bpp) 474static int radeon_align_pitch(struct radeon_device *rdev, int width, int bpp, bool tiled)
451{ 475{
452 int aligned = width; 476 int aligned = width;
453 int align_large = (ASIC_IS_AVIVO(rdev)); 477 int align_large = (ASIC_IS_AVIVO(rdev)) || tiled;
454 int pitch_mask = 0; 478 int pitch_mask = 0;
455 479
456 switch (bpp / 8) { 480 switch (bpp / 8) {
@@ -488,12 +512,13 @@ int radeonfb_create(struct radeon_device *rdev,
488 u64 fb_gpuaddr; 512 u64 fb_gpuaddr;
489 void *fbptr = NULL; 513 void *fbptr = NULL;
490 unsigned long tmp; 514 unsigned long tmp;
515 bool fb_tiled = false; /* useful for testing */
491 516
492 mode_cmd.width = surface_width; 517 mode_cmd.width = surface_width;
493 mode_cmd.height = surface_height; 518 mode_cmd.height = surface_height;
494 mode_cmd.bpp = 32; 519 mode_cmd.bpp = 32;
495 /* need to align pitch with crtc limits */ 520 /* need to align pitch with crtc limits */
496 mode_cmd.pitch = radeon_align_pitch(rdev, mode_cmd.width, mode_cmd.bpp) * ((mode_cmd.bpp + 1) / 8); 521 mode_cmd.pitch = radeon_align_pitch(rdev, mode_cmd.width, mode_cmd.bpp, fb_tiled) * ((mode_cmd.bpp + 1) / 8);
497 mode_cmd.depth = 24; 522 mode_cmd.depth = 24;
498 523
499 size = mode_cmd.pitch * mode_cmd.height; 524 size = mode_cmd.pitch * mode_cmd.height;
@@ -511,6 +536,8 @@ int radeonfb_create(struct radeon_device *rdev,
511 } 536 }
512 robj = gobj->driver_private; 537 robj = gobj->driver_private;
513 538
539 if (fb_tiled)
540 radeon_object_set_tiling_flags(robj, RADEON_TILING_MACRO|RADEON_TILING_SURFACE, mode_cmd.pitch);
514 mutex_lock(&rdev->ddev->struct_mutex); 541 mutex_lock(&rdev->ddev->struct_mutex);
515 fb = radeon_framebuffer_create(rdev->ddev, &mode_cmd, gobj); 542 fb = radeon_framebuffer_create(rdev->ddev, &mode_cmd, gobj);
516 if (fb == NULL) { 543 if (fb == NULL) {
@@ -539,6 +566,9 @@ int radeonfb_create(struct radeon_device *rdev,
539 } 566 }
540 rfbdev = info->par; 567 rfbdev = info->par;
541 568
569 if (fb_tiled)
570 radeon_object_check_tiling(robj, 0, 0);
571
542 ret = radeon_object_kmap(robj, &fbptr); 572 ret = radeon_object_kmap(robj, &fbptr);
543 if (ret) { 573 if (ret) {
544 goto out_unref; 574 goto out_unref;
@@ -572,6 +602,11 @@ int radeonfb_create(struct radeon_device *rdev,
572 info->var.width = -1; 602 info->var.width = -1;
573 info->var.xres = fb_width; 603 info->var.xres = fb_width;
574 info->var.yres = fb_height; 604 info->var.yres = fb_height;
605
606 /* setup aperture base/size for vesafb takeover */
607 info->aperture_base = rdev->ddev->mode_config.fb_base;
608 info->aperture_size = rdev->mc.real_vram_size;
609
575 info->fix.mmio_start = 0; 610 info->fix.mmio_start = 0;
576 info->fix.mmio_len = 0; 611 info->fix.mmio_len = 0;
577 info->pixmap.size = 64*1024; 612 info->pixmap.size = 64*1024;
@@ -600,6 +635,7 @@ int radeonfb_create(struct radeon_device *rdev,
600 info->var.transp.offset = 0; 635 info->var.transp.offset = 0;
601 info->var.transp.length = 0; 636 info->var.transp.length = 0;
602 break; 637 break;
638#ifdef __LITTLE_ENDIAN
603 case 15: 639 case 15:
604 info->var.red.offset = 10; 640 info->var.red.offset = 10;
605 info->var.green.offset = 5; 641 info->var.green.offset = 5;
@@ -639,7 +675,29 @@ int radeonfb_create(struct radeon_device *rdev,
639 info->var.transp.offset = 24; 675 info->var.transp.offset = 24;
640 info->var.transp.length = 8; 676 info->var.transp.length = 8;
641 break; 677 break;
678#else
679 case 24:
680 info->var.red.offset = 8;
681 info->var.green.offset = 16;
682 info->var.blue.offset = 24;
683 info->var.red.length = 8;
684 info->var.green.length = 8;
685 info->var.blue.length = 8;
686 info->var.transp.offset = 0;
687 info->var.transp.length = 0;
688 break;
689 case 32:
690 info->var.red.offset = 8;
691 info->var.green.offset = 16;
692 info->var.blue.offset = 24;
693 info->var.red.length = 8;
694 info->var.green.length = 8;
695 info->var.blue.length = 8;
696 info->var.transp.offset = 0;
697 info->var.transp.length = 8;
698 break;
642 default: 699 default:
700#endif
643 break; 701 break;
644 } 702 }
645 703
diff --git a/drivers/gpu/drm/radeon/radeon_fence.c b/drivers/gpu/drm/radeon/radeon_fence.c
index 96afbf5ae2ad..b4e48dd2e859 100644
--- a/drivers/gpu/drm/radeon/radeon_fence.c
+++ b/drivers/gpu/drm/radeon/radeon_fence.c
@@ -195,7 +195,7 @@ retry:
195 r = wait_event_interruptible_timeout(rdev->fence_drv.queue, 195 r = wait_event_interruptible_timeout(rdev->fence_drv.queue,
196 radeon_fence_signaled(fence), timeout); 196 radeon_fence_signaled(fence), timeout);
197 if (unlikely(r == -ERESTARTSYS)) { 197 if (unlikely(r == -ERESTARTSYS)) {
198 return -ERESTART; 198 return -EBUSY;
199 } 199 }
200 } else { 200 } else {
201 r = wait_event_timeout(rdev->fence_drv.queue, 201 r = wait_event_timeout(rdev->fence_drv.queue,
diff --git a/drivers/gpu/drm/radeon/radeon_gart.c b/drivers/gpu/drm/radeon/radeon_gart.c
index d343a15316ec..2977539880fb 100644
--- a/drivers/gpu/drm/radeon/radeon_gart.c
+++ b/drivers/gpu/drm/radeon/radeon_gart.c
@@ -177,7 +177,7 @@ int radeon_gart_bind(struct radeon_device *rdev, unsigned offset,
177 return -ENOMEM; 177 return -ENOMEM;
178 } 178 }
179 rdev->gart.pages[p] = pagelist[i]; 179 rdev->gart.pages[p] = pagelist[i];
180 page_base = (uint32_t)rdev->gart.pages_addr[p]; 180 page_base = rdev->gart.pages_addr[p];
181 for (j = 0; j < (PAGE_SIZE / 4096); j++, t++) { 181 for (j = 0; j < (PAGE_SIZE / 4096); j++, t++) {
182 radeon_gart_set_page(rdev, t, page_base); 182 radeon_gart_set_page(rdev, t, page_base);
183 page_base += 4096; 183 page_base += 4096;
diff --git a/drivers/gpu/drm/radeon/radeon_gem.c b/drivers/gpu/drm/radeon/radeon_gem.c
index eb516034235d..cded5180c752 100644
--- a/drivers/gpu/drm/radeon/radeon_gem.c
+++ b/drivers/gpu/drm/radeon/radeon_gem.c
@@ -157,9 +157,9 @@ int radeon_gem_info_ioctl(struct drm_device *dev, void *data,
157 struct radeon_device *rdev = dev->dev_private; 157 struct radeon_device *rdev = dev->dev_private;
158 struct drm_radeon_gem_info *args = data; 158 struct drm_radeon_gem_info *args = data;
159 159
160 args->vram_size = rdev->mc.vram_size; 160 args->vram_size = rdev->mc.real_vram_size;
161 /* FIXME: report somethings that makes sense */ 161 /* FIXME: report somethings that makes sense */
162 args->vram_visible = rdev->mc.vram_size - (4 * 1024 * 1024); 162 args->vram_visible = rdev->mc.real_vram_size - (4 * 1024 * 1024);
163 args->gart_size = rdev->mc.gtt_size; 163 args->gart_size = rdev->mc.gtt_size;
164 return 0; 164 return 0;
165} 165}
@@ -285,3 +285,44 @@ int radeon_gem_wait_idle_ioctl(struct drm_device *dev, void *data,
285 mutex_unlock(&dev->struct_mutex); 285 mutex_unlock(&dev->struct_mutex);
286 return r; 286 return r;
287} 287}
288
289int radeon_gem_set_tiling_ioctl(struct drm_device *dev, void *data,
290 struct drm_file *filp)
291{
292 struct drm_radeon_gem_set_tiling *args = data;
293 struct drm_gem_object *gobj;
294 struct radeon_object *robj;
295 int r = 0;
296
297 DRM_DEBUG("%d \n", args->handle);
298 gobj = drm_gem_object_lookup(dev, filp, args->handle);
299 if (gobj == NULL)
300 return -EINVAL;
301 robj = gobj->driver_private;
302 radeon_object_set_tiling_flags(robj, args->tiling_flags, args->pitch);
303 mutex_lock(&dev->struct_mutex);
304 drm_gem_object_unreference(gobj);
305 mutex_unlock(&dev->struct_mutex);
306 return r;
307}
308
309int radeon_gem_get_tiling_ioctl(struct drm_device *dev, void *data,
310 struct drm_file *filp)
311{
312 struct drm_radeon_gem_get_tiling *args = data;
313 struct drm_gem_object *gobj;
314 struct radeon_object *robj;
315 int r = 0;
316
317 DRM_DEBUG("\n");
318 gobj = drm_gem_object_lookup(dev, filp, args->handle);
319 if (gobj == NULL)
320 return -EINVAL;
321 robj = gobj->driver_private;
322 radeon_object_get_tiling_flags(robj, &args->tiling_flags,
323 &args->pitch);
324 mutex_lock(&dev->struct_mutex);
325 drm_gem_object_unreference(gobj);
326 mutex_unlock(&dev->struct_mutex);
327 return r;
328}
diff --git a/drivers/gpu/drm/radeon/radeon_kms.c b/drivers/gpu/drm/radeon/radeon_kms.c
index 4612a7c146d1..937a2f1cdb46 100644
--- a/drivers/gpu/drm/radeon/radeon_kms.c
+++ b/drivers/gpu/drm/radeon/radeon_kms.c
@@ -291,5 +291,7 @@ struct drm_ioctl_desc radeon_ioctls_kms[] = {
291 DRM_IOCTL_DEF(DRM_RADEON_GEM_WAIT_IDLE, radeon_gem_wait_idle_ioctl, DRM_AUTH), 291 DRM_IOCTL_DEF(DRM_RADEON_GEM_WAIT_IDLE, radeon_gem_wait_idle_ioctl, DRM_AUTH),
292 DRM_IOCTL_DEF(DRM_RADEON_CS, radeon_cs_ioctl, DRM_AUTH), 292 DRM_IOCTL_DEF(DRM_RADEON_CS, radeon_cs_ioctl, DRM_AUTH),
293 DRM_IOCTL_DEF(DRM_RADEON_INFO, radeon_info_ioctl, DRM_AUTH), 293 DRM_IOCTL_DEF(DRM_RADEON_INFO, radeon_info_ioctl, DRM_AUTH),
294 DRM_IOCTL_DEF(DRM_RADEON_GEM_SET_TILING, radeon_gem_set_tiling_ioctl, DRM_AUTH),
295 DRM_IOCTL_DEF(DRM_RADEON_GEM_GET_TILING, radeon_gem_get_tiling_ioctl, DRM_AUTH),
294}; 296};
295int radeon_max_kms_ioctl = DRM_ARRAY_SIZE(radeon_ioctls_kms); 297int radeon_max_kms_ioctl = DRM_ARRAY_SIZE(radeon_ioctls_kms);
diff --git a/drivers/gpu/drm/radeon/radeon_legacy_crtc.c b/drivers/gpu/drm/radeon/radeon_legacy_crtc.c
index 8086ecf7f03d..7d06dc98a42a 100644
--- a/drivers/gpu/drm/radeon/radeon_legacy_crtc.c
+++ b/drivers/gpu/drm/radeon/radeon_legacy_crtc.c
@@ -29,6 +29,171 @@
29#include "radeon_fixed.h" 29#include "radeon_fixed.h"
30#include "radeon.h" 30#include "radeon.h"
31 31
32static void radeon_legacy_rmx_mode_set(struct drm_crtc *crtc,
33 struct drm_display_mode *mode,
34 struct drm_display_mode *adjusted_mode)
35{
36 struct drm_device *dev = crtc->dev;
37 struct radeon_device *rdev = dev->dev_private;
38 struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc);
39 int xres = mode->hdisplay;
40 int yres = mode->vdisplay;
41 bool hscale = true, vscale = true;
42 int hsync_wid;
43 int vsync_wid;
44 int hsync_start;
45 int blank_width;
46 u32 scale, inc, crtc_more_cntl;
47 u32 fp_horz_stretch, fp_vert_stretch, fp_horz_vert_active;
48 u32 fp_h_sync_strt_wid, fp_crtc_h_total_disp;
49 u32 fp_v_sync_strt_wid, fp_crtc_v_total_disp;
50 struct radeon_native_mode *native_mode = &radeon_crtc->native_mode;
51
52 fp_vert_stretch = RREG32(RADEON_FP_VERT_STRETCH) &
53 (RADEON_VERT_STRETCH_RESERVED |
54 RADEON_VERT_AUTO_RATIO_INC);
55 fp_horz_stretch = RREG32(RADEON_FP_HORZ_STRETCH) &
56 (RADEON_HORZ_FP_LOOP_STRETCH |
57 RADEON_HORZ_AUTO_RATIO_INC);
58
59 crtc_more_cntl = 0;
60 if ((rdev->family == CHIP_RS100) ||
61 (rdev->family == CHIP_RS200)) {
62 /* This is to workaround the asic bug for RMX, some versions
63 of BIOS dosen't have this register initialized correctly. */
64 crtc_more_cntl |= RADEON_CRTC_H_CUTOFF_ACTIVE_EN;
65 }
66
67
68 fp_crtc_h_total_disp = ((((mode->crtc_htotal / 8) - 1) & 0x3ff)
69 | ((((mode->crtc_hdisplay / 8) - 1) & 0x1ff) << 16));
70
71 hsync_wid = (mode->crtc_hsync_end - mode->crtc_hsync_start) / 8;
72 if (!hsync_wid)
73 hsync_wid = 1;
74 hsync_start = mode->crtc_hsync_start - 8;
75
76 fp_h_sync_strt_wid = ((hsync_start & 0x1fff)
77 | ((hsync_wid & 0x3f) << 16)
78 | ((mode->flags & DRM_MODE_FLAG_NHSYNC)
79 ? RADEON_CRTC_H_SYNC_POL
80 : 0));
81
82 fp_crtc_v_total_disp = (((mode->crtc_vtotal - 1) & 0xffff)
83 | ((mode->crtc_vdisplay - 1) << 16));
84
85 vsync_wid = mode->crtc_vsync_end - mode->crtc_vsync_start;
86 if (!vsync_wid)
87 vsync_wid = 1;
88
89 fp_v_sync_strt_wid = (((mode->crtc_vsync_start - 1) & 0xfff)
90 | ((vsync_wid & 0x1f) << 16)
91 | ((mode->flags & DRM_MODE_FLAG_NVSYNC)
92 ? RADEON_CRTC_V_SYNC_POL
93 : 0));
94
95 fp_horz_vert_active = 0;
96
97 if (native_mode->panel_xres == 0 ||
98 native_mode->panel_yres == 0) {
99 hscale = false;
100 vscale = false;
101 } else {
102 if (xres > native_mode->panel_xres)
103 xres = native_mode->panel_xres;
104 if (yres > native_mode->panel_yres)
105 yres = native_mode->panel_yres;
106
107 if (xres == native_mode->panel_xres)
108 hscale = false;
109 if (yres == native_mode->panel_yres)
110 vscale = false;
111 }
112
113 switch (radeon_crtc->rmx_type) {
114 case RMX_FULL:
115 case RMX_ASPECT:
116 if (!hscale)
117 fp_horz_stretch |= ((xres/8-1) << 16);
118 else {
119 inc = (fp_horz_stretch & RADEON_HORZ_AUTO_RATIO_INC) ? 1 : 0;
120 scale = ((xres + inc) * RADEON_HORZ_STRETCH_RATIO_MAX)
121 / native_mode->panel_xres + 1;
122 fp_horz_stretch |= (((scale) & RADEON_HORZ_STRETCH_RATIO_MASK) |
123 RADEON_HORZ_STRETCH_BLEND |
124 RADEON_HORZ_STRETCH_ENABLE |
125 ((native_mode->panel_xres/8-1) << 16));
126 }
127
128 if (!vscale)
129 fp_vert_stretch |= ((yres-1) << 12);
130 else {
131 inc = (fp_vert_stretch & RADEON_VERT_AUTO_RATIO_INC) ? 1 : 0;
132 scale = ((yres + inc) * RADEON_VERT_STRETCH_RATIO_MAX)
133 / native_mode->panel_yres + 1;
134 fp_vert_stretch |= (((scale) & RADEON_VERT_STRETCH_RATIO_MASK) |
135 RADEON_VERT_STRETCH_ENABLE |
136 RADEON_VERT_STRETCH_BLEND |
137 ((native_mode->panel_yres-1) << 12));
138 }
139 break;
140 case RMX_CENTER:
141 fp_horz_stretch |= ((xres/8-1) << 16);
142 fp_vert_stretch |= ((yres-1) << 12);
143
144 crtc_more_cntl |= (RADEON_CRTC_AUTO_HORZ_CENTER_EN |
145 RADEON_CRTC_AUTO_VERT_CENTER_EN);
146
147 blank_width = (mode->crtc_hblank_end - mode->crtc_hblank_start) / 8;
148 if (blank_width > 110)
149 blank_width = 110;
150
151 fp_crtc_h_total_disp = (((blank_width) & 0x3ff)
152 | ((((mode->crtc_hdisplay / 8) - 1) & 0x1ff) << 16));
153
154 hsync_wid = (mode->crtc_hsync_end - mode->crtc_hsync_start) / 8;
155 if (!hsync_wid)
156 hsync_wid = 1;
157
158 fp_h_sync_strt_wid = ((((mode->crtc_hsync_start - mode->crtc_hblank_start) / 8) & 0x1fff)
159 | ((hsync_wid & 0x3f) << 16)
160 | ((mode->flags & DRM_MODE_FLAG_NHSYNC)
161 ? RADEON_CRTC_H_SYNC_POL
162 : 0));
163
164 fp_crtc_v_total_disp = (((mode->crtc_vblank_end - mode->crtc_vblank_start) & 0xffff)
165 | ((mode->crtc_vdisplay - 1) << 16));
166
167 vsync_wid = mode->crtc_vsync_end - mode->crtc_vsync_start;
168 if (!vsync_wid)
169 vsync_wid = 1;
170
171 fp_v_sync_strt_wid = ((((mode->crtc_vsync_start - mode->crtc_vblank_start) & 0xfff)
172 | ((vsync_wid & 0x1f) << 16)
173 | ((mode->flags & DRM_MODE_FLAG_NVSYNC)
174 ? RADEON_CRTC_V_SYNC_POL
175 : 0)));
176
177 fp_horz_vert_active = (((native_mode->panel_yres) & 0xfff) |
178 (((native_mode->panel_xres / 8) & 0x1ff) << 16));
179 break;
180 case RMX_OFF:
181 default:
182 fp_horz_stretch |= ((xres/8-1) << 16);
183 fp_vert_stretch |= ((yres-1) << 12);
184 break;
185 }
186
187 WREG32(RADEON_FP_HORZ_STRETCH, fp_horz_stretch);
188 WREG32(RADEON_FP_VERT_STRETCH, fp_vert_stretch);
189 WREG32(RADEON_CRTC_MORE_CNTL, crtc_more_cntl);
190 WREG32(RADEON_FP_HORZ_VERT_ACTIVE, fp_horz_vert_active);
191 WREG32(RADEON_FP_H_SYNC_STRT_WID, fp_h_sync_strt_wid);
192 WREG32(RADEON_FP_V_SYNC_STRT_WID, fp_v_sync_strt_wid);
193 WREG32(RADEON_FP_CRTC_H_TOTAL_DISP, fp_crtc_h_total_disp);
194 WREG32(RADEON_FP_CRTC_V_TOTAL_DISP, fp_crtc_v_total_disp);
195}
196
32void radeon_restore_common_regs(struct drm_device *dev) 197void radeon_restore_common_regs(struct drm_device *dev)
33{ 198{
34 /* don't need this yet */ 199 /* don't need this yet */
@@ -235,6 +400,7 @@ int radeon_crtc_set_base(struct drm_crtc *crtc, int x, int y,
235 uint64_t base; 400 uint64_t base;
236 uint32_t crtc_offset, crtc_offset_cntl, crtc_tile_x0_y0 = 0; 401 uint32_t crtc_offset, crtc_offset_cntl, crtc_tile_x0_y0 = 0;
237 uint32_t crtc_pitch, pitch_pixels; 402 uint32_t crtc_pitch, pitch_pixels;
403 uint32_t tiling_flags;
238 404
239 DRM_DEBUG("\n"); 405 DRM_DEBUG("\n");
240 406
@@ -244,7 +410,12 @@ int radeon_crtc_set_base(struct drm_crtc *crtc, int x, int y,
244 if (radeon_gem_object_pin(obj, RADEON_GEM_DOMAIN_VRAM, &base)) { 410 if (radeon_gem_object_pin(obj, RADEON_GEM_DOMAIN_VRAM, &base)) {
245 return -EINVAL; 411 return -EINVAL;
246 } 412 }
247 crtc_offset = (u32)base; 413 /* if scanout was in GTT this really wouldn't work */
414 /* crtc offset is from display base addr not FB location */
415 radeon_crtc->legacy_display_base_addr = rdev->mc.vram_location;
416
417 base -= radeon_crtc->legacy_display_base_addr;
418
248 crtc_offset_cntl = 0; 419 crtc_offset_cntl = 0;
249 420
250 pitch_pixels = crtc->fb->pitch / (crtc->fb->bits_per_pixel / 8); 421 pitch_pixels = crtc->fb->pitch / (crtc->fb->bits_per_pixel / 8);
@@ -253,8 +424,12 @@ int radeon_crtc_set_base(struct drm_crtc *crtc, int x, int y,
253 (crtc->fb->bits_per_pixel * 8)); 424 (crtc->fb->bits_per_pixel * 8));
254 crtc_pitch |= crtc_pitch << 16; 425 crtc_pitch |= crtc_pitch << 16;
255 426
256 /* TODO tiling */ 427 radeon_object_get_tiling_flags(obj->driver_private,
257 if (0) { 428 &tiling_flags, NULL);
429 if (tiling_flags & RADEON_TILING_MICRO)
430 DRM_ERROR("trying to scanout microtiled buffer\n");
431
432 if (tiling_flags & RADEON_TILING_MACRO) {
258 if (ASIC_IS_R300(rdev)) 433 if (ASIC_IS_R300(rdev))
259 crtc_offset_cntl |= (R300_CRTC_X_Y_MODE_EN | 434 crtc_offset_cntl |= (R300_CRTC_X_Y_MODE_EN |
260 R300_CRTC_MICRO_TILE_BUFFER_DIS | 435 R300_CRTC_MICRO_TILE_BUFFER_DIS |
@@ -270,15 +445,13 @@ int radeon_crtc_set_base(struct drm_crtc *crtc, int x, int y,
270 crtc_offset_cntl &= ~RADEON_CRTC_TILE_EN; 445 crtc_offset_cntl &= ~RADEON_CRTC_TILE_EN;
271 } 446 }
272 447
273 448 if (tiling_flags & RADEON_TILING_MACRO) {
274 /* TODO more tiling */
275 if (0) {
276 if (ASIC_IS_R300(rdev)) { 449 if (ASIC_IS_R300(rdev)) {
277 crtc_tile_x0_y0 = x | (y << 16); 450 crtc_tile_x0_y0 = x | (y << 16);
278 base &= ~0x7ff; 451 base &= ~0x7ff;
279 } else { 452 } else {
280 int byteshift = crtc->fb->bits_per_pixel >> 4; 453 int byteshift = crtc->fb->bits_per_pixel >> 4;
281 int tile_addr = (((y >> 3) * crtc->fb->width + x) >> (8 - byteshift)) << 11; 454 int tile_addr = (((y >> 3) * pitch_pixels + x) >> (8 - byteshift)) << 11;
282 base += tile_addr + ((x << byteshift) % 256) + ((y % 8) << 8); 455 base += tile_addr + ((x << byteshift) % 256) + ((y % 8) << 8);
283 crtc_offset_cntl |= (y % 16); 456 crtc_offset_cntl |= (y % 16);
284 } 457 }
@@ -303,11 +476,9 @@ int radeon_crtc_set_base(struct drm_crtc *crtc, int x, int y,
303 476
304 base &= ~7; 477 base &= ~7;
305 478
306 /* update sarea TODO */
307
308 crtc_offset = (u32)base; 479 crtc_offset = (u32)base;
309 480
310 WREG32(RADEON_DISPLAY_BASE_ADDR + radeon_crtc->crtc_offset, rdev->mc.vram_location); 481 WREG32(RADEON_DISPLAY_BASE_ADDR + radeon_crtc->crtc_offset, radeon_crtc->legacy_display_base_addr);
311 482
312 if (ASIC_IS_R300(rdev)) { 483 if (ASIC_IS_R300(rdev)) {
313 if (radeon_crtc->crtc_id) 484 if (radeon_crtc->crtc_id)
@@ -751,6 +922,8 @@ static bool radeon_crtc_mode_fixup(struct drm_crtc *crtc,
751 struct drm_display_mode *mode, 922 struct drm_display_mode *mode,
752 struct drm_display_mode *adjusted_mode) 923 struct drm_display_mode *adjusted_mode)
753{ 924{
925 if (!radeon_crtc_scaling_mode_fixup(crtc, mode, adjusted_mode))
926 return false;
754 return true; 927 return true;
755} 928}
756 929
@@ -759,16 +932,25 @@ static int radeon_crtc_mode_set(struct drm_crtc *crtc,
759 struct drm_display_mode *adjusted_mode, 932 struct drm_display_mode *adjusted_mode,
760 int x, int y, struct drm_framebuffer *old_fb) 933 int x, int y, struct drm_framebuffer *old_fb)
761{ 934{
762 935 struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc);
763 DRM_DEBUG("\n"); 936 struct drm_device *dev = crtc->dev;
937 struct radeon_device *rdev = dev->dev_private;
764 938
765 /* TODO TV */ 939 /* TODO TV */
766
767 radeon_crtc_set_base(crtc, x, y, old_fb); 940 radeon_crtc_set_base(crtc, x, y, old_fb);
768 radeon_set_crtc_timing(crtc, adjusted_mode); 941 radeon_set_crtc_timing(crtc, adjusted_mode);
769 radeon_set_pll(crtc, adjusted_mode); 942 radeon_set_pll(crtc, adjusted_mode);
770 radeon_init_disp_bandwidth(crtc->dev); 943 radeon_bandwidth_update(rdev);
771 944 if (radeon_crtc->crtc_id == 0) {
945 radeon_legacy_rmx_mode_set(crtc, mode, adjusted_mode);
946 } else {
947 if (radeon_crtc->rmx_type != RMX_OFF) {
948 /* FIXME: only first crtc has rmx what should we
949 * do ?
950 */
951 DRM_ERROR("Mode need scaling but only first crtc can do that.\n");
952 }
953 }
772 return 0; 954 return 0;
773} 955}
774 956
@@ -799,478 +981,3 @@ void radeon_legacy_init_crtc(struct drm_device *dev,
799 radeon_crtc->crtc_offset = RADEON_CRTC2_H_TOTAL_DISP - RADEON_CRTC_H_TOTAL_DISP; 981 radeon_crtc->crtc_offset = RADEON_CRTC2_H_TOTAL_DISP - RADEON_CRTC_H_TOTAL_DISP;
800 drm_crtc_helper_add(&radeon_crtc->base, &legacy_helper_funcs); 982 drm_crtc_helper_add(&radeon_crtc->base, &legacy_helper_funcs);
801} 983}
802
803void radeon_init_disp_bw_legacy(struct drm_device *dev,
804 struct drm_display_mode *mode1,
805 uint32_t pixel_bytes1,
806 struct drm_display_mode *mode2,
807 uint32_t pixel_bytes2)
808{
809 struct radeon_device *rdev = dev->dev_private;
810 fixed20_12 trcd_ff, trp_ff, tras_ff, trbs_ff, tcas_ff;
811 fixed20_12 sclk_ff, mclk_ff, sclk_eff_ff, sclk_delay_ff;
812 fixed20_12 peak_disp_bw, mem_bw, pix_clk, pix_clk2, temp_ff, crit_point_ff;
813 uint32_t temp, data, mem_trcd, mem_trp, mem_tras;
814 fixed20_12 memtcas_ff[8] = {
815 fixed_init(1),
816 fixed_init(2),
817 fixed_init(3),
818 fixed_init(0),
819 fixed_init_half(1),
820 fixed_init_half(2),
821 fixed_init(0),
822 };
823 fixed20_12 memtcas_rs480_ff[8] = {
824 fixed_init(0),
825 fixed_init(1),
826 fixed_init(2),
827 fixed_init(3),
828 fixed_init(0),
829 fixed_init_half(1),
830 fixed_init_half(2),
831 fixed_init_half(3),
832 };
833 fixed20_12 memtcas2_ff[8] = {
834 fixed_init(0),
835 fixed_init(1),
836 fixed_init(2),
837 fixed_init(3),
838 fixed_init(4),
839 fixed_init(5),
840 fixed_init(6),
841 fixed_init(7),
842 };
843 fixed20_12 memtrbs[8] = {
844 fixed_init(1),
845 fixed_init_half(1),
846 fixed_init(2),
847 fixed_init_half(2),
848 fixed_init(3),
849 fixed_init_half(3),
850 fixed_init(4),
851 fixed_init_half(4)
852 };
853 fixed20_12 memtrbs_r4xx[8] = {
854 fixed_init(4),
855 fixed_init(5),
856 fixed_init(6),
857 fixed_init(7),
858 fixed_init(8),
859 fixed_init(9),
860 fixed_init(10),
861 fixed_init(11)
862 };
863 fixed20_12 min_mem_eff;
864 fixed20_12 mc_latency_sclk, mc_latency_mclk, k1;
865 fixed20_12 cur_latency_mclk, cur_latency_sclk;
866 fixed20_12 disp_latency, disp_latency_overhead, disp_drain_rate,
867 disp_drain_rate2, read_return_rate;
868 fixed20_12 time_disp1_drop_priority;
869 int c;
870 int cur_size = 16; /* in octawords */
871 int critical_point = 0, critical_point2;
872/* uint32_t read_return_rate, time_disp1_drop_priority; */
873 int stop_req, max_stop_req;
874
875 min_mem_eff.full = rfixed_const_8(0);
876 /* get modes */
877 if ((rdev->disp_priority == 2) && ASIC_IS_R300(rdev)) {
878 uint32_t mc_init_misc_lat_timer = RREG32(R300_MC_INIT_MISC_LAT_TIMER);
879 mc_init_misc_lat_timer &= ~(R300_MC_DISP1R_INIT_LAT_MASK << R300_MC_DISP1R_INIT_LAT_SHIFT);
880 mc_init_misc_lat_timer &= ~(R300_MC_DISP0R_INIT_LAT_MASK << R300_MC_DISP0R_INIT_LAT_SHIFT);
881 /* check crtc enables */
882 if (mode2)
883 mc_init_misc_lat_timer |= (1 << R300_MC_DISP1R_INIT_LAT_SHIFT);
884 if (mode1)
885 mc_init_misc_lat_timer |= (1 << R300_MC_DISP0R_INIT_LAT_SHIFT);
886 WREG32(R300_MC_INIT_MISC_LAT_TIMER, mc_init_misc_lat_timer);
887 }
888
889 /*
890 * determine is there is enough bw for current mode
891 */
892 mclk_ff.full = rfixed_const(rdev->clock.default_mclk);
893 temp_ff.full = rfixed_const(100);
894 mclk_ff.full = rfixed_div(mclk_ff, temp_ff);
895 sclk_ff.full = rfixed_const(rdev->clock.default_sclk);
896 sclk_ff.full = rfixed_div(sclk_ff, temp_ff);
897
898 temp = (rdev->mc.vram_width / 8) * (rdev->mc.vram_is_ddr ? 2 : 1);
899 temp_ff.full = rfixed_const(temp);
900 mem_bw.full = rfixed_mul(mclk_ff, temp_ff);
901
902 pix_clk.full = 0;
903 pix_clk2.full = 0;
904 peak_disp_bw.full = 0;
905 if (mode1) {
906 temp_ff.full = rfixed_const(1000);
907 pix_clk.full = rfixed_const(mode1->clock); /* convert to fixed point */
908 pix_clk.full = rfixed_div(pix_clk, temp_ff);
909 temp_ff.full = rfixed_const(pixel_bytes1);
910 peak_disp_bw.full += rfixed_mul(pix_clk, temp_ff);
911 }
912 if (mode2) {
913 temp_ff.full = rfixed_const(1000);
914 pix_clk2.full = rfixed_const(mode2->clock); /* convert to fixed point */
915 pix_clk2.full = rfixed_div(pix_clk2, temp_ff);
916 temp_ff.full = rfixed_const(pixel_bytes2);
917 peak_disp_bw.full += rfixed_mul(pix_clk2, temp_ff);
918 }
919
920 mem_bw.full = rfixed_mul(mem_bw, min_mem_eff);
921 if (peak_disp_bw.full >= mem_bw.full) {
922 DRM_ERROR("You may not have enough display bandwidth for current mode\n"
923 "If you have flickering problem, try to lower resolution, refresh rate, or color depth\n");
924 }
925
926 /* Get values from the EXT_MEM_CNTL register...converting its contents. */
927 temp = RREG32(RADEON_MEM_TIMING_CNTL);
928 if ((rdev->family == CHIP_RV100) || (rdev->flags & RADEON_IS_IGP)) { /* RV100, M6, IGPs */
929 mem_trcd = ((temp >> 2) & 0x3) + 1;
930 mem_trp = ((temp & 0x3)) + 1;
931 mem_tras = ((temp & 0x70) >> 4) + 1;
932 } else if (rdev->family == CHIP_R300 ||
933 rdev->family == CHIP_R350) { /* r300, r350 */
934 mem_trcd = (temp & 0x7) + 1;
935 mem_trp = ((temp >> 8) & 0x7) + 1;
936 mem_tras = ((temp >> 11) & 0xf) + 4;
937 } else if (rdev->family == CHIP_RV350 ||
938 rdev->family <= CHIP_RV380) {
939 /* rv3x0 */
940 mem_trcd = (temp & 0x7) + 3;
941 mem_trp = ((temp >> 8) & 0x7) + 3;
942 mem_tras = ((temp >> 11) & 0xf) + 6;
943 } else if (rdev->family == CHIP_R420 ||
944 rdev->family == CHIP_R423 ||
945 rdev->family == CHIP_RV410) {
946 /* r4xx */
947 mem_trcd = (temp & 0xf) + 3;
948 if (mem_trcd > 15)
949 mem_trcd = 15;
950 mem_trp = ((temp >> 8) & 0xf) + 3;
951 if (mem_trp > 15)
952 mem_trp = 15;
953 mem_tras = ((temp >> 12) & 0x1f) + 6;
954 if (mem_tras > 31)
955 mem_tras = 31;
956 } else { /* RV200, R200 */
957 mem_trcd = (temp & 0x7) + 1;
958 mem_trp = ((temp >> 8) & 0x7) + 1;
959 mem_tras = ((temp >> 12) & 0xf) + 4;
960 }
961 /* convert to FF */
962 trcd_ff.full = rfixed_const(mem_trcd);
963 trp_ff.full = rfixed_const(mem_trp);
964 tras_ff.full = rfixed_const(mem_tras);
965
966 /* Get values from the MEM_SDRAM_MODE_REG register...converting its */
967 temp = RREG32(RADEON_MEM_SDRAM_MODE_REG);
968 data = (temp & (7 << 20)) >> 20;
969 if ((rdev->family == CHIP_RV100) || rdev->flags & RADEON_IS_IGP) {
970 if (rdev->family == CHIP_RS480) /* don't think rs400 */
971 tcas_ff = memtcas_rs480_ff[data];
972 else
973 tcas_ff = memtcas_ff[data];
974 } else
975 tcas_ff = memtcas2_ff[data];
976
977 if (rdev->family == CHIP_RS400 ||
978 rdev->family == CHIP_RS480) {
979 /* extra cas latency stored in bits 23-25 0-4 clocks */
980 data = (temp >> 23) & 0x7;
981 if (data < 5)
982 tcas_ff.full += rfixed_const(data);
983 }
984
985 if (ASIC_IS_R300(rdev) && !(rdev->flags & RADEON_IS_IGP)) {
986 /* on the R300, Tcas is included in Trbs.
987 */
988 temp = RREG32(RADEON_MEM_CNTL);
989 data = (R300_MEM_NUM_CHANNELS_MASK & temp);
990 if (data == 1) {
991 if (R300_MEM_USE_CD_CH_ONLY & temp) {
992 temp = RREG32(R300_MC_IND_INDEX);
993 temp &= ~R300_MC_IND_ADDR_MASK;
994 temp |= R300_MC_READ_CNTL_CD_mcind;
995 WREG32(R300_MC_IND_INDEX, temp);
996 temp = RREG32(R300_MC_IND_DATA);
997 data = (R300_MEM_RBS_POSITION_C_MASK & temp);
998 } else {
999 temp = RREG32(R300_MC_READ_CNTL_AB);
1000 data = (R300_MEM_RBS_POSITION_A_MASK & temp);
1001 }
1002 } else {
1003 temp = RREG32(R300_MC_READ_CNTL_AB);
1004 data = (R300_MEM_RBS_POSITION_A_MASK & temp);
1005 }
1006 if (rdev->family == CHIP_RV410 ||
1007 rdev->family == CHIP_R420 ||
1008 rdev->family == CHIP_R423)
1009 trbs_ff = memtrbs_r4xx[data];
1010 else
1011 trbs_ff = memtrbs[data];
1012 tcas_ff.full += trbs_ff.full;
1013 }
1014
1015 sclk_eff_ff.full = sclk_ff.full;
1016
1017 if (rdev->flags & RADEON_IS_AGP) {
1018 fixed20_12 agpmode_ff;
1019 agpmode_ff.full = rfixed_const(radeon_agpmode);
1020 temp_ff.full = rfixed_const_666(16);
1021 sclk_eff_ff.full -= rfixed_mul(agpmode_ff, temp_ff);
1022 }
1023 /* TODO PCIE lanes may affect this - agpmode == 16?? */
1024
1025 if (ASIC_IS_R300(rdev)) {
1026 sclk_delay_ff.full = rfixed_const(250);
1027 } else {
1028 if ((rdev->family == CHIP_RV100) ||
1029 rdev->flags & RADEON_IS_IGP) {
1030 if (rdev->mc.vram_is_ddr)
1031 sclk_delay_ff.full = rfixed_const(41);
1032 else
1033 sclk_delay_ff.full = rfixed_const(33);
1034 } else {
1035 if (rdev->mc.vram_width == 128)
1036 sclk_delay_ff.full = rfixed_const(57);
1037 else
1038 sclk_delay_ff.full = rfixed_const(41);
1039 }
1040 }
1041
1042 mc_latency_sclk.full = rfixed_div(sclk_delay_ff, sclk_eff_ff);
1043
1044 if (rdev->mc.vram_is_ddr) {
1045 if (rdev->mc.vram_width == 32) {
1046 k1.full = rfixed_const(40);
1047 c = 3;
1048 } else {
1049 k1.full = rfixed_const(20);
1050 c = 1;
1051 }
1052 } else {
1053 k1.full = rfixed_const(40);
1054 c = 3;
1055 }
1056
1057 temp_ff.full = rfixed_const(2);
1058 mc_latency_mclk.full = rfixed_mul(trcd_ff, temp_ff);
1059 temp_ff.full = rfixed_const(c);
1060 mc_latency_mclk.full += rfixed_mul(tcas_ff, temp_ff);
1061 temp_ff.full = rfixed_const(4);
1062 mc_latency_mclk.full += rfixed_mul(tras_ff, temp_ff);
1063 mc_latency_mclk.full += rfixed_mul(trp_ff, temp_ff);
1064 mc_latency_mclk.full += k1.full;
1065
1066 mc_latency_mclk.full = rfixed_div(mc_latency_mclk, mclk_ff);
1067 mc_latency_mclk.full += rfixed_div(temp_ff, sclk_eff_ff);
1068
1069 /*
1070 HW cursor time assuming worst case of full size colour cursor.
1071 */
1072 temp_ff.full = rfixed_const((2 * (cur_size - (rdev->mc.vram_is_ddr + 1))));
1073 temp_ff.full += trcd_ff.full;
1074 if (temp_ff.full < tras_ff.full)
1075 temp_ff.full = tras_ff.full;
1076 cur_latency_mclk.full = rfixed_div(temp_ff, mclk_ff);
1077
1078 temp_ff.full = rfixed_const(cur_size);
1079 cur_latency_sclk.full = rfixed_div(temp_ff, sclk_eff_ff);
1080 /*
1081 Find the total latency for the display data.
1082 */
1083 disp_latency_overhead.full = rfixed_const(80);
1084 disp_latency_overhead.full = rfixed_div(disp_latency_overhead, sclk_ff);
1085 mc_latency_mclk.full += disp_latency_overhead.full + cur_latency_mclk.full;
1086 mc_latency_sclk.full += disp_latency_overhead.full + cur_latency_sclk.full;
1087
1088 if (mc_latency_mclk.full > mc_latency_sclk.full)
1089 disp_latency.full = mc_latency_mclk.full;
1090 else
1091 disp_latency.full = mc_latency_sclk.full;
1092
1093 /* setup Max GRPH_STOP_REQ default value */
1094 if (ASIC_IS_RV100(rdev))
1095 max_stop_req = 0x5c;
1096 else
1097 max_stop_req = 0x7c;
1098
1099 if (mode1) {
1100 /* CRTC1
1101 Set GRPH_BUFFER_CNTL register using h/w defined optimal values.
1102 GRPH_STOP_REQ <= MIN[ 0x7C, (CRTC_H_DISP + 1) * (bit depth) / 0x10 ]
1103 */
1104 stop_req = mode1->hdisplay * pixel_bytes1 / 16;
1105
1106 if (stop_req > max_stop_req)
1107 stop_req = max_stop_req;
1108
1109 /*
1110 Find the drain rate of the display buffer.
1111 */
1112 temp_ff.full = rfixed_const((16/pixel_bytes1));
1113 disp_drain_rate.full = rfixed_div(pix_clk, temp_ff);
1114
1115 /*
1116 Find the critical point of the display buffer.
1117 */
1118 crit_point_ff.full = rfixed_mul(disp_drain_rate, disp_latency);
1119 crit_point_ff.full += rfixed_const_half(0);
1120
1121 critical_point = rfixed_trunc(crit_point_ff);
1122
1123 if (rdev->disp_priority == 2) {
1124 critical_point = 0;
1125 }
1126
1127 /*
1128 The critical point should never be above max_stop_req-4. Setting
1129 GRPH_CRITICAL_CNTL = 0 will thus force high priority all the time.
1130 */
1131 if (max_stop_req - critical_point < 4)
1132 critical_point = 0;
1133
1134 if (critical_point == 0 && mode2 && rdev->family == CHIP_R300) {
1135 /* some R300 cards have problem with this set to 0, when CRTC2 is enabled.*/
1136 critical_point = 0x10;
1137 }
1138
1139 temp = RREG32(RADEON_GRPH_BUFFER_CNTL);
1140 temp &= ~(RADEON_GRPH_STOP_REQ_MASK);
1141 temp |= (stop_req << RADEON_GRPH_STOP_REQ_SHIFT);
1142 temp &= ~(RADEON_GRPH_START_REQ_MASK);
1143 if ((rdev->family == CHIP_R350) &&
1144 (stop_req > 0x15)) {
1145 stop_req -= 0x10;
1146 }
1147 temp |= (stop_req << RADEON_GRPH_START_REQ_SHIFT);
1148 temp |= RADEON_GRPH_BUFFER_SIZE;
1149 temp &= ~(RADEON_GRPH_CRITICAL_CNTL |
1150 RADEON_GRPH_CRITICAL_AT_SOF |
1151 RADEON_GRPH_STOP_CNTL);
1152 /*
1153 Write the result into the register.
1154 */
1155 WREG32(RADEON_GRPH_BUFFER_CNTL, ((temp & ~RADEON_GRPH_CRITICAL_POINT_MASK) |
1156 (critical_point << RADEON_GRPH_CRITICAL_POINT_SHIFT)));
1157
1158#if 0
1159 if ((rdev->family == CHIP_RS400) ||
1160 (rdev->family == CHIP_RS480)) {
1161 /* attempt to program RS400 disp regs correctly ??? */
1162 temp = RREG32(RS400_DISP1_REG_CNTL);
1163 temp &= ~(RS400_DISP1_START_REQ_LEVEL_MASK |
1164 RS400_DISP1_STOP_REQ_LEVEL_MASK);
1165 WREG32(RS400_DISP1_REQ_CNTL1, (temp |
1166 (critical_point << RS400_DISP1_START_REQ_LEVEL_SHIFT) |
1167 (critical_point << RS400_DISP1_STOP_REQ_LEVEL_SHIFT)));
1168 temp = RREG32(RS400_DMIF_MEM_CNTL1);
1169 temp &= ~(RS400_DISP1_CRITICAL_POINT_START_MASK |
1170 RS400_DISP1_CRITICAL_POINT_STOP_MASK);
1171 WREG32(RS400_DMIF_MEM_CNTL1, (temp |
1172 (critical_point << RS400_DISP1_CRITICAL_POINT_START_SHIFT) |
1173 (critical_point << RS400_DISP1_CRITICAL_POINT_STOP_SHIFT)));
1174 }
1175#endif
1176
1177 DRM_DEBUG("GRPH_BUFFER_CNTL from to %x\n",
1178 /* (unsigned int)info->SavedReg->grph_buffer_cntl, */
1179 (unsigned int)RREG32(RADEON_GRPH_BUFFER_CNTL));
1180 }
1181
1182 if (mode2) {
1183 u32 grph2_cntl;
1184 stop_req = mode2->hdisplay * pixel_bytes2 / 16;
1185
1186 if (stop_req > max_stop_req)
1187 stop_req = max_stop_req;
1188
1189 /*
1190 Find the drain rate of the display buffer.
1191 */
1192 temp_ff.full = rfixed_const((16/pixel_bytes2));
1193 disp_drain_rate2.full = rfixed_div(pix_clk2, temp_ff);
1194
1195 grph2_cntl = RREG32(RADEON_GRPH2_BUFFER_CNTL);
1196 grph2_cntl &= ~(RADEON_GRPH_STOP_REQ_MASK);
1197 grph2_cntl |= (stop_req << RADEON_GRPH_STOP_REQ_SHIFT);
1198 grph2_cntl &= ~(RADEON_GRPH_START_REQ_MASK);
1199 if ((rdev->family == CHIP_R350) &&
1200 (stop_req > 0x15)) {
1201 stop_req -= 0x10;
1202 }
1203 grph2_cntl |= (stop_req << RADEON_GRPH_START_REQ_SHIFT);
1204 grph2_cntl |= RADEON_GRPH_BUFFER_SIZE;
1205 grph2_cntl &= ~(RADEON_GRPH_CRITICAL_CNTL |
1206 RADEON_GRPH_CRITICAL_AT_SOF |
1207 RADEON_GRPH_STOP_CNTL);
1208
1209 if ((rdev->family == CHIP_RS100) ||
1210 (rdev->family == CHIP_RS200))
1211 critical_point2 = 0;
1212 else {
1213 temp = (rdev->mc.vram_width * rdev->mc.vram_is_ddr + 1)/128;
1214 temp_ff.full = rfixed_const(temp);
1215 temp_ff.full = rfixed_mul(mclk_ff, temp_ff);
1216 if (sclk_ff.full < temp_ff.full)
1217 temp_ff.full = sclk_ff.full;
1218
1219 read_return_rate.full = temp_ff.full;
1220
1221 if (mode1) {
1222 temp_ff.full = read_return_rate.full - disp_drain_rate.full;
1223 time_disp1_drop_priority.full = rfixed_div(crit_point_ff, temp_ff);
1224 } else {
1225 time_disp1_drop_priority.full = 0;
1226 }
1227 crit_point_ff.full = disp_latency.full + time_disp1_drop_priority.full + disp_latency.full;
1228 crit_point_ff.full = rfixed_mul(crit_point_ff, disp_drain_rate2);
1229 crit_point_ff.full += rfixed_const_half(0);
1230
1231 critical_point2 = rfixed_trunc(crit_point_ff);
1232
1233 if (rdev->disp_priority == 2) {
1234 critical_point2 = 0;
1235 }
1236
1237 if (max_stop_req - critical_point2 < 4)
1238 critical_point2 = 0;
1239
1240 }
1241
1242 if (critical_point2 == 0 && rdev->family == CHIP_R300) {
1243 /* some R300 cards have problem with this set to 0 */
1244 critical_point2 = 0x10;
1245 }
1246
1247 WREG32(RADEON_GRPH2_BUFFER_CNTL, ((grph2_cntl & ~RADEON_GRPH_CRITICAL_POINT_MASK) |
1248 (critical_point2 << RADEON_GRPH_CRITICAL_POINT_SHIFT)));
1249
1250 if ((rdev->family == CHIP_RS400) ||
1251 (rdev->family == CHIP_RS480)) {
1252#if 0
1253 /* attempt to program RS400 disp2 regs correctly ??? */
1254 temp = RREG32(RS400_DISP2_REQ_CNTL1);
1255 temp &= ~(RS400_DISP2_START_REQ_LEVEL_MASK |
1256 RS400_DISP2_STOP_REQ_LEVEL_MASK);
1257 WREG32(RS400_DISP2_REQ_CNTL1, (temp |
1258 (critical_point2 << RS400_DISP1_START_REQ_LEVEL_SHIFT) |
1259 (critical_point2 << RS400_DISP1_STOP_REQ_LEVEL_SHIFT)));
1260 temp = RREG32(RS400_DISP2_REQ_CNTL2);
1261 temp &= ~(RS400_DISP2_CRITICAL_POINT_START_MASK |
1262 RS400_DISP2_CRITICAL_POINT_STOP_MASK);
1263 WREG32(RS400_DISP2_REQ_CNTL2, (temp |
1264 (critical_point2 << RS400_DISP2_CRITICAL_POINT_START_SHIFT) |
1265 (critical_point2 << RS400_DISP2_CRITICAL_POINT_STOP_SHIFT)));
1266#endif
1267 WREG32(RS400_DISP2_REQ_CNTL1, 0x105DC1CC);
1268 WREG32(RS400_DISP2_REQ_CNTL2, 0x2749D000);
1269 WREG32(RS400_DMIF_MEM_CNTL1, 0x29CA71DC);
1270 WREG32(RS400_DISP1_REQ_CNTL1, 0x28FBC3AC);
1271 }
1272
1273 DRM_DEBUG("GRPH2_BUFFER_CNTL from to %x\n",
1274 (unsigned int)RREG32(RADEON_GRPH2_BUFFER_CNTL));
1275 }
1276}
diff --git a/drivers/gpu/drm/radeon/radeon_legacy_encoders.c b/drivers/gpu/drm/radeon/radeon_legacy_encoders.c
index 2c2f42de1d4c..34d0f58eb944 100644
--- a/drivers/gpu/drm/radeon/radeon_legacy_encoders.c
+++ b/drivers/gpu/drm/radeon/radeon_legacy_encoders.c
@@ -30,170 +30,6 @@
30#include "atom.h" 30#include "atom.h"
31 31
32 32
33static void radeon_legacy_rmx_mode_set(struct drm_encoder *encoder,
34 struct drm_display_mode *mode,
35 struct drm_display_mode *adjusted_mode)
36{
37 struct drm_device *dev = encoder->dev;
38 struct radeon_device *rdev = dev->dev_private;
39 struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder);
40 int xres = mode->hdisplay;
41 int yres = mode->vdisplay;
42 bool hscale = true, vscale = true;
43 int hsync_wid;
44 int vsync_wid;
45 int hsync_start;
46 uint32_t scale, inc;
47 uint32_t fp_horz_stretch, fp_vert_stretch, crtc_more_cntl, fp_horz_vert_active;
48 uint32_t fp_h_sync_strt_wid, fp_v_sync_strt_wid, fp_crtc_h_total_disp, fp_crtc_v_total_disp;
49 struct radeon_native_mode *native_mode = &radeon_encoder->native_mode;
50
51 DRM_DEBUG("\n");
52
53 fp_vert_stretch = RREG32(RADEON_FP_VERT_STRETCH) &
54 (RADEON_VERT_STRETCH_RESERVED |
55 RADEON_VERT_AUTO_RATIO_INC);
56 fp_horz_stretch = RREG32(RADEON_FP_HORZ_STRETCH) &
57 (RADEON_HORZ_FP_LOOP_STRETCH |
58 RADEON_HORZ_AUTO_RATIO_INC);
59
60 crtc_more_cntl = 0;
61 if ((rdev->family == CHIP_RS100) ||
62 (rdev->family == CHIP_RS200)) {
63 /* This is to workaround the asic bug for RMX, some versions
64 of BIOS dosen't have this register initialized correctly. */
65 crtc_more_cntl |= RADEON_CRTC_H_CUTOFF_ACTIVE_EN;
66 }
67
68
69 fp_crtc_h_total_disp = ((((mode->crtc_htotal / 8) - 1) & 0x3ff)
70 | ((((mode->crtc_hdisplay / 8) - 1) & 0x1ff) << 16));
71
72 hsync_wid = (mode->crtc_hsync_end - mode->crtc_hsync_start) / 8;
73 if (!hsync_wid)
74 hsync_wid = 1;
75 hsync_start = mode->crtc_hsync_start - 8;
76
77 fp_h_sync_strt_wid = ((hsync_start & 0x1fff)
78 | ((hsync_wid & 0x3f) << 16)
79 | ((mode->flags & DRM_MODE_FLAG_NHSYNC)
80 ? RADEON_CRTC_H_SYNC_POL
81 : 0));
82
83 fp_crtc_v_total_disp = (((mode->crtc_vtotal - 1) & 0xffff)
84 | ((mode->crtc_vdisplay - 1) << 16));
85
86 vsync_wid = mode->crtc_vsync_end - mode->crtc_vsync_start;
87 if (!vsync_wid)
88 vsync_wid = 1;
89
90 fp_v_sync_strt_wid = (((mode->crtc_vsync_start - 1) & 0xfff)
91 | ((vsync_wid & 0x1f) << 16)
92 | ((mode->flags & DRM_MODE_FLAG_NVSYNC)
93 ? RADEON_CRTC_V_SYNC_POL
94 : 0));
95
96 fp_horz_vert_active = 0;
97
98 if (native_mode->panel_xres == 0 ||
99 native_mode->panel_yres == 0) {
100 hscale = false;
101 vscale = false;
102 } else {
103 if (xres > native_mode->panel_xres)
104 xres = native_mode->panel_xres;
105 if (yres > native_mode->panel_yres)
106 yres = native_mode->panel_yres;
107
108 if (xres == native_mode->panel_xres)
109 hscale = false;
110 if (yres == native_mode->panel_yres)
111 vscale = false;
112 }
113
114 if (radeon_encoder->flags & RADEON_USE_RMX) {
115 if (radeon_encoder->rmx_type != RMX_CENTER) {
116 if (!hscale)
117 fp_horz_stretch |= ((xres/8-1) << 16);
118 else {
119 inc = (fp_horz_stretch & RADEON_HORZ_AUTO_RATIO_INC) ? 1 : 0;
120 scale = ((xres + inc) * RADEON_HORZ_STRETCH_RATIO_MAX)
121 / native_mode->panel_xres + 1;
122 fp_horz_stretch |= (((scale) & RADEON_HORZ_STRETCH_RATIO_MASK) |
123 RADEON_HORZ_STRETCH_BLEND |
124 RADEON_HORZ_STRETCH_ENABLE |
125 ((native_mode->panel_xres/8-1) << 16));
126 }
127
128 if (!vscale)
129 fp_vert_stretch |= ((yres-1) << 12);
130 else {
131 inc = (fp_vert_stretch & RADEON_VERT_AUTO_RATIO_INC) ? 1 : 0;
132 scale = ((yres + inc) * RADEON_VERT_STRETCH_RATIO_MAX)
133 / native_mode->panel_yres + 1;
134 fp_vert_stretch |= (((scale) & RADEON_VERT_STRETCH_RATIO_MASK) |
135 RADEON_VERT_STRETCH_ENABLE |
136 RADEON_VERT_STRETCH_BLEND |
137 ((native_mode->panel_yres-1) << 12));
138 }
139 } else if (radeon_encoder->rmx_type == RMX_CENTER) {
140 int blank_width;
141
142 fp_horz_stretch |= ((xres/8-1) << 16);
143 fp_vert_stretch |= ((yres-1) << 12);
144
145 crtc_more_cntl |= (RADEON_CRTC_AUTO_HORZ_CENTER_EN |
146 RADEON_CRTC_AUTO_VERT_CENTER_EN);
147
148 blank_width = (mode->crtc_hblank_end - mode->crtc_hblank_start) / 8;
149 if (blank_width > 110)
150 blank_width = 110;
151
152 fp_crtc_h_total_disp = (((blank_width) & 0x3ff)
153 | ((((mode->crtc_hdisplay / 8) - 1) & 0x1ff) << 16));
154
155 hsync_wid = (mode->crtc_hsync_end - mode->crtc_hsync_start) / 8;
156 if (!hsync_wid)
157 hsync_wid = 1;
158
159 fp_h_sync_strt_wid = ((((mode->crtc_hsync_start - mode->crtc_hblank_start) / 8) & 0x1fff)
160 | ((hsync_wid & 0x3f) << 16)
161 | ((mode->flags & DRM_MODE_FLAG_NHSYNC)
162 ? RADEON_CRTC_H_SYNC_POL
163 : 0));
164
165 fp_crtc_v_total_disp = (((mode->crtc_vblank_end - mode->crtc_vblank_start) & 0xffff)
166 | ((mode->crtc_vdisplay - 1) << 16));
167
168 vsync_wid = mode->crtc_vsync_end - mode->crtc_vsync_start;
169 if (!vsync_wid)
170 vsync_wid = 1;
171
172 fp_v_sync_strt_wid = ((((mode->crtc_vsync_start - mode->crtc_vblank_start) & 0xfff)
173 | ((vsync_wid & 0x1f) << 16)
174 | ((mode->flags & DRM_MODE_FLAG_NVSYNC)
175 ? RADEON_CRTC_V_SYNC_POL
176 : 0)));
177
178 fp_horz_vert_active = (((native_mode->panel_yres) & 0xfff) |
179 (((native_mode->panel_xres / 8) & 0x1ff) << 16));
180 }
181 } else {
182 fp_horz_stretch |= ((xres/8-1) << 16);
183 fp_vert_stretch |= ((yres-1) << 12);
184 }
185
186 WREG32(RADEON_FP_HORZ_STRETCH, fp_horz_stretch);
187 WREG32(RADEON_FP_VERT_STRETCH, fp_vert_stretch);
188 WREG32(RADEON_CRTC_MORE_CNTL, crtc_more_cntl);
189 WREG32(RADEON_FP_HORZ_VERT_ACTIVE, fp_horz_vert_active);
190 WREG32(RADEON_FP_H_SYNC_STRT_WID, fp_h_sync_strt_wid);
191 WREG32(RADEON_FP_V_SYNC_STRT_WID, fp_v_sync_strt_wid);
192 WREG32(RADEON_FP_CRTC_H_TOTAL_DISP, fp_crtc_h_total_disp);
193 WREG32(RADEON_FP_CRTC_V_TOTAL_DISP, fp_crtc_v_total_disp);
194
195}
196
197static void radeon_legacy_lvds_dpms(struct drm_encoder *encoder, int mode) 33static void radeon_legacy_lvds_dpms(struct drm_encoder *encoder, int mode)
198{ 34{
199 struct drm_device *dev = encoder->dev; 35 struct drm_device *dev = encoder->dev;
@@ -287,9 +123,6 @@ static void radeon_legacy_lvds_mode_set(struct drm_encoder *encoder,
287 123
288 DRM_DEBUG("\n"); 124 DRM_DEBUG("\n");
289 125
290 if (radeon_crtc->crtc_id == 0)
291 radeon_legacy_rmx_mode_set(encoder, mode, adjusted_mode);
292
293 lvds_pll_cntl = RREG32(RADEON_LVDS_PLL_CNTL); 126 lvds_pll_cntl = RREG32(RADEON_LVDS_PLL_CNTL);
294 lvds_pll_cntl &= ~RADEON_LVDS_PLL_EN; 127 lvds_pll_cntl &= ~RADEON_LVDS_PLL_EN;
295 128
@@ -318,7 +151,7 @@ static void radeon_legacy_lvds_mode_set(struct drm_encoder *encoder,
318 151
319 if (radeon_crtc->crtc_id == 0) { 152 if (radeon_crtc->crtc_id == 0) {
320 if (ASIC_IS_R300(rdev)) { 153 if (ASIC_IS_R300(rdev)) {
321 if (radeon_encoder->flags & RADEON_USE_RMX) 154 if (radeon_encoder->rmx_type != RMX_OFF)
322 lvds_pll_cntl |= R300_LVDS_SRC_SEL_RMX; 155 lvds_pll_cntl |= R300_LVDS_SRC_SEL_RMX;
323 } else 156 } else
324 lvds_gen_cntl &= ~RADEON_LVDS_SEL_CRTC2; 157 lvds_gen_cntl &= ~RADEON_LVDS_SEL_CRTC2;
@@ -350,8 +183,6 @@ static bool radeon_legacy_lvds_mode_fixup(struct drm_encoder *encoder,
350 183
351 drm_mode_set_crtcinfo(adjusted_mode, 0); 184 drm_mode_set_crtcinfo(adjusted_mode, 0);
352 185
353 radeon_encoder->flags &= ~RADEON_USE_RMX;
354
355 if (radeon_encoder->rmx_type != RMX_OFF) 186 if (radeon_encoder->rmx_type != RMX_OFF)
356 radeon_rmx_mode_fixup(encoder, mode, adjusted_mode); 187 radeon_rmx_mode_fixup(encoder, mode, adjusted_mode);
357 188
@@ -455,9 +286,6 @@ static void radeon_legacy_primary_dac_mode_set(struct drm_encoder *encoder,
455 286
456 DRM_DEBUG("\n"); 287 DRM_DEBUG("\n");
457 288
458 if (radeon_crtc->crtc_id == 0)
459 radeon_legacy_rmx_mode_set(encoder, mode, adjusted_mode);
460
461 if (radeon_crtc->crtc_id == 0) { 289 if (radeon_crtc->crtc_id == 0) {
462 if (rdev->family == CHIP_R200 || ASIC_IS_R300(rdev)) { 290 if (rdev->family == CHIP_R200 || ASIC_IS_R300(rdev)) {
463 disp_output_cntl = RREG32(RADEON_DISP_OUTPUT_CNTL) & 291 disp_output_cntl = RREG32(RADEON_DISP_OUTPUT_CNTL) &
@@ -653,9 +481,6 @@ static void radeon_legacy_tmds_int_mode_set(struct drm_encoder *encoder,
653 481
654 DRM_DEBUG("\n"); 482 DRM_DEBUG("\n");
655 483
656 if (radeon_crtc->crtc_id == 0)
657 radeon_legacy_rmx_mode_set(encoder, mode, adjusted_mode);
658
659 tmp = tmds_pll_cntl = RREG32(RADEON_TMDS_PLL_CNTL); 484 tmp = tmds_pll_cntl = RREG32(RADEON_TMDS_PLL_CNTL);
660 tmp &= 0xfffff; 485 tmp &= 0xfffff;
661 if (rdev->family == CHIP_RV280) { 486 if (rdev->family == CHIP_RV280) {
@@ -711,7 +536,7 @@ static void radeon_legacy_tmds_int_mode_set(struct drm_encoder *encoder,
711 if (radeon_crtc->crtc_id == 0) { 536 if (radeon_crtc->crtc_id == 0) {
712 if (ASIC_IS_R300(rdev) || rdev->family == CHIP_R200) { 537 if (ASIC_IS_R300(rdev) || rdev->family == CHIP_R200) {
713 fp_gen_cntl &= ~R200_FP_SOURCE_SEL_MASK; 538 fp_gen_cntl &= ~R200_FP_SOURCE_SEL_MASK;
714 if (radeon_encoder->flags & RADEON_USE_RMX) 539 if (radeon_encoder->rmx_type != RMX_OFF)
715 fp_gen_cntl |= R200_FP_SOURCE_SEL_RMX; 540 fp_gen_cntl |= R200_FP_SOURCE_SEL_RMX;
716 else 541 else
717 fp_gen_cntl |= R200_FP_SOURCE_SEL_CRTC1; 542 fp_gen_cntl |= R200_FP_SOURCE_SEL_CRTC1;
@@ -820,9 +645,6 @@ static void radeon_legacy_tmds_ext_mode_set(struct drm_encoder *encoder,
820 645
821 DRM_DEBUG("\n"); 646 DRM_DEBUG("\n");
822 647
823 if (radeon_crtc->crtc_id == 0)
824 radeon_legacy_rmx_mode_set(encoder, mode, adjusted_mode);
825
826 if (rdev->is_atom_bios) { 648 if (rdev->is_atom_bios) {
827 radeon_encoder->pixel_clock = adjusted_mode->clock; 649 radeon_encoder->pixel_clock = adjusted_mode->clock;
828 atombios_external_tmds_setup(encoder, ATOM_ENABLE); 650 atombios_external_tmds_setup(encoder, ATOM_ENABLE);
@@ -856,7 +678,7 @@ static void radeon_legacy_tmds_ext_mode_set(struct drm_encoder *encoder,
856 if (radeon_crtc->crtc_id == 0) { 678 if (radeon_crtc->crtc_id == 0) {
857 if ((rdev->family == CHIP_R200) || ASIC_IS_R300(rdev)) { 679 if ((rdev->family == CHIP_R200) || ASIC_IS_R300(rdev)) {
858 fp2_gen_cntl &= ~R200_FP2_SOURCE_SEL_MASK; 680 fp2_gen_cntl &= ~R200_FP2_SOURCE_SEL_MASK;
859 if (radeon_encoder->flags & RADEON_USE_RMX) 681 if (radeon_encoder->rmx_type != RMX_OFF)
860 fp2_gen_cntl |= R200_FP2_SOURCE_SEL_RMX; 682 fp2_gen_cntl |= R200_FP2_SOURCE_SEL_RMX;
861 else 683 else
862 fp2_gen_cntl |= R200_FP2_SOURCE_SEL_CRTC1; 684 fp2_gen_cntl |= R200_FP2_SOURCE_SEL_CRTC1;
@@ -1014,9 +836,6 @@ static void radeon_legacy_tv_dac_mode_set(struct drm_encoder *encoder,
1014 836
1015 DRM_DEBUG("\n"); 837 DRM_DEBUG("\n");
1016 838
1017 if (radeon_crtc->crtc_id == 0)
1018 radeon_legacy_rmx_mode_set(encoder, mode, adjusted_mode);
1019
1020 if (rdev->family != CHIP_R200) { 839 if (rdev->family != CHIP_R200) {
1021 tv_dac_cntl = RREG32(RADEON_TV_DAC_CNTL); 840 tv_dac_cntl = RREG32(RADEON_TV_DAC_CNTL);
1022 if (rdev->family == CHIP_R420 || 841 if (rdev->family == CHIP_R420 ||
@@ -1243,6 +1062,7 @@ radeon_add_legacy_encoder(struct drm_device *dev, uint32_t encoder_id, uint32_t
1243 1062
1244 radeon_encoder->encoder_id = encoder_id; 1063 radeon_encoder->encoder_id = encoder_id;
1245 radeon_encoder->devices = supported_device; 1064 radeon_encoder->devices = supported_device;
1065 radeon_encoder->rmx_type = RMX_OFF;
1246 1066
1247 switch (radeon_encoder->encoder_id) { 1067 switch (radeon_encoder->encoder_id) {
1248 case ENCODER_OBJECT_ID_INTERNAL_LVDS: 1068 case ENCODER_OBJECT_ID_INTERNAL_LVDS:
diff --git a/drivers/gpu/drm/radeon/radeon_mode.h b/drivers/gpu/drm/radeon/radeon_mode.h
index 9173b687462b..3b09a1f2d8f9 100644
--- a/drivers/gpu/drm/radeon/radeon_mode.h
+++ b/drivers/gpu/drm/radeon/radeon_mode.h
@@ -36,6 +36,9 @@
36#include <linux/i2c.h> 36#include <linux/i2c.h>
37#include <linux/i2c-id.h> 37#include <linux/i2c-id.h>
38#include <linux/i2c-algo-bit.h> 38#include <linux/i2c-algo-bit.h>
39#include "radeon_fixed.h"
40
41struct radeon_device;
39 42
40#define to_radeon_crtc(x) container_of(x, struct radeon_crtc, base) 43#define to_radeon_crtc(x) container_of(x, struct radeon_crtc, base)
41#define to_radeon_connector(x) container_of(x, struct radeon_connector, base) 44#define to_radeon_connector(x) container_of(x, struct radeon_connector, base)
@@ -124,6 +127,7 @@ struct radeon_tmds_pll {
124#define RADEON_PLL_PREFER_LOW_POST_DIV (1 << 8) 127#define RADEON_PLL_PREFER_LOW_POST_DIV (1 << 8)
125#define RADEON_PLL_PREFER_HIGH_POST_DIV (1 << 9) 128#define RADEON_PLL_PREFER_HIGH_POST_DIV (1 << 9)
126#define RADEON_PLL_USE_FRAC_FB_DIV (1 << 10) 129#define RADEON_PLL_USE_FRAC_FB_DIV (1 << 10)
130#define RADEON_PLL_PREFER_CLOSEST_LOWER (1 << 11)
127 131
128struct radeon_pll { 132struct radeon_pll {
129 uint16_t reference_freq; 133 uint16_t reference_freq;
@@ -170,6 +174,18 @@ struct radeon_mode_info {
170 struct atom_context *atom_context; 174 struct atom_context *atom_context;
171 enum radeon_connector_table connector_table; 175 enum radeon_connector_table connector_table;
172 bool mode_config_initialized; 176 bool mode_config_initialized;
177 struct radeon_crtc *crtcs[2];
178};
179
180struct radeon_native_mode {
181 /* preferred mode */
182 uint32_t panel_xres, panel_yres;
183 uint32_t hoverplus, hsync_width;
184 uint32_t hblank;
185 uint32_t voverplus, vsync_width;
186 uint32_t vblank;
187 uint32_t dotclock;
188 uint32_t flags;
173}; 189};
174 190
175struct radeon_crtc { 191struct radeon_crtc {
@@ -185,19 +201,13 @@ struct radeon_crtc {
185 uint64_t cursor_addr; 201 uint64_t cursor_addr;
186 int cursor_width; 202 int cursor_width;
187 int cursor_height; 203 int cursor_height;
188}; 204 uint32_t legacy_display_base_addr;
189 205 uint32_t legacy_cursor_offset;
190#define RADEON_USE_RMX 1 206 enum radeon_rmx_type rmx_type;
191 207 uint32_t devices;
192struct radeon_native_mode { 208 fixed20_12 vsc;
193 /* preferred mode */ 209 fixed20_12 hsc;
194 uint32_t panel_xres, panel_yres; 210 struct radeon_native_mode native_mode;
195 uint32_t hoverplus, hsync_width;
196 uint32_t hblank;
197 uint32_t voverplus, vsync_width;
198 uint32_t vblank;
199 uint32_t dotclock;
200 uint32_t flags;
201}; 211};
202 212
203struct radeon_encoder_primary_dac { 213struct radeon_encoder_primary_dac {
@@ -383,16 +393,9 @@ void radeon_enc_destroy(struct drm_encoder *encoder);
383void radeon_copy_fb(struct drm_device *dev, struct drm_gem_object *dst_obj); 393void radeon_copy_fb(struct drm_device *dev, struct drm_gem_object *dst_obj);
384void radeon_combios_asic_init(struct drm_device *dev); 394void radeon_combios_asic_init(struct drm_device *dev);
385extern int radeon_static_clocks_init(struct drm_device *dev); 395extern int radeon_static_clocks_init(struct drm_device *dev);
386void radeon_init_disp_bw_legacy(struct drm_device *dev, 396bool radeon_crtc_scaling_mode_fixup(struct drm_crtc *crtc,
387 struct drm_display_mode *mode1, 397 struct drm_display_mode *mode,
388 uint32_t pixel_bytes1, 398 struct drm_display_mode *adjusted_mode);
389 struct drm_display_mode *mode2, 399void atom_rv515_force_tv_scaler(struct radeon_device *rdev);
390 uint32_t pixel_bytes2);
391void radeon_init_disp_bw_avivo(struct drm_device *dev,
392 struct drm_display_mode *mode1,
393 uint32_t pixel_bytes1,
394 struct drm_display_mode *mode2,
395 uint32_t pixel_bytes2);
396void radeon_init_disp_bandwidth(struct drm_device *dev);
397 400
398#endif 401#endif
diff --git a/drivers/gpu/drm/radeon/radeon_object.c b/drivers/gpu/drm/radeon/radeon_object.c
index bac0d06c52ac..dd9ac2fed6d6 100644
--- a/drivers/gpu/drm/radeon/radeon_object.c
+++ b/drivers/gpu/drm/radeon/radeon_object.c
@@ -44,6 +44,9 @@ struct radeon_object {
44 uint64_t gpu_addr; 44 uint64_t gpu_addr;
45 void *kptr; 45 void *kptr;
46 bool is_iomem; 46 bool is_iomem;
47 uint32_t tiling_flags;
48 uint32_t pitch;
49 int surface_reg;
47}; 50};
48 51
49int radeon_ttm_init(struct radeon_device *rdev); 52int radeon_ttm_init(struct radeon_device *rdev);
@@ -70,6 +73,7 @@ static void radeon_ttm_object_object_destroy(struct ttm_buffer_object *tobj)
70 73
71 robj = container_of(tobj, struct radeon_object, tobj); 74 robj = container_of(tobj, struct radeon_object, tobj);
72 list_del_init(&robj->list); 75 list_del_init(&robj->list);
76 radeon_object_clear_surface_reg(robj);
73 kfree(robj); 77 kfree(robj);
74} 78}
75 79
@@ -99,16 +103,16 @@ static inline uint32_t radeon_object_flags_from_domain(uint32_t domain)
99{ 103{
100 uint32_t flags = 0; 104 uint32_t flags = 0;
101 if (domain & RADEON_GEM_DOMAIN_VRAM) { 105 if (domain & RADEON_GEM_DOMAIN_VRAM) {
102 flags |= TTM_PL_FLAG_VRAM; 106 flags |= TTM_PL_FLAG_VRAM | TTM_PL_FLAG_WC | TTM_PL_FLAG_UNCACHED;
103 } 107 }
104 if (domain & RADEON_GEM_DOMAIN_GTT) { 108 if (domain & RADEON_GEM_DOMAIN_GTT) {
105 flags |= TTM_PL_FLAG_TT; 109 flags |= TTM_PL_FLAG_TT | TTM_PL_FLAG_WC | TTM_PL_FLAG_UNCACHED;
106 } 110 }
107 if (domain & RADEON_GEM_DOMAIN_CPU) { 111 if (domain & RADEON_GEM_DOMAIN_CPU) {
108 flags |= TTM_PL_FLAG_SYSTEM; 112 flags |= TTM_PL_FLAG_SYSTEM | TTM_PL_MASK_CACHING;
109 } 113 }
110 if (!flags) { 114 if (!flags) {
111 flags |= TTM_PL_FLAG_SYSTEM; 115 flags |= TTM_PL_FLAG_SYSTEM | TTM_PL_MASK_CACHING;
112 } 116 }
113 return flags; 117 return flags;
114} 118}
@@ -141,6 +145,7 @@ int radeon_object_create(struct radeon_device *rdev,
141 } 145 }
142 robj->rdev = rdev; 146 robj->rdev = rdev;
143 robj->gobj = gobj; 147 robj->gobj = gobj;
148 robj->surface_reg = -1;
144 INIT_LIST_HEAD(&robj->list); 149 INIT_LIST_HEAD(&robj->list);
145 150
146 flags = radeon_object_flags_from_domain(domain); 151 flags = radeon_object_flags_from_domain(domain);
@@ -304,7 +309,7 @@ int radeon_object_wait(struct radeon_object *robj)
304 } 309 }
305 spin_lock(&robj->tobj.lock); 310 spin_lock(&robj->tobj.lock);
306 if (robj->tobj.sync_obj) { 311 if (robj->tobj.sync_obj) {
307 r = ttm_bo_wait(&robj->tobj, true, false, false); 312 r = ttm_bo_wait(&robj->tobj, true, true, false);
308 } 313 }
309 spin_unlock(&robj->tobj.lock); 314 spin_unlock(&robj->tobj.lock);
310 radeon_object_unreserve(robj); 315 radeon_object_unreserve(robj);
@@ -403,7 +408,6 @@ int radeon_object_list_validate(struct list_head *head, void *fence)
403 struct radeon_object *robj; 408 struct radeon_object *robj;
404 struct radeon_fence *old_fence = NULL; 409 struct radeon_fence *old_fence = NULL;
405 struct list_head *i; 410 struct list_head *i;
406 uint32_t flags;
407 int r; 411 int r;
408 412
409 r = radeon_object_list_reserve(head); 413 r = radeon_object_list_reserve(head);
@@ -414,27 +418,25 @@ int radeon_object_list_validate(struct list_head *head, void *fence)
414 list_for_each(i, head) { 418 list_for_each(i, head) {
415 lobj = list_entry(i, struct radeon_object_list, list); 419 lobj = list_entry(i, struct radeon_object_list, list);
416 robj = lobj->robj; 420 robj = lobj->robj;
417 if (lobj->wdomain) {
418 flags = radeon_object_flags_from_domain(lobj->wdomain);
419 flags |= TTM_PL_FLAG_TT;
420 } else {
421 flags = radeon_object_flags_from_domain(lobj->rdomain);
422 flags |= TTM_PL_FLAG_TT;
423 flags |= TTM_PL_FLAG_VRAM;
424 }
425 if (!robj->pin_count) { 421 if (!robj->pin_count) {
426 robj->tobj.proposed_placement = flags | TTM_PL_MASK_CACHING; 422 if (lobj->wdomain) {
423 robj->tobj.proposed_placement =
424 radeon_object_flags_from_domain(lobj->wdomain);
425 } else {
426 robj->tobj.proposed_placement =
427 radeon_object_flags_from_domain(lobj->rdomain);
428 }
427 r = ttm_buffer_object_validate(&robj->tobj, 429 r = ttm_buffer_object_validate(&robj->tobj,
428 robj->tobj.proposed_placement, 430 robj->tobj.proposed_placement,
429 true, false); 431 true, false);
430 if (unlikely(r)) { 432 if (unlikely(r)) {
431 radeon_object_list_unreserve(head);
432 DRM_ERROR("radeon: failed to validate.\n"); 433 DRM_ERROR("radeon: failed to validate.\n");
433 return r; 434 return r;
434 } 435 }
435 radeon_object_gpu_addr(robj); 436 radeon_object_gpu_addr(robj);
436 } 437 }
437 lobj->gpu_offset = robj->gpu_addr; 438 lobj->gpu_offset = robj->gpu_addr;
439 lobj->tiling_flags = robj->tiling_flags;
438 if (fence) { 440 if (fence) {
439 old_fence = (struct radeon_fence *)robj->tobj.sync_obj; 441 old_fence = (struct radeon_fence *)robj->tobj.sync_obj;
440 robj->tobj.sync_obj = radeon_fence_ref(fence); 442 robj->tobj.sync_obj = radeon_fence_ref(fence);
@@ -479,3 +481,127 @@ unsigned long radeon_object_size(struct radeon_object *robj)
479{ 481{
480 return robj->tobj.num_pages << PAGE_SHIFT; 482 return robj->tobj.num_pages << PAGE_SHIFT;
481} 483}
484
485int radeon_object_get_surface_reg(struct radeon_object *robj)
486{
487 struct radeon_device *rdev = robj->rdev;
488 struct radeon_surface_reg *reg;
489 struct radeon_object *old_object;
490 int steal;
491 int i;
492
493 if (!robj->tiling_flags)
494 return 0;
495
496 if (robj->surface_reg >= 0) {
497 reg = &rdev->surface_regs[robj->surface_reg];
498 i = robj->surface_reg;
499 goto out;
500 }
501
502 steal = -1;
503 for (i = 0; i < RADEON_GEM_MAX_SURFACES; i++) {
504
505 reg = &rdev->surface_regs[i];
506 if (!reg->robj)
507 break;
508
509 old_object = reg->robj;
510 if (old_object->pin_count == 0)
511 steal = i;
512 }
513
514 /* if we are all out */
515 if (i == RADEON_GEM_MAX_SURFACES) {
516 if (steal == -1)
517 return -ENOMEM;
518 /* find someone with a surface reg and nuke their BO */
519 reg = &rdev->surface_regs[steal];
520 old_object = reg->robj;
521 /* blow away the mapping */
522 DRM_DEBUG("stealing surface reg %d from %p\n", steal, old_object);
523 ttm_bo_unmap_virtual(&old_object->tobj);
524 old_object->surface_reg = -1;
525 i = steal;
526 }
527
528 robj->surface_reg = i;
529 reg->robj = robj;
530
531out:
532 radeon_set_surface_reg(rdev, i, robj->tiling_flags, robj->pitch,
533 robj->tobj.mem.mm_node->start << PAGE_SHIFT,
534 robj->tobj.num_pages << PAGE_SHIFT);
535 return 0;
536}
537
538void radeon_object_clear_surface_reg(struct radeon_object *robj)
539{
540 struct radeon_device *rdev = robj->rdev;
541 struct radeon_surface_reg *reg;
542
543 if (robj->surface_reg == -1)
544 return;
545
546 reg = &rdev->surface_regs[robj->surface_reg];
547 radeon_clear_surface_reg(rdev, robj->surface_reg);
548
549 reg->robj = NULL;
550 robj->surface_reg = -1;
551}
552
553void radeon_object_set_tiling_flags(struct radeon_object *robj,
554 uint32_t tiling_flags, uint32_t pitch)
555{
556 robj->tiling_flags = tiling_flags;
557 robj->pitch = pitch;
558}
559
560void radeon_object_get_tiling_flags(struct radeon_object *robj,
561 uint32_t *tiling_flags,
562 uint32_t *pitch)
563{
564 if (tiling_flags)
565 *tiling_flags = robj->tiling_flags;
566 if (pitch)
567 *pitch = robj->pitch;
568}
569
570int radeon_object_check_tiling(struct radeon_object *robj, bool has_moved,
571 bool force_drop)
572{
573 if (!(robj->tiling_flags & RADEON_TILING_SURFACE))
574 return 0;
575
576 if (force_drop) {
577 radeon_object_clear_surface_reg(robj);
578 return 0;
579 }
580
581 if (robj->tobj.mem.mem_type != TTM_PL_VRAM) {
582 if (!has_moved)
583 return 0;
584
585 if (robj->surface_reg >= 0)
586 radeon_object_clear_surface_reg(robj);
587 return 0;
588 }
589
590 if ((robj->surface_reg >= 0) && !has_moved)
591 return 0;
592
593 return radeon_object_get_surface_reg(robj);
594}
595
596void radeon_bo_move_notify(struct ttm_buffer_object *bo,
597 struct ttm_mem_reg *mem)
598{
599 struct radeon_object *robj = container_of(bo, struct radeon_object, tobj);
600 radeon_object_check_tiling(robj, 0, 1);
601}
602
603void radeon_bo_fault_reserve_notify(struct ttm_buffer_object *bo)
604{
605 struct radeon_object *robj = container_of(bo, struct radeon_object, tobj);
606 radeon_object_check_tiling(robj, 0, 0);
607}
diff --git a/drivers/gpu/drm/radeon/radeon_ring.c b/drivers/gpu/drm/radeon/radeon_ring.c
index a853261d1881..60d159308b88 100644
--- a/drivers/gpu/drm/radeon/radeon_ring.c
+++ b/drivers/gpu/drm/radeon/radeon_ring.c
@@ -126,32 +126,19 @@ static void radeon_ib_align(struct radeon_device *rdev, struct radeon_ib *ib)
126 } 126 }
127} 127}
128 128
129static void radeon_ib_cpu_flush(struct radeon_device *rdev,
130 struct radeon_ib *ib)
131{
132 unsigned long tmp;
133 unsigned i;
134
135 /* To force CPU cache flush ugly but seems reliable */
136 for (i = 0; i < ib->length_dw; i += (rdev->cp.align_mask + 1)) {
137 tmp = readl(&ib->ptr[i]);
138 }
139}
140
141int radeon_ib_schedule(struct radeon_device *rdev, struct radeon_ib *ib) 129int radeon_ib_schedule(struct radeon_device *rdev, struct radeon_ib *ib)
142{ 130{
143 int r = 0; 131 int r = 0;
144 132
145 mutex_lock(&rdev->ib_pool.mutex); 133 mutex_lock(&rdev->ib_pool.mutex);
146 radeon_ib_align(rdev, ib); 134 radeon_ib_align(rdev, ib);
147 radeon_ib_cpu_flush(rdev, ib);
148 if (!ib->length_dw || !rdev->cp.ready) { 135 if (!ib->length_dw || !rdev->cp.ready) {
149 /* TODO: Nothings in the ib we should report. */ 136 /* TODO: Nothings in the ib we should report. */
150 mutex_unlock(&rdev->ib_pool.mutex); 137 mutex_unlock(&rdev->ib_pool.mutex);
151 DRM_ERROR("radeon: couldn't schedule IB(%lu).\n", ib->idx); 138 DRM_ERROR("radeon: couldn't schedule IB(%lu).\n", ib->idx);
152 return -EINVAL; 139 return -EINVAL;
153 } 140 }
154 /* 64 dwords should be enought for fence too */ 141 /* 64 dwords should be enough for fence too */
155 r = radeon_ring_lock(rdev, 64); 142 r = radeon_ring_lock(rdev, 64);
156 if (r) { 143 if (r) {
157 DRM_ERROR("radeon: scheduling IB failled (%d).\n", r); 144 DRM_ERROR("radeon: scheduling IB failled (%d).\n", r);
diff --git a/drivers/gpu/drm/radeon/radeon_share.h b/drivers/gpu/drm/radeon/radeon_share.h
new file mode 100644
index 000000000000..63a773578f17
--- /dev/null
+++ b/drivers/gpu/drm/radeon/radeon_share.h
@@ -0,0 +1,39 @@
1/*
2 * Copyright 2008 Advanced Micro Devices, Inc.
3 * Copyright 2008 Red Hat Inc.
4 * Copyright 2009 Jerome Glisse.
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the "Software"),
8 * to deal in the Software without restriction, including without limitation
9 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 * and/or sell copies of the Software, and to permit persons to whom the
11 * Software is furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
20 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
21 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
22 * OTHER DEALINGS IN THE SOFTWARE.
23 *
24 * Authors: Dave Airlie
25 * Alex Deucher
26 * Jerome Glisse
27 */
28#ifndef __RADEON_SHARE_H__
29#define __RADEON_SHARE_H__
30
31void r100_vram_init_sizes(struct radeon_device *rdev);
32
33void rs690_line_buffer_adjust(struct radeon_device *rdev,
34 struct drm_display_mode *mode1,
35 struct drm_display_mode *mode2);
36
37void rv515_bandwidth_avivo_update(struct radeon_device *rdev);
38
39#endif
diff --git a/drivers/gpu/drm/radeon/radeon_test.c b/drivers/gpu/drm/radeon/radeon_test.c
new file mode 100644
index 000000000000..03c33cf4e14c
--- /dev/null
+++ b/drivers/gpu/drm/radeon/radeon_test.c
@@ -0,0 +1,209 @@
1/*
2 * Copyright 2009 VMware, Inc.
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
10 *
11 * The above copyright notice and this permission notice shall be included in
12 * all copies or substantial portions of the Software.
13 *
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
17 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20 * OTHER DEALINGS IN THE SOFTWARE.
21 *
22 * Authors: Michel Dänzer
23 */
24#include <drm/drmP.h>
25#include <drm/radeon_drm.h>
26#include "radeon_reg.h"
27#include "radeon.h"
28
29
30/* Test BO GTT->VRAM and VRAM->GTT GPU copies across the whole GTT aperture */
31void radeon_test_moves(struct radeon_device *rdev)
32{
33 struct radeon_object *vram_obj = NULL;
34 struct radeon_object **gtt_obj = NULL;
35 struct radeon_fence *fence = NULL;
36 uint64_t gtt_addr, vram_addr;
37 unsigned i, n, size;
38 int r;
39
40 size = 1024 * 1024;
41
42 /* Number of tests =
43 * (Total GTT - IB pool - writeback page - ring buffer) / test size
44 */
45 n = (rdev->mc.gtt_size - RADEON_IB_POOL_SIZE*64*1024 - 4096 -
46 rdev->cp.ring_size) / size;
47
48 gtt_obj = kzalloc(n * sizeof(*gtt_obj), GFP_KERNEL);
49 if (!gtt_obj) {
50 DRM_ERROR("Failed to allocate %d pointers\n", n);
51 r = 1;
52 goto out_cleanup;
53 }
54
55 r = radeon_object_create(rdev, NULL, size, true, RADEON_GEM_DOMAIN_VRAM,
56 false, &vram_obj);
57 if (r) {
58 DRM_ERROR("Failed to create VRAM object\n");
59 goto out_cleanup;
60 }
61
62 r = radeon_object_pin(vram_obj, RADEON_GEM_DOMAIN_VRAM, &vram_addr);
63 if (r) {
64 DRM_ERROR("Failed to pin VRAM object\n");
65 goto out_cleanup;
66 }
67
68 for (i = 0; i < n; i++) {
69 void *gtt_map, *vram_map;
70 void **gtt_start, **gtt_end;
71 void **vram_start, **vram_end;
72
73 r = radeon_object_create(rdev, NULL, size, true,
74 RADEON_GEM_DOMAIN_GTT, false, gtt_obj + i);
75 if (r) {
76 DRM_ERROR("Failed to create GTT object %d\n", i);
77 goto out_cleanup;
78 }
79
80 r = radeon_object_pin(gtt_obj[i], RADEON_GEM_DOMAIN_GTT, &gtt_addr);
81 if (r) {
82 DRM_ERROR("Failed to pin GTT object %d\n", i);
83 goto out_cleanup;
84 }
85
86 r = radeon_object_kmap(gtt_obj[i], &gtt_map);
87 if (r) {
88 DRM_ERROR("Failed to map GTT object %d\n", i);
89 goto out_cleanup;
90 }
91
92 for (gtt_start = gtt_map, gtt_end = gtt_map + size;
93 gtt_start < gtt_end;
94 gtt_start++)
95 *gtt_start = gtt_start;
96
97 radeon_object_kunmap(gtt_obj[i]);
98
99 r = radeon_fence_create(rdev, &fence);
100 if (r) {
101 DRM_ERROR("Failed to create GTT->VRAM fence %d\n", i);
102 goto out_cleanup;
103 }
104
105 r = radeon_copy(rdev, gtt_addr, vram_addr, size / 4096, fence);
106 if (r) {
107 DRM_ERROR("Failed GTT->VRAM copy %d\n", i);
108 goto out_cleanup;
109 }
110
111 r = radeon_fence_wait(fence, false);
112 if (r) {
113 DRM_ERROR("Failed to wait for GTT->VRAM fence %d\n", i);
114 goto out_cleanup;
115 }
116
117 radeon_fence_unref(&fence);
118
119 r = radeon_object_kmap(vram_obj, &vram_map);
120 if (r) {
121 DRM_ERROR("Failed to map VRAM object after copy %d\n", i);
122 goto out_cleanup;
123 }
124
125 for (gtt_start = gtt_map, gtt_end = gtt_map + size,
126 vram_start = vram_map, vram_end = vram_map + size;
127 vram_start < vram_end;
128 gtt_start++, vram_start++) {
129 if (*vram_start != gtt_start) {
130 DRM_ERROR("Incorrect GTT->VRAM copy %d: Got 0x%p, "
131 "expected 0x%p (GTT map 0x%p-0x%p)\n",
132 i, *vram_start, gtt_start, gtt_map,
133 gtt_end);
134 radeon_object_kunmap(vram_obj);
135 goto out_cleanup;
136 }
137 *vram_start = vram_start;
138 }
139
140 radeon_object_kunmap(vram_obj);
141
142 r = radeon_fence_create(rdev, &fence);
143 if (r) {
144 DRM_ERROR("Failed to create VRAM->GTT fence %d\n", i);
145 goto out_cleanup;
146 }
147
148 r = radeon_copy(rdev, vram_addr, gtt_addr, size / 4096, fence);
149 if (r) {
150 DRM_ERROR("Failed VRAM->GTT copy %d\n", i);
151 goto out_cleanup;
152 }
153
154 r = radeon_fence_wait(fence, false);
155 if (r) {
156 DRM_ERROR("Failed to wait for VRAM->GTT fence %d\n", i);
157 goto out_cleanup;
158 }
159
160 radeon_fence_unref(&fence);
161
162 r = radeon_object_kmap(gtt_obj[i], &gtt_map);
163 if (r) {
164 DRM_ERROR("Failed to map GTT object after copy %d\n", i);
165 goto out_cleanup;
166 }
167
168 for (gtt_start = gtt_map, gtt_end = gtt_map + size,
169 vram_start = vram_map, vram_end = vram_map + size;
170 gtt_start < gtt_end;
171 gtt_start++, vram_start++) {
172 if (*gtt_start != vram_start) {
173 DRM_ERROR("Incorrect VRAM->GTT copy %d: Got 0x%p, "
174 "expected 0x%p (VRAM map 0x%p-0x%p)\n",
175 i, *gtt_start, vram_start, vram_map,
176 vram_end);
177 radeon_object_kunmap(gtt_obj[i]);
178 goto out_cleanup;
179 }
180 }
181
182 radeon_object_kunmap(gtt_obj[i]);
183
184 DRM_INFO("Tested GTT->VRAM and VRAM->GTT copy for GTT offset 0x%llx\n",
185 gtt_addr - rdev->mc.gtt_location);
186 }
187
188out_cleanup:
189 if (vram_obj) {
190 radeon_object_unpin(vram_obj);
191 radeon_object_unref(&vram_obj);
192 }
193 if (gtt_obj) {
194 for (i = 0; i < n; i++) {
195 if (gtt_obj[i]) {
196 radeon_object_unpin(gtt_obj[i]);
197 radeon_object_unref(&gtt_obj[i]);
198 }
199 }
200 kfree(gtt_obj);
201 }
202 if (fence) {
203 radeon_fence_unref(&fence);
204 }
205 if (r) {
206 printk(KERN_WARNING "Error while testing BO move.\n");
207 }
208}
209
diff --git a/drivers/gpu/drm/radeon/radeon_ttm.c b/drivers/gpu/drm/radeon/radeon_ttm.c
index 1227a97f5169..15c3531377ed 100644
--- a/drivers/gpu/drm/radeon/radeon_ttm.c
+++ b/drivers/gpu/drm/radeon/radeon_ttm.c
@@ -355,23 +355,26 @@ static int radeon_bo_move(struct ttm_buffer_object *bo,
355 if (!rdev->cp.ready) { 355 if (!rdev->cp.ready) {
356 /* use memcpy */ 356 /* use memcpy */
357 DRM_ERROR("CP is not ready use memcpy.\n"); 357 DRM_ERROR("CP is not ready use memcpy.\n");
358 return ttm_bo_move_memcpy(bo, evict, no_wait, new_mem); 358 goto memcpy;
359 } 359 }
360 360
361 if (old_mem->mem_type == TTM_PL_VRAM && 361 if (old_mem->mem_type == TTM_PL_VRAM &&
362 new_mem->mem_type == TTM_PL_SYSTEM) { 362 new_mem->mem_type == TTM_PL_SYSTEM) {
363 return radeon_move_vram_ram(bo, evict, interruptible, 363 r = radeon_move_vram_ram(bo, evict, interruptible,
364 no_wait, new_mem); 364 no_wait, new_mem);
365 } else if (old_mem->mem_type == TTM_PL_SYSTEM && 365 } else if (old_mem->mem_type == TTM_PL_SYSTEM &&
366 new_mem->mem_type == TTM_PL_VRAM) { 366 new_mem->mem_type == TTM_PL_VRAM) {
367 return radeon_move_ram_vram(bo, evict, interruptible, 367 r = radeon_move_ram_vram(bo, evict, interruptible,
368 no_wait, new_mem); 368 no_wait, new_mem);
369 } else { 369 } else {
370 r = radeon_move_blit(bo, evict, no_wait, new_mem, old_mem); 370 r = radeon_move_blit(bo, evict, no_wait, new_mem, old_mem);
371 if (unlikely(r)) {
372 return r;
373 }
374 } 371 }
372
373 if (r) {
374memcpy:
375 r = ttm_bo_move_memcpy(bo, evict, no_wait, new_mem);
376 }
377
375 return r; 378 return r;
376} 379}
377 380
@@ -429,6 +432,8 @@ static struct ttm_bo_driver radeon_bo_driver = {
429 .sync_obj_flush = &radeon_sync_obj_flush, 432 .sync_obj_flush = &radeon_sync_obj_flush,
430 .sync_obj_unref = &radeon_sync_obj_unref, 433 .sync_obj_unref = &radeon_sync_obj_unref,
431 .sync_obj_ref = &radeon_sync_obj_ref, 434 .sync_obj_ref = &radeon_sync_obj_ref,
435 .move_notify = &radeon_bo_move_notify,
436 .fault_reserve_notify = &radeon_bo_fault_reserve_notify,
432}; 437};
433 438
434int radeon_ttm_init(struct radeon_device *rdev) 439int radeon_ttm_init(struct radeon_device *rdev)
@@ -442,13 +447,14 @@ int radeon_ttm_init(struct radeon_device *rdev)
442 /* No others user of address space so set it to 0 */ 447 /* No others user of address space so set it to 0 */
443 r = ttm_bo_device_init(&rdev->mman.bdev, 448 r = ttm_bo_device_init(&rdev->mman.bdev,
444 rdev->mman.mem_global_ref.object, 449 rdev->mman.mem_global_ref.object,
445 &radeon_bo_driver, DRM_FILE_PAGE_OFFSET); 450 &radeon_bo_driver, DRM_FILE_PAGE_OFFSET,
451 rdev->need_dma32);
446 if (r) { 452 if (r) {
447 DRM_ERROR("failed initializing buffer object driver(%d).\n", r); 453 DRM_ERROR("failed initializing buffer object driver(%d).\n", r);
448 return r; 454 return r;
449 } 455 }
450 r = ttm_bo_init_mm(&rdev->mman.bdev, TTM_PL_VRAM, 0, 456 r = ttm_bo_init_mm(&rdev->mman.bdev, TTM_PL_VRAM, 0,
451 ((rdev->mc.aper_size) >> PAGE_SHIFT)); 457 ((rdev->mc.real_vram_size) >> PAGE_SHIFT));
452 if (r) { 458 if (r) {
453 DRM_ERROR("Failed initializing VRAM heap.\n"); 459 DRM_ERROR("Failed initializing VRAM heap.\n");
454 return r; 460 return r;
@@ -465,7 +471,7 @@ int radeon_ttm_init(struct radeon_device *rdev)
465 return r; 471 return r;
466 } 472 }
467 DRM_INFO("radeon: %uM of VRAM memory ready\n", 473 DRM_INFO("radeon: %uM of VRAM memory ready\n",
468 rdev->mc.vram_size / (1024 * 1024)); 474 rdev->mc.real_vram_size / (1024 * 1024));
469 r = ttm_bo_init_mm(&rdev->mman.bdev, TTM_PL_TT, 0, 475 r = ttm_bo_init_mm(&rdev->mman.bdev, TTM_PL_TT, 0,
470 ((rdev->mc.gtt_size) >> PAGE_SHIFT)); 476 ((rdev->mc.gtt_size) >> PAGE_SHIFT));
471 if (r) { 477 if (r) {
diff --git a/drivers/gpu/drm/radeon/rs400.c b/drivers/gpu/drm/radeon/rs400.c
index cc074b5a8f74..b29affd9c5d8 100644
--- a/drivers/gpu/drm/radeon/rs400.c
+++ b/drivers/gpu/drm/radeon/rs400.c
@@ -29,6 +29,7 @@
29#include <drm/drmP.h> 29#include <drm/drmP.h>
30#include "radeon_reg.h" 30#include "radeon_reg.h"
31#include "radeon.h" 31#include "radeon.h"
32#include "radeon_share.h"
32 33
33/* rs400,rs480 depends on : */ 34/* rs400,rs480 depends on : */
34void r100_hdp_reset(struct radeon_device *rdev); 35void r100_hdp_reset(struct radeon_device *rdev);
@@ -164,7 +165,9 @@ int rs400_gart_enable(struct radeon_device *rdev)
164 WREG32(RADEON_BUS_CNTL, tmp); 165 WREG32(RADEON_BUS_CNTL, tmp);
165 } 166 }
166 /* Table should be in 32bits address space so ignore bits above. */ 167 /* Table should be in 32bits address space so ignore bits above. */
167 tmp = rdev->gart.table_addr & 0xfffff000; 168 tmp = (u32)rdev->gart.table_addr & 0xfffff000;
169 tmp |= (upper_32_bits(rdev->gart.table_addr) & 0xff) << 4;
170
168 WREG32_MC(RS480_GART_BASE, tmp); 171 WREG32_MC(RS480_GART_BASE, tmp);
169 /* TODO: more tweaking here */ 172 /* TODO: more tweaking here */
170 WREG32_MC(RS480_GART_FEATURE_ID, 173 WREG32_MC(RS480_GART_FEATURE_ID,
@@ -201,10 +204,17 @@ void rs400_gart_disable(struct radeon_device *rdev)
201 204
202int rs400_gart_set_page(struct radeon_device *rdev, int i, uint64_t addr) 205int rs400_gart_set_page(struct radeon_device *rdev, int i, uint64_t addr)
203{ 206{
207 uint32_t entry;
208
204 if (i < 0 || i > rdev->gart.num_gpu_pages) { 209 if (i < 0 || i > rdev->gart.num_gpu_pages) {
205 return -EINVAL; 210 return -EINVAL;
206 } 211 }
207 rdev->gart.table.ram.ptr[i] = cpu_to_le32(((uint32_t)addr) | 0xC); 212
213 entry = (lower_32_bits(addr) & PAGE_MASK) |
214 ((upper_32_bits(addr) & 0xff) << 4) |
215 0xc;
216 entry = cpu_to_le32(entry);
217 rdev->gart.table.ram.ptr[i] = entry;
208 return 0; 218 return 0;
209} 219}
210 220
@@ -223,10 +233,9 @@ int rs400_mc_init(struct radeon_device *rdev)
223 233
224 rs400_gpu_init(rdev); 234 rs400_gpu_init(rdev);
225 rs400_gart_disable(rdev); 235 rs400_gart_disable(rdev);
226 rdev->mc.gtt_location = rdev->mc.vram_size; 236 rdev->mc.gtt_location = rdev->mc.mc_vram_size;
227 rdev->mc.gtt_location += (rdev->mc.gtt_size - 1); 237 rdev->mc.gtt_location += (rdev->mc.gtt_size - 1);
228 rdev->mc.gtt_location &= ~(rdev->mc.gtt_size - 1); 238 rdev->mc.gtt_location &= ~(rdev->mc.gtt_size - 1);
229 rdev->mc.vram_location = 0xFFFFFFFFUL;
230 r = radeon_mc_setup(rdev); 239 r = radeon_mc_setup(rdev);
231 if (r) { 240 if (r) {
232 return r; 241 return r;
@@ -238,7 +247,7 @@ int rs400_mc_init(struct radeon_device *rdev)
238 "programming pipes. Bad things might happen.\n"); 247 "programming pipes. Bad things might happen.\n");
239 } 248 }
240 249
241 tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; 250 tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1;
242 tmp = REG_SET(RADEON_MC_FB_TOP, tmp >> 16); 251 tmp = REG_SET(RADEON_MC_FB_TOP, tmp >> 16);
243 tmp |= REG_SET(RADEON_MC_FB_START, rdev->mc.vram_location >> 16); 252 tmp |= REG_SET(RADEON_MC_FB_START, rdev->mc.vram_location >> 16);
244 WREG32(RADEON_MC_FB_LOCATION, tmp); 253 WREG32(RADEON_MC_FB_LOCATION, tmp);
@@ -284,21 +293,12 @@ void rs400_gpu_init(struct radeon_device *rdev)
284 */ 293 */
285void rs400_vram_info(struct radeon_device *rdev) 294void rs400_vram_info(struct radeon_device *rdev)
286{ 295{
287 uint32_t tom;
288
289 rs400_gart_adjust_size(rdev); 296 rs400_gart_adjust_size(rdev);
290 /* DDR for all card after R300 & IGP */ 297 /* DDR for all card after R300 & IGP */
291 rdev->mc.vram_is_ddr = true; 298 rdev->mc.vram_is_ddr = true;
292 rdev->mc.vram_width = 128; 299 rdev->mc.vram_width = 128;
293 300
294 /* read NB_TOM to get the amount of ram stolen for the GPU */ 301 r100_vram_init_sizes(rdev);
295 tom = RREG32(RADEON_NB_TOM);
296 rdev->mc.vram_size = (((tom >> 16) - (tom & 0xffff) + 1) << 16);
297 WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.vram_size);
298
299 /* Could aper size report 0 ? */
300 rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0);
301 rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0);
302} 302}
303 303
304 304
diff --git a/drivers/gpu/drm/radeon/rs600.c b/drivers/gpu/drm/radeon/rs600.c
index ab0c967553e6..bbea6dee4a94 100644
--- a/drivers/gpu/drm/radeon/rs600.c
+++ b/drivers/gpu/drm/radeon/rs600.c
@@ -223,7 +223,7 @@ int rs600_mc_init(struct radeon_device *rdev)
223 printk(KERN_WARNING "Failed to wait MC idle while " 223 printk(KERN_WARNING "Failed to wait MC idle while "
224 "programming pipes. Bad things might happen.\n"); 224 "programming pipes. Bad things might happen.\n");
225 } 225 }
226 tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; 226 tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1;
227 tmp = REG_SET(RS600_MC_FB_TOP, tmp >> 16); 227 tmp = REG_SET(RS600_MC_FB_TOP, tmp >> 16);
228 tmp |= REG_SET(RS600_MC_FB_START, rdev->mc.vram_location >> 16); 228 tmp |= REG_SET(RS600_MC_FB_START, rdev->mc.vram_location >> 16);
229 WREG32_MC(RS600_MC_FB_LOCATION, tmp); 229 WREG32_MC(RS600_MC_FB_LOCATION, tmp);
@@ -301,6 +301,11 @@ void rs600_vram_info(struct radeon_device *rdev)
301 rdev->mc.vram_width = 128; 301 rdev->mc.vram_width = 128;
302} 302}
303 303
304void rs600_bandwidth_update(struct radeon_device *rdev)
305{
306 /* FIXME: implement, should this be like rs690 ? */
307}
308
304 309
305/* 310/*
306 * Indirect registers accessor 311 * Indirect registers accessor
diff --git a/drivers/gpu/drm/radeon/rs690.c b/drivers/gpu/drm/radeon/rs690.c
index 79ba85042b5f..839595b00728 100644
--- a/drivers/gpu/drm/radeon/rs690.c
+++ b/drivers/gpu/drm/radeon/rs690.c
@@ -28,6 +28,9 @@
28#include "drmP.h" 28#include "drmP.h"
29#include "radeon_reg.h" 29#include "radeon_reg.h"
30#include "radeon.h" 30#include "radeon.h"
31#include "rs690r.h"
32#include "atom.h"
33#include "atom-bits.h"
31 34
32/* rs690,rs740 depends on : */ 35/* rs690,rs740 depends on : */
33void r100_hdp_reset(struct radeon_device *rdev); 36void r100_hdp_reset(struct radeon_device *rdev);
@@ -64,7 +67,7 @@ int rs690_mc_init(struct radeon_device *rdev)
64 rs400_gart_disable(rdev); 67 rs400_gart_disable(rdev);
65 68
66 /* Setup GPU memory space */ 69 /* Setup GPU memory space */
67 rdev->mc.gtt_location = rdev->mc.vram_size; 70 rdev->mc.gtt_location = rdev->mc.mc_vram_size;
68 rdev->mc.gtt_location += (rdev->mc.gtt_size - 1); 71 rdev->mc.gtt_location += (rdev->mc.gtt_size - 1);
69 rdev->mc.gtt_location &= ~(rdev->mc.gtt_size - 1); 72 rdev->mc.gtt_location &= ~(rdev->mc.gtt_size - 1);
70 rdev->mc.vram_location = 0xFFFFFFFFUL; 73 rdev->mc.vram_location = 0xFFFFFFFFUL;
@@ -79,7 +82,7 @@ int rs690_mc_init(struct radeon_device *rdev)
79 printk(KERN_WARNING "Failed to wait MC idle while " 82 printk(KERN_WARNING "Failed to wait MC idle while "
80 "programming pipes. Bad things might happen.\n"); 83 "programming pipes. Bad things might happen.\n");
81 } 84 }
82 tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; 85 tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1;
83 tmp = REG_SET(RS690_MC_FB_TOP, tmp >> 16); 86 tmp = REG_SET(RS690_MC_FB_TOP, tmp >> 16);
84 tmp |= REG_SET(RS690_MC_FB_START, rdev->mc.vram_location >> 16); 87 tmp |= REG_SET(RS690_MC_FB_START, rdev->mc.vram_location >> 16);
85 WREG32_MC(RS690_MCCFG_FB_LOCATION, tmp); 88 WREG32_MC(RS690_MCCFG_FB_LOCATION, tmp);
@@ -138,9 +141,82 @@ void rs690_gpu_init(struct radeon_device *rdev)
138/* 141/*
139 * VRAM info. 142 * VRAM info.
140 */ 143 */
144void rs690_pm_info(struct radeon_device *rdev)
145{
146 int index = GetIndexIntoMasterTable(DATA, IntegratedSystemInfo);
147 struct _ATOM_INTEGRATED_SYSTEM_INFO *info;
148 struct _ATOM_INTEGRATED_SYSTEM_INFO_V2 *info_v2;
149 void *ptr;
150 uint16_t data_offset;
151 uint8_t frev, crev;
152 fixed20_12 tmp;
153
154 atom_parse_data_header(rdev->mode_info.atom_context, index, NULL,
155 &frev, &crev, &data_offset);
156 ptr = rdev->mode_info.atom_context->bios + data_offset;
157 info = (struct _ATOM_INTEGRATED_SYSTEM_INFO *)ptr;
158 info_v2 = (struct _ATOM_INTEGRATED_SYSTEM_INFO_V2 *)ptr;
159 /* Get various system informations from bios */
160 switch (crev) {
161 case 1:
162 tmp.full = rfixed_const(100);
163 rdev->pm.igp_sideport_mclk.full = rfixed_const(info->ulBootUpMemoryClock);
164 rdev->pm.igp_sideport_mclk.full = rfixed_div(rdev->pm.igp_sideport_mclk, tmp);
165 rdev->pm.igp_system_mclk.full = rfixed_const(le16_to_cpu(info->usK8MemoryClock));
166 rdev->pm.igp_ht_link_clk.full = rfixed_const(le16_to_cpu(info->usFSBClock));
167 rdev->pm.igp_ht_link_width.full = rfixed_const(info->ucHTLinkWidth);
168 break;
169 case 2:
170 tmp.full = rfixed_const(100);
171 rdev->pm.igp_sideport_mclk.full = rfixed_const(info_v2->ulBootUpSidePortClock);
172 rdev->pm.igp_sideport_mclk.full = rfixed_div(rdev->pm.igp_sideport_mclk, tmp);
173 rdev->pm.igp_system_mclk.full = rfixed_const(info_v2->ulBootUpUMAClock);
174 rdev->pm.igp_system_mclk.full = rfixed_div(rdev->pm.igp_system_mclk, tmp);
175 rdev->pm.igp_ht_link_clk.full = rfixed_const(info_v2->ulHTLinkFreq);
176 rdev->pm.igp_ht_link_clk.full = rfixed_div(rdev->pm.igp_ht_link_clk, tmp);
177 rdev->pm.igp_ht_link_width.full = rfixed_const(le16_to_cpu(info_v2->usMinHTLinkWidth));
178 break;
179 default:
180 tmp.full = rfixed_const(100);
181 /* We assume the slower possible clock ie worst case */
182 /* DDR 333Mhz */
183 rdev->pm.igp_sideport_mclk.full = rfixed_const(333);
184 /* FIXME: system clock ? */
185 rdev->pm.igp_system_mclk.full = rfixed_const(100);
186 rdev->pm.igp_system_mclk.full = rfixed_div(rdev->pm.igp_system_mclk, tmp);
187 rdev->pm.igp_ht_link_clk.full = rfixed_const(200);
188 rdev->pm.igp_ht_link_width.full = rfixed_const(8);
189 DRM_ERROR("No integrated system info for your GPU, using safe default\n");
190 break;
191 }
192 /* Compute various bandwidth */
193 /* k8_bandwidth = (memory_clk / 2) * 2 * 8 * 0.5 = memory_clk * 4 */
194 tmp.full = rfixed_const(4);
195 rdev->pm.k8_bandwidth.full = rfixed_mul(rdev->pm.igp_system_mclk, tmp);
196 /* ht_bandwidth = ht_clk * 2 * ht_width / 8 * 0.8
197 * = ht_clk * ht_width / 5
198 */
199 tmp.full = rfixed_const(5);
200 rdev->pm.ht_bandwidth.full = rfixed_mul(rdev->pm.igp_ht_link_clk,
201 rdev->pm.igp_ht_link_width);
202 rdev->pm.ht_bandwidth.full = rfixed_div(rdev->pm.ht_bandwidth, tmp);
203 if (tmp.full < rdev->pm.max_bandwidth.full) {
204 /* HT link is a limiting factor */
205 rdev->pm.max_bandwidth.full = tmp.full;
206 }
207 /* sideport_bandwidth = (sideport_clk / 2) * 2 * 2 * 0.7
208 * = (sideport_clk * 14) / 10
209 */
210 tmp.full = rfixed_const(14);
211 rdev->pm.sideport_bandwidth.full = rfixed_mul(rdev->pm.igp_sideport_mclk, tmp);
212 tmp.full = rfixed_const(10);
213 rdev->pm.sideport_bandwidth.full = rfixed_div(rdev->pm.sideport_bandwidth, tmp);
214}
215
141void rs690_vram_info(struct radeon_device *rdev) 216void rs690_vram_info(struct radeon_device *rdev)
142{ 217{
143 uint32_t tmp; 218 uint32_t tmp;
219 fixed20_12 a;
144 220
145 rs400_gart_adjust_size(rdev); 221 rs400_gart_adjust_size(rdev);
146 /* DDR for all card after R300 & IGP */ 222 /* DDR for all card after R300 & IGP */
@@ -152,12 +228,409 @@ void rs690_vram_info(struct radeon_device *rdev)
152 } else { 228 } else {
153 rdev->mc.vram_width = 64; 229 rdev->mc.vram_width = 64;
154 } 230 }
155 rdev->mc.vram_size = RREG32(RADEON_CONFIG_MEMSIZE); 231 rdev->mc.real_vram_size = RREG32(RADEON_CONFIG_MEMSIZE);
232 rdev->mc.mc_vram_size = rdev->mc.real_vram_size;
156 233
157 rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); 234 rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0);
158 rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0); 235 rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0);
236 rs690_pm_info(rdev);
237 /* FIXME: we should enforce default clock in case GPU is not in
238 * default setup
239 */
240 a.full = rfixed_const(100);
241 rdev->pm.sclk.full = rfixed_const(rdev->clock.default_sclk);
242 rdev->pm.sclk.full = rfixed_div(rdev->pm.sclk, a);
243 a.full = rfixed_const(16);
244 /* core_bandwidth = sclk(Mhz) * 16 */
245 rdev->pm.core_bandwidth.full = rfixed_div(rdev->pm.sclk, a);
246}
247
248void rs690_line_buffer_adjust(struct radeon_device *rdev,
249 struct drm_display_mode *mode1,
250 struct drm_display_mode *mode2)
251{
252 u32 tmp;
253
254 /*
255 * Line Buffer Setup
256 * There is a single line buffer shared by both display controllers.
257 * DC_LB_MEMORY_SPLIT controls how that line buffer is shared between
258 * the display controllers. The paritioning can either be done
259 * manually or via one of four preset allocations specified in bits 1:0:
260 * 0 - line buffer is divided in half and shared between crtc
261 * 1 - D1 gets 3/4 of the line buffer, D2 gets 1/4
262 * 2 - D1 gets the whole buffer
263 * 3 - D1 gets 1/4 of the line buffer, D2 gets 3/4
264 * Setting bit 2 of DC_LB_MEMORY_SPLIT controls switches to manual
265 * allocation mode. In manual allocation mode, D1 always starts at 0,
266 * D1 end/2 is specified in bits 14:4; D2 allocation follows D1.
267 */
268 tmp = RREG32(DC_LB_MEMORY_SPLIT) & ~DC_LB_MEMORY_SPLIT_MASK;
269 tmp &= ~DC_LB_MEMORY_SPLIT_SHIFT_MODE;
270 /* auto */
271 if (mode1 && mode2) {
272 if (mode1->hdisplay > mode2->hdisplay) {
273 if (mode1->hdisplay > 2560)
274 tmp |= DC_LB_MEMORY_SPLIT_D1_3Q_D2_1Q;
275 else
276 tmp |= DC_LB_MEMORY_SPLIT_D1HALF_D2HALF;
277 } else if (mode2->hdisplay > mode1->hdisplay) {
278 if (mode2->hdisplay > 2560)
279 tmp |= DC_LB_MEMORY_SPLIT_D1_1Q_D2_3Q;
280 else
281 tmp |= DC_LB_MEMORY_SPLIT_D1HALF_D2HALF;
282 } else
283 tmp |= AVIVO_DC_LB_MEMORY_SPLIT_D1HALF_D2HALF;
284 } else if (mode1) {
285 tmp |= DC_LB_MEMORY_SPLIT_D1_ONLY;
286 } else if (mode2) {
287 tmp |= DC_LB_MEMORY_SPLIT_D1_1Q_D2_3Q;
288 }
289 WREG32(DC_LB_MEMORY_SPLIT, tmp);
159} 290}
160 291
292struct rs690_watermark {
293 u32 lb_request_fifo_depth;
294 fixed20_12 num_line_pair;
295 fixed20_12 estimated_width;
296 fixed20_12 worst_case_latency;
297 fixed20_12 consumption_rate;
298 fixed20_12 active_time;
299 fixed20_12 dbpp;
300 fixed20_12 priority_mark_max;
301 fixed20_12 priority_mark;
302 fixed20_12 sclk;
303};
304
305void rs690_crtc_bandwidth_compute(struct radeon_device *rdev,
306 struct radeon_crtc *crtc,
307 struct rs690_watermark *wm)
308{
309 struct drm_display_mode *mode = &crtc->base.mode;
310 fixed20_12 a, b, c;
311 fixed20_12 pclk, request_fifo_depth, tolerable_latency, estimated_width;
312 fixed20_12 consumption_time, line_time, chunk_time, read_delay_latency;
313 /* FIXME: detect IGP with sideport memory, i don't think there is any
314 * such product available
315 */
316 bool sideport = false;
317
318 if (!crtc->base.enabled) {
319 /* FIXME: wouldn't it better to set priority mark to maximum */
320 wm->lb_request_fifo_depth = 4;
321 return;
322 }
323
324 if (crtc->vsc.full > rfixed_const(2))
325 wm->num_line_pair.full = rfixed_const(2);
326 else
327 wm->num_line_pair.full = rfixed_const(1);
328
329 b.full = rfixed_const(mode->crtc_hdisplay);
330 c.full = rfixed_const(256);
331 a.full = rfixed_mul(wm->num_line_pair, b);
332 request_fifo_depth.full = rfixed_div(a, c);
333 if (a.full < rfixed_const(4)) {
334 wm->lb_request_fifo_depth = 4;
335 } else {
336 wm->lb_request_fifo_depth = rfixed_trunc(request_fifo_depth);
337 }
338
339 /* Determine consumption rate
340 * pclk = pixel clock period(ns) = 1000 / (mode.clock / 1000)
341 * vtaps = number of vertical taps,
342 * vsc = vertical scaling ratio, defined as source/destination
343 * hsc = horizontal scaling ration, defined as source/destination
344 */
345 a.full = rfixed_const(mode->clock);
346 b.full = rfixed_const(1000);
347 a.full = rfixed_div(a, b);
348 pclk.full = rfixed_div(b, a);
349 if (crtc->rmx_type != RMX_OFF) {
350 b.full = rfixed_const(2);
351 if (crtc->vsc.full > b.full)
352 b.full = crtc->vsc.full;
353 b.full = rfixed_mul(b, crtc->hsc);
354 c.full = rfixed_const(2);
355 b.full = rfixed_div(b, c);
356 consumption_time.full = rfixed_div(pclk, b);
357 } else {
358 consumption_time.full = pclk.full;
359 }
360 a.full = rfixed_const(1);
361 wm->consumption_rate.full = rfixed_div(a, consumption_time);
362
363
364 /* Determine line time
365 * LineTime = total time for one line of displayhtotal
366 * LineTime = total number of horizontal pixels
367 * pclk = pixel clock period(ns)
368 */
369 a.full = rfixed_const(crtc->base.mode.crtc_htotal);
370 line_time.full = rfixed_mul(a, pclk);
371
372 /* Determine active time
373 * ActiveTime = time of active region of display within one line,
374 * hactive = total number of horizontal active pixels
375 * htotal = total number of horizontal pixels
376 */
377 a.full = rfixed_const(crtc->base.mode.crtc_htotal);
378 b.full = rfixed_const(crtc->base.mode.crtc_hdisplay);
379 wm->active_time.full = rfixed_mul(line_time, b);
380 wm->active_time.full = rfixed_div(wm->active_time, a);
381
382 /* Maximun bandwidth is the minimun bandwidth of all component */
383 rdev->pm.max_bandwidth = rdev->pm.core_bandwidth;
384 if (sideport) {
385 if (rdev->pm.max_bandwidth.full > rdev->pm.sideport_bandwidth.full &&
386 rdev->pm.sideport_bandwidth.full)
387 rdev->pm.max_bandwidth = rdev->pm.sideport_bandwidth;
388 read_delay_latency.full = rfixed_const(370 * 800 * 1000);
389 read_delay_latency.full = rfixed_div(read_delay_latency,
390 rdev->pm.igp_sideport_mclk);
391 } else {
392 if (rdev->pm.max_bandwidth.full > rdev->pm.k8_bandwidth.full &&
393 rdev->pm.k8_bandwidth.full)
394 rdev->pm.max_bandwidth = rdev->pm.k8_bandwidth;
395 if (rdev->pm.max_bandwidth.full > rdev->pm.ht_bandwidth.full &&
396 rdev->pm.ht_bandwidth.full)
397 rdev->pm.max_bandwidth = rdev->pm.ht_bandwidth;
398 read_delay_latency.full = rfixed_const(5000);
399 }
400
401 /* sclk = system clocks(ns) = 1000 / max_bandwidth / 16 */
402 a.full = rfixed_const(16);
403 rdev->pm.sclk.full = rfixed_mul(rdev->pm.max_bandwidth, a);
404 a.full = rfixed_const(1000);
405 rdev->pm.sclk.full = rfixed_div(a, rdev->pm.sclk);
406 /* Determine chunk time
407 * ChunkTime = the time it takes the DCP to send one chunk of data
408 * to the LB which consists of pipeline delay and inter chunk gap
409 * sclk = system clock(ns)
410 */
411 a.full = rfixed_const(256 * 13);
412 chunk_time.full = rfixed_mul(rdev->pm.sclk, a);
413 a.full = rfixed_const(10);
414 chunk_time.full = rfixed_div(chunk_time, a);
415
416 /* Determine the worst case latency
417 * NumLinePair = Number of line pairs to request(1=2 lines, 2=4 lines)
418 * WorstCaseLatency = worst case time from urgent to when the MC starts
419 * to return data
420 * READ_DELAY_IDLE_MAX = constant of 1us
421 * ChunkTime = time it takes the DCP to send one chunk of data to the LB
422 * which consists of pipeline delay and inter chunk gap
423 */
424 if (rfixed_trunc(wm->num_line_pair) > 1) {
425 a.full = rfixed_const(3);
426 wm->worst_case_latency.full = rfixed_mul(a, chunk_time);
427 wm->worst_case_latency.full += read_delay_latency.full;
428 } else {
429 a.full = rfixed_const(2);
430 wm->worst_case_latency.full = rfixed_mul(a, chunk_time);
431 wm->worst_case_latency.full += read_delay_latency.full;
432 }
433
434 /* Determine the tolerable latency
435 * TolerableLatency = Any given request has only 1 line time
436 * for the data to be returned
437 * LBRequestFifoDepth = Number of chunk requests the LB can
438 * put into the request FIFO for a display
439 * LineTime = total time for one line of display
440 * ChunkTime = the time it takes the DCP to send one chunk
441 * of data to the LB which consists of
442 * pipeline delay and inter chunk gap
443 */
444 if ((2+wm->lb_request_fifo_depth) >= rfixed_trunc(request_fifo_depth)) {
445 tolerable_latency.full = line_time.full;
446 } else {
447 tolerable_latency.full = rfixed_const(wm->lb_request_fifo_depth - 2);
448 tolerable_latency.full = request_fifo_depth.full - tolerable_latency.full;
449 tolerable_latency.full = rfixed_mul(tolerable_latency, chunk_time);
450 tolerable_latency.full = line_time.full - tolerable_latency.full;
451 }
452 /* We assume worst case 32bits (4 bytes) */
453 wm->dbpp.full = rfixed_const(4 * 8);
454
455 /* Determine the maximum priority mark
456 * width = viewport width in pixels
457 */
458 a.full = rfixed_const(16);
459 wm->priority_mark_max.full = rfixed_const(crtc->base.mode.crtc_hdisplay);
460 wm->priority_mark_max.full = rfixed_div(wm->priority_mark_max, a);
461
462 /* Determine estimated width */
463 estimated_width.full = tolerable_latency.full - wm->worst_case_latency.full;
464 estimated_width.full = rfixed_div(estimated_width, consumption_time);
465 if (rfixed_trunc(estimated_width) > crtc->base.mode.crtc_hdisplay) {
466 wm->priority_mark.full = rfixed_const(10);
467 } else {
468 a.full = rfixed_const(16);
469 wm->priority_mark.full = rfixed_div(estimated_width, a);
470 wm->priority_mark.full = wm->priority_mark_max.full - wm->priority_mark.full;
471 }
472}
473
474void rs690_bandwidth_update(struct radeon_device *rdev)
475{
476 struct drm_display_mode *mode0 = NULL;
477 struct drm_display_mode *mode1 = NULL;
478 struct rs690_watermark wm0;
479 struct rs690_watermark wm1;
480 u32 tmp;
481 fixed20_12 priority_mark02, priority_mark12, fill_rate;
482 fixed20_12 a, b;
483
484 if (rdev->mode_info.crtcs[0]->base.enabled)
485 mode0 = &rdev->mode_info.crtcs[0]->base.mode;
486 if (rdev->mode_info.crtcs[1]->base.enabled)
487 mode1 = &rdev->mode_info.crtcs[1]->base.mode;
488 /*
489 * Set display0/1 priority up in the memory controller for
490 * modes if the user specifies HIGH for displaypriority
491 * option.
492 */
493 if (rdev->disp_priority == 2) {
494 tmp = RREG32_MC(MC_INIT_MISC_LAT_TIMER);
495 tmp &= ~MC_DISP1R_INIT_LAT_MASK;
496 tmp &= ~MC_DISP0R_INIT_LAT_MASK;
497 if (mode1)
498 tmp |= (1 << MC_DISP1R_INIT_LAT_SHIFT);
499 if (mode0)
500 tmp |= (1 << MC_DISP0R_INIT_LAT_SHIFT);
501 WREG32_MC(MC_INIT_MISC_LAT_TIMER, tmp);
502 }
503 rs690_line_buffer_adjust(rdev, mode0, mode1);
504
505 if ((rdev->family == CHIP_RS690) || (rdev->family == CHIP_RS740))
506 WREG32(DCP_CONTROL, 0);
507 if ((rdev->family == CHIP_RS780) || (rdev->family == CHIP_RS880))
508 WREG32(DCP_CONTROL, 2);
509
510 rs690_crtc_bandwidth_compute(rdev, rdev->mode_info.crtcs[0], &wm0);
511 rs690_crtc_bandwidth_compute(rdev, rdev->mode_info.crtcs[1], &wm1);
512
513 tmp = (wm0.lb_request_fifo_depth - 1);
514 tmp |= (wm1.lb_request_fifo_depth - 1) << 16;
515 WREG32(LB_MAX_REQ_OUTSTANDING, tmp);
516
517 if (mode0 && mode1) {
518 if (rfixed_trunc(wm0.dbpp) > 64)
519 a.full = rfixed_mul(wm0.dbpp, wm0.num_line_pair);
520 else
521 a.full = wm0.num_line_pair.full;
522 if (rfixed_trunc(wm1.dbpp) > 64)
523 b.full = rfixed_mul(wm1.dbpp, wm1.num_line_pair);
524 else
525 b.full = wm1.num_line_pair.full;
526 a.full += b.full;
527 fill_rate.full = rfixed_div(wm0.sclk, a);
528 if (wm0.consumption_rate.full > fill_rate.full) {
529 b.full = wm0.consumption_rate.full - fill_rate.full;
530 b.full = rfixed_mul(b, wm0.active_time);
531 a.full = rfixed_mul(wm0.worst_case_latency,
532 wm0.consumption_rate);
533 a.full = a.full + b.full;
534 b.full = rfixed_const(16 * 1000);
535 priority_mark02.full = rfixed_div(a, b);
536 } else {
537 a.full = rfixed_mul(wm0.worst_case_latency,
538 wm0.consumption_rate);
539 b.full = rfixed_const(16 * 1000);
540 priority_mark02.full = rfixed_div(a, b);
541 }
542 if (wm1.consumption_rate.full > fill_rate.full) {
543 b.full = wm1.consumption_rate.full - fill_rate.full;
544 b.full = rfixed_mul(b, wm1.active_time);
545 a.full = rfixed_mul(wm1.worst_case_latency,
546 wm1.consumption_rate);
547 a.full = a.full + b.full;
548 b.full = rfixed_const(16 * 1000);
549 priority_mark12.full = rfixed_div(a, b);
550 } else {
551 a.full = rfixed_mul(wm1.worst_case_latency,
552 wm1.consumption_rate);
553 b.full = rfixed_const(16 * 1000);
554 priority_mark12.full = rfixed_div(a, b);
555 }
556 if (wm0.priority_mark.full > priority_mark02.full)
557 priority_mark02.full = wm0.priority_mark.full;
558 if (rfixed_trunc(priority_mark02) < 0)
559 priority_mark02.full = 0;
560 if (wm0.priority_mark_max.full > priority_mark02.full)
561 priority_mark02.full = wm0.priority_mark_max.full;
562 if (wm1.priority_mark.full > priority_mark12.full)
563 priority_mark12.full = wm1.priority_mark.full;
564 if (rfixed_trunc(priority_mark12) < 0)
565 priority_mark12.full = 0;
566 if (wm1.priority_mark_max.full > priority_mark12.full)
567 priority_mark12.full = wm1.priority_mark_max.full;
568 WREG32(D1MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark02));
569 WREG32(D1MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark02));
570 WREG32(D2MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark12));
571 WREG32(D2MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark12));
572 } else if (mode0) {
573 if (rfixed_trunc(wm0.dbpp) > 64)
574 a.full = rfixed_mul(wm0.dbpp, wm0.num_line_pair);
575 else
576 a.full = wm0.num_line_pair.full;
577 fill_rate.full = rfixed_div(wm0.sclk, a);
578 if (wm0.consumption_rate.full > fill_rate.full) {
579 b.full = wm0.consumption_rate.full - fill_rate.full;
580 b.full = rfixed_mul(b, wm0.active_time);
581 a.full = rfixed_mul(wm0.worst_case_latency,
582 wm0.consumption_rate);
583 a.full = a.full + b.full;
584 b.full = rfixed_const(16 * 1000);
585 priority_mark02.full = rfixed_div(a, b);
586 } else {
587 a.full = rfixed_mul(wm0.worst_case_latency,
588 wm0.consumption_rate);
589 b.full = rfixed_const(16 * 1000);
590 priority_mark02.full = rfixed_div(a, b);
591 }
592 if (wm0.priority_mark.full > priority_mark02.full)
593 priority_mark02.full = wm0.priority_mark.full;
594 if (rfixed_trunc(priority_mark02) < 0)
595 priority_mark02.full = 0;
596 if (wm0.priority_mark_max.full > priority_mark02.full)
597 priority_mark02.full = wm0.priority_mark_max.full;
598 WREG32(D1MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark02));
599 WREG32(D1MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark02));
600 WREG32(D2MODE_PRIORITY_A_CNT, MODE_PRIORITY_OFF);
601 WREG32(D2MODE_PRIORITY_B_CNT, MODE_PRIORITY_OFF);
602 } else {
603 if (rfixed_trunc(wm1.dbpp) > 64)
604 a.full = rfixed_mul(wm1.dbpp, wm1.num_line_pair);
605 else
606 a.full = wm1.num_line_pair.full;
607 fill_rate.full = rfixed_div(wm1.sclk, a);
608 if (wm1.consumption_rate.full > fill_rate.full) {
609 b.full = wm1.consumption_rate.full - fill_rate.full;
610 b.full = rfixed_mul(b, wm1.active_time);
611 a.full = rfixed_mul(wm1.worst_case_latency,
612 wm1.consumption_rate);
613 a.full = a.full + b.full;
614 b.full = rfixed_const(16 * 1000);
615 priority_mark12.full = rfixed_div(a, b);
616 } else {
617 a.full = rfixed_mul(wm1.worst_case_latency,
618 wm1.consumption_rate);
619 b.full = rfixed_const(16 * 1000);
620 priority_mark12.full = rfixed_div(a, b);
621 }
622 if (wm1.priority_mark.full > priority_mark12.full)
623 priority_mark12.full = wm1.priority_mark.full;
624 if (rfixed_trunc(priority_mark12) < 0)
625 priority_mark12.full = 0;
626 if (wm1.priority_mark_max.full > priority_mark12.full)
627 priority_mark12.full = wm1.priority_mark_max.full;
628 WREG32(D1MODE_PRIORITY_A_CNT, MODE_PRIORITY_OFF);
629 WREG32(D1MODE_PRIORITY_B_CNT, MODE_PRIORITY_OFF);
630 WREG32(D2MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark12));
631 WREG32(D2MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark12));
632 }
633}
161 634
162/* 635/*
163 * Indirect registers accessor 636 * Indirect registers accessor
diff --git a/drivers/gpu/drm/radeon/rs690r.h b/drivers/gpu/drm/radeon/rs690r.h
new file mode 100644
index 000000000000..c0d9faa2175b
--- /dev/null
+++ b/drivers/gpu/drm/radeon/rs690r.h
@@ -0,0 +1,99 @@
1/*
2 * Copyright 2008 Advanced Micro Devices, Inc.
3 * Copyright 2008 Red Hat Inc.
4 * Copyright 2009 Jerome Glisse.
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the "Software"),
8 * to deal in the Software without restriction, including without limitation
9 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 * and/or sell copies of the Software, and to permit persons to whom the
11 * Software is furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
20 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
21 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
22 * OTHER DEALINGS IN THE SOFTWARE.
23 *
24 * Authors: Dave Airlie
25 * Alex Deucher
26 * Jerome Glisse
27 */
28#ifndef RS690R_H
29#define RS690R_H
30
31/* RS690/RS740 registers */
32#define MC_INDEX 0x0078
33# define MC_INDEX_MASK 0x1FF
34# define MC_INDEX_WR_EN (1 << 9)
35# define MC_INDEX_WR_ACK 0x7F
36#define MC_DATA 0x007C
37#define HDP_FB_LOCATION 0x0134
38#define DC_LB_MEMORY_SPLIT 0x6520
39#define DC_LB_MEMORY_SPLIT_MASK 0x00000003
40#define DC_LB_MEMORY_SPLIT_SHIFT 0
41#define DC_LB_MEMORY_SPLIT_D1HALF_D2HALF 0
42#define DC_LB_MEMORY_SPLIT_D1_3Q_D2_1Q 1
43#define DC_LB_MEMORY_SPLIT_D1_ONLY 2
44#define DC_LB_MEMORY_SPLIT_D1_1Q_D2_3Q 3
45#define DC_LB_MEMORY_SPLIT_SHIFT_MODE (1 << 2)
46#define DC_LB_DISP1_END_ADR_SHIFT 4
47#define DC_LB_DISP1_END_ADR_MASK 0x00007FF0
48#define D1MODE_PRIORITY_A_CNT 0x6548
49#define MODE_PRIORITY_MARK_MASK 0x00007FFF
50#define MODE_PRIORITY_OFF (1 << 16)
51#define MODE_PRIORITY_ALWAYS_ON (1 << 20)
52#define MODE_PRIORITY_FORCE_MASK (1 << 24)
53#define D1MODE_PRIORITY_B_CNT 0x654C
54#define LB_MAX_REQ_OUTSTANDING 0x6D58
55#define LB_D1_MAX_REQ_OUTSTANDING_MASK 0x0000000F
56#define LB_D1_MAX_REQ_OUTSTANDING_SHIFT 0
57#define LB_D2_MAX_REQ_OUTSTANDING_MASK 0x000F0000
58#define LB_D2_MAX_REQ_OUTSTANDING_SHIFT 16
59#define DCP_CONTROL 0x6C9C
60#define D2MODE_PRIORITY_A_CNT 0x6D48
61#define D2MODE_PRIORITY_B_CNT 0x6D4C
62
63/* MC indirect registers */
64#define MC_STATUS_IDLE (1 << 0)
65#define MC_MISC_CNTL 0x18
66#define DISABLE_GTW (1 << 1)
67#define GART_INDEX_REG_EN (1 << 12)
68#define BLOCK_GFX_D3_EN (1 << 14)
69#define GART_FEATURE_ID 0x2B
70#define HANG_EN (1 << 11)
71#define TLB_ENABLE (1 << 18)
72#define P2P_ENABLE (1 << 19)
73#define GTW_LAC_EN (1 << 25)
74#define LEVEL2_GART (0 << 30)
75#define LEVEL1_GART (1 << 30)
76#define PDC_EN (1 << 31)
77#define GART_BASE 0x2C
78#define GART_CACHE_CNTRL 0x2E
79# define GART_CACHE_INVALIDATE (1 << 0)
80#define MC_STATUS 0x90
81#define MCCFG_FB_LOCATION 0x100
82#define MC_FB_START_MASK 0x0000FFFF
83#define MC_FB_START_SHIFT 0
84#define MC_FB_TOP_MASK 0xFFFF0000
85#define MC_FB_TOP_SHIFT 16
86#define MCCFG_AGP_LOCATION 0x101
87#define MC_AGP_START_MASK 0x0000FFFF
88#define MC_AGP_START_SHIFT 0
89#define MC_AGP_TOP_MASK 0xFFFF0000
90#define MC_AGP_TOP_SHIFT 16
91#define MCCFG_AGP_BASE 0x102
92#define MCCFG_AGP_BASE_2 0x103
93#define MC_INIT_MISC_LAT_TIMER 0x104
94#define MC_DISP0R_INIT_LAT_SHIFT 8
95#define MC_DISP0R_INIT_LAT_MASK 0x00000F00
96#define MC_DISP1R_INIT_LAT_SHIFT 12
97#define MC_DISP1R_INIT_LAT_MASK 0x0000F000
98
99#endif
diff --git a/drivers/gpu/drm/radeon/rv515.c b/drivers/gpu/drm/radeon/rv515.c
index ffea37b1b3e2..551e608702e4 100644
--- a/drivers/gpu/drm/radeon/rv515.c
+++ b/drivers/gpu/drm/radeon/rv515.c
@@ -27,8 +27,9 @@
27 */ 27 */
28#include <linux/seq_file.h> 28#include <linux/seq_file.h>
29#include "drmP.h" 29#include "drmP.h"
30#include "radeon_reg.h" 30#include "rv515r.h"
31#include "radeon.h" 31#include "radeon.h"
32#include "radeon_share.h"
32 33
33/* rv515 depends on : */ 34/* rv515 depends on : */
34void r100_hdp_reset(struct radeon_device *rdev); 35void r100_hdp_reset(struct radeon_device *rdev);
@@ -99,26 +100,26 @@ int rv515_mc_init(struct radeon_device *rdev)
99 "programming pipes. Bad things might happen.\n"); 100 "programming pipes. Bad things might happen.\n");
100 } 101 }
101 /* Write VRAM size in case we are limiting it */ 102 /* Write VRAM size in case we are limiting it */
102 WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.vram_size); 103 WREG32(RADEON_CONFIG_MEMSIZE, rdev->mc.real_vram_size);
103 tmp = REG_SET(RV515_MC_FB_START, rdev->mc.vram_location >> 16); 104 tmp = REG_SET(MC_FB_START, rdev->mc.vram_location >> 16);
104 WREG32(0x134, tmp); 105 WREG32(0x134, tmp);
105 tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; 106 tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1;
106 tmp = REG_SET(RV515_MC_FB_TOP, tmp >> 16); 107 tmp = REG_SET(MC_FB_TOP, tmp >> 16);
107 tmp |= REG_SET(RV515_MC_FB_START, rdev->mc.vram_location >> 16); 108 tmp |= REG_SET(MC_FB_START, rdev->mc.vram_location >> 16);
108 WREG32_MC(RV515_MC_FB_LOCATION, tmp); 109 WREG32_MC(MC_FB_LOCATION, tmp);
109 WREG32(RS690_HDP_FB_LOCATION, rdev->mc.vram_location >> 16); 110 WREG32(HDP_FB_LOCATION, rdev->mc.vram_location >> 16);
110 WREG32(0x310, rdev->mc.vram_location); 111 WREG32(0x310, rdev->mc.vram_location);
111 if (rdev->flags & RADEON_IS_AGP) { 112 if (rdev->flags & RADEON_IS_AGP) {
112 tmp = rdev->mc.gtt_location + rdev->mc.gtt_size - 1; 113 tmp = rdev->mc.gtt_location + rdev->mc.gtt_size - 1;
113 tmp = REG_SET(RV515_MC_AGP_TOP, tmp >> 16); 114 tmp = REG_SET(MC_AGP_TOP, tmp >> 16);
114 tmp |= REG_SET(RV515_MC_AGP_START, rdev->mc.gtt_location >> 16); 115 tmp |= REG_SET(MC_AGP_START, rdev->mc.gtt_location >> 16);
115 WREG32_MC(RV515_MC_AGP_LOCATION, tmp); 116 WREG32_MC(MC_AGP_LOCATION, tmp);
116 WREG32_MC(RV515_MC_AGP_BASE, rdev->mc.agp_base); 117 WREG32_MC(MC_AGP_BASE, rdev->mc.agp_base);
117 WREG32_MC(RV515_MC_AGP_BASE_2, 0); 118 WREG32_MC(MC_AGP_BASE_2, 0);
118 } else { 119 } else {
119 WREG32_MC(RV515_MC_AGP_LOCATION, 0x0FFFFFFF); 120 WREG32_MC(MC_AGP_LOCATION, 0x0FFFFFFF);
120 WREG32_MC(RV515_MC_AGP_BASE, 0); 121 WREG32_MC(MC_AGP_BASE, 0);
121 WREG32_MC(RV515_MC_AGP_BASE_2, 0); 122 WREG32_MC(MC_AGP_BASE_2, 0);
122 } 123 }
123 return 0; 124 return 0;
124} 125}
@@ -136,95 +137,67 @@ void rv515_mc_fini(struct radeon_device *rdev)
136 */ 137 */
137void rv515_ring_start(struct radeon_device *rdev) 138void rv515_ring_start(struct radeon_device *rdev)
138{ 139{
139 unsigned gb_tile_config;
140 int r; 140 int r;
141 141
142 /* Sub pixel 1/12 so we can have 4K rendering according to doc */
143 gb_tile_config = R300_ENABLE_TILING | R300_TILE_SIZE_16;
144 switch (rdev->num_gb_pipes) {
145 case 2:
146 gb_tile_config |= R300_PIPE_COUNT_R300;
147 break;
148 case 3:
149 gb_tile_config |= R300_PIPE_COUNT_R420_3P;
150 break;
151 case 4:
152 gb_tile_config |= R300_PIPE_COUNT_R420;
153 break;
154 case 1:
155 default:
156 gb_tile_config |= R300_PIPE_COUNT_RV350;
157 break;
158 }
159
160 r = radeon_ring_lock(rdev, 64); 142 r = radeon_ring_lock(rdev, 64);
161 if (r) { 143 if (r) {
162 return; 144 return;
163 } 145 }
164 radeon_ring_write(rdev, PACKET0(RADEON_ISYNC_CNTL, 0)); 146 radeon_ring_write(rdev, PACKET0(ISYNC_CNTL, 0));
165 radeon_ring_write(rdev,
166 RADEON_ISYNC_ANY2D_IDLE3D |
167 RADEON_ISYNC_ANY3D_IDLE2D |
168 RADEON_ISYNC_WAIT_IDLEGUI |
169 RADEON_ISYNC_CPSCRATCH_IDLEGUI);
170 radeon_ring_write(rdev, PACKET0(R300_GB_TILE_CONFIG, 0));
171 radeon_ring_write(rdev, gb_tile_config);
172 radeon_ring_write(rdev, PACKET0(RADEON_WAIT_UNTIL, 0));
173 radeon_ring_write(rdev, 147 radeon_ring_write(rdev,
174 RADEON_WAIT_2D_IDLECLEAN | 148 ISYNC_ANY2D_IDLE3D |
175 RADEON_WAIT_3D_IDLECLEAN); 149 ISYNC_ANY3D_IDLE2D |
150 ISYNC_WAIT_IDLEGUI |
151 ISYNC_CPSCRATCH_IDLEGUI);
152 radeon_ring_write(rdev, PACKET0(WAIT_UNTIL, 0));
153 radeon_ring_write(rdev, WAIT_2D_IDLECLEAN | WAIT_3D_IDLECLEAN);
176 radeon_ring_write(rdev, PACKET0(0x170C, 0)); 154 radeon_ring_write(rdev, PACKET0(0x170C, 0));
177 radeon_ring_write(rdev, 1 << 31); 155 radeon_ring_write(rdev, 1 << 31);
178 radeon_ring_write(rdev, PACKET0(R300_GB_SELECT, 0)); 156 radeon_ring_write(rdev, PACKET0(GB_SELECT, 0));
179 radeon_ring_write(rdev, 0); 157 radeon_ring_write(rdev, 0);
180 radeon_ring_write(rdev, PACKET0(R300_GB_ENABLE, 0)); 158 radeon_ring_write(rdev, PACKET0(GB_ENABLE, 0));
181 radeon_ring_write(rdev, 0); 159 radeon_ring_write(rdev, 0);
182 radeon_ring_write(rdev, PACKET0(0x42C8, 0)); 160 radeon_ring_write(rdev, PACKET0(0x42C8, 0));
183 radeon_ring_write(rdev, (1 << rdev->num_gb_pipes) - 1); 161 radeon_ring_write(rdev, (1 << rdev->num_gb_pipes) - 1);
184 radeon_ring_write(rdev, PACKET0(R500_VAP_INDEX_OFFSET, 0)); 162 radeon_ring_write(rdev, PACKET0(VAP_INDEX_OFFSET, 0));
185 radeon_ring_write(rdev, 0); 163 radeon_ring_write(rdev, 0);
186 radeon_ring_write(rdev, PACKET0(R300_RB3D_DSTCACHE_CTLSTAT, 0)); 164 radeon_ring_write(rdev, PACKET0(RB3D_DSTCACHE_CTLSTAT, 0));
187 radeon_ring_write(rdev, R300_RB3D_DC_FLUSH | R300_RB3D_DC_FREE); 165 radeon_ring_write(rdev, RB3D_DC_FLUSH | RB3D_DC_FREE);
188 radeon_ring_write(rdev, PACKET0(R300_RB3D_ZCACHE_CTLSTAT, 0)); 166 radeon_ring_write(rdev, PACKET0(ZB_ZCACHE_CTLSTAT, 0));
189 radeon_ring_write(rdev, R300_ZC_FLUSH | R300_ZC_FREE); 167 radeon_ring_write(rdev, ZC_FLUSH | ZC_FREE);
190 radeon_ring_write(rdev, PACKET0(RADEON_WAIT_UNTIL, 0)); 168 radeon_ring_write(rdev, PACKET0(WAIT_UNTIL, 0));
191 radeon_ring_write(rdev, 169 radeon_ring_write(rdev, WAIT_2D_IDLECLEAN | WAIT_3D_IDLECLEAN);
192 RADEON_WAIT_2D_IDLECLEAN | 170 radeon_ring_write(rdev, PACKET0(GB_AA_CONFIG, 0));
193 RADEON_WAIT_3D_IDLECLEAN);
194 radeon_ring_write(rdev, PACKET0(R300_GB_AA_CONFIG, 0));
195 radeon_ring_write(rdev, 0); 171 radeon_ring_write(rdev, 0);
196 radeon_ring_write(rdev, PACKET0(R300_RB3D_DSTCACHE_CTLSTAT, 0)); 172 radeon_ring_write(rdev, PACKET0(RB3D_DSTCACHE_CTLSTAT, 0));
197 radeon_ring_write(rdev, R300_RB3D_DC_FLUSH | R300_RB3D_DC_FREE); 173 radeon_ring_write(rdev, RB3D_DC_FLUSH | RB3D_DC_FREE);
198 radeon_ring_write(rdev, PACKET0(R300_RB3D_ZCACHE_CTLSTAT, 0)); 174 radeon_ring_write(rdev, PACKET0(ZB_ZCACHE_CTLSTAT, 0));
199 radeon_ring_write(rdev, R300_ZC_FLUSH | R300_ZC_FREE); 175 radeon_ring_write(rdev, ZC_FLUSH | ZC_FREE);
200 radeon_ring_write(rdev, PACKET0(R300_GB_MSPOS0, 0)); 176 radeon_ring_write(rdev, PACKET0(GB_MSPOS0, 0));
201 radeon_ring_write(rdev,
202 ((6 << R300_MS_X0_SHIFT) |
203 (6 << R300_MS_Y0_SHIFT) |
204 (6 << R300_MS_X1_SHIFT) |
205 (6 << R300_MS_Y1_SHIFT) |
206 (6 << R300_MS_X2_SHIFT) |
207 (6 << R300_MS_Y2_SHIFT) |
208 (6 << R300_MSBD0_Y_SHIFT) |
209 (6 << R300_MSBD0_X_SHIFT)));
210 radeon_ring_write(rdev, PACKET0(R300_GB_MSPOS1, 0));
211 radeon_ring_write(rdev, 177 radeon_ring_write(rdev,
212 ((6 << R300_MS_X3_SHIFT) | 178 ((6 << MS_X0_SHIFT) |
213 (6 << R300_MS_Y3_SHIFT) | 179 (6 << MS_Y0_SHIFT) |
214 (6 << R300_MS_X4_SHIFT) | 180 (6 << MS_X1_SHIFT) |
215 (6 << R300_MS_Y4_SHIFT) | 181 (6 << MS_Y1_SHIFT) |
216 (6 << R300_MS_X5_SHIFT) | 182 (6 << MS_X2_SHIFT) |
217 (6 << R300_MS_Y5_SHIFT) | 183 (6 << MS_Y2_SHIFT) |
218 (6 << R300_MSBD1_SHIFT))); 184 (6 << MSBD0_Y_SHIFT) |
219 radeon_ring_write(rdev, PACKET0(R300_GA_ENHANCE, 0)); 185 (6 << MSBD0_X_SHIFT)));
220 radeon_ring_write(rdev, R300_GA_DEADLOCK_CNTL | R300_GA_FASTSYNC_CNTL); 186 radeon_ring_write(rdev, PACKET0(GB_MSPOS1, 0));
221 radeon_ring_write(rdev, PACKET0(R300_GA_POLY_MODE, 0));
222 radeon_ring_write(rdev, 187 radeon_ring_write(rdev,
223 R300_FRONT_PTYPE_TRIANGE | R300_BACK_PTYPE_TRIANGE); 188 ((6 << MS_X3_SHIFT) |
224 radeon_ring_write(rdev, PACKET0(R300_GA_ROUND_MODE, 0)); 189 (6 << MS_Y3_SHIFT) |
225 radeon_ring_write(rdev, 190 (6 << MS_X4_SHIFT) |
226 R300_GEOMETRY_ROUND_NEAREST | 191 (6 << MS_Y4_SHIFT) |
227 R300_COLOR_ROUND_NEAREST); 192 (6 << MS_X5_SHIFT) |
193 (6 << MS_Y5_SHIFT) |
194 (6 << MSBD1_SHIFT)));
195 radeon_ring_write(rdev, PACKET0(GA_ENHANCE, 0));
196 radeon_ring_write(rdev, GA_DEADLOCK_CNTL | GA_FASTSYNC_CNTL);
197 radeon_ring_write(rdev, PACKET0(GA_POLY_MODE, 0));
198 radeon_ring_write(rdev, FRONT_PTYPE_TRIANGE | BACK_PTYPE_TRIANGE);
199 radeon_ring_write(rdev, PACKET0(GA_ROUND_MODE, 0));
200 radeon_ring_write(rdev, GEOMETRY_ROUND_NEAREST | COLOR_ROUND_NEAREST);
228 radeon_ring_write(rdev, PACKET0(0x20C8, 0)); 201 radeon_ring_write(rdev, PACKET0(0x20C8, 0));
229 radeon_ring_write(rdev, 0); 202 radeon_ring_write(rdev, 0);
230 radeon_ring_unlock_commit(rdev); 203 radeon_ring_unlock_commit(rdev);
@@ -242,8 +215,8 @@ int rv515_mc_wait_for_idle(struct radeon_device *rdev)
242 215
243 for (i = 0; i < rdev->usec_timeout; i++) { 216 for (i = 0; i < rdev->usec_timeout; i++) {
244 /* read MC_STATUS */ 217 /* read MC_STATUS */
245 tmp = RREG32_MC(RV515_MC_STATUS); 218 tmp = RREG32_MC(MC_STATUS);
246 if (tmp & RV515_MC_STATUS_IDLE) { 219 if (tmp & MC_STATUS_IDLE) {
247 return 0; 220 return 0;
248 } 221 }
249 DRM_UDELAY(1); 222 DRM_UDELAY(1);
@@ -291,33 +264,33 @@ int rv515_ga_reset(struct radeon_device *rdev)
291 reinit_cp = rdev->cp.ready; 264 reinit_cp = rdev->cp.ready;
292 rdev->cp.ready = false; 265 rdev->cp.ready = false;
293 for (i = 0; i < rdev->usec_timeout; i++) { 266 for (i = 0; i < rdev->usec_timeout; i++) {
294 WREG32(RADEON_CP_CSQ_MODE, 0); 267 WREG32(CP_CSQ_MODE, 0);
295 WREG32(RADEON_CP_CSQ_CNTL, 0); 268 WREG32(CP_CSQ_CNTL, 0);
296 WREG32(RADEON_RBBM_SOFT_RESET, 0x32005); 269 WREG32(RBBM_SOFT_RESET, 0x32005);
297 (void)RREG32(RADEON_RBBM_SOFT_RESET); 270 (void)RREG32(RBBM_SOFT_RESET);
298 udelay(200); 271 udelay(200);
299 WREG32(RADEON_RBBM_SOFT_RESET, 0); 272 WREG32(RBBM_SOFT_RESET, 0);
300 /* Wait to prevent race in RBBM_STATUS */ 273 /* Wait to prevent race in RBBM_STATUS */
301 mdelay(1); 274 mdelay(1);
302 tmp = RREG32(RADEON_RBBM_STATUS); 275 tmp = RREG32(RBBM_STATUS);
303 if (tmp & ((1 << 20) | (1 << 26))) { 276 if (tmp & ((1 << 20) | (1 << 26))) {
304 DRM_ERROR("VAP & CP still busy (RBBM_STATUS=0x%08X)\n", tmp); 277 DRM_ERROR("VAP & CP still busy (RBBM_STATUS=0x%08X)\n", tmp);
305 /* GA still busy soft reset it */ 278 /* GA still busy soft reset it */
306 WREG32(0x429C, 0x200); 279 WREG32(0x429C, 0x200);
307 WREG32(R300_VAP_PVS_STATE_FLUSH_REG, 0); 280 WREG32(VAP_PVS_STATE_FLUSH_REG, 0);
308 WREG32(0x43E0, 0); 281 WREG32(0x43E0, 0);
309 WREG32(0x43E4, 0); 282 WREG32(0x43E4, 0);
310 WREG32(0x24AC, 0); 283 WREG32(0x24AC, 0);
311 } 284 }
312 /* Wait to prevent race in RBBM_STATUS */ 285 /* Wait to prevent race in RBBM_STATUS */
313 mdelay(1); 286 mdelay(1);
314 tmp = RREG32(RADEON_RBBM_STATUS); 287 tmp = RREG32(RBBM_STATUS);
315 if (!(tmp & ((1 << 20) | (1 << 26)))) { 288 if (!(tmp & ((1 << 20) | (1 << 26)))) {
316 break; 289 break;
317 } 290 }
318 } 291 }
319 for (i = 0; i < rdev->usec_timeout; i++) { 292 for (i = 0; i < rdev->usec_timeout; i++) {
320 tmp = RREG32(RADEON_RBBM_STATUS); 293 tmp = RREG32(RBBM_STATUS);
321 if (!(tmp & ((1 << 20) | (1 << 26)))) { 294 if (!(tmp & ((1 << 20) | (1 << 26)))) {
322 DRM_INFO("GA reset succeed (RBBM_STATUS=0x%08X)\n", 295 DRM_INFO("GA reset succeed (RBBM_STATUS=0x%08X)\n",
323 tmp); 296 tmp);
@@ -331,7 +304,7 @@ int rv515_ga_reset(struct radeon_device *rdev)
331 } 304 }
332 DRM_UDELAY(1); 305 DRM_UDELAY(1);
333 } 306 }
334 tmp = RREG32(RADEON_RBBM_STATUS); 307 tmp = RREG32(RBBM_STATUS);
335 DRM_ERROR("Failed to reset GA ! (RBBM_STATUS=0x%08X)\n", tmp); 308 DRM_ERROR("Failed to reset GA ! (RBBM_STATUS=0x%08X)\n", tmp);
336 return -1; 309 return -1;
337} 310}
@@ -341,7 +314,7 @@ int rv515_gpu_reset(struct radeon_device *rdev)
341 uint32_t status; 314 uint32_t status;
342 315
343 /* reset order likely matter */ 316 /* reset order likely matter */
344 status = RREG32(RADEON_RBBM_STATUS); 317 status = RREG32(RBBM_STATUS);
345 /* reset HDP */ 318 /* reset HDP */
346 r100_hdp_reset(rdev); 319 r100_hdp_reset(rdev);
347 /* reset rb2d */ 320 /* reset rb2d */
@@ -353,12 +326,12 @@ int rv515_gpu_reset(struct radeon_device *rdev)
353 rv515_ga_reset(rdev); 326 rv515_ga_reset(rdev);
354 } 327 }
355 /* reset CP */ 328 /* reset CP */
356 status = RREG32(RADEON_RBBM_STATUS); 329 status = RREG32(RBBM_STATUS);
357 if (status & (1 << 16)) { 330 if (status & (1 << 16)) {
358 r100_cp_reset(rdev); 331 r100_cp_reset(rdev);
359 } 332 }
360 /* Check if GPU is idle */ 333 /* Check if GPU is idle */
361 status = RREG32(RADEON_RBBM_STATUS); 334 status = RREG32(RBBM_STATUS);
362 if (status & (1 << 31)) { 335 if (status & (1 << 31)) {
363 DRM_ERROR("Failed to reset GPU (RBBM_STATUS=0x%08X)\n", status); 336 DRM_ERROR("Failed to reset GPU (RBBM_STATUS=0x%08X)\n", status);
364 return -1; 337 return -1;
@@ -377,8 +350,7 @@ static void rv515_vram_get_type(struct radeon_device *rdev)
377 350
378 rdev->mc.vram_width = 128; 351 rdev->mc.vram_width = 128;
379 rdev->mc.vram_is_ddr = true; 352 rdev->mc.vram_is_ddr = true;
380 tmp = RREG32_MC(RV515_MC_CNTL); 353 tmp = RREG32_MC(RV515_MC_CNTL) & MEM_NUM_CHANNELS_MASK;
381 tmp &= RV515_MEM_NUM_CHANNELS_MASK;
382 switch (tmp) { 354 switch (tmp) {
383 case 0: 355 case 0:
384 rdev->mc.vram_width = 64; 356 rdev->mc.vram_width = 64;
@@ -394,11 +366,16 @@ static void rv515_vram_get_type(struct radeon_device *rdev)
394 366
395void rv515_vram_info(struct radeon_device *rdev) 367void rv515_vram_info(struct radeon_device *rdev)
396{ 368{
369 fixed20_12 a;
370
397 rv515_vram_get_type(rdev); 371 rv515_vram_get_type(rdev);
398 rdev->mc.vram_size = RREG32(RADEON_CONFIG_MEMSIZE);
399 372
400 rdev->mc.aper_base = drm_get_resource_start(rdev->ddev, 0); 373 /* FIXME: we should enforce default clock in case GPU is not in
401 rdev->mc.aper_size = drm_get_resource_len(rdev->ddev, 0); 374 * default setup
375 */
376 a.full = rfixed_const(100);
377 rdev->pm.sclk.full = rfixed_const(rdev->clock.default_sclk);
378 rdev->pm.sclk.full = rfixed_div(rdev->pm.sclk, a);
402} 379}
403 380
404 381
@@ -409,35 +386,35 @@ uint32_t rv515_mc_rreg(struct radeon_device *rdev, uint32_t reg)
409{ 386{
410 uint32_t r; 387 uint32_t r;
411 388
412 WREG32(R520_MC_IND_INDEX, 0x7f0000 | (reg & 0xffff)); 389 WREG32(MC_IND_INDEX, 0x7f0000 | (reg & 0xffff));
413 r = RREG32(R520_MC_IND_DATA); 390 r = RREG32(MC_IND_DATA);
414 WREG32(R520_MC_IND_INDEX, 0); 391 WREG32(MC_IND_INDEX, 0);
415 return r; 392 return r;
416} 393}
417 394
418void rv515_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v) 395void rv515_mc_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v)
419{ 396{
420 WREG32(R520_MC_IND_INDEX, 0xff0000 | ((reg) & 0xffff)); 397 WREG32(MC_IND_INDEX, 0xff0000 | ((reg) & 0xffff));
421 WREG32(R520_MC_IND_DATA, (v)); 398 WREG32(MC_IND_DATA, (v));
422 WREG32(R520_MC_IND_INDEX, 0); 399 WREG32(MC_IND_INDEX, 0);
423} 400}
424 401
425uint32_t rv515_pcie_rreg(struct radeon_device *rdev, uint32_t reg) 402uint32_t rv515_pcie_rreg(struct radeon_device *rdev, uint32_t reg)
426{ 403{
427 uint32_t r; 404 uint32_t r;
428 405
429 WREG32(RADEON_PCIE_INDEX, ((reg) & 0x7ff)); 406 WREG32(PCIE_INDEX, ((reg) & 0x7ff));
430 (void)RREG32(RADEON_PCIE_INDEX); 407 (void)RREG32(PCIE_INDEX);
431 r = RREG32(RADEON_PCIE_DATA); 408 r = RREG32(PCIE_DATA);
432 return r; 409 return r;
433} 410}
434 411
435void rv515_pcie_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v) 412void rv515_pcie_wreg(struct radeon_device *rdev, uint32_t reg, uint32_t v)
436{ 413{
437 WREG32(RADEON_PCIE_INDEX, ((reg) & 0x7ff)); 414 WREG32(PCIE_INDEX, ((reg) & 0x7ff));
438 (void)RREG32(RADEON_PCIE_INDEX); 415 (void)RREG32(PCIE_INDEX);
439 WREG32(RADEON_PCIE_DATA, (v)); 416 WREG32(PCIE_DATA, (v));
440 (void)RREG32(RADEON_PCIE_DATA); 417 (void)RREG32(PCIE_DATA);
441} 418}
442 419
443 420
@@ -452,13 +429,13 @@ static int rv515_debugfs_pipes_info(struct seq_file *m, void *data)
452 struct radeon_device *rdev = dev->dev_private; 429 struct radeon_device *rdev = dev->dev_private;
453 uint32_t tmp; 430 uint32_t tmp;
454 431
455 tmp = RREG32(R400_GB_PIPE_SELECT); 432 tmp = RREG32(GB_PIPE_SELECT);
456 seq_printf(m, "GB_PIPE_SELECT 0x%08x\n", tmp); 433 seq_printf(m, "GB_PIPE_SELECT 0x%08x\n", tmp);
457 tmp = RREG32(R500_SU_REG_DEST); 434 tmp = RREG32(SU_REG_DEST);
458 seq_printf(m, "SU_REG_DEST 0x%08x\n", tmp); 435 seq_printf(m, "SU_REG_DEST 0x%08x\n", tmp);
459 tmp = RREG32(R300_GB_TILE_CONFIG); 436 tmp = RREG32(GB_TILE_CONFIG);
460 seq_printf(m, "GB_TILE_CONFIG 0x%08x\n", tmp); 437 seq_printf(m, "GB_TILE_CONFIG 0x%08x\n", tmp);
461 tmp = RREG32(R300_DST_PIPE_CONFIG); 438 tmp = RREG32(DST_PIPE_CONFIG);
462 seq_printf(m, "DST_PIPE_CONFIG 0x%08x\n", tmp); 439 seq_printf(m, "DST_PIPE_CONFIG 0x%08x\n", tmp);
463 return 0; 440 return 0;
464} 441}
@@ -509,9 +486,9 @@ int rv515_debugfs_ga_info_init(struct radeon_device *rdev)
509/* 486/*
510 * Asic initialization 487 * Asic initialization
511 */ 488 */
512static const unsigned r500_reg_safe_bm[159] = { 489static const unsigned r500_reg_safe_bm[219] = {
490 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
513 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 491 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
514 0xFFFFFFBF, 0xFFFFFFFF, 0xFFFFFFBF, 0xFFFFFFFF,
515 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 492 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
516 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 493 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
517 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 494 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
@@ -549,14 +526,575 @@ static const unsigned r500_reg_safe_bm[159] = {
549 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 526 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
550 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFF80FFFF, 527 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFF80FFFF,
551 0x00000000, 0x00000000, 0x00000000, 0x00000000, 528 0x00000000, 0x00000000, 0x00000000, 0x00000000,
552 0x0003FC01, 0x3FFFFCF8, 0xFE800B19, 529 0x0003FC01, 0x3FFFFCF8, 0xFE800B19, 0xFFFFFFFF,
530 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
531 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
532 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
533 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
534 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
535 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
536 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
537 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
538 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
539 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
540 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
541 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
542 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
543 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
544 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF,
553}; 545};
554 546
555
556
557int rv515_init(struct radeon_device *rdev) 547int rv515_init(struct radeon_device *rdev)
558{ 548{
559 rdev->config.r300.reg_safe_bm = r500_reg_safe_bm; 549 rdev->config.r300.reg_safe_bm = r500_reg_safe_bm;
560 rdev->config.r300.reg_safe_bm_size = ARRAY_SIZE(r500_reg_safe_bm); 550 rdev->config.r300.reg_safe_bm_size = ARRAY_SIZE(r500_reg_safe_bm);
561 return 0; 551 return 0;
562} 552}
553
554void atom_rv515_force_tv_scaler(struct radeon_device *rdev)
555{
556
557 WREG32(0x659C, 0x0);
558 WREG32(0x6594, 0x705);
559 WREG32(0x65A4, 0x10001);
560 WREG32(0x65D8, 0x0);
561 WREG32(0x65B0, 0x0);
562 WREG32(0x65C0, 0x0);
563 WREG32(0x65D4, 0x0);
564 WREG32(0x6578, 0x0);
565 WREG32(0x657C, 0x841880A8);
566 WREG32(0x6578, 0x1);
567 WREG32(0x657C, 0x84208680);
568 WREG32(0x6578, 0x2);
569 WREG32(0x657C, 0xBFF880B0);
570 WREG32(0x6578, 0x100);
571 WREG32(0x657C, 0x83D88088);
572 WREG32(0x6578, 0x101);
573 WREG32(0x657C, 0x84608680);
574 WREG32(0x6578, 0x102);
575 WREG32(0x657C, 0xBFF080D0);
576 WREG32(0x6578, 0x200);
577 WREG32(0x657C, 0x83988068);
578 WREG32(0x6578, 0x201);
579 WREG32(0x657C, 0x84A08680);
580 WREG32(0x6578, 0x202);
581 WREG32(0x657C, 0xBFF080F8);
582 WREG32(0x6578, 0x300);
583 WREG32(0x657C, 0x83588058);
584 WREG32(0x6578, 0x301);
585 WREG32(0x657C, 0x84E08660);
586 WREG32(0x6578, 0x302);
587 WREG32(0x657C, 0xBFF88120);
588 WREG32(0x6578, 0x400);
589 WREG32(0x657C, 0x83188040);
590 WREG32(0x6578, 0x401);
591 WREG32(0x657C, 0x85008660);
592 WREG32(0x6578, 0x402);
593 WREG32(0x657C, 0xBFF88150);
594 WREG32(0x6578, 0x500);
595 WREG32(0x657C, 0x82D88030);
596 WREG32(0x6578, 0x501);
597 WREG32(0x657C, 0x85408640);
598 WREG32(0x6578, 0x502);
599 WREG32(0x657C, 0xBFF88180);
600 WREG32(0x6578, 0x600);
601 WREG32(0x657C, 0x82A08018);
602 WREG32(0x6578, 0x601);
603 WREG32(0x657C, 0x85808620);
604 WREG32(0x6578, 0x602);
605 WREG32(0x657C, 0xBFF081B8);
606 WREG32(0x6578, 0x700);
607 WREG32(0x657C, 0x82608010);
608 WREG32(0x6578, 0x701);
609 WREG32(0x657C, 0x85A08600);
610 WREG32(0x6578, 0x702);
611 WREG32(0x657C, 0x800081F0);
612 WREG32(0x6578, 0x800);
613 WREG32(0x657C, 0x8228BFF8);
614 WREG32(0x6578, 0x801);
615 WREG32(0x657C, 0x85E085E0);
616 WREG32(0x6578, 0x802);
617 WREG32(0x657C, 0xBFF88228);
618 WREG32(0x6578, 0x10000);
619 WREG32(0x657C, 0x82A8BF00);
620 WREG32(0x6578, 0x10001);
621 WREG32(0x657C, 0x82A08CC0);
622 WREG32(0x6578, 0x10002);
623 WREG32(0x657C, 0x8008BEF8);
624 WREG32(0x6578, 0x10100);
625 WREG32(0x657C, 0x81F0BF28);
626 WREG32(0x6578, 0x10101);
627 WREG32(0x657C, 0x83608CA0);
628 WREG32(0x6578, 0x10102);
629 WREG32(0x657C, 0x8018BED0);
630 WREG32(0x6578, 0x10200);
631 WREG32(0x657C, 0x8148BF38);
632 WREG32(0x6578, 0x10201);
633 WREG32(0x657C, 0x84408C80);
634 WREG32(0x6578, 0x10202);
635 WREG32(0x657C, 0x8008BEB8);
636 WREG32(0x6578, 0x10300);
637 WREG32(0x657C, 0x80B0BF78);
638 WREG32(0x6578, 0x10301);
639 WREG32(0x657C, 0x85008C20);
640 WREG32(0x6578, 0x10302);
641 WREG32(0x657C, 0x8020BEA0);
642 WREG32(0x6578, 0x10400);
643 WREG32(0x657C, 0x8028BF90);
644 WREG32(0x6578, 0x10401);
645 WREG32(0x657C, 0x85E08BC0);
646 WREG32(0x6578, 0x10402);
647 WREG32(0x657C, 0x8018BE90);
648 WREG32(0x6578, 0x10500);
649 WREG32(0x657C, 0xBFB8BFB0);
650 WREG32(0x6578, 0x10501);
651 WREG32(0x657C, 0x86C08B40);
652 WREG32(0x6578, 0x10502);
653 WREG32(0x657C, 0x8010BE90);
654 WREG32(0x6578, 0x10600);
655 WREG32(0x657C, 0xBF58BFC8);
656 WREG32(0x6578, 0x10601);
657 WREG32(0x657C, 0x87A08AA0);
658 WREG32(0x6578, 0x10602);
659 WREG32(0x657C, 0x8010BE98);
660 WREG32(0x6578, 0x10700);
661 WREG32(0x657C, 0xBF10BFF0);
662 WREG32(0x6578, 0x10701);
663 WREG32(0x657C, 0x886089E0);
664 WREG32(0x6578, 0x10702);
665 WREG32(0x657C, 0x8018BEB0);
666 WREG32(0x6578, 0x10800);
667 WREG32(0x657C, 0xBED8BFE8);
668 WREG32(0x6578, 0x10801);
669 WREG32(0x657C, 0x89408940);
670 WREG32(0x6578, 0x10802);
671 WREG32(0x657C, 0xBFE8BED8);
672 WREG32(0x6578, 0x20000);
673 WREG32(0x657C, 0x80008000);
674 WREG32(0x6578, 0x20001);
675 WREG32(0x657C, 0x90008000);
676 WREG32(0x6578, 0x20002);
677 WREG32(0x657C, 0x80008000);
678 WREG32(0x6578, 0x20003);
679 WREG32(0x657C, 0x80008000);
680 WREG32(0x6578, 0x20100);
681 WREG32(0x657C, 0x80108000);
682 WREG32(0x6578, 0x20101);
683 WREG32(0x657C, 0x8FE0BF70);
684 WREG32(0x6578, 0x20102);
685 WREG32(0x657C, 0xBFE880C0);
686 WREG32(0x6578, 0x20103);
687 WREG32(0x657C, 0x80008000);
688 WREG32(0x6578, 0x20200);
689 WREG32(0x657C, 0x8018BFF8);
690 WREG32(0x6578, 0x20201);
691 WREG32(0x657C, 0x8F80BF08);
692 WREG32(0x6578, 0x20202);
693 WREG32(0x657C, 0xBFD081A0);
694 WREG32(0x6578, 0x20203);
695 WREG32(0x657C, 0xBFF88000);
696 WREG32(0x6578, 0x20300);
697 WREG32(0x657C, 0x80188000);
698 WREG32(0x6578, 0x20301);
699 WREG32(0x657C, 0x8EE0BEC0);
700 WREG32(0x6578, 0x20302);
701 WREG32(0x657C, 0xBFB082A0);
702 WREG32(0x6578, 0x20303);
703 WREG32(0x657C, 0x80008000);
704 WREG32(0x6578, 0x20400);
705 WREG32(0x657C, 0x80188000);
706 WREG32(0x6578, 0x20401);
707 WREG32(0x657C, 0x8E00BEA0);
708 WREG32(0x6578, 0x20402);
709 WREG32(0x657C, 0xBF8883C0);
710 WREG32(0x6578, 0x20403);
711 WREG32(0x657C, 0x80008000);
712 WREG32(0x6578, 0x20500);
713 WREG32(0x657C, 0x80188000);
714 WREG32(0x6578, 0x20501);
715 WREG32(0x657C, 0x8D00BE90);
716 WREG32(0x6578, 0x20502);
717 WREG32(0x657C, 0xBF588500);
718 WREG32(0x6578, 0x20503);
719 WREG32(0x657C, 0x80008008);
720 WREG32(0x6578, 0x20600);
721 WREG32(0x657C, 0x80188000);
722 WREG32(0x6578, 0x20601);
723 WREG32(0x657C, 0x8BC0BE98);
724 WREG32(0x6578, 0x20602);
725 WREG32(0x657C, 0xBF308660);
726 WREG32(0x6578, 0x20603);
727 WREG32(0x657C, 0x80008008);
728 WREG32(0x6578, 0x20700);
729 WREG32(0x657C, 0x80108000);
730 WREG32(0x6578, 0x20701);
731 WREG32(0x657C, 0x8A80BEB0);
732 WREG32(0x6578, 0x20702);
733 WREG32(0x657C, 0xBF0087C0);
734 WREG32(0x6578, 0x20703);
735 WREG32(0x657C, 0x80008008);
736 WREG32(0x6578, 0x20800);
737 WREG32(0x657C, 0x80108000);
738 WREG32(0x6578, 0x20801);
739 WREG32(0x657C, 0x8920BED0);
740 WREG32(0x6578, 0x20802);
741 WREG32(0x657C, 0xBED08920);
742 WREG32(0x6578, 0x20803);
743 WREG32(0x657C, 0x80008010);
744 WREG32(0x6578, 0x30000);
745 WREG32(0x657C, 0x90008000);
746 WREG32(0x6578, 0x30001);
747 WREG32(0x657C, 0x80008000);
748 WREG32(0x6578, 0x30100);
749 WREG32(0x657C, 0x8FE0BF90);
750 WREG32(0x6578, 0x30101);
751 WREG32(0x657C, 0xBFF880A0);
752 WREG32(0x6578, 0x30200);
753 WREG32(0x657C, 0x8F60BF40);
754 WREG32(0x6578, 0x30201);
755 WREG32(0x657C, 0xBFE88180);
756 WREG32(0x6578, 0x30300);
757 WREG32(0x657C, 0x8EC0BF00);
758 WREG32(0x6578, 0x30301);
759 WREG32(0x657C, 0xBFC88280);
760 WREG32(0x6578, 0x30400);
761 WREG32(0x657C, 0x8DE0BEE0);
762 WREG32(0x6578, 0x30401);
763 WREG32(0x657C, 0xBFA083A0);
764 WREG32(0x6578, 0x30500);
765 WREG32(0x657C, 0x8CE0BED0);
766 WREG32(0x6578, 0x30501);
767 WREG32(0x657C, 0xBF7884E0);
768 WREG32(0x6578, 0x30600);
769 WREG32(0x657C, 0x8BA0BED8);
770 WREG32(0x6578, 0x30601);
771 WREG32(0x657C, 0xBF508640);
772 WREG32(0x6578, 0x30700);
773 WREG32(0x657C, 0x8A60BEE8);
774 WREG32(0x6578, 0x30701);
775 WREG32(0x657C, 0xBF2087A0);
776 WREG32(0x6578, 0x30800);
777 WREG32(0x657C, 0x8900BF00);
778 WREG32(0x6578, 0x30801);
779 WREG32(0x657C, 0xBF008900);
780}
781
782struct rv515_watermark {
783 u32 lb_request_fifo_depth;
784 fixed20_12 num_line_pair;
785 fixed20_12 estimated_width;
786 fixed20_12 worst_case_latency;
787 fixed20_12 consumption_rate;
788 fixed20_12 active_time;
789 fixed20_12 dbpp;
790 fixed20_12 priority_mark_max;
791 fixed20_12 priority_mark;
792 fixed20_12 sclk;
793};
794
795void rv515_crtc_bandwidth_compute(struct radeon_device *rdev,
796 struct radeon_crtc *crtc,
797 struct rv515_watermark *wm)
798{
799 struct drm_display_mode *mode = &crtc->base.mode;
800 fixed20_12 a, b, c;
801 fixed20_12 pclk, request_fifo_depth, tolerable_latency, estimated_width;
802 fixed20_12 consumption_time, line_time, chunk_time, read_delay_latency;
803
804 if (!crtc->base.enabled) {
805 /* FIXME: wouldn't it better to set priority mark to maximum */
806 wm->lb_request_fifo_depth = 4;
807 return;
808 }
809
810 if (crtc->vsc.full > rfixed_const(2))
811 wm->num_line_pair.full = rfixed_const(2);
812 else
813 wm->num_line_pair.full = rfixed_const(1);
814
815 b.full = rfixed_const(mode->crtc_hdisplay);
816 c.full = rfixed_const(256);
817 a.full = rfixed_mul(wm->num_line_pair, b);
818 request_fifo_depth.full = rfixed_div(a, c);
819 if (a.full < rfixed_const(4)) {
820 wm->lb_request_fifo_depth = 4;
821 } else {
822 wm->lb_request_fifo_depth = rfixed_trunc(request_fifo_depth);
823 }
824
825 /* Determine consumption rate
826 * pclk = pixel clock period(ns) = 1000 / (mode.clock / 1000)
827 * vtaps = number of vertical taps,
828 * vsc = vertical scaling ratio, defined as source/destination
829 * hsc = horizontal scaling ration, defined as source/destination
830 */
831 a.full = rfixed_const(mode->clock);
832 b.full = rfixed_const(1000);
833 a.full = rfixed_div(a, b);
834 pclk.full = rfixed_div(b, a);
835 if (crtc->rmx_type != RMX_OFF) {
836 b.full = rfixed_const(2);
837 if (crtc->vsc.full > b.full)
838 b.full = crtc->vsc.full;
839 b.full = rfixed_mul(b, crtc->hsc);
840 c.full = rfixed_const(2);
841 b.full = rfixed_div(b, c);
842 consumption_time.full = rfixed_div(pclk, b);
843 } else {
844 consumption_time.full = pclk.full;
845 }
846 a.full = rfixed_const(1);
847 wm->consumption_rate.full = rfixed_div(a, consumption_time);
848
849
850 /* Determine line time
851 * LineTime = total time for one line of displayhtotal
852 * LineTime = total number of horizontal pixels
853 * pclk = pixel clock period(ns)
854 */
855 a.full = rfixed_const(crtc->base.mode.crtc_htotal);
856 line_time.full = rfixed_mul(a, pclk);
857
858 /* Determine active time
859 * ActiveTime = time of active region of display within one line,
860 * hactive = total number of horizontal active pixels
861 * htotal = total number of horizontal pixels
862 */
863 a.full = rfixed_const(crtc->base.mode.crtc_htotal);
864 b.full = rfixed_const(crtc->base.mode.crtc_hdisplay);
865 wm->active_time.full = rfixed_mul(line_time, b);
866 wm->active_time.full = rfixed_div(wm->active_time, a);
867
868 /* Determine chunk time
869 * ChunkTime = the time it takes the DCP to send one chunk of data
870 * to the LB which consists of pipeline delay and inter chunk gap
871 * sclk = system clock(Mhz)
872 */
873 a.full = rfixed_const(600 * 1000);
874 chunk_time.full = rfixed_div(a, rdev->pm.sclk);
875 read_delay_latency.full = rfixed_const(1000);
876
877 /* Determine the worst case latency
878 * NumLinePair = Number of line pairs to request(1=2 lines, 2=4 lines)
879 * WorstCaseLatency = worst case time from urgent to when the MC starts
880 * to return data
881 * READ_DELAY_IDLE_MAX = constant of 1us
882 * ChunkTime = time it takes the DCP to send one chunk of data to the LB
883 * which consists of pipeline delay and inter chunk gap
884 */
885 if (rfixed_trunc(wm->num_line_pair) > 1) {
886 a.full = rfixed_const(3);
887 wm->worst_case_latency.full = rfixed_mul(a, chunk_time);
888 wm->worst_case_latency.full += read_delay_latency.full;
889 } else {
890 wm->worst_case_latency.full = chunk_time.full + read_delay_latency.full;
891 }
892
893 /* Determine the tolerable latency
894 * TolerableLatency = Any given request has only 1 line time
895 * for the data to be returned
896 * LBRequestFifoDepth = Number of chunk requests the LB can
897 * put into the request FIFO for a display
898 * LineTime = total time for one line of display
899 * ChunkTime = the time it takes the DCP to send one chunk
900 * of data to the LB which consists of
901 * pipeline delay and inter chunk gap
902 */
903 if ((2+wm->lb_request_fifo_depth) >= rfixed_trunc(request_fifo_depth)) {
904 tolerable_latency.full = line_time.full;
905 } else {
906 tolerable_latency.full = rfixed_const(wm->lb_request_fifo_depth - 2);
907 tolerable_latency.full = request_fifo_depth.full - tolerable_latency.full;
908 tolerable_latency.full = rfixed_mul(tolerable_latency, chunk_time);
909 tolerable_latency.full = line_time.full - tolerable_latency.full;
910 }
911 /* We assume worst case 32bits (4 bytes) */
912 wm->dbpp.full = rfixed_const(2 * 16);
913
914 /* Determine the maximum priority mark
915 * width = viewport width in pixels
916 */
917 a.full = rfixed_const(16);
918 wm->priority_mark_max.full = rfixed_const(crtc->base.mode.crtc_hdisplay);
919 wm->priority_mark_max.full = rfixed_div(wm->priority_mark_max, a);
920
921 /* Determine estimated width */
922 estimated_width.full = tolerable_latency.full - wm->worst_case_latency.full;
923 estimated_width.full = rfixed_div(estimated_width, consumption_time);
924 if (rfixed_trunc(estimated_width) > crtc->base.mode.crtc_hdisplay) {
925 wm->priority_mark.full = rfixed_const(10);
926 } else {
927 a.full = rfixed_const(16);
928 wm->priority_mark.full = rfixed_div(estimated_width, a);
929 wm->priority_mark.full = wm->priority_mark_max.full - wm->priority_mark.full;
930 }
931}
932
933void rv515_bandwidth_avivo_update(struct radeon_device *rdev)
934{
935 struct drm_display_mode *mode0 = NULL;
936 struct drm_display_mode *mode1 = NULL;
937 struct rv515_watermark wm0;
938 struct rv515_watermark wm1;
939 u32 tmp;
940 fixed20_12 priority_mark02, priority_mark12, fill_rate;
941 fixed20_12 a, b;
942
943 if (rdev->mode_info.crtcs[0]->base.enabled)
944 mode0 = &rdev->mode_info.crtcs[0]->base.mode;
945 if (rdev->mode_info.crtcs[1]->base.enabled)
946 mode1 = &rdev->mode_info.crtcs[1]->base.mode;
947 rs690_line_buffer_adjust(rdev, mode0, mode1);
948
949 rv515_crtc_bandwidth_compute(rdev, rdev->mode_info.crtcs[0], &wm0);
950 rv515_crtc_bandwidth_compute(rdev, rdev->mode_info.crtcs[1], &wm1);
951
952 tmp = wm0.lb_request_fifo_depth;
953 tmp |= wm1.lb_request_fifo_depth << 16;
954 WREG32(LB_MAX_REQ_OUTSTANDING, tmp);
955
956 if (mode0 && mode1) {
957 if (rfixed_trunc(wm0.dbpp) > 64)
958 a.full = rfixed_div(wm0.dbpp, wm0.num_line_pair);
959 else
960 a.full = wm0.num_line_pair.full;
961 if (rfixed_trunc(wm1.dbpp) > 64)
962 b.full = rfixed_div(wm1.dbpp, wm1.num_line_pair);
963 else
964 b.full = wm1.num_line_pair.full;
965 a.full += b.full;
966 fill_rate.full = rfixed_div(wm0.sclk, a);
967 if (wm0.consumption_rate.full > fill_rate.full) {
968 b.full = wm0.consumption_rate.full - fill_rate.full;
969 b.full = rfixed_mul(b, wm0.active_time);
970 a.full = rfixed_const(16);
971 b.full = rfixed_div(b, a);
972 a.full = rfixed_mul(wm0.worst_case_latency,
973 wm0.consumption_rate);
974 priority_mark02.full = a.full + b.full;
975 } else {
976 a.full = rfixed_mul(wm0.worst_case_latency,
977 wm0.consumption_rate);
978 b.full = rfixed_const(16 * 1000);
979 priority_mark02.full = rfixed_div(a, b);
980 }
981 if (wm1.consumption_rate.full > fill_rate.full) {
982 b.full = wm1.consumption_rate.full - fill_rate.full;
983 b.full = rfixed_mul(b, wm1.active_time);
984 a.full = rfixed_const(16);
985 b.full = rfixed_div(b, a);
986 a.full = rfixed_mul(wm1.worst_case_latency,
987 wm1.consumption_rate);
988 priority_mark12.full = a.full + b.full;
989 } else {
990 a.full = rfixed_mul(wm1.worst_case_latency,
991 wm1.consumption_rate);
992 b.full = rfixed_const(16 * 1000);
993 priority_mark12.full = rfixed_div(a, b);
994 }
995 if (wm0.priority_mark.full > priority_mark02.full)
996 priority_mark02.full = wm0.priority_mark.full;
997 if (rfixed_trunc(priority_mark02) < 0)
998 priority_mark02.full = 0;
999 if (wm0.priority_mark_max.full > priority_mark02.full)
1000 priority_mark02.full = wm0.priority_mark_max.full;
1001 if (wm1.priority_mark.full > priority_mark12.full)
1002 priority_mark12.full = wm1.priority_mark.full;
1003 if (rfixed_trunc(priority_mark12) < 0)
1004 priority_mark12.full = 0;
1005 if (wm1.priority_mark_max.full > priority_mark12.full)
1006 priority_mark12.full = wm1.priority_mark_max.full;
1007 WREG32(D1MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark02));
1008 WREG32(D1MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark02));
1009 WREG32(D2MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark12));
1010 WREG32(D2MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark12));
1011 } else if (mode0) {
1012 if (rfixed_trunc(wm0.dbpp) > 64)
1013 a.full = rfixed_div(wm0.dbpp, wm0.num_line_pair);
1014 else
1015 a.full = wm0.num_line_pair.full;
1016 fill_rate.full = rfixed_div(wm0.sclk, a);
1017 if (wm0.consumption_rate.full > fill_rate.full) {
1018 b.full = wm0.consumption_rate.full - fill_rate.full;
1019 b.full = rfixed_mul(b, wm0.active_time);
1020 a.full = rfixed_const(16);
1021 b.full = rfixed_div(b, a);
1022 a.full = rfixed_mul(wm0.worst_case_latency,
1023 wm0.consumption_rate);
1024 priority_mark02.full = a.full + b.full;
1025 } else {
1026 a.full = rfixed_mul(wm0.worst_case_latency,
1027 wm0.consumption_rate);
1028 b.full = rfixed_const(16);
1029 priority_mark02.full = rfixed_div(a, b);
1030 }
1031 if (wm0.priority_mark.full > priority_mark02.full)
1032 priority_mark02.full = wm0.priority_mark.full;
1033 if (rfixed_trunc(priority_mark02) < 0)
1034 priority_mark02.full = 0;
1035 if (wm0.priority_mark_max.full > priority_mark02.full)
1036 priority_mark02.full = wm0.priority_mark_max.full;
1037 WREG32(D1MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark02));
1038 WREG32(D1MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark02));
1039 WREG32(D2MODE_PRIORITY_A_CNT, MODE_PRIORITY_OFF);
1040 WREG32(D2MODE_PRIORITY_B_CNT, MODE_PRIORITY_OFF);
1041 } else {
1042 if (rfixed_trunc(wm1.dbpp) > 64)
1043 a.full = rfixed_div(wm1.dbpp, wm1.num_line_pair);
1044 else
1045 a.full = wm1.num_line_pair.full;
1046 fill_rate.full = rfixed_div(wm1.sclk, a);
1047 if (wm1.consumption_rate.full > fill_rate.full) {
1048 b.full = wm1.consumption_rate.full - fill_rate.full;
1049 b.full = rfixed_mul(b, wm1.active_time);
1050 a.full = rfixed_const(16);
1051 b.full = rfixed_div(b, a);
1052 a.full = rfixed_mul(wm1.worst_case_latency,
1053 wm1.consumption_rate);
1054 priority_mark12.full = a.full + b.full;
1055 } else {
1056 a.full = rfixed_mul(wm1.worst_case_latency,
1057 wm1.consumption_rate);
1058 b.full = rfixed_const(16 * 1000);
1059 priority_mark12.full = rfixed_div(a, b);
1060 }
1061 if (wm1.priority_mark.full > priority_mark12.full)
1062 priority_mark12.full = wm1.priority_mark.full;
1063 if (rfixed_trunc(priority_mark12) < 0)
1064 priority_mark12.full = 0;
1065 if (wm1.priority_mark_max.full > priority_mark12.full)
1066 priority_mark12.full = wm1.priority_mark_max.full;
1067 WREG32(D1MODE_PRIORITY_A_CNT, MODE_PRIORITY_OFF);
1068 WREG32(D1MODE_PRIORITY_B_CNT, MODE_PRIORITY_OFF);
1069 WREG32(D2MODE_PRIORITY_A_CNT, rfixed_trunc(priority_mark12));
1070 WREG32(D2MODE_PRIORITY_B_CNT, rfixed_trunc(priority_mark12));
1071 }
1072}
1073
1074void rv515_bandwidth_update(struct radeon_device *rdev)
1075{
1076 uint32_t tmp;
1077 struct drm_display_mode *mode0 = NULL;
1078 struct drm_display_mode *mode1 = NULL;
1079
1080 if (rdev->mode_info.crtcs[0]->base.enabled)
1081 mode0 = &rdev->mode_info.crtcs[0]->base.mode;
1082 if (rdev->mode_info.crtcs[1]->base.enabled)
1083 mode1 = &rdev->mode_info.crtcs[1]->base.mode;
1084 /*
1085 * Set display0/1 priority up in the memory controller for
1086 * modes if the user specifies HIGH for displaypriority
1087 * option.
1088 */
1089 if (rdev->disp_priority == 2) {
1090 tmp = RREG32_MC(MC_MISC_LAT_TIMER);
1091 tmp &= ~MC_DISP1R_INIT_LAT_MASK;
1092 tmp &= ~MC_DISP0R_INIT_LAT_MASK;
1093 if (mode1)
1094 tmp |= (1 << MC_DISP1R_INIT_LAT_SHIFT);
1095 if (mode0)
1096 tmp |= (1 << MC_DISP0R_INIT_LAT_SHIFT);
1097 WREG32_MC(MC_MISC_LAT_TIMER, tmp);
1098 }
1099 rv515_bandwidth_avivo_update(rdev);
1100}
diff --git a/drivers/gpu/drm/radeon/rv515r.h b/drivers/gpu/drm/radeon/rv515r.h
new file mode 100644
index 000000000000..f3cf84039906
--- /dev/null
+++ b/drivers/gpu/drm/radeon/rv515r.h
@@ -0,0 +1,170 @@
1/*
2 * Copyright 2008 Advanced Micro Devices, Inc.
3 * Copyright 2008 Red Hat Inc.
4 * Copyright 2009 Jerome Glisse.
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the "Software"),
8 * to deal in the Software without restriction, including without limitation
9 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 * and/or sell copies of the Software, and to permit persons to whom the
11 * Software is furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
20 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
21 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
22 * OTHER DEALINGS IN THE SOFTWARE.
23 *
24 * Authors: Dave Airlie
25 * Alex Deucher
26 * Jerome Glisse
27 */
28#ifndef RV515R_H
29#define RV515R_H
30
31/* RV515 registers */
32#define PCIE_INDEX 0x0030
33#define PCIE_DATA 0x0034
34#define MC_IND_INDEX 0x0070
35#define MC_IND_WR_EN (1 << 24)
36#define MC_IND_DATA 0x0074
37#define RBBM_SOFT_RESET 0x00F0
38#define CONFIG_MEMSIZE 0x00F8
39#define HDP_FB_LOCATION 0x0134
40#define CP_CSQ_CNTL 0x0740
41#define CP_CSQ_MODE 0x0744
42#define CP_CSQ_ADDR 0x07F0
43#define CP_CSQ_DATA 0x07F4
44#define CP_CSQ_STAT 0x07F8
45#define CP_CSQ2_STAT 0x07FC
46#define RBBM_STATUS 0x0E40
47#define DST_PIPE_CONFIG 0x170C
48#define WAIT_UNTIL 0x1720
49#define WAIT_2D_IDLE (1 << 14)
50#define WAIT_3D_IDLE (1 << 15)
51#define WAIT_2D_IDLECLEAN (1 << 16)
52#define WAIT_3D_IDLECLEAN (1 << 17)
53#define ISYNC_CNTL 0x1724
54#define ISYNC_ANY2D_IDLE3D (1 << 0)
55#define ISYNC_ANY3D_IDLE2D (1 << 1)
56#define ISYNC_TRIG2D_IDLE3D (1 << 2)
57#define ISYNC_TRIG3D_IDLE2D (1 << 3)
58#define ISYNC_WAIT_IDLEGUI (1 << 4)
59#define ISYNC_CPSCRATCH_IDLEGUI (1 << 5)
60#define VAP_INDEX_OFFSET 0x208C
61#define VAP_PVS_STATE_FLUSH_REG 0x2284
62#define GB_ENABLE 0x4008
63#define GB_MSPOS0 0x4010
64#define MS_X0_SHIFT 0
65#define MS_Y0_SHIFT 4
66#define MS_X1_SHIFT 8
67#define MS_Y1_SHIFT 12
68#define MS_X2_SHIFT 16
69#define MS_Y2_SHIFT 20
70#define MSBD0_Y_SHIFT 24
71#define MSBD0_X_SHIFT 28
72#define GB_MSPOS1 0x4014
73#define MS_X3_SHIFT 0
74#define MS_Y3_SHIFT 4
75#define MS_X4_SHIFT 8
76#define MS_Y4_SHIFT 12
77#define MS_X5_SHIFT 16
78#define MS_Y5_SHIFT 20
79#define MSBD1_SHIFT 24
80#define GB_TILE_CONFIG 0x4018
81#define ENABLE_TILING (1 << 0)
82#define PIPE_COUNT_MASK 0x0000000E
83#define PIPE_COUNT_SHIFT 1
84#define TILE_SIZE_8 (0 << 4)
85#define TILE_SIZE_16 (1 << 4)
86#define TILE_SIZE_32 (2 << 4)
87#define SUBPIXEL_1_12 (0 << 16)
88#define SUBPIXEL_1_16 (1 << 16)
89#define GB_SELECT 0x401C
90#define GB_AA_CONFIG 0x4020
91#define GB_PIPE_SELECT 0x402C
92#define GA_ENHANCE 0x4274
93#define GA_DEADLOCK_CNTL (1 << 0)
94#define GA_FASTSYNC_CNTL (1 << 1)
95#define GA_POLY_MODE 0x4288
96#define FRONT_PTYPE_POINT (0 << 4)
97#define FRONT_PTYPE_LINE (1 << 4)
98#define FRONT_PTYPE_TRIANGE (2 << 4)
99#define BACK_PTYPE_POINT (0 << 7)
100#define BACK_PTYPE_LINE (1 << 7)
101#define BACK_PTYPE_TRIANGE (2 << 7)
102#define GA_ROUND_MODE 0x428C
103#define GEOMETRY_ROUND_TRUNC (0 << 0)
104#define GEOMETRY_ROUND_NEAREST (1 << 0)
105#define COLOR_ROUND_TRUNC (0 << 2)
106#define COLOR_ROUND_NEAREST (1 << 2)
107#define SU_REG_DEST 0x42C8
108#define RB3D_DSTCACHE_CTLSTAT 0x4E4C
109#define RB3D_DC_FLUSH (2 << 0)
110#define RB3D_DC_FREE (2 << 2)
111#define RB3D_DC_FINISH (1 << 4)
112#define ZB_ZCACHE_CTLSTAT 0x4F18
113#define ZC_FLUSH (1 << 0)
114#define ZC_FREE (1 << 1)
115#define DC_LB_MEMORY_SPLIT 0x6520
116#define DC_LB_MEMORY_SPLIT_MASK 0x00000003
117#define DC_LB_MEMORY_SPLIT_SHIFT 0
118#define DC_LB_MEMORY_SPLIT_D1HALF_D2HALF 0
119#define DC_LB_MEMORY_SPLIT_D1_3Q_D2_1Q 1
120#define DC_LB_MEMORY_SPLIT_D1_ONLY 2
121#define DC_LB_MEMORY_SPLIT_D1_1Q_D2_3Q 3
122#define DC_LB_MEMORY_SPLIT_SHIFT_MODE (1 << 2)
123#define DC_LB_DISP1_END_ADR_SHIFT 4
124#define DC_LB_DISP1_END_ADR_MASK 0x00007FF0
125#define D1MODE_PRIORITY_A_CNT 0x6548
126#define MODE_PRIORITY_MARK_MASK 0x00007FFF
127#define MODE_PRIORITY_OFF (1 << 16)
128#define MODE_PRIORITY_ALWAYS_ON (1 << 20)
129#define MODE_PRIORITY_FORCE_MASK (1 << 24)
130#define D1MODE_PRIORITY_B_CNT 0x654C
131#define LB_MAX_REQ_OUTSTANDING 0x6D58
132#define LB_D1_MAX_REQ_OUTSTANDING_MASK 0x0000000F
133#define LB_D1_MAX_REQ_OUTSTANDING_SHIFT 0
134#define LB_D2_MAX_REQ_OUTSTANDING_MASK 0x000F0000
135#define LB_D2_MAX_REQ_OUTSTANDING_SHIFT 16
136#define D2MODE_PRIORITY_A_CNT 0x6D48
137#define D2MODE_PRIORITY_B_CNT 0x6D4C
138
139/* ix[MC] registers */
140#define MC_FB_LOCATION 0x01
141#define MC_FB_START_MASK 0x0000FFFF
142#define MC_FB_START_SHIFT 0
143#define MC_FB_TOP_MASK 0xFFFF0000
144#define MC_FB_TOP_SHIFT 16
145#define MC_AGP_LOCATION 0x02
146#define MC_AGP_START_MASK 0x0000FFFF
147#define MC_AGP_START_SHIFT 0
148#define MC_AGP_TOP_MASK 0xFFFF0000
149#define MC_AGP_TOP_SHIFT 16
150#define MC_AGP_BASE 0x03
151#define MC_AGP_BASE_2 0x04
152#define MC_CNTL 0x5
153#define MEM_NUM_CHANNELS_MASK 0x00000003
154#define MC_STATUS 0x08
155#define MC_STATUS_IDLE (1 << 4)
156#define MC_MISC_LAT_TIMER 0x09
157#define MC_CPR_INIT_LAT_MASK 0x0000000F
158#define MC_VF_INIT_LAT_MASK 0x000000F0
159#define MC_DISP0R_INIT_LAT_MASK 0x00000F00
160#define MC_DISP0R_INIT_LAT_SHIFT 8
161#define MC_DISP1R_INIT_LAT_MASK 0x0000F000
162#define MC_DISP1R_INIT_LAT_SHIFT 12
163#define MC_FIXED_INIT_LAT_MASK 0x000F0000
164#define MC_E2R_INIT_LAT_MASK 0x00F00000
165#define SAME_PAGE_PRIO_MASK 0x0F000000
166#define MC_GLOBW_INIT_LAT_MASK 0xF0000000
167
168
169#endif
170
diff --git a/drivers/gpu/drm/radeon/rv770.c b/drivers/gpu/drm/radeon/rv770.c
index da50cc51ede3..21d8ffd57308 100644
--- a/drivers/gpu/drm/radeon/rv770.c
+++ b/drivers/gpu/drm/radeon/rv770.c
@@ -67,7 +67,7 @@ int rv770_mc_init(struct radeon_device *rdev)
67 "programming pipes. Bad things might happen.\n"); 67 "programming pipes. Bad things might happen.\n");
68 } 68 }
69 69
70 tmp = rdev->mc.vram_location + rdev->mc.vram_size - 1; 70 tmp = rdev->mc.vram_location + rdev->mc.mc_vram_size - 1;
71 tmp = REG_SET(R700_MC_FB_TOP, tmp >> 24); 71 tmp = REG_SET(R700_MC_FB_TOP, tmp >> 24);
72 tmp |= REG_SET(R700_MC_FB_BASE, rdev->mc.vram_location >> 24); 72 tmp |= REG_SET(R700_MC_FB_BASE, rdev->mc.vram_location >> 24);
73 WREG32(R700_MC_VM_FB_LOCATION, tmp); 73 WREG32(R700_MC_VM_FB_LOCATION, tmp);
diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c
index c1c407f7cca3..6538d4236989 100644
--- a/drivers/gpu/drm/ttm/ttm_bo.c
+++ b/drivers/gpu/drm/ttm/ttm_bo.c
@@ -43,7 +43,6 @@
43#define TTM_BO_HASH_ORDER 13 43#define TTM_BO_HASH_ORDER 13
44 44
45static int ttm_bo_setup_vm(struct ttm_buffer_object *bo); 45static int ttm_bo_setup_vm(struct ttm_buffer_object *bo);
46static void ttm_bo_unmap_virtual(struct ttm_buffer_object *bo);
47static int ttm_bo_swapout(struct ttm_mem_shrink *shrink); 46static int ttm_bo_swapout(struct ttm_mem_shrink *shrink);
48 47
49static inline uint32_t ttm_bo_type_flags(unsigned type) 48static inline uint32_t ttm_bo_type_flags(unsigned type)
@@ -224,6 +223,9 @@ static int ttm_bo_add_ttm(struct ttm_buffer_object *bo, bool zero_alloc)
224 TTM_ASSERT_LOCKED(&bo->mutex); 223 TTM_ASSERT_LOCKED(&bo->mutex);
225 bo->ttm = NULL; 224 bo->ttm = NULL;
226 225
226 if (bdev->need_dma32)
227 page_flags |= TTM_PAGE_FLAG_DMA32;
228
227 switch (bo->type) { 229 switch (bo->type) {
228 case ttm_bo_type_device: 230 case ttm_bo_type_device:
229 if (zero_alloc) 231 if (zero_alloc)
@@ -304,6 +306,9 @@ static int ttm_bo_handle_move_mem(struct ttm_buffer_object *bo,
304 306
305 } 307 }
306 308
309 if (bdev->driver->move_notify)
310 bdev->driver->move_notify(bo, mem);
311
307 if (!(old_man->flags & TTM_MEMTYPE_FLAG_FIXED) && 312 if (!(old_man->flags & TTM_MEMTYPE_FLAG_FIXED) &&
308 !(new_man->flags & TTM_MEMTYPE_FLAG_FIXED)) 313 !(new_man->flags & TTM_MEMTYPE_FLAG_FIXED))
309 ret = ttm_bo_move_ttm(bo, evict, no_wait, mem); 314 ret = ttm_bo_move_ttm(bo, evict, no_wait, mem);
@@ -655,31 +660,52 @@ retry_pre_get:
655 return 0; 660 return 0;
656} 661}
657 662
663static uint32_t ttm_bo_select_caching(struct ttm_mem_type_manager *man,
664 uint32_t cur_placement,
665 uint32_t proposed_placement)
666{
667 uint32_t caching = proposed_placement & TTM_PL_MASK_CACHING;
668 uint32_t result = proposed_placement & ~TTM_PL_MASK_CACHING;
669
670 /**
671 * Keep current caching if possible.
672 */
673
674 if ((cur_placement & caching) != 0)
675 result |= (cur_placement & caching);
676 else if ((man->default_caching & caching) != 0)
677 result |= man->default_caching;
678 else if ((TTM_PL_FLAG_CACHED & caching) != 0)
679 result |= TTM_PL_FLAG_CACHED;
680 else if ((TTM_PL_FLAG_WC & caching) != 0)
681 result |= TTM_PL_FLAG_WC;
682 else if ((TTM_PL_FLAG_UNCACHED & caching) != 0)
683 result |= TTM_PL_FLAG_UNCACHED;
684
685 return result;
686}
687
688
658static bool ttm_bo_mt_compatible(struct ttm_mem_type_manager *man, 689static bool ttm_bo_mt_compatible(struct ttm_mem_type_manager *man,
659 bool disallow_fixed, 690 bool disallow_fixed,
660 uint32_t mem_type, 691 uint32_t mem_type,
661 uint32_t mask, uint32_t *res_mask) 692 uint32_t proposed_placement,
693 uint32_t *masked_placement)
662{ 694{
663 uint32_t cur_flags = ttm_bo_type_flags(mem_type); 695 uint32_t cur_flags = ttm_bo_type_flags(mem_type);
664 696
665 if ((man->flags & TTM_MEMTYPE_FLAG_FIXED) && disallow_fixed) 697 if ((man->flags & TTM_MEMTYPE_FLAG_FIXED) && disallow_fixed)
666 return false; 698 return false;
667 699
668 if ((cur_flags & mask & TTM_PL_MASK_MEM) == 0) 700 if ((cur_flags & proposed_placement & TTM_PL_MASK_MEM) == 0)
669 return false; 701 return false;
670 702
671 if ((mask & man->available_caching) == 0) 703 if ((proposed_placement & man->available_caching) == 0)
672 return false; 704 return false;
673 if (mask & man->default_caching)
674 cur_flags |= man->default_caching;
675 else if (mask & TTM_PL_FLAG_CACHED)
676 cur_flags |= TTM_PL_FLAG_CACHED;
677 else if (mask & TTM_PL_FLAG_WC)
678 cur_flags |= TTM_PL_FLAG_WC;
679 else
680 cur_flags |= TTM_PL_FLAG_UNCACHED;
681 705
682 *res_mask = cur_flags; 706 cur_flags |= (proposed_placement & man->available_caching);
707
708 *masked_placement = cur_flags;
683 return true; 709 return true;
684} 710}
685 711
@@ -723,6 +749,9 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
723 if (!type_ok) 749 if (!type_ok)
724 continue; 750 continue;
725 751
752 cur_flags = ttm_bo_select_caching(man, bo->mem.placement,
753 cur_flags);
754
726 if (mem_type == TTM_PL_SYSTEM) 755 if (mem_type == TTM_PL_SYSTEM)
727 break; 756 break;
728 757
@@ -779,6 +808,9 @@ int ttm_bo_mem_space(struct ttm_buffer_object *bo,
779 proposed_placement, &cur_flags)) 808 proposed_placement, &cur_flags))
780 continue; 809 continue;
781 810
811 cur_flags = ttm_bo_select_caching(man, bo->mem.placement,
812 cur_flags);
813
782 ret = ttm_bo_mem_force_space(bdev, mem, mem_type, 814 ret = ttm_bo_mem_force_space(bdev, mem, mem_type,
783 interruptible, no_wait); 815 interruptible, no_wait);
784 816
@@ -1305,7 +1337,8 @@ EXPORT_SYMBOL(ttm_bo_device_release);
1305 1337
1306int ttm_bo_device_init(struct ttm_bo_device *bdev, 1338int ttm_bo_device_init(struct ttm_bo_device *bdev,
1307 struct ttm_mem_global *mem_glob, 1339 struct ttm_mem_global *mem_glob,
1308 struct ttm_bo_driver *driver, uint64_t file_page_offset) 1340 struct ttm_bo_driver *driver, uint64_t file_page_offset,
1341 bool need_dma32)
1309{ 1342{
1310 int ret = -EINVAL; 1343 int ret = -EINVAL;
1311 1344
@@ -1342,6 +1375,7 @@ int ttm_bo_device_init(struct ttm_bo_device *bdev,
1342 INIT_LIST_HEAD(&bdev->ddestroy); 1375 INIT_LIST_HEAD(&bdev->ddestroy);
1343 INIT_LIST_HEAD(&bdev->swap_lru); 1376 INIT_LIST_HEAD(&bdev->swap_lru);
1344 bdev->dev_mapping = NULL; 1377 bdev->dev_mapping = NULL;
1378 bdev->need_dma32 = need_dma32;
1345 ttm_mem_init_shrink(&bdev->shrink, ttm_bo_swapout); 1379 ttm_mem_init_shrink(&bdev->shrink, ttm_bo_swapout);
1346 ret = ttm_mem_register_shrink(mem_glob, &bdev->shrink); 1380 ret = ttm_mem_register_shrink(mem_glob, &bdev->shrink);
1347 if (unlikely(ret != 0)) { 1381 if (unlikely(ret != 0)) {
@@ -1419,6 +1453,7 @@ void ttm_bo_unmap_virtual(struct ttm_buffer_object *bo)
1419 1453
1420 unmap_mapping_range(bdev->dev_mapping, offset, holelen, 1); 1454 unmap_mapping_range(bdev->dev_mapping, offset, holelen, 1);
1421} 1455}
1456EXPORT_SYMBOL(ttm_bo_unmap_virtual);
1422 1457
1423static void ttm_bo_vm_insert_rb(struct ttm_buffer_object *bo) 1458static void ttm_bo_vm_insert_rb(struct ttm_buffer_object *bo)
1424{ 1459{
diff --git a/drivers/gpu/drm/ttm/ttm_bo_util.c b/drivers/gpu/drm/ttm/ttm_bo_util.c
index bdec583901eb..ce2e6f38ea01 100644
--- a/drivers/gpu/drm/ttm/ttm_bo_util.c
+++ b/drivers/gpu/drm/ttm/ttm_bo_util.c
@@ -136,7 +136,8 @@ static int ttm_copy_io_page(void *dst, void *src, unsigned long page)
136} 136}
137 137
138static int ttm_copy_io_ttm_page(struct ttm_tt *ttm, void *src, 138static int ttm_copy_io_ttm_page(struct ttm_tt *ttm, void *src,
139 unsigned long page) 139 unsigned long page,
140 pgprot_t prot)
140{ 141{
141 struct page *d = ttm_tt_get_page(ttm, page); 142 struct page *d = ttm_tt_get_page(ttm, page);
142 void *dst; 143 void *dst;
@@ -145,17 +146,35 @@ static int ttm_copy_io_ttm_page(struct ttm_tt *ttm, void *src,
145 return -ENOMEM; 146 return -ENOMEM;
146 147
147 src = (void *)((unsigned long)src + (page << PAGE_SHIFT)); 148 src = (void *)((unsigned long)src + (page << PAGE_SHIFT));
148 dst = kmap(d); 149
150#ifdef CONFIG_X86
151 dst = kmap_atomic_prot(d, KM_USER0, prot);
152#else
153 if (prot != PAGE_KERNEL)
154 dst = vmap(&d, 1, 0, prot);
155 else
156 dst = kmap(d);
157#endif
149 if (!dst) 158 if (!dst)
150 return -ENOMEM; 159 return -ENOMEM;
151 160
152 memcpy_fromio(dst, src, PAGE_SIZE); 161 memcpy_fromio(dst, src, PAGE_SIZE);
153 kunmap(d); 162
163#ifdef CONFIG_X86
164 kunmap_atomic(dst, KM_USER0);
165#else
166 if (prot != PAGE_KERNEL)
167 vunmap(dst);
168 else
169 kunmap(d);
170#endif
171
154 return 0; 172 return 0;
155} 173}
156 174
157static int ttm_copy_ttm_io_page(struct ttm_tt *ttm, void *dst, 175static int ttm_copy_ttm_io_page(struct ttm_tt *ttm, void *dst,
158 unsigned long page) 176 unsigned long page,
177 pgprot_t prot)
159{ 178{
160 struct page *s = ttm_tt_get_page(ttm, page); 179 struct page *s = ttm_tt_get_page(ttm, page);
161 void *src; 180 void *src;
@@ -164,12 +183,28 @@ static int ttm_copy_ttm_io_page(struct ttm_tt *ttm, void *dst,
164 return -ENOMEM; 183 return -ENOMEM;
165 184
166 dst = (void *)((unsigned long)dst + (page << PAGE_SHIFT)); 185 dst = (void *)((unsigned long)dst + (page << PAGE_SHIFT));
167 src = kmap(s); 186#ifdef CONFIG_X86
187 src = kmap_atomic_prot(s, KM_USER0, prot);
188#else
189 if (prot != PAGE_KERNEL)
190 src = vmap(&s, 1, 0, prot);
191 else
192 src = kmap(s);
193#endif
168 if (!src) 194 if (!src)
169 return -ENOMEM; 195 return -ENOMEM;
170 196
171 memcpy_toio(dst, src, PAGE_SIZE); 197 memcpy_toio(dst, src, PAGE_SIZE);
172 kunmap(s); 198
199#ifdef CONFIG_X86
200 kunmap_atomic(src, KM_USER0);
201#else
202 if (prot != PAGE_KERNEL)
203 vunmap(src);
204 else
205 kunmap(s);
206#endif
207
173 return 0; 208 return 0;
174} 209}
175 210
@@ -214,11 +249,17 @@ int ttm_bo_move_memcpy(struct ttm_buffer_object *bo,
214 249
215 for (i = 0; i < new_mem->num_pages; ++i) { 250 for (i = 0; i < new_mem->num_pages; ++i) {
216 page = i * dir + add; 251 page = i * dir + add;
217 if (old_iomap == NULL) 252 if (old_iomap == NULL) {
218 ret = ttm_copy_ttm_io_page(ttm, new_iomap, page); 253 pgprot_t prot = ttm_io_prot(old_mem->placement,
219 else if (new_iomap == NULL) 254 PAGE_KERNEL);
220 ret = ttm_copy_io_ttm_page(ttm, old_iomap, page); 255 ret = ttm_copy_ttm_io_page(ttm, new_iomap, page,
221 else 256 prot);
257 } else if (new_iomap == NULL) {
258 pgprot_t prot = ttm_io_prot(new_mem->placement,
259 PAGE_KERNEL);
260 ret = ttm_copy_io_ttm_page(ttm, old_iomap, page,
261 prot);
262 } else
222 ret = ttm_copy_io_page(new_iomap, old_iomap, page); 263 ret = ttm_copy_io_page(new_iomap, old_iomap, page);
223 if (ret) 264 if (ret)
224 goto out1; 265 goto out1;
@@ -509,8 +550,8 @@ int ttm_bo_move_accel_cleanup(struct ttm_buffer_object *bo,
509 if (evict) { 550 if (evict) {
510 ret = ttm_bo_wait(bo, false, false, false); 551 ret = ttm_bo_wait(bo, false, false, false);
511 spin_unlock(&bo->lock); 552 spin_unlock(&bo->lock);
512 driver->sync_obj_unref(&bo->sync_obj); 553 if (tmp_obj)
513 554 driver->sync_obj_unref(&tmp_obj);
514 if (ret) 555 if (ret)
515 return ret; 556 return ret;
516 557
@@ -532,6 +573,8 @@ int ttm_bo_move_accel_cleanup(struct ttm_buffer_object *bo,
532 573
533 set_bit(TTM_BO_PRIV_FLAG_MOVING, &bo->priv_flags); 574 set_bit(TTM_BO_PRIV_FLAG_MOVING, &bo->priv_flags);
534 spin_unlock(&bo->lock); 575 spin_unlock(&bo->lock);
576 if (tmp_obj)
577 driver->sync_obj_unref(&tmp_obj);
535 578
536 ret = ttm_buffer_object_transfer(bo, &ghost_obj); 579 ret = ttm_buffer_object_transfer(bo, &ghost_obj);
537 if (ret) 580 if (ret)
diff --git a/drivers/gpu/drm/ttm/ttm_bo_vm.c b/drivers/gpu/drm/ttm/ttm_bo_vm.c
index fe949a12fe40..33de7637c0c6 100644
--- a/drivers/gpu/drm/ttm/ttm_bo_vm.c
+++ b/drivers/gpu/drm/ttm/ttm_bo_vm.c
@@ -101,6 +101,9 @@ static int ttm_bo_vm_fault(struct vm_area_struct *vma, struct vm_fault *vmf)
101 return VM_FAULT_NOPAGE; 101 return VM_FAULT_NOPAGE;
102 } 102 }
103 103
104 if (bdev->driver->fault_reserve_notify)
105 bdev->driver->fault_reserve_notify(bo);
106
104 /* 107 /*
105 * Wait for buffer data in transit, due to a pipelined 108 * Wait for buffer data in transit, due to a pipelined
106 * move. 109 * move.
diff --git a/drivers/gpu/drm/ttm/ttm_tt.c b/drivers/gpu/drm/ttm/ttm_tt.c
index 75dc8bd24592..b8b6c4a5f983 100644
--- a/drivers/gpu/drm/ttm/ttm_tt.c
+++ b/drivers/gpu/drm/ttm/ttm_tt.c
@@ -86,10 +86,16 @@ void ttm_tt_cache_flush(struct page *pages[], unsigned long num_pages)
86 unsigned long i; 86 unsigned long i;
87 87
88 for (i = 0; i < num_pages; ++i) { 88 for (i = 0; i < num_pages; ++i) {
89 if (pages[i]) { 89 struct page *page = pages[i];
90 unsigned long start = (unsigned long)page_address(pages[i]); 90 void *page_virtual;
91 flush_dcache_range(start, start + PAGE_SIZE); 91
92 } 92 if (unlikely(page == NULL))
93 continue;
94
95 page_virtual = kmap_atomic(page, KM_USER0);
96 flush_dcache_range((unsigned long) page_virtual,
97 (unsigned long) page_virtual + PAGE_SIZE);
98 kunmap_atomic(page_virtual, KM_USER0);
93 } 99 }
94#else 100#else
95 if (on_each_cpu(ttm_tt_ipi_handler, NULL, 1) != 0) 101 if (on_each_cpu(ttm_tt_ipi_handler, NULL, 1) != 0)
@@ -131,10 +137,17 @@ static void ttm_tt_free_page_directory(struct ttm_tt *ttm)
131 137
132static struct page *ttm_tt_alloc_page(unsigned page_flags) 138static struct page *ttm_tt_alloc_page(unsigned page_flags)
133{ 139{
140 gfp_t gfp_flags = GFP_USER;
141
134 if (page_flags & TTM_PAGE_FLAG_ZERO_ALLOC) 142 if (page_flags & TTM_PAGE_FLAG_ZERO_ALLOC)
135 return alloc_page(GFP_HIGHUSER | __GFP_ZERO); 143 gfp_flags |= __GFP_ZERO;
144
145 if (page_flags & TTM_PAGE_FLAG_DMA32)
146 gfp_flags |= __GFP_DMA32;
147 else
148 gfp_flags |= __GFP_HIGHMEM;
136 149
137 return alloc_page(GFP_HIGHUSER); 150 return alloc_page(gfp_flags);
138} 151}
139 152
140static void ttm_tt_free_user_pages(struct ttm_tt *ttm) 153static void ttm_tt_free_user_pages(struct ttm_tt *ttm)
diff --git a/drivers/i2c/busses/i2c-omap.c b/drivers/i2c/busses/i2c-omap.c
index fdd83277c8a8..d258b02aef44 100644
--- a/drivers/i2c/busses/i2c-omap.c
+++ b/drivers/i2c/busses/i2c-omap.c
@@ -672,9 +672,10 @@ omap_i2c_isr(int this_irq, void *dev_id)
672 break; 672 break;
673 } 673 }
674 674
675 err = 0;
676complete:
675 omap_i2c_write_reg(dev, OMAP_I2C_STAT_REG, stat); 677 omap_i2c_write_reg(dev, OMAP_I2C_STAT_REG, stat);
676 678
677 err = 0;
678 if (stat & OMAP_I2C_STAT_NACK) { 679 if (stat & OMAP_I2C_STAT_NACK) {
679 err |= OMAP_I2C_STAT_NACK; 680 err |= OMAP_I2C_STAT_NACK;
680 omap_i2c_write_reg(dev, OMAP_I2C_CON_REG, 681 omap_i2c_write_reg(dev, OMAP_I2C_CON_REG,
@@ -685,16 +686,19 @@ omap_i2c_isr(int this_irq, void *dev_id)
685 err |= OMAP_I2C_STAT_AL; 686 err |= OMAP_I2C_STAT_AL;
686 } 687 }
687 if (stat & (OMAP_I2C_STAT_ARDY | OMAP_I2C_STAT_NACK | 688 if (stat & (OMAP_I2C_STAT_ARDY | OMAP_I2C_STAT_NACK |
688 OMAP_I2C_STAT_AL)) 689 OMAP_I2C_STAT_AL)) {
689 omap_i2c_complete_cmd(dev, err); 690 omap_i2c_complete_cmd(dev, err);
691 return IRQ_HANDLED;
692 }
690 if (stat & (OMAP_I2C_STAT_RRDY | OMAP_I2C_STAT_RDR)) { 693 if (stat & (OMAP_I2C_STAT_RRDY | OMAP_I2C_STAT_RDR)) {
691 u8 num_bytes = 1; 694 u8 num_bytes = 1;
692 if (dev->fifo_size) { 695 if (dev->fifo_size) {
693 if (stat & OMAP_I2C_STAT_RRDY) 696 if (stat & OMAP_I2C_STAT_RRDY)
694 num_bytes = dev->fifo_size; 697 num_bytes = dev->fifo_size;
695 else 698 else /* read RXSTAT on RDR interrupt */
696 num_bytes = omap_i2c_read_reg(dev, 699 num_bytes = (omap_i2c_read_reg(dev,
697 OMAP_I2C_BUFSTAT_REG); 700 OMAP_I2C_BUFSTAT_REG)
701 >> 8) & 0x3F;
698 } 702 }
699 while (num_bytes) { 703 while (num_bytes) {
700 num_bytes--; 704 num_bytes--;
@@ -731,9 +735,10 @@ omap_i2c_isr(int this_irq, void *dev_id)
731 if (dev->fifo_size) { 735 if (dev->fifo_size) {
732 if (stat & OMAP_I2C_STAT_XRDY) 736 if (stat & OMAP_I2C_STAT_XRDY)
733 num_bytes = dev->fifo_size; 737 num_bytes = dev->fifo_size;
734 else 738 else /* read TXSTAT on XDR interrupt */
735 num_bytes = omap_i2c_read_reg(dev, 739 num_bytes = omap_i2c_read_reg(dev,
736 OMAP_I2C_BUFSTAT_REG); 740 OMAP_I2C_BUFSTAT_REG)
741 & 0x3F;
737 } 742 }
738 while (num_bytes) { 743 while (num_bytes) {
739 num_bytes--; 744 num_bytes--;
@@ -760,6 +765,27 @@ omap_i2c_isr(int this_irq, void *dev_id)
760 "data to send\n"); 765 "data to send\n");
761 break; 766 break;
762 } 767 }
768
769 /*
770 * OMAP3430 Errata 1.153: When an XRDY/XDR
771 * is hit, wait for XUDF before writing data
772 * to DATA_REG. Otherwise some data bytes can
773 * be lost while transferring them from the
774 * memory to the I2C interface.
775 */
776
777 if (cpu_is_omap34xx()) {
778 while (!(stat & OMAP_I2C_STAT_XUDF)) {
779 if (stat & (OMAP_I2C_STAT_NACK | OMAP_I2C_STAT_AL)) {
780 omap_i2c_ack_stat(dev, stat & (OMAP_I2C_STAT_XRDY | OMAP_I2C_STAT_XDR));
781 err |= OMAP_I2C_STAT_XUDF;
782 goto complete;
783 }
784 cpu_relax();
785 stat = omap_i2c_read_reg(dev, OMAP_I2C_STAT_REG);
786 }
787 }
788
763 omap_i2c_write_reg(dev, OMAP_I2C_DATA_REG, w); 789 omap_i2c_write_reg(dev, OMAP_I2C_DATA_REG, w);
764 } 790 }
765 omap_i2c_ack_stat(dev, 791 omap_i2c_ack_stat(dev,
@@ -879,7 +905,7 @@ omap_i2c_probe(struct platform_device *pdev)
879 i2c_set_adapdata(adap, dev); 905 i2c_set_adapdata(adap, dev);
880 adap->owner = THIS_MODULE; 906 adap->owner = THIS_MODULE;
881 adap->class = I2C_CLASS_HWMON; 907 adap->class = I2C_CLASS_HWMON;
882 strncpy(adap->name, "OMAP I2C adapter", sizeof(adap->name)); 908 strlcpy(adap->name, "OMAP I2C adapter", sizeof(adap->name));
883 adap->algo = &omap_i2c_algo; 909 adap->algo = &omap_i2c_algo;
884 adap->dev.parent = &pdev->dev; 910 adap->dev.parent = &pdev->dev;
885 911
diff --git a/drivers/i2c/busses/i2c-s3c2410.c b/drivers/i2c/busses/i2c-s3c2410.c
index 3be0d6a4d630..96aafb91b69a 100644
--- a/drivers/i2c/busses/i2c-s3c2410.c
+++ b/drivers/i2c/busses/i2c-s3c2410.c
@@ -763,11 +763,6 @@ static int s3c24xx_i2c_init(struct s3c24xx_i2c *i2c)
763 dev_info(i2c->dev, "bus frequency set to %d KHz\n", freq); 763 dev_info(i2c->dev, "bus frequency set to %d KHz\n", freq);
764 dev_dbg(i2c->dev, "S3C2410_IICCON=0x%02lx\n", iicon); 764 dev_dbg(i2c->dev, "S3C2410_IICCON=0x%02lx\n", iicon);
765 765
766 /* check for s3c2440 i2c controller */
767
768 if (s3c24xx_i2c_is2440(i2c))
769 writel(0x0, i2c->regs + S3C2440_IICLC);
770
771 return 0; 766 return 0;
772} 767}
773 768
diff --git a/drivers/i2c/busses/i2c-sh_mobile.c b/drivers/i2c/busses/i2c-sh_mobile.c
index 4f3d99cd1692..820487d0d5c7 100644
--- a/drivers/i2c/busses/i2c-sh_mobile.c
+++ b/drivers/i2c/busses/i2c-sh_mobile.c
@@ -637,7 +637,7 @@ static void __exit sh_mobile_i2c_adap_exit(void)
637 platform_driver_unregister(&sh_mobile_i2c_driver); 637 platform_driver_unregister(&sh_mobile_i2c_driver);
638} 638}
639 639
640module_init(sh_mobile_i2c_adap_init); 640subsys_initcall(sh_mobile_i2c_adap_init);
641module_exit(sh_mobile_i2c_adap_exit); 641module_exit(sh_mobile_i2c_adap_exit);
642 642
643MODULE_DESCRIPTION("SuperH Mobile I2C Bus Controller driver"); 643MODULE_DESCRIPTION("SuperH Mobile I2C Bus Controller driver");
diff --git a/drivers/misc/eeprom/at25.c b/drivers/misc/eeprom/at25.c
index b34cb5f79eea..2e535a0ccd5e 100644
--- a/drivers/misc/eeprom/at25.c
+++ b/drivers/misc/eeprom/at25.c
@@ -173,6 +173,7 @@ at25_ee_write(struct at25_data *at25, const char *buf, loff_t off,
173 unsigned segment; 173 unsigned segment;
174 unsigned offset = (unsigned) off; 174 unsigned offset = (unsigned) off;
175 u8 *cp = bounce + 1; 175 u8 *cp = bounce + 1;
176 int sr;
176 177
177 *cp = AT25_WREN; 178 *cp = AT25_WREN;
178 status = spi_write(at25->spi, cp, 1); 179 status = spi_write(at25->spi, cp, 1);
@@ -214,7 +215,6 @@ at25_ee_write(struct at25_data *at25, const char *buf, loff_t off,
214 timeout = jiffies + msecs_to_jiffies(EE_TIMEOUT); 215 timeout = jiffies + msecs_to_jiffies(EE_TIMEOUT);
215 retries = 0; 216 retries = 0;
216 do { 217 do {
217 int sr;
218 218
219 sr = spi_w8r8(at25->spi, AT25_RDSR); 219 sr = spi_w8r8(at25->spi, AT25_RDSR);
220 if (sr < 0 || (sr & AT25_SR_nRDY)) { 220 if (sr < 0 || (sr & AT25_SR_nRDY)) {
@@ -228,7 +228,7 @@ at25_ee_write(struct at25_data *at25, const char *buf, loff_t off,
228 break; 228 break;
229 } while (retries++ < 3 || time_before_eq(jiffies, timeout)); 229 } while (retries++ < 3 || time_before_eq(jiffies, timeout));
230 230
231 if (time_after(jiffies, timeout)) { 231 if ((sr < 0) || (sr & AT25_SR_nRDY)) {
232 dev_err(&at25->spi->dev, 232 dev_err(&at25->spi->dev,
233 "write %d bytes offset %d, " 233 "write %d bytes offset %d, "
234 "timeout after %u msecs\n", 234 "timeout after %u msecs\n",
diff --git a/drivers/mmc/host/sdhci-of.c b/drivers/mmc/host/sdhci-of.c
index d79fa55c3b89..908844327db0 100644
--- a/drivers/mmc/host/sdhci-of.c
+++ b/drivers/mmc/host/sdhci-of.c
@@ -158,6 +158,13 @@ static unsigned int esdhc_get_max_clock(struct sdhci_host *host)
158 return of_host->clock; 158 return of_host->clock;
159} 159}
160 160
161static unsigned int esdhc_get_min_clock(struct sdhci_host *host)
162{
163 struct sdhci_of_host *of_host = sdhci_priv(host);
164
165 return of_host->clock / 256 / 16;
166}
167
161static unsigned int esdhc_get_timeout_clock(struct sdhci_host *host) 168static unsigned int esdhc_get_timeout_clock(struct sdhci_host *host)
162{ 169{
163 struct sdhci_of_host *of_host = sdhci_priv(host); 170 struct sdhci_of_host *of_host = sdhci_priv(host);
@@ -184,6 +191,7 @@ static struct sdhci_of_data sdhci_esdhc = {
184 .set_clock = esdhc_set_clock, 191 .set_clock = esdhc_set_clock,
185 .enable_dma = esdhc_enable_dma, 192 .enable_dma = esdhc_enable_dma,
186 .get_max_clock = esdhc_get_max_clock, 193 .get_max_clock = esdhc_get_max_clock,
194 .get_min_clock = esdhc_get_min_clock,
187 .get_timeout_clock = esdhc_get_timeout_clock, 195 .get_timeout_clock = esdhc_get_timeout_clock,
188 }, 196 },
189}; 197};
diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c
index 6779b4ecab18..62041c7e9246 100644
--- a/drivers/mmc/host/sdhci.c
+++ b/drivers/mmc/host/sdhci.c
@@ -1766,7 +1766,10 @@ int sdhci_add_host(struct sdhci_host *host)
1766 * Set host parameters. 1766 * Set host parameters.
1767 */ 1767 */
1768 mmc->ops = &sdhci_ops; 1768 mmc->ops = &sdhci_ops;
1769 mmc->f_min = host->max_clk / 256; 1769 if (host->ops->get_min_clock)
1770 mmc->f_min = host->ops->get_min_clock(host);
1771 else
1772 mmc->f_min = host->max_clk / 256;
1770 mmc->f_max = host->max_clk; 1773 mmc->f_max = host->max_clk;
1771 mmc->caps = MMC_CAP_SDIO_IRQ; 1774 mmc->caps = MMC_CAP_SDIO_IRQ;
1772 1775
diff --git a/drivers/mmc/host/sdhci.h b/drivers/mmc/host/sdhci.h
index 831ddf7dcb49..c77e9ff30223 100644
--- a/drivers/mmc/host/sdhci.h
+++ b/drivers/mmc/host/sdhci.h
@@ -302,6 +302,7 @@ struct sdhci_ops {
302 302
303 int (*enable_dma)(struct sdhci_host *host); 303 int (*enable_dma)(struct sdhci_host *host);
304 unsigned int (*get_max_clock)(struct sdhci_host *host); 304 unsigned int (*get_max_clock)(struct sdhci_host *host);
305 unsigned int (*get_min_clock)(struct sdhci_host *host);
305 unsigned int (*get_timeout_clock)(struct sdhci_host *host); 306 unsigned int (*get_timeout_clock)(struct sdhci_host *host);
306}; 307};
307 308
diff --git a/drivers/rtc/rtc-cmos.c b/drivers/rtc/rtc-cmos.c
index 23e10b6263d6..f7a4701bf863 100644
--- a/drivers/rtc/rtc-cmos.c
+++ b/drivers/rtc/rtc-cmos.c
@@ -1174,23 +1174,34 @@ static struct platform_driver cmos_platform_driver = {
1174 } 1174 }
1175}; 1175};
1176 1176
1177#ifdef CONFIG_PNP
1178static bool pnp_driver_registered;
1179#endif
1180static bool platform_driver_registered;
1181
1177static int __init cmos_init(void) 1182static int __init cmos_init(void)
1178{ 1183{
1179 int retval = 0; 1184 int retval = 0;
1180 1185
1181#ifdef CONFIG_PNP 1186#ifdef CONFIG_PNP
1182 pnp_register_driver(&cmos_pnp_driver); 1187 retval = pnp_register_driver(&cmos_pnp_driver);
1188 if (retval == 0)
1189 pnp_driver_registered = true;
1183#endif 1190#endif
1184 1191
1185 if (!cmos_rtc.dev) 1192 if (!cmos_rtc.dev) {
1186 retval = platform_driver_probe(&cmos_platform_driver, 1193 retval = platform_driver_probe(&cmos_platform_driver,
1187 cmos_platform_probe); 1194 cmos_platform_probe);
1195 if (retval == 0)
1196 platform_driver_registered = true;
1197 }
1188 1198
1189 if (retval == 0) 1199 if (retval == 0)
1190 return 0; 1200 return 0;
1191 1201
1192#ifdef CONFIG_PNP 1202#ifdef CONFIG_PNP
1193 pnp_unregister_driver(&cmos_pnp_driver); 1203 if (pnp_driver_registered)
1204 pnp_unregister_driver(&cmos_pnp_driver);
1194#endif 1205#endif
1195 return retval; 1206 return retval;
1196} 1207}
@@ -1199,9 +1210,11 @@ module_init(cmos_init);
1199static void __exit cmos_exit(void) 1210static void __exit cmos_exit(void)
1200{ 1211{
1201#ifdef CONFIG_PNP 1212#ifdef CONFIG_PNP
1202 pnp_unregister_driver(&cmos_pnp_driver); 1213 if (pnp_driver_registered)
1214 pnp_unregister_driver(&cmos_pnp_driver);
1203#endif 1215#endif
1204 platform_driver_unregister(&cmos_platform_driver); 1216 if (platform_driver_registered)
1217 platform_driver_unregister(&cmos_platform_driver);
1205} 1218}
1206module_exit(cmos_exit); 1219module_exit(cmos_exit);
1207 1220
diff --git a/drivers/serial/atmel_serial.c b/drivers/serial/atmel_serial.c
index 338b15c0a548..607d43a31048 100644
--- a/drivers/serial/atmel_serial.c
+++ b/drivers/serial/atmel_serial.c
@@ -1551,6 +1551,7 @@ static int __devinit atmel_serial_probe(struct platform_device *pdev)
1551 if (ret) 1551 if (ret)
1552 goto err_add_port; 1552 goto err_add_port;
1553 1553
1554#ifdef CONFIG_SERIAL_ATMEL_CONSOLE
1554 if (atmel_is_console_port(&port->uart) 1555 if (atmel_is_console_port(&port->uart)
1555 && ATMEL_CONSOLE_DEVICE->flags & CON_ENABLED) { 1556 && ATMEL_CONSOLE_DEVICE->flags & CON_ENABLED) {
1556 /* 1557 /*
@@ -1559,6 +1560,7 @@ static int __devinit atmel_serial_probe(struct platform_device *pdev)
1559 */ 1560 */
1560 clk_disable(port->clk); 1561 clk_disable(port->clk);
1561 } 1562 }
1563#endif
1562 1564
1563 device_init_wakeup(&pdev->dev, 1); 1565 device_init_wakeup(&pdev->dev, 1);
1564 platform_set_drvdata(pdev, port); 1566 platform_set_drvdata(pdev, port);
diff --git a/drivers/spi/omap2_mcspi.c b/drivers/spi/omap2_mcspi.c
index eee4b6e0af2c..9b80ad36dbba 100644
--- a/drivers/spi/omap2_mcspi.c
+++ b/drivers/spi/omap2_mcspi.c
@@ -59,6 +59,8 @@
59 59
60/* per-register bitmasks: */ 60/* per-register bitmasks: */
61 61
62#define OMAP2_MCSPI_SYSCONFIG_SMARTIDLE (2 << 3)
63#define OMAP2_MCSPI_SYSCONFIG_ENAWAKEUP (1 << 2)
62#define OMAP2_MCSPI_SYSCONFIG_AUTOIDLE (1 << 0) 64#define OMAP2_MCSPI_SYSCONFIG_AUTOIDLE (1 << 0)
63#define OMAP2_MCSPI_SYSCONFIG_SOFTRESET (1 << 1) 65#define OMAP2_MCSPI_SYSCONFIG_SOFTRESET (1 << 1)
64 66
@@ -90,6 +92,7 @@
90 92
91#define OMAP2_MCSPI_CHCTRL_EN (1 << 0) 93#define OMAP2_MCSPI_CHCTRL_EN (1 << 0)
92 94
95#define OMAP2_MCSPI_WAKEUPENABLE_WKEN (1 << 0)
93 96
94/* We have 2 DMA channels per CS, one for RX and one for TX */ 97/* We have 2 DMA channels per CS, one for RX and one for TX */
95struct omap2_mcspi_dma { 98struct omap2_mcspi_dma {
@@ -269,7 +272,7 @@ omap2_mcspi_txrx_dma(struct spi_device *spi, struct spi_transfer *xfer)
269 272
270 if (rx != NULL) { 273 if (rx != NULL) {
271 omap_set_dma_transfer_params(mcspi_dma->dma_rx_channel, 274 omap_set_dma_transfer_params(mcspi_dma->dma_rx_channel,
272 data_type, element_count, 1, 275 data_type, element_count - 1, 1,
273 OMAP_DMA_SYNC_ELEMENT, 276 OMAP_DMA_SYNC_ELEMENT,
274 mcspi_dma->dma_rx_sync_dev, 1); 277 mcspi_dma->dma_rx_sync_dev, 1);
275 278
@@ -300,6 +303,25 @@ omap2_mcspi_txrx_dma(struct spi_device *spi, struct spi_transfer *xfer)
300 if (rx != NULL) { 303 if (rx != NULL) {
301 wait_for_completion(&mcspi_dma->dma_rx_completion); 304 wait_for_completion(&mcspi_dma->dma_rx_completion);
302 dma_unmap_single(NULL, xfer->rx_dma, count, DMA_FROM_DEVICE); 305 dma_unmap_single(NULL, xfer->rx_dma, count, DMA_FROM_DEVICE);
306 omap2_mcspi_set_enable(spi, 0);
307 if (likely(mcspi_read_cs_reg(spi, OMAP2_MCSPI_CHSTAT0)
308 & OMAP2_MCSPI_CHSTAT_RXS)) {
309 u32 w;
310
311 w = mcspi_read_cs_reg(spi, OMAP2_MCSPI_RX0);
312 if (word_len <= 8)
313 ((u8 *)xfer->rx_buf)[element_count - 1] = w;
314 else if (word_len <= 16)
315 ((u16 *)xfer->rx_buf)[element_count - 1] = w;
316 else /* word_len <= 32 */
317 ((u32 *)xfer->rx_buf)[element_count - 1] = w;
318 } else {
319 dev_err(&spi->dev, "DMA RX last word empty");
320 count -= (word_len <= 8) ? 1 :
321 (word_len <= 16) ? 2 :
322 /* word_len <= 32 */ 4;
323 }
324 omap2_mcspi_set_enable(spi, 1);
303 } 325 }
304 return count; 326 return count;
305} 327}
@@ -873,8 +895,12 @@ static int __init omap2_mcspi_reset(struct omap2_mcspi *mcspi)
873 } while (!(tmp & OMAP2_MCSPI_SYSSTATUS_RESETDONE)); 895 } while (!(tmp & OMAP2_MCSPI_SYSSTATUS_RESETDONE));
874 896
875 mcspi_write_reg(master, OMAP2_MCSPI_SYSCONFIG, 897 mcspi_write_reg(master, OMAP2_MCSPI_SYSCONFIG,
876 /* (3 << 8) | (2 << 3) | */ 898 OMAP2_MCSPI_SYSCONFIG_AUTOIDLE |
877 OMAP2_MCSPI_SYSCONFIG_AUTOIDLE); 899 OMAP2_MCSPI_SYSCONFIG_ENAWAKEUP |
900 OMAP2_MCSPI_SYSCONFIG_SMARTIDLE);
901
902 mcspi_write_reg(master, OMAP2_MCSPI_WAKEUPENABLE,
903 OMAP2_MCSPI_WAKEUPENABLE_WKEN);
878 904
879 omap2_mcspi_set_master_mode(master); 905 omap2_mcspi_set_master_mode(master);
880 906
diff --git a/drivers/staging/Kconfig b/drivers/staging/Kconfig
index 348bf61a8fec..975ecddbce30 100644
--- a/drivers/staging/Kconfig
+++ b/drivers/staging/Kconfig
@@ -103,8 +103,6 @@ source "drivers/staging/pohmelfs/Kconfig"
103 103
104source "drivers/staging/stlc45xx/Kconfig" 104source "drivers/staging/stlc45xx/Kconfig"
105 105
106source "drivers/staging/uc2322/Kconfig"
107
108source "drivers/staging/b3dfg/Kconfig" 106source "drivers/staging/b3dfg/Kconfig"
109 107
110source "drivers/staging/phison/Kconfig" 108source "drivers/staging/phison/Kconfig"
diff --git a/drivers/staging/Makefile b/drivers/staging/Makefile
index 8d61d7b4debf..2241ae1b21ee 100644
--- a/drivers/staging/Makefile
+++ b/drivers/staging/Makefile
@@ -34,7 +34,6 @@ obj-$(CONFIG_ANDROID) += android/
34obj-$(CONFIG_DST) += dst/ 34obj-$(CONFIG_DST) += dst/
35obj-$(CONFIG_POHMELFS) += pohmelfs/ 35obj-$(CONFIG_POHMELFS) += pohmelfs/
36obj-$(CONFIG_STLC45XX) += stlc45xx/ 36obj-$(CONFIG_STLC45XX) += stlc45xx/
37obj-$(CONFIG_USB_SERIAL_ATEN2011) += uc2322/
38obj-$(CONFIG_B3DFG) += b3dfg/ 37obj-$(CONFIG_B3DFG) += b3dfg/
39obj-$(CONFIG_IDE_PHISON) += phison/ 38obj-$(CONFIG_IDE_PHISON) += phison/
40obj-$(CONFIG_PLAN9AUTH) += p9auth/ 39obj-$(CONFIG_PLAN9AUTH) += p9auth/
diff --git a/drivers/staging/android/lowmemorykiller.c b/drivers/staging/android/lowmemorykiller.c
index fe72240f5a9e..f934393f3959 100644
--- a/drivers/staging/android/lowmemorykiller.c
+++ b/drivers/staging/android/lowmemorykiller.c
@@ -96,19 +96,21 @@ static int lowmem_shrink(int nr_to_scan, gfp_t gfp_mask)
96 96
97 read_lock(&tasklist_lock); 97 read_lock(&tasklist_lock);
98 for_each_process(p) { 98 for_each_process(p) {
99 struct mm_struct *mm;
99 int oom_adj; 100 int oom_adj;
100 101
101 task_lock(p); 102 task_lock(p);
102 if (!p->mm) { 103 mm = p->mm;
104 if (!mm) {
103 task_unlock(p); 105 task_unlock(p);
104 continue; 106 continue;
105 } 107 }
106 oom_adj = p->oomkilladj; 108 oom_adj = mm->oom_adj;
107 if (oom_adj < min_adj) { 109 if (oom_adj < min_adj) {
108 task_unlock(p); 110 task_unlock(p);
109 continue; 111 continue;
110 } 112 }
111 tasksize = get_mm_rss(p->mm); 113 tasksize = get_mm_rss(mm);
112 task_unlock(p); 114 task_unlock(p);
113 if (tasksize <= 0) 115 if (tasksize <= 0)
114 continue; 116 continue;
diff --git a/drivers/staging/serqt_usb2/serqt_usb2.c b/drivers/staging/serqt_usb2/serqt_usb2.c
index a9bd4106beb7..0fdf8c6dc648 100644
--- a/drivers/staging/serqt_usb2/serqt_usb2.c
+++ b/drivers/staging/serqt_usb2/serqt_usb2.c
@@ -360,18 +360,18 @@ static void qt_read_bulk_callback(struct urb *urb)
360 if (port_paranoia_check(port, __func__) != 0) { 360 if (port_paranoia_check(port, __func__) != 0) {
361 dbg("%s - port_paranoia_check, exiting\n", __func__); 361 dbg("%s - port_paranoia_check, exiting\n", __func__);
362 qt_port->ReadBulkStopped = 1; 362 qt_port->ReadBulkStopped = 1;
363 return; 363 goto exit;
364 } 364 }
365 365
366 if (!serial) { 366 if (!serial) {
367 dbg("%s - bad serial pointer, exiting\n", __func__); 367 dbg("%s - bad serial pointer, exiting\n", __func__);
368 return; 368 goto exit;
369 } 369 }
370 if (qt_port->closePending == 1) { 370 if (qt_port->closePending == 1) {
371 /* Were closing , stop reading */ 371 /* Were closing , stop reading */
372 dbg("%s - (qt_port->closepending == 1\n", __func__); 372 dbg("%s - (qt_port->closepending == 1\n", __func__);
373 qt_port->ReadBulkStopped = 1; 373 qt_port->ReadBulkStopped = 1;
374 return; 374 goto exit;
375 } 375 }
376 376
377 /* 377 /*
@@ -381,7 +381,7 @@ static void qt_read_bulk_callback(struct urb *urb)
381 */ 381 */
382 if (qt_port->RxHolding == 1) { 382 if (qt_port->RxHolding == 1) {
383 qt_port->ReadBulkStopped = 1; 383 qt_port->ReadBulkStopped = 1;
384 return; 384 goto exit;
385 } 385 }
386 386
387 if (urb->status) { 387 if (urb->status) {
@@ -389,7 +389,7 @@ static void qt_read_bulk_callback(struct urb *urb)
389 389
390 dbg("%s - nonzero read bulk status received: %d\n", 390 dbg("%s - nonzero read bulk status received: %d\n",
391 __func__, urb->status); 391 __func__, urb->status);
392 return; 392 goto exit;
393 } 393 }
394 394
395 if (tty && RxCount) { 395 if (tty && RxCount) {
@@ -463,6 +463,8 @@ static void qt_read_bulk_callback(struct urb *urb)
463 } 463 }
464 464
465 schedule_work(&port->work); 465 schedule_work(&port->work);
466exit:
467 tty_kref_put(tty);
466} 468}
467 469
468/* 470/*
@@ -736,6 +738,11 @@ static int qt_startup(struct usb_serial *serial)
736 if (!qt_port) { 738 if (!qt_port) {
737 dbg("%s: kmalloc for quatech_port (%d) failed!.", 739 dbg("%s: kmalloc for quatech_port (%d) failed!.",
738 __func__, i); 740 __func__, i);
741 for(--i; i >= 0; i--) {
742 port = serial->port[i];
743 kfree(usb_get_serial_port_data(port));
744 usb_set_serial_port_data(port, NULL);
745 }
739 return -ENOMEM; 746 return -ENOMEM;
740 } 747 }
741 spin_lock_init(&qt_port->lock); 748 spin_lock_init(&qt_port->lock);
@@ -1041,7 +1048,7 @@ static void qt_block_until_empty(struct tty_struct *tty,
1041 } 1048 }
1042} 1049}
1043 1050
1044static void qt_close( struct usb_serial_port *port) 1051static void qt_close(struct usb_serial_port *port)
1045{ 1052{
1046 struct usb_serial *serial = port->serial; 1053 struct usb_serial *serial = port->serial;
1047 struct quatech_port *qt_port; 1054 struct quatech_port *qt_port;
@@ -1068,6 +1075,7 @@ static void qt_close( struct usb_serial_port *port)
1068 /* wait up to for transmitter to empty */ 1075 /* wait up to for transmitter to empty */
1069 if (serial->dev) 1076 if (serial->dev)
1070 qt_block_until_empty(tty, qt_port); 1077 qt_block_until_empty(tty, qt_port);
1078 tty_kref_put(tty);
1071 1079
1072 /* Close uart channel */ 1080 /* Close uart channel */
1073 status = qt_close_channel(serial, index); 1081 status = qt_close_channel(serial, index);
diff --git a/drivers/staging/uc2322/Kconfig b/drivers/staging/uc2322/Kconfig
deleted file mode 100644
index 2e0c6e79df2b..000000000000
--- a/drivers/staging/uc2322/Kconfig
+++ /dev/null
@@ -1,10 +0,0 @@
1config USB_SERIAL_ATEN2011
2 tristate "ATEN 2011 USB to serial device support"
3 depends on USB_SERIAL
4 default N
5 ---help---
6 Say Y here if you want to use a ATEN 2011 dual port USB to serial
7 adapter.
8
9 To compile this driver as a module, choose M here: the module will be
10 called aten2011.
diff --git a/drivers/staging/uc2322/Makefile b/drivers/staging/uc2322/Makefile
deleted file mode 100644
index 49c18d6e579f..000000000000
--- a/drivers/staging/uc2322/Makefile
+++ /dev/null
@@ -1 +0,0 @@
1obj-$(CONFIG_USB_SERIAL_ATEN2011) += aten2011.o
diff --git a/drivers/staging/uc2322/TODO b/drivers/staging/uc2322/TODO
deleted file mode 100644
index c189a64c4185..000000000000
--- a/drivers/staging/uc2322/TODO
+++ /dev/null
@@ -1,7 +0,0 @@
1TODO:
2 - checkpatch.pl cleanups
3 - remove dead and useless code (auditing the tty ioctls to
4 verify that they really are correct and needed.)
5
6Please send any patches to Greg Kroah-Hartman <greg@kroah.com> and
7Russell Lang <gsview@ghostgum.com.au>.
diff --git a/drivers/staging/uc2322/aten2011.c b/drivers/staging/uc2322/aten2011.c
deleted file mode 100644
index 39d0926d1a90..000000000000
--- a/drivers/staging/uc2322/aten2011.c
+++ /dev/null
@@ -1,2430 +0,0 @@
1/*
2 * Aten 2011 USB serial driver for 4 port devices
3 *
4 * Copyright (C) 2000 Inside Out Networks
5 * Copyright (C) 2001-2002, 2009 Greg Kroah-Hartman <greg@kroah.com>
6 * Copyright (C) 2009 Novell Inc.
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
13 */
14
15#include <linux/kernel.h>
16#include <linux/errno.h>
17#include <linux/init.h>
18#include <linux/slab.h>
19#include <linux/tty.h>
20#include <linux/tty_driver.h>
21#include <linux/tty_flip.h>
22#include <linux/module.h>
23#include <linux/serial.h>
24#include <linux/uaccess.h>
25#include <linux/usb.h>
26#include <linux/usb/serial.h>
27
28
29#define ZLP_REG1 0x3A /* Zero_Flag_Reg1 58 */
30#define ZLP_REG2 0x3B /* Zero_Flag_Reg2 59 */
31#define ZLP_REG3 0x3C /* Zero_Flag_Reg3 60 */
32#define ZLP_REG4 0x3D /* Zero_Flag_Reg4 61 */
33#define ZLP_REG5 0x3E /* Zero_Flag_Reg5 62 */
34
35/* Interrupt Rotinue Defines */
36#define SERIAL_IIR_RLS 0x06
37#define SERIAL_IIR_RDA 0x04
38#define SERIAL_IIR_CTI 0x0c
39#define SERIAL_IIR_THR 0x02
40#define SERIAL_IIR_MS 0x00
41
42/* Emulation of the bit mask on the LINE STATUS REGISTER. */
43#define SERIAL_LSR_DR 0x0001
44#define SERIAL_LSR_OE 0x0002
45#define SERIAL_LSR_PE 0x0004
46#define SERIAL_LSR_FE 0x0008
47#define SERIAL_LSR_BI 0x0010
48#define SERIAL_LSR_THRE 0x0020
49#define SERIAL_LSR_TEMT 0x0040
50#define SERIAL_LSR_FIFOERR 0x0080
51
52/* MSR bit defines(place holders) */
53#define ATEN_MSR_DELTA_CTS 0x10
54#define ATEN_MSR_DELTA_DSR 0x20
55#define ATEN_MSR_DELTA_RI 0x40
56#define ATEN_MSR_DELTA_CD 0x80
57
58/* Serial Port register Address */
59#define RECEIVE_BUFFER_REGISTER ((__u16)(0x00))
60#define TRANSMIT_HOLDING_REGISTER ((__u16)(0x00))
61#define INTERRUPT_ENABLE_REGISTER ((__u16)(0x01))
62#define INTERRUPT_IDENT_REGISTER ((__u16)(0x02))
63#define FIFO_CONTROL_REGISTER ((__u16)(0x02))
64#define LINE_CONTROL_REGISTER ((__u16)(0x03))
65#define MODEM_CONTROL_REGISTER ((__u16)(0x04))
66#define LINE_STATUS_REGISTER ((__u16)(0x05))
67#define MODEM_STATUS_REGISTER ((__u16)(0x06))
68#define SCRATCH_PAD_REGISTER ((__u16)(0x07))
69#define DIVISOR_LATCH_LSB ((__u16)(0x00))
70#define DIVISOR_LATCH_MSB ((__u16)(0x01))
71
72#define SP1_REGISTER ((__u16)(0x00))
73#define CONTROL1_REGISTER ((__u16)(0x01))
74#define CLK_MULTI_REGISTER ((__u16)(0x02))
75#define CLK_START_VALUE_REGISTER ((__u16)(0x03))
76#define DCR1_REGISTER ((__u16)(0x04))
77#define GPIO_REGISTER ((__u16)(0x07))
78
79#define SERIAL_LCR_DLAB ((__u16)(0x0080))
80
81/*
82 * URB POOL related defines
83 */
84#define NUM_URBS 16 /* URB Count */
85#define URB_TRANSFER_BUFFER_SIZE 32 /* URB Size */
86
87#define USB_VENDOR_ID_ATENINTL 0x0557
88#define ATENINTL_DEVICE_ID_2011 0x2011
89#define ATENINTL_DEVICE_ID_7820 0x7820
90
91static struct usb_device_id id_table[] = {
92 { USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_2011) },
93 { USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_7820) },
94 { } /* terminating entry */
95};
96MODULE_DEVICE_TABLE(usb, id_table);
97
98/* This structure holds all of the local port information */
99struct ATENINTL_port {
100 int port_num; /*Actual port number in the device(1,2,etc)*/
101 __u8 bulk_out_endpoint; /* the bulk out endpoint handle */
102 unsigned char *bulk_out_buffer; /* buffer used for the bulk out endpoint */
103 struct urb *write_urb; /* write URB for this port */
104 __u8 bulk_in_endpoint; /* the bulk in endpoint handle */
105 unsigned char *bulk_in_buffer; /* the buffer we use for the bulk in endpoint */
106 struct urb *read_urb; /* read URB for this port */
107 __u8 shadowLCR; /* last LCR value received */
108 __u8 shadowMCR; /* last MCR value received */
109 char open;
110 char chaseResponsePending;
111 wait_queue_head_t wait_chase; /* for handling sleeping while waiting for chase to finish */
112 wait_queue_head_t wait_command; /* for handling sleeping while waiting for command to finish */
113 struct async_icount icount;
114 struct usb_serial_port *port; /* loop back to the owner of this object */
115 /*Offsets*/
116 __u8 SpRegOffset;
117 __u8 ControlRegOffset;
118 __u8 DcrRegOffset;
119 /* for processing control URBS in interrupt context */
120 struct urb *control_urb;
121 char *ctrl_buf;
122 int MsrLsr;
123
124 struct urb *write_urb_pool[NUM_URBS];
125 /* we pass a pointer to this as the arguement sent to cypress_set_termios old_termios */
126 struct ktermios tmp_termios; /* stores the old termios settings */
127 spinlock_t lock; /* private lock */
128};
129
130/* This structure holds all of the individual serial device information */
131struct ATENINTL_serial {
132 __u8 interrupt_in_endpoint; /* the interrupt endpoint handle */
133 unsigned char *interrupt_in_buffer; /* the buffer we use for the interrupt endpoint */
134 struct urb *interrupt_read_urb; /* our interrupt urb */
135 __u8 bulk_in_endpoint; /* the bulk in endpoint handle */
136 unsigned char *bulk_in_buffer; /* the buffer we use for the bulk in endpoint */
137 struct urb *read_urb; /* our bulk read urb */
138 __u8 bulk_out_endpoint; /* the bulk out endpoint handle */
139 struct usb_serial *serial; /* loop back to the owner of this object */
140 int ATEN2011_spectrum_2or4ports; /* this says the number of ports in the device */
141 /* Indicates about the no.of opened ports of an individual USB-serial adapater. */
142 unsigned int NoOfOpenPorts;
143 /* a flag for Status endpoint polling */
144 unsigned char status_polling_started;
145};
146
147static void ATEN2011_set_termios(struct tty_struct *tty,
148 struct usb_serial_port *port,
149 struct ktermios *old_termios);
150static void ATEN2011_change_port_settings(struct tty_struct *tty,
151 struct ATENINTL_port *ATEN2011_port,
152 struct ktermios *old_termios);
153
154/*************************************
155 * Bit definitions for each register *
156 *************************************/
157#define LCR_BITS_5 0x00 /* 5 bits/char */
158#define LCR_BITS_6 0x01 /* 6 bits/char */
159#define LCR_BITS_7 0x02 /* 7 bits/char */
160#define LCR_BITS_8 0x03 /* 8 bits/char */
161#define LCR_BITS_MASK 0x03 /* Mask for bits/char field */
162
163#define LCR_STOP_1 0x00 /* 1 stop bit */
164#define LCR_STOP_1_5 0x04 /* 1.5 stop bits (if 5 bits/char) */
165#define LCR_STOP_2 0x04 /* 2 stop bits (if 6-8 bits/char) */
166#define LCR_STOP_MASK 0x04 /* Mask for stop bits field */
167
168#define LCR_PAR_NONE 0x00 /* No parity */
169#define LCR_PAR_ODD 0x08 /* Odd parity */
170#define LCR_PAR_EVEN 0x18 /* Even parity */
171#define LCR_PAR_MARK 0x28 /* Force parity bit to 1 */
172#define LCR_PAR_SPACE 0x38 /* Force parity bit to 0 */
173#define LCR_PAR_MASK 0x38 /* Mask for parity field */
174
175#define LCR_SET_BREAK 0x40 /* Set Break condition */
176#define LCR_DL_ENABLE 0x80 /* Enable access to divisor latch */
177
178#define MCR_DTR 0x01 /* Assert DTR */
179#define MCR_RTS 0x02 /* Assert RTS */
180#define MCR_OUT1 0x04 /* Loopback only: Sets state of RI */
181#define MCR_MASTER_IE 0x08 /* Enable interrupt outputs */
182#define MCR_LOOPBACK 0x10 /* Set internal (digital) loopback mode */
183#define MCR_XON_ANY 0x20 /* Enable any char to exit XOFF mode */
184
185#define ATEN2011_MSR_CTS 0x10 /* Current state of CTS */
186#define ATEN2011_MSR_DSR 0x20 /* Current state of DSR */
187#define ATEN2011_MSR_RI 0x40 /* Current state of RI */
188#define ATEN2011_MSR_CD 0x80 /* Current state of CD */
189
190
191static int debug;
192
193/*
194 * Version Information
195 */
196#define DRIVER_VERSION "2.0"
197#define DRIVER_DESC "ATENINTL 2011 USB Serial Adapter"
198
199/*
200 * Defines used for sending commands to port
201 */
202
203#define ATEN_WDR_TIMEOUT (50) /* default urb timeout */
204
205/* Requests */
206#define ATEN_RD_RTYPE 0xC0
207#define ATEN_WR_RTYPE 0x40
208#define ATEN_RDREQ 0x0D
209#define ATEN_WRREQ 0x0E
210#define ATEN_CTRL_TIMEOUT 500
211#define VENDOR_READ_LENGTH (0x01)
212
213/* set to 1 for RS485 mode and 0 for RS232 mode */
214/* FIXME make this somehow dynamic and not build time specific */
215static int RS485mode;
216
217static int set_reg_sync(struct usb_serial_port *port, __u16 reg, __u16 val)
218{
219 struct usb_device *dev = port->serial->dev;
220 val = val & 0x00ff;
221
222 dbg("%s: is %x, value %x", __func__, reg, val);
223
224 return usb_control_msg(dev, usb_sndctrlpipe(dev, 0), ATEN_WRREQ,
225 ATEN_WR_RTYPE, val, reg, NULL, 0,
226 ATEN_WDR_TIMEOUT);
227}
228
229static int get_reg_sync(struct usb_serial_port *port, __u16 reg, __u16 *val)
230{
231 struct usb_device *dev = port->serial->dev;
232 int ret;
233
234 ret = usb_control_msg(dev, usb_rcvctrlpipe(dev, 0), ATEN_RDREQ,
235 ATEN_RD_RTYPE, 0, reg, val, VENDOR_READ_LENGTH,
236 ATEN_WDR_TIMEOUT);
237 dbg("%s: offset is %x, return val %x", __func__, reg, *val);
238 *val = (*val) & 0x00ff;
239 return ret;
240}
241
242static int set_uart_reg(struct usb_serial_port *port, __u16 reg, __u16 val)
243{
244 struct usb_device *dev = port->serial->dev;
245 struct ATENINTL_serial *a_serial;
246 __u16 minor;
247
248 a_serial = usb_get_serial_data(port->serial);
249 minor = port->serial->minor;
250 if (minor == SERIAL_TTY_NO_MINOR)
251 minor = 0;
252 val = val & 0x00ff;
253
254 /*
255 * For the UART control registers,
256 * the application number need to be Or'ed
257 */
258 if (a_serial->ATEN2011_spectrum_2or4ports == 4)
259 val |= (((__u16)port->number - minor) + 1) << 8;
260 else {
261 if (((__u16) port->number - minor) == 0)
262 val |= (((__u16)port->number - minor) + 1) << 8;
263 else
264 val |= (((__u16)port->number - minor) + 2) << 8;
265 }
266 dbg("%s: application number is %x", __func__, val);
267
268 return usb_control_msg(dev, usb_sndctrlpipe(dev, 0), ATEN_WRREQ,
269 ATEN_WR_RTYPE, val, reg, NULL, 0,
270 ATEN_WDR_TIMEOUT);
271}
272
273static int get_uart_reg(struct usb_serial_port *port, __u16 reg, __u16 *val)
274{
275 struct usb_device *dev = port->serial->dev;
276 int ret = 0;
277 __u16 wval;
278 struct ATENINTL_serial *a_serial;
279 __u16 minor = port->serial->minor;
280
281 a_serial = usb_get_serial_data(port->serial);
282 if (minor == SERIAL_TTY_NO_MINOR)
283 minor = 0;
284
285 /* wval is same as application number */
286 if (a_serial->ATEN2011_spectrum_2or4ports == 4)
287 wval = (((__u16)port->number - minor) + 1) << 8;
288 else {
289 if (((__u16) port->number - minor) == 0)
290 wval = (((__u16) port->number - minor) + 1) << 8;
291 else
292 wval = (((__u16) port->number - minor) + 2) << 8;
293 }
294 dbg("%s: application number is %x", __func__, wval);
295 ret = usb_control_msg(dev, usb_rcvctrlpipe(dev, 0), ATEN_RDREQ,
296 ATEN_RD_RTYPE, wval, reg, val, VENDOR_READ_LENGTH,
297 ATEN_WDR_TIMEOUT);
298 *val = (*val) & 0x00ff;
299 return ret;
300}
301
302static int handle_newMsr(struct ATENINTL_port *port, __u8 newMsr)
303{
304 struct ATENINTL_port *ATEN2011_port;
305 struct async_icount *icount;
306 ATEN2011_port = port;
307 icount = &ATEN2011_port->icount;
308 if (newMsr &
309 (ATEN_MSR_DELTA_CTS | ATEN_MSR_DELTA_DSR | ATEN_MSR_DELTA_RI |
310 ATEN_MSR_DELTA_CD)) {
311 icount = &ATEN2011_port->icount;
312
313 /* update input line counters */
314 if (newMsr & ATEN_MSR_DELTA_CTS)
315 icount->cts++;
316 if (newMsr & ATEN_MSR_DELTA_DSR)
317 icount->dsr++;
318 if (newMsr & ATEN_MSR_DELTA_CD)
319 icount->dcd++;
320 if (newMsr & ATEN_MSR_DELTA_RI)
321 icount->rng++;
322 }
323
324 return 0;
325}
326
327static int handle_newLsr(struct ATENINTL_port *port, __u8 newLsr)
328{
329 struct async_icount *icount;
330
331 dbg("%s - %02x", __func__, newLsr);
332
333 if (newLsr & SERIAL_LSR_BI) {
334 /*
335 * Parity and Framing errors only count if they occur exclusive
336 * of a break being received.
337 */
338 newLsr &= (__u8) (SERIAL_LSR_OE | SERIAL_LSR_BI);
339 }
340
341 /* update input line counters */
342 icount = &port->icount;
343 if (newLsr & SERIAL_LSR_BI)
344 icount->brk++;
345 if (newLsr & SERIAL_LSR_OE)
346 icount->overrun++;
347 if (newLsr & SERIAL_LSR_PE)
348 icount->parity++;
349 if (newLsr & SERIAL_LSR_FE)
350 icount->frame++;
351
352 return 0;
353}
354
355static void ATEN2011_control_callback(struct urb *urb)
356{
357 unsigned char *data;
358 struct ATENINTL_port *ATEN2011_port;
359 __u8 regval = 0x0;
360
361 switch (urb->status) {
362 case 0:
363 /* success */
364 break;
365 case -ECONNRESET:
366 case -ENOENT:
367 case -ESHUTDOWN:
368 /* this urb is terminated, clean up */
369 dbg("%s - urb shutting down with status: %d", __func__,
370 urb->status);
371 return;
372 default:
373 dbg("%s - nonzero urb status received: %d", __func__,
374 urb->status);
375 goto exit;
376 }
377
378 ATEN2011_port = (struct ATENINTL_port *)urb->context;
379
380 dbg("%s urb buffer size is %d", __func__, urb->actual_length);
381 dbg("%s ATEN2011_port->MsrLsr is %d port %d", __func__,
382 ATEN2011_port->MsrLsr, ATEN2011_port->port_num);
383 data = urb->transfer_buffer;
384 regval = (__u8) data[0];
385 dbg("%s data is %x", __func__, regval);
386 if (ATEN2011_port->MsrLsr == 0)
387 handle_newMsr(ATEN2011_port, regval);
388 else if (ATEN2011_port->MsrLsr == 1)
389 handle_newLsr(ATEN2011_port, regval);
390
391exit:
392 return;
393}
394
395static int ATEN2011_get_reg(struct ATENINTL_port *ATEN, __u16 Wval, __u16 reg,
396 __u16 *val)
397{
398 struct usb_device *dev = ATEN->port->serial->dev;
399 struct usb_ctrlrequest *dr = NULL;
400 unsigned char *buffer = NULL;
401 int ret = 0;
402 buffer = (__u8 *) ATEN->ctrl_buf;
403
404 dr = (void *)(buffer + 2);
405 dr->bRequestType = ATEN_RD_RTYPE;
406 dr->bRequest = ATEN_RDREQ;
407 dr->wValue = cpu_to_le16(Wval);
408 dr->wIndex = cpu_to_le16(reg);
409 dr->wLength = cpu_to_le16(2);
410
411 usb_fill_control_urb(ATEN->control_urb, dev, usb_rcvctrlpipe(dev, 0),
412 (unsigned char *)dr, buffer, 2,
413 ATEN2011_control_callback, ATEN);
414 ATEN->control_urb->transfer_buffer_length = 2;
415 ret = usb_submit_urb(ATEN->control_urb, GFP_ATOMIC);
416 return ret;
417}
418
419static void ATEN2011_interrupt_callback(struct urb *urb)
420{
421 int result;
422 int length;
423 struct ATENINTL_port *ATEN2011_port;
424 struct ATENINTL_serial *ATEN2011_serial;
425 struct usb_serial *serial;
426 __u16 Data;
427 unsigned char *data;
428 __u8 sp[5], st;
429 int i;
430 __u16 wval;
431 int minor;
432
433 dbg("%s", " : Entering");
434
435 ATEN2011_serial = (struct ATENINTL_serial *)urb->context;
436
437 switch (urb->status) {
438 case 0:
439 /* success */
440 break;
441 case -ECONNRESET:
442 case -ENOENT:
443 case -ESHUTDOWN:
444 /* this urb is terminated, clean up */
445 dbg("%s - urb shutting down with status: %d", __func__,
446 urb->status);
447 return;
448 default:
449 dbg("%s - nonzero urb status received: %d", __func__,
450 urb->status);
451 goto exit;
452 }
453 length = urb->actual_length;
454 data = urb->transfer_buffer;
455
456 serial = ATEN2011_serial->serial;
457
458 /* ATENINTL get 5 bytes
459 * Byte 1 IIR Port 1 (port.number is 0)
460 * Byte 2 IIR Port 2 (port.number is 1)
461 * Byte 3 IIR Port 3 (port.number is 2)
462 * Byte 4 IIR Port 4 (port.number is 3)
463 * Byte 5 FIFO status for both */
464
465 if (length && length > 5) {
466 dbg("%s", "Wrong data !!!");
467 return;
468 }
469
470 /* MATRIX */
471 if (ATEN2011_serial->ATEN2011_spectrum_2or4ports == 4) {
472 sp[0] = (__u8) data[0];
473 sp[1] = (__u8) data[1];
474 sp[2] = (__u8) data[2];
475 sp[3] = (__u8) data[3];
476 st = (__u8) data[4];
477 } else {
478 sp[0] = (__u8) data[0];
479 sp[1] = (__u8) data[2];
480 /* sp[2]=(__u8)data[2]; */
481 /* sp[3]=(__u8)data[3]; */
482 st = (__u8) data[4];
483
484 }
485 for (i = 0; i < serial->num_ports; i++) {
486 ATEN2011_port = usb_get_serial_port_data(serial->port[i]);
487 minor = serial->minor;
488 if (minor == SERIAL_TTY_NO_MINOR)
489 minor = 0;
490 if ((ATEN2011_serial->ATEN2011_spectrum_2or4ports == 2)
491 && (i != 0))
492 wval =
493 (((__u16) serial->port[i]->number -
494 (__u16) (minor)) + 2) << 8;
495 else
496 wval =
497 (((__u16) serial->port[i]->number -
498 (__u16) (minor)) + 1) << 8;
499 if (ATEN2011_port->open != 0) {
500 if (sp[i] & 0x01) {
501 dbg("SP%d No Interrupt !!!", i);
502 } else {
503 switch (sp[i] & 0x0f) {
504 case SERIAL_IIR_RLS:
505 dbg("Serial Port %d: Receiver status error or address bit detected in 9-bit mode", i);
506 ATEN2011_port->MsrLsr = 1;
507 ATEN2011_get_reg(ATEN2011_port, wval,
508 LINE_STATUS_REGISTER,
509 &Data);
510 break;
511 case SERIAL_IIR_MS:
512 dbg("Serial Port %d: Modem status change", i);
513 ATEN2011_port->MsrLsr = 0;
514 ATEN2011_get_reg(ATEN2011_port, wval,
515 MODEM_STATUS_REGISTER,
516 &Data);
517 break;
518 }
519 }
520 }
521
522 }
523exit:
524 if (ATEN2011_serial->status_polling_started == 0)
525 return;
526
527 result = usb_submit_urb(urb, GFP_ATOMIC);
528 if (result) {
529 dev_err(&urb->dev->dev,
530 "%s - Error %d submitting interrupt urb\n",
531 __func__, result);
532 }
533
534 return;
535}
536
537static void ATEN2011_bulk_in_callback(struct urb *urb)
538{
539 int status;
540 unsigned char *data;
541 struct usb_serial *serial;
542 struct usb_serial_port *port;
543 struct ATENINTL_serial *ATEN2011_serial;
544 struct ATENINTL_port *ATEN2011_port;
545 struct tty_struct *tty;
546
547 if (urb->status) {
548 dbg("nonzero read bulk status received: %d", urb->status);
549 return;
550 }
551
552 ATEN2011_port = (struct ATENINTL_port *)urb->context;
553
554 port = (struct usb_serial_port *)ATEN2011_port->port;
555 serial = port->serial;
556
557 dbg("%s", "Entering...");
558
559 data = urb->transfer_buffer;
560 ATEN2011_serial = usb_get_serial_data(serial);
561
562 if (urb->actual_length) {
563 tty = tty_port_tty_get(&ATEN2011_port->port->port);
564 if (tty) {
565 tty_buffer_request_room(tty, urb->actual_length);
566 tty_insert_flip_string(tty, data, urb->actual_length);
567 tty_flip_buffer_push(tty);
568 tty_kref_put(tty);
569 }
570
571 ATEN2011_port->icount.rx += urb->actual_length;
572 dbg("ATEN2011_port->icount.rx is %d:",
573 ATEN2011_port->icount.rx);
574 }
575
576 if (!ATEN2011_port->read_urb) {
577 dbg("%s", "URB KILLED !!!");
578 return;
579 }
580
581 if (ATEN2011_port->read_urb->status != -EINPROGRESS) {
582 ATEN2011_port->read_urb->dev = serial->dev;
583
584 status = usb_submit_urb(ATEN2011_port->read_urb, GFP_ATOMIC);
585 if (status)
586 dbg("usb_submit_urb(read bulk) failed, status = %d", status);
587 }
588}
589
590static void ATEN2011_bulk_out_data_callback(struct urb *urb)
591{
592 struct ATENINTL_port *ATEN2011_port;
593 struct tty_struct *tty;
594
595 if (urb->status) {
596 dbg("nonzero write bulk status received:%d", urb->status);
597 return;
598 }
599
600 ATEN2011_port = (struct ATENINTL_port *)urb->context;
601
602 dbg("%s", "Entering .........");
603
604 tty = tty_port_tty_get(&ATEN2011_port->port->port);
605
606 if (tty && ATEN2011_port->open)
607 /* tell the tty driver that something has changed */
608 tty_wakeup(tty);
609
610 /* schedule_work(&ATEN2011_port->port->work); */
611 tty_kref_put(tty);
612
613}
614
615#ifdef ATENSerialProbe
616static int ATEN2011_serial_probe(struct usb_serial *serial,
617 const struct usb_device_id *id)
618{
619
620 /*need to implement the mode_reg reading and updating\
621 structures usb_serial_ device_type\
622 (i.e num_ports, num_bulkin,bulkout etc) */
623 /* Also we can update the changes attach */
624 return 1;
625}
626#endif
627
628static int ATEN2011_open(struct tty_struct *tty, struct usb_serial_port *port,
629 struct file *filp)
630{
631 int response;
632 int j;
633 struct usb_serial *serial;
634 struct urb *urb;
635 __u16 Data;
636 int status;
637 struct ATENINTL_serial *ATEN2011_serial;
638 struct ATENINTL_port *ATEN2011_port;
639 struct ktermios tmp_termios;
640 int minor;
641
642 serial = port->serial;
643
644 ATEN2011_port = usb_get_serial_port_data(port);
645
646 if (ATEN2011_port == NULL)
647 return -ENODEV;
648
649 ATEN2011_serial = usb_get_serial_data(serial);
650 if (ATEN2011_serial == NULL)
651 return -ENODEV;
652
653 /* increment the number of opened ports counter here */
654 ATEN2011_serial->NoOfOpenPorts++;
655
656 usb_clear_halt(serial->dev, port->write_urb->pipe);
657 usb_clear_halt(serial->dev, port->read_urb->pipe);
658
659 /* Initialising the write urb pool */
660 for (j = 0; j < NUM_URBS; ++j) {
661 urb = usb_alloc_urb(0, GFP_ATOMIC);
662 ATEN2011_port->write_urb_pool[j] = urb;
663
664 if (urb == NULL) {
665 err("No more urbs???");
666 continue;
667 }
668
669 urb->transfer_buffer = NULL;
670 urb->transfer_buffer =
671 kmalloc(URB_TRANSFER_BUFFER_SIZE, GFP_KERNEL);
672 if (!urb->transfer_buffer) {
673 err("%s-out of memory for urb buffers.", __func__);
674 continue;
675 }
676 }
677
678/*****************************************************************************
679 * Initialize ATEN2011 -- Write Init values to corresponding Registers
680 *
681 * Register Index
682 * 1 : IER
683 * 2 : FCR
684 * 3 : LCR
685 * 4 : MCR
686 *
687 * 0x08 : SP1/2 Control Reg
688 *****************************************************************************/
689
690/* NEED to check the fallowing Block */
691
692 Data = 0x0;
693 status = get_reg_sync(port, ATEN2011_port->SpRegOffset, &Data);
694 if (status < 0) {
695 dbg("Reading Spreg failed");
696 return -1;
697 }
698 Data |= 0x80;
699 status = set_reg_sync(port, ATEN2011_port->SpRegOffset, Data);
700 if (status < 0) {
701 dbg("writing Spreg failed");
702 return -1;
703 }
704
705 Data &= ~0x80;
706 status = set_reg_sync(port, ATEN2011_port->SpRegOffset, Data);
707 if (status < 0) {
708 dbg("writing Spreg failed");
709 return -1;
710 }
711
712/* End of block to be checked */
713/**************************CHECK***************************/
714
715 if (RS485mode == 0)
716 Data = 0xC0;
717 else
718 Data = 0x00;
719 status = set_uart_reg(port, SCRATCH_PAD_REGISTER, Data);
720 if (status < 0) {
721 dbg("Writing SCRATCH_PAD_REGISTER failed status-0x%x", status);
722 return -1;
723 } else
724 dbg("SCRATCH_PAD_REGISTER Writing success status%d", status);
725
726/**************************CHECK***************************/
727
728 Data = 0x0;
729 status = get_reg_sync(port, ATEN2011_port->ControlRegOffset, &Data);
730 if (status < 0) {
731 dbg("Reading Controlreg failed");
732 return -1;
733 }
734 Data |= 0x08; /* Driver done bit */
735 Data |= 0x20; /* rx_disable */
736 status = 0;
737 status =
738 set_reg_sync(port, ATEN2011_port->ControlRegOffset, Data);
739 if (status < 0) {
740 dbg("writing Controlreg failed");
741 return -1;
742 }
743 /*
744 * do register settings here
745 * Set all regs to the device default values.
746 * First Disable all interrupts.
747 */
748
749 Data = 0x00;
750 status = set_uart_reg(port, INTERRUPT_ENABLE_REGISTER, Data);
751 if (status < 0) {
752 dbg("disableing interrupts failed");
753 return -1;
754 }
755 /* Set FIFO_CONTROL_REGISTER to the default value */
756 Data = 0x00;
757 status = set_uart_reg(port, FIFO_CONTROL_REGISTER, Data);
758 if (status < 0) {
759 dbg("Writing FIFO_CONTROL_REGISTER failed");
760 return -1;
761 }
762
763 Data = 0xcf; /* chk */
764 status = set_uart_reg(port, FIFO_CONTROL_REGISTER, Data);
765 if (status < 0) {
766 dbg("Writing FIFO_CONTROL_REGISTER failed");
767 return -1;
768 }
769
770 Data = 0x03; /* LCR_BITS_8 */
771 status = set_uart_reg(port, LINE_CONTROL_REGISTER, Data);
772 ATEN2011_port->shadowLCR = Data;
773
774 Data = 0x0b; /* MCR_DTR|MCR_RTS|MCR_MASTER_IE */
775 status = set_uart_reg(port, MODEM_CONTROL_REGISTER, Data);
776 ATEN2011_port->shadowMCR = Data;
777
778#ifdef Check
779 Data = 0x00;
780 status = get_uart_reg(port, LINE_CONTROL_REGISTER, &Data);
781 ATEN2011_port->shadowLCR = Data;
782
783 Data |= SERIAL_LCR_DLAB; /* data latch enable in LCR 0x80 */
784 status = set_uart_reg(port, LINE_CONTROL_REGISTER, Data);
785
786 Data = 0x0c;
787 status = set_uart_reg(port, DIVISOR_LATCH_LSB, Data);
788
789 Data = 0x0;
790 status = set_uart_reg(port, DIVISOR_LATCH_MSB, Data);
791
792 Data = 0x00;
793 status = get_uart_reg(port, LINE_CONTROL_REGISTER, &Data);
794
795/* Data = ATEN2011_port->shadowLCR; */ /* data latch disable */
796 Data = Data & ~SERIAL_LCR_DLAB;
797 status = set_uart_reg(port, LINE_CONTROL_REGISTER, Data);
798 ATEN2011_port->shadowLCR = Data;
799#endif
800 /* clearing Bulkin and Bulkout Fifo */
801 Data = 0x0;
802 status = get_reg_sync(port, ATEN2011_port->SpRegOffset, &Data);
803
804 Data = Data | 0x0c;
805 status = set_reg_sync(port, ATEN2011_port->SpRegOffset, Data);
806
807 Data = Data & ~0x0c;
808 status = set_reg_sync(port, ATEN2011_port->SpRegOffset, Data);
809 /* Finally enable all interrupts */
810 Data = 0x0;
811 Data = 0x0c;
812 status = set_uart_reg(port, INTERRUPT_ENABLE_REGISTER, Data);
813
814 /* clearing rx_disable */
815 Data = 0x0;
816 status = get_reg_sync(port, ATEN2011_port->ControlRegOffset, &Data);
817 Data = Data & ~0x20;
818 status = set_reg_sync(port, ATEN2011_port->ControlRegOffset, Data);
819
820 /* rx_negate */
821 Data = 0x0;
822 status = get_reg_sync(port, ATEN2011_port->ControlRegOffset, &Data);
823 Data = Data | 0x10;
824 status = 0;
825 status = set_reg_sync(port, ATEN2011_port->ControlRegOffset, Data);
826
827 /*
828 * Check to see if we've set up our endpoint info yet
829 * (can't set it up in ATEN2011_startup as the structures
830 * were not set up at that time.)
831 */
832 if (ATEN2011_serial->NoOfOpenPorts == 1) {
833 /* start the status polling here */
834 ATEN2011_serial->status_polling_started = 1;
835 /* If not yet set, Set here */
836 ATEN2011_serial->interrupt_in_buffer =
837 serial->port[0]->interrupt_in_buffer;
838 ATEN2011_serial->interrupt_in_endpoint =
839 serial->port[0]->interrupt_in_endpointAddress;
840 ATEN2011_serial->interrupt_read_urb =
841 serial->port[0]->interrupt_in_urb;
842
843 /* set up interrupt urb */
844 usb_fill_int_urb(ATEN2011_serial->interrupt_read_urb,
845 serial->dev,
846 usb_rcvintpipe(serial->dev,
847 ATEN2011_serial->
848 interrupt_in_endpoint),
849 ATEN2011_serial->interrupt_in_buffer,
850 ATEN2011_serial->interrupt_read_urb->
851 transfer_buffer_length,
852 ATEN2011_interrupt_callback, ATEN2011_serial,
853 ATEN2011_serial->interrupt_read_urb->interval);
854
855 /* start interrupt read for ATEN2011 *
856 * will continue as long as ATEN2011 is connected */
857
858 response =
859 usb_submit_urb(ATEN2011_serial->interrupt_read_urb,
860 GFP_KERNEL);
861 if (response) {
862 dbg("%s - Error %d submitting interrupt urb",
863 __func__, response);
864 }
865
866 }
867
868 /*
869 * See if we've set up our endpoint info yet
870 * (can't set it up in ATEN2011_startup as the
871 * structures were not set up at that time.)
872 */
873
874 dbg("port number is %d", port->number);
875 dbg("serial number is %d", port->serial->minor);
876 dbg("Bulkin endpoint is %d", port->bulk_in_endpointAddress);
877 dbg("BulkOut endpoint is %d", port->bulk_out_endpointAddress);
878 dbg("Interrupt endpoint is %d",
879 port->interrupt_in_endpointAddress);
880 dbg("port's number in the device is %d", ATEN2011_port->port_num);
881 ATEN2011_port->bulk_in_buffer = port->bulk_in_buffer;
882 ATEN2011_port->bulk_in_endpoint = port->bulk_in_endpointAddress;
883 ATEN2011_port->read_urb = port->read_urb;
884 ATEN2011_port->bulk_out_endpoint = port->bulk_out_endpointAddress;
885
886 minor = port->serial->minor;
887 if (minor == SERIAL_TTY_NO_MINOR)
888 minor = 0;
889
890 /* set up our bulk in urb */
891 if ((ATEN2011_serial->ATEN2011_spectrum_2or4ports == 2)
892 && (((__u16) port->number - (__u16) (minor)) != 0)) {
893 usb_fill_bulk_urb(ATEN2011_port->read_urb, serial->dev,
894 usb_rcvbulkpipe(serial->dev,
895 (port->
896 bulk_in_endpointAddress +
897 2)), port->bulk_in_buffer,
898 ATEN2011_port->read_urb->
899 transfer_buffer_length,
900 ATEN2011_bulk_in_callback, ATEN2011_port);
901 } else
902 usb_fill_bulk_urb(ATEN2011_port->read_urb,
903 serial->dev,
904 usb_rcvbulkpipe(serial->dev,
905 port->
906 bulk_in_endpointAddress),
907 port->bulk_in_buffer,
908 ATEN2011_port->read_urb->
909 transfer_buffer_length,
910 ATEN2011_bulk_in_callback, ATEN2011_port);
911
912 dbg("ATEN2011_open: bulkin endpoint is %d",
913 port->bulk_in_endpointAddress);
914 response = usb_submit_urb(ATEN2011_port->read_urb, GFP_KERNEL);
915 if (response) {
916 err("%s - Error %d submitting control urb", __func__,
917 response);
918 }
919
920 /* initialize our wait queues */
921 init_waitqueue_head(&ATEN2011_port->wait_chase);
922 init_waitqueue_head(&ATEN2011_port->wait_command);
923
924 /* initialize our icount structure */
925 memset(&(ATEN2011_port->icount), 0x00, sizeof(ATEN2011_port->icount));
926
927 /* initialize our port settings */
928 ATEN2011_port->shadowMCR = MCR_MASTER_IE; /* Must set to enable ints! */
929 ATEN2011_port->chaseResponsePending = 0;
930 /* send a open port command */
931 ATEN2011_port->open = 1;
932 /* ATEN2011_change_port_settings(ATEN2011_port,old_termios); */
933 /* Setup termios */
934 ATEN2011_set_termios(tty, port, &tmp_termios);
935 ATEN2011_port->icount.tx = 0;
936 ATEN2011_port->icount.rx = 0;
937
938 dbg("usb_serial serial:%x ATEN2011_port:%x\nATEN2011_serial:%x usb_serial_port port:%x",
939 (unsigned int)serial, (unsigned int)ATEN2011_port,
940 (unsigned int)ATEN2011_serial, (unsigned int)port);
941
942 return 0;
943
944}
945
946static int ATEN2011_chars_in_buffer(struct tty_struct *tty)
947{
948 struct usb_serial_port *port = tty->driver_data;
949 int i;
950 int chars = 0;
951 struct ATENINTL_port *ATEN2011_port;
952
953 /* dbg("%s"," ATEN2011_chars_in_buffer:entering ..........."); */
954
955 ATEN2011_port = usb_get_serial_port_data(port);
956 if (ATEN2011_port == NULL) {
957 dbg("%s", "ATEN2011_break:leaving ...........");
958 return -1;
959 }
960
961 for (i = 0; i < NUM_URBS; ++i)
962 if (ATEN2011_port->write_urb_pool[i]->status == -EINPROGRESS)
963 chars += URB_TRANSFER_BUFFER_SIZE;
964
965 dbg("%s - returns %d", __func__, chars);
966 return chars;
967
968}
969
970static void ATEN2011_block_until_tx_empty(struct tty_struct *tty,
971 struct ATENINTL_port *ATEN2011_port)
972{
973 int timeout = HZ / 10;
974 int wait = 30;
975 int count;
976
977 while (1) {
978 count = ATEN2011_chars_in_buffer(tty);
979
980 /* Check for Buffer status */
981 if (count <= 0)
982 return;
983
984 /* Block the thread for a while */
985 interruptible_sleep_on_timeout(&ATEN2011_port->wait_chase,
986 timeout);
987
988 /* No activity.. count down section */
989 wait--;
990 if (wait == 0) {
991 dbg("%s - TIMEOUT", __func__);
992 return;
993 } else {
994 /* Reset timout value back to seconds */
995 wait = 30;
996 }
997 }
998}
999
1000static void ATEN2011_close(struct tty_struct *tty, struct usb_serial_port *port,
1001 struct file *filp)
1002{
1003 struct usb_serial *serial;
1004 struct ATENINTL_serial *ATEN2011_serial;
1005 struct ATENINTL_port *ATEN2011_port;
1006 int no_urbs;
1007 __u16 Data;
1008
1009 dbg("%s", "ATEN2011_close:entering...");
1010 serial = port->serial;
1011
1012 /* take the Adpater and port's private data */
1013 ATEN2011_serial = usb_get_serial_data(serial);
1014 ATEN2011_port = usb_get_serial_port_data(port);
1015 if ((ATEN2011_serial == NULL) || (ATEN2011_port == NULL))
1016 return;
1017
1018 if (serial->dev) {
1019 /* flush and block(wait) until tx is empty */
1020 ATEN2011_block_until_tx_empty(tty, ATEN2011_port);
1021 }
1022 /* kill the ports URB's */
1023 for (no_urbs = 0; no_urbs < NUM_URBS; no_urbs++)
1024 usb_kill_urb(ATEN2011_port->write_urb_pool[no_urbs]);
1025 /* Freeing Write URBs */
1026 for (no_urbs = 0; no_urbs < NUM_URBS; ++no_urbs) {
1027 kfree(ATEN2011_port->write_urb_pool[no_urbs]->transfer_buffer);
1028 usb_free_urb(ATEN2011_port->write_urb_pool[no_urbs]);
1029 }
1030 /* While closing port, shutdown all bulk read, write *
1031 * and interrupt read if they exists */
1032 if (serial->dev) {
1033 if (ATEN2011_port->write_urb) {
1034 dbg("%s", "Shutdown bulk write");
1035 usb_kill_urb(ATEN2011_port->write_urb);
1036 }
1037 if (ATEN2011_port->read_urb) {
1038 dbg("%s", "Shutdown bulk read");
1039 usb_kill_urb(ATEN2011_port->read_urb);
1040 }
1041 if ((&ATEN2011_port->control_urb)) {
1042 dbg("%s", "Shutdown control read");
1043 /* usb_kill_urb (ATEN2011_port->control_urb); */
1044
1045 }
1046 }
1047 /* if(ATEN2011_port->ctrl_buf != NULL) */
1048 /* kfree(ATEN2011_port->ctrl_buf); */
1049 /* decrement the no.of open ports counter of an individual USB-serial adapter. */
1050 ATEN2011_serial->NoOfOpenPorts--;
1051 dbg("NoOfOpenPorts in close%d:in port%d",
1052 ATEN2011_serial->NoOfOpenPorts, port->number);
1053 if (ATEN2011_serial->NoOfOpenPorts == 0) {
1054 /* stop the stus polling here */
1055 ATEN2011_serial->status_polling_started = 0;
1056 if (ATEN2011_serial->interrupt_read_urb) {
1057 dbg("%s", "Shutdown interrupt_read_urb");
1058 /* ATEN2011_serial->interrupt_in_buffer=NULL; */
1059 /* usb_kill_urb (ATEN2011_serial->interrupt_read_urb); */
1060 }
1061 }
1062 if (ATEN2011_port->write_urb) {
1063 /* if this urb had a transfer buffer already (old tx) free it */
1064 kfree(ATEN2011_port->write_urb->transfer_buffer);
1065 usb_free_urb(ATEN2011_port->write_urb);
1066 }
1067
1068 /* clear the MCR & IER */
1069 Data = 0x00;
1070 set_uart_reg(port, MODEM_CONTROL_REGISTER, Data);
1071 Data = 0x00;
1072 set_uart_reg(port, INTERRUPT_ENABLE_REGISTER, Data);
1073
1074 ATEN2011_port->open = 0;
1075 dbg("%s", "Leaving ............");
1076
1077}
1078
1079static void ATEN2011_block_until_chase_response(struct tty_struct *tty,
1080 struct ATENINTL_port
1081 *ATEN2011_port)
1082{
1083 int timeout = 1 * HZ;
1084 int wait = 10;
1085 int count;
1086
1087 while (1) {
1088 count = ATEN2011_chars_in_buffer(tty);
1089
1090 /* Check for Buffer status */
1091 if (count <= 0) {
1092 ATEN2011_port->chaseResponsePending = 0;
1093 return;
1094 }
1095
1096 /* Block the thread for a while */
1097 interruptible_sleep_on_timeout(&ATEN2011_port->wait_chase,
1098 timeout);
1099 /* No activity.. count down section */
1100 wait--;
1101 if (wait == 0) {
1102 dbg("%s - TIMEOUT", __func__);
1103 return;
1104 } else {
1105 /* Reset timout value back to seconds */
1106 wait = 10;
1107 }
1108 }
1109
1110}
1111
1112static void ATEN2011_break(struct tty_struct *tty, int break_state)
1113{
1114 struct usb_serial_port *port = tty->driver_data;
1115 unsigned char data;
1116 struct usb_serial *serial;
1117 struct ATENINTL_serial *ATEN2011_serial;
1118 struct ATENINTL_port *ATEN2011_port;
1119
1120 dbg("%s", "Entering ...........");
1121 dbg("ATEN2011_break: Start");
1122
1123 serial = port->serial;
1124
1125 ATEN2011_serial = usb_get_serial_data(serial);
1126 ATEN2011_port = usb_get_serial_port_data(port);
1127
1128 if ((ATEN2011_serial == NULL) || (ATEN2011_port == NULL))
1129 return;
1130
1131 /* flush and chase */
1132 ATEN2011_port->chaseResponsePending = 1;
1133
1134 if (serial->dev) {
1135 /* flush and block until tx is empty */
1136 ATEN2011_block_until_chase_response(tty, ATEN2011_port);
1137 }
1138
1139 if (break_state == -1)
1140 data = ATEN2011_port->shadowLCR | LCR_SET_BREAK;
1141 else
1142 data = ATEN2011_port->shadowLCR & ~LCR_SET_BREAK;
1143
1144 ATEN2011_port->shadowLCR = data;
1145 dbg("ATEN2011_break ATEN2011_port->shadowLCR is %x",
1146 ATEN2011_port->shadowLCR);
1147 set_uart_reg(port, LINE_CONTROL_REGISTER, ATEN2011_port->shadowLCR);
1148
1149 return;
1150}
1151
1152static int ATEN2011_write_room(struct tty_struct *tty)
1153{
1154 struct usb_serial_port *port = tty->driver_data;
1155 int i;
1156 int room = 0;
1157 struct ATENINTL_port *ATEN2011_port;
1158
1159 ATEN2011_port = usb_get_serial_port_data(port);
1160 if (ATEN2011_port == NULL) {
1161 dbg("%s", "ATEN2011_break:leaving ...........");
1162 return -1;
1163 }
1164
1165 for (i = 0; i < NUM_URBS; ++i)
1166 if (ATEN2011_port->write_urb_pool[i]->status != -EINPROGRESS)
1167 room += URB_TRANSFER_BUFFER_SIZE;
1168
1169 dbg("%s - returns %d", __func__, room);
1170 return room;
1171
1172}
1173
1174static int ATEN2011_write(struct tty_struct *tty, struct usb_serial_port *port,
1175 const unsigned char *data, int count)
1176{
1177 int status;
1178 int i;
1179 int bytes_sent = 0;
1180 int transfer_size;
1181 int minor;
1182
1183 struct ATENINTL_port *ATEN2011_port;
1184 struct usb_serial *serial;
1185 struct ATENINTL_serial *ATEN2011_serial;
1186 struct urb *urb;
1187 const unsigned char *current_position = data;
1188 unsigned char *data1;
1189 dbg("%s", "entering ...........");
1190
1191 serial = port->serial;
1192
1193 ATEN2011_port = usb_get_serial_port_data(port);
1194 if (ATEN2011_port == NULL) {
1195 dbg("%s", "ATEN2011_port is NULL");
1196 return -1;
1197 }
1198
1199 ATEN2011_serial = usb_get_serial_data(serial);
1200 if (ATEN2011_serial == NULL) {
1201 dbg("%s", "ATEN2011_serial is NULL");
1202 return -1;
1203 }
1204
1205 /* try to find a free urb in the list */
1206 urb = NULL;
1207
1208 for (i = 0; i < NUM_URBS; ++i) {
1209 if (ATEN2011_port->write_urb_pool[i]->status != -EINPROGRESS) {
1210 urb = ATEN2011_port->write_urb_pool[i];
1211 dbg("URB:%d", i);
1212 break;
1213 }
1214 }
1215
1216 if (urb == NULL) {
1217 dbg("%s - no more free urbs", __func__);
1218 goto exit;
1219 }
1220
1221 if (urb->transfer_buffer == NULL) {
1222 urb->transfer_buffer =
1223 kmalloc(URB_TRANSFER_BUFFER_SIZE, GFP_KERNEL);
1224
1225 if (urb->transfer_buffer == NULL) {
1226 err("%s no more kernel memory...", __func__);
1227 goto exit;
1228 }
1229 }
1230 transfer_size = min(count, URB_TRANSFER_BUFFER_SIZE);
1231
1232 memcpy(urb->transfer_buffer, current_position, transfer_size);
1233 /* usb_serial_debug_data (__FILE__, __func__, transfer_size, urb->transfer_buffer); */
1234
1235 /* fill urb with data and submit */
1236 minor = port->serial->minor;
1237 if (minor == SERIAL_TTY_NO_MINOR)
1238 minor = 0;
1239 if ((ATEN2011_serial->ATEN2011_spectrum_2or4ports == 2)
1240 && (((__u16) port->number - (__u16) (minor)) != 0)) {
1241 usb_fill_bulk_urb(urb, ATEN2011_serial->serial->dev,
1242 usb_sndbulkpipe(ATEN2011_serial->serial->dev,
1243 (port->
1244 bulk_out_endpointAddress) +
1245 2), urb->transfer_buffer,
1246 transfer_size,
1247 ATEN2011_bulk_out_data_callback,
1248 ATEN2011_port);
1249 } else
1250
1251 usb_fill_bulk_urb(urb,
1252 ATEN2011_serial->serial->dev,
1253 usb_sndbulkpipe(ATEN2011_serial->serial->dev,
1254 port->
1255 bulk_out_endpointAddress),
1256 urb->transfer_buffer, transfer_size,
1257 ATEN2011_bulk_out_data_callback,
1258 ATEN2011_port);
1259
1260 data1 = urb->transfer_buffer;
1261 dbg("bulkout endpoint is %d", port->bulk_out_endpointAddress);
1262 /* for(i=0;i < urb->actual_length;i++) */
1263 /* dbg("Data is %c ",data1[i]); */
1264
1265 /* send it down the pipe */
1266 status = usb_submit_urb(urb, GFP_ATOMIC);
1267
1268 if (status) {
1269 err("%s - usb_submit_urb(write bulk) failed with status = %d",
1270 __func__, status);
1271 bytes_sent = status;
1272 goto exit;
1273 }
1274 bytes_sent = transfer_size;
1275 ATEN2011_port->icount.tx += transfer_size;
1276 dbg("ATEN2011_port->icount.tx is %d:", ATEN2011_port->icount.tx);
1277
1278exit:
1279 return bytes_sent;
1280}
1281
1282static void ATEN2011_throttle(struct tty_struct *tty)
1283{
1284 struct usb_serial_port *port = tty->driver_data;
1285 struct ATENINTL_port *ATEN2011_port;
1286 int status;
1287
1288 dbg("- port %d", port->number);
1289
1290 ATEN2011_port = usb_get_serial_port_data(port);
1291
1292 if (ATEN2011_port == NULL)
1293 return;
1294
1295 if (!ATEN2011_port->open) {
1296 dbg("%s", "port not opened");
1297 return;
1298 }
1299
1300 dbg("%s", "Entering .......... ");
1301
1302 if (!tty) {
1303 dbg("%s - no tty available", __func__);
1304 return;
1305 }
1306
1307 /* if we are implementing XON/XOFF, send the stop character */
1308 if (I_IXOFF(tty)) {
1309 unsigned char stop_char = STOP_CHAR(tty);
1310 status = ATEN2011_write(tty, port, &stop_char, 1);
1311 if (status <= 0)
1312 return;
1313 }
1314
1315 /* if we are implementing RTS/CTS, toggle that line */
1316 if (tty->termios->c_cflag & CRTSCTS) {
1317 ATEN2011_port->shadowMCR &= ~MCR_RTS;
1318 status = set_uart_reg(port, MODEM_CONTROL_REGISTER,
1319 ATEN2011_port->shadowMCR);
1320 if (status < 0)
1321 return;
1322 }
1323
1324 return;
1325}
1326
1327static void ATEN2011_unthrottle(struct tty_struct *tty)
1328{
1329 struct usb_serial_port *port = tty->driver_data;
1330 int status;
1331 struct ATENINTL_port *ATEN2011_port = usb_get_serial_port_data(port);
1332
1333 if (ATEN2011_port == NULL)
1334 return;
1335
1336 if (!ATEN2011_port->open) {
1337 dbg("%s - port not opened", __func__);
1338 return;
1339 }
1340
1341 dbg("%s", "Entering .......... ");
1342
1343 if (!tty) {
1344 dbg("%s - no tty available", __func__);
1345 return;
1346 }
1347
1348 /* if we are implementing XON/XOFF, send the start character */
1349 if (I_IXOFF(tty)) {
1350 unsigned char start_char = START_CHAR(tty);
1351 status = ATEN2011_write(tty, port, &start_char, 1);
1352 if (status <= 0)
1353 return;
1354 }
1355
1356 /* if we are implementing RTS/CTS, toggle that line */
1357 if (tty->termios->c_cflag & CRTSCTS) {
1358 ATEN2011_port->shadowMCR |= MCR_RTS;
1359 status = set_uart_reg(port, MODEM_CONTROL_REGISTER,
1360 ATEN2011_port->shadowMCR);
1361 if (status < 0)
1362 return;
1363 }
1364
1365 return;
1366}
1367
1368static int ATEN2011_tiocmget(struct tty_struct *tty, struct file *file)
1369{
1370 struct usb_serial_port *port = tty->driver_data;
1371 struct ATENINTL_port *ATEN2011_port;
1372 unsigned int result;
1373 __u16 msr;
1374 __u16 mcr;
1375 /* unsigned int mcr; */
1376 int status = 0;
1377 ATEN2011_port = usb_get_serial_port_data(port);
1378
1379 dbg("%s - port %d", __func__, port->number);
1380
1381 if (ATEN2011_port == NULL)
1382 return -ENODEV;
1383
1384 status = get_uart_reg(port, MODEM_STATUS_REGISTER, &msr);
1385 status = get_uart_reg(port, MODEM_CONTROL_REGISTER, &mcr);
1386 /* mcr = ATEN2011_port->shadowMCR; */
1387 /* COMMENT2: the Fallowing three line are commented for updating only MSR values */
1388 result = ((mcr & MCR_DTR) ? TIOCM_DTR : 0)
1389 | ((mcr & MCR_RTS) ? TIOCM_RTS : 0)
1390 | ((mcr & MCR_LOOPBACK) ? TIOCM_LOOP : 0)
1391 | ((msr & ATEN2011_MSR_CTS) ? TIOCM_CTS : 0)
1392 | ((msr & ATEN2011_MSR_CD) ? TIOCM_CAR : 0)
1393 | ((msr & ATEN2011_MSR_RI) ? TIOCM_RI : 0)
1394 | ((msr & ATEN2011_MSR_DSR) ? TIOCM_DSR : 0);
1395
1396 dbg("%s - 0x%04X", __func__, result);
1397
1398 return result;
1399}
1400
1401static int ATEN2011_tiocmset(struct tty_struct *tty, struct file *file,
1402 unsigned int set, unsigned int clear)
1403{
1404 struct usb_serial_port *port = tty->driver_data;
1405 struct ATENINTL_port *ATEN2011_port;
1406 unsigned int mcr;
1407 unsigned int status;
1408
1409 dbg("%s - port %d", __func__, port->number);
1410
1411 ATEN2011_port = usb_get_serial_port_data(port);
1412
1413 if (ATEN2011_port == NULL)
1414 return -ENODEV;
1415
1416 mcr = ATEN2011_port->shadowMCR;
1417 if (clear & TIOCM_RTS)
1418 mcr &= ~MCR_RTS;
1419 if (clear & TIOCM_DTR)
1420 mcr &= ~MCR_DTR;
1421 if (clear & TIOCM_LOOP)
1422 mcr &= ~MCR_LOOPBACK;
1423
1424 if (set & TIOCM_RTS)
1425 mcr |= MCR_RTS;
1426 if (set & TIOCM_DTR)
1427 mcr |= MCR_DTR;
1428 if (set & TIOCM_LOOP)
1429 mcr |= MCR_LOOPBACK;
1430
1431 ATEN2011_port->shadowMCR = mcr;
1432
1433 status = set_uart_reg(port, MODEM_CONTROL_REGISTER, mcr);
1434 if (status < 0) {
1435 dbg("setting MODEM_CONTROL_REGISTER Failed");
1436 return -1;
1437 }
1438
1439 return 0;
1440}
1441
1442static void ATEN2011_set_termios(struct tty_struct *tty,
1443 struct usb_serial_port *port,
1444 struct ktermios *old_termios)
1445{
1446 int status;
1447 unsigned int cflag;
1448 struct usb_serial *serial;
1449 struct ATENINTL_port *ATEN2011_port;
1450
1451 dbg("ATEN2011_set_termios: START");
1452
1453 serial = port->serial;
1454
1455 ATEN2011_port = usb_get_serial_port_data(port);
1456
1457 if (ATEN2011_port == NULL)
1458 return;
1459
1460 if (!ATEN2011_port->open) {
1461 dbg("%s - port not opened", __func__);
1462 return;
1463 }
1464
1465 dbg("%s", "setting termios - ");
1466
1467 cflag = tty->termios->c_cflag;
1468
1469 dbg("%s - cflag %08x iflag %08x", __func__,
1470 tty->termios->c_cflag, RELEVANT_IFLAG(tty->termios->c_iflag));
1471
1472 if (old_termios) {
1473 dbg("%s - old clfag %08x old iflag %08x", __func__,
1474 old_termios->c_cflag, RELEVANT_IFLAG(old_termios->c_iflag));
1475 }
1476
1477 dbg("%s - port %d", __func__, port->number);
1478
1479 /* change the port settings to the new ones specified */
1480
1481 ATEN2011_change_port_settings(tty, ATEN2011_port, old_termios);
1482
1483 if (!ATEN2011_port->read_urb) {
1484 dbg("%s", "URB KILLED !!!!!");
1485 return;
1486 }
1487
1488 if (ATEN2011_port->read_urb->status != -EINPROGRESS) {
1489 ATEN2011_port->read_urb->dev = serial->dev;
1490 status = usb_submit_urb(ATEN2011_port->read_urb, GFP_ATOMIC);
1491 if (status) {
1492 dbg
1493 (" usb_submit_urb(read bulk) failed, status = %d",
1494 status);
1495 }
1496 }
1497 return;
1498}
1499
1500static int get_lsr_info(struct tty_struct *tty,
1501 struct ATENINTL_port *ATEN2011_port,
1502 unsigned int __user *value)
1503{
1504 int count;
1505 unsigned int result = 0;
1506
1507 count = ATEN2011_chars_in_buffer(tty);
1508 if (count == 0) {
1509 dbg("%s -- Empty", __func__);
1510 result = TIOCSER_TEMT;
1511 }
1512
1513 if (copy_to_user(value, &result, sizeof(int)))
1514 return -EFAULT;
1515 return 0;
1516}
1517
1518static int get_number_bytes_avail(struct tty_struct *tty,
1519 struct ATENINTL_port *ATEN2011_port,
1520 unsigned int __user *value)
1521{
1522 unsigned int result = 0;
1523
1524 if (!tty)
1525 return -ENOIOCTLCMD;
1526
1527 result = tty->read_cnt;
1528
1529 dbg("%s(%d) = %d", __func__, ATEN2011_port->port->number, result);
1530 if (copy_to_user(value, &result, sizeof(int)))
1531 return -EFAULT;
1532
1533 return -ENOIOCTLCMD;
1534}
1535
1536static int set_modem_info(struct ATENINTL_port *ATEN2011_port, unsigned int cmd,
1537 unsigned int __user *value)
1538{
1539 unsigned int mcr;
1540 unsigned int arg;
1541 __u16 Data;
1542 int status;
1543 struct usb_serial_port *port;
1544
1545 if (ATEN2011_port == NULL)
1546 return -1;
1547
1548 port = (struct usb_serial_port *)ATEN2011_port->port;
1549
1550 mcr = ATEN2011_port->shadowMCR;
1551
1552 if (copy_from_user(&arg, value, sizeof(int)))
1553 return -EFAULT;
1554
1555 switch (cmd) {
1556 case TIOCMBIS:
1557 if (arg & TIOCM_RTS)
1558 mcr |= MCR_RTS;
1559 if (arg & TIOCM_DTR)
1560 mcr |= MCR_RTS;
1561 if (arg & TIOCM_LOOP)
1562 mcr |= MCR_LOOPBACK;
1563 break;
1564
1565 case TIOCMBIC:
1566 if (arg & TIOCM_RTS)
1567 mcr &= ~MCR_RTS;
1568 if (arg & TIOCM_DTR)
1569 mcr &= ~MCR_RTS;
1570 if (arg & TIOCM_LOOP)
1571 mcr &= ~MCR_LOOPBACK;
1572 break;
1573
1574 case TIOCMSET:
1575 /* turn off the RTS and DTR and LOOPBACK
1576 * and then only turn on what was asked to */
1577 mcr &= ~(MCR_RTS | MCR_DTR | MCR_LOOPBACK);
1578 mcr |= ((arg & TIOCM_RTS) ? MCR_RTS : 0);
1579 mcr |= ((arg & TIOCM_DTR) ? MCR_DTR : 0);
1580 mcr |= ((arg & TIOCM_LOOP) ? MCR_LOOPBACK : 0);
1581 break;
1582 }
1583
1584 ATEN2011_port->shadowMCR = mcr;
1585
1586 Data = ATEN2011_port->shadowMCR;
1587 status = set_uart_reg(port, MODEM_CONTROL_REGISTER, Data);
1588 if (status < 0) {
1589 dbg("setting MODEM_CONTROL_REGISTER Failed");
1590 return -1;
1591 }
1592
1593 return 0;
1594}
1595
1596static int get_modem_info(struct ATENINTL_port *ATEN2011_port,
1597 unsigned int __user *value)
1598{
1599 unsigned int result = 0;
1600 __u16 msr;
1601 unsigned int mcr = ATEN2011_port->shadowMCR;
1602 int status;
1603
1604 status = get_uart_reg(ATEN2011_port->port, MODEM_STATUS_REGISTER, &msr);
1605 result = ((mcr & MCR_DTR) ? TIOCM_DTR : 0) /* 0x002 */
1606 |((mcr & MCR_RTS) ? TIOCM_RTS : 0) /* 0x004 */
1607 |((msr & ATEN2011_MSR_CTS) ? TIOCM_CTS : 0) /* 0x020 */
1608 |((msr & ATEN2011_MSR_CD) ? TIOCM_CAR : 0) /* 0x040 */
1609 |((msr & ATEN2011_MSR_RI) ? TIOCM_RI : 0) /* 0x080 */
1610 |((msr & ATEN2011_MSR_DSR) ? TIOCM_DSR : 0); /* 0x100 */
1611
1612 dbg("%s -- %x", __func__, result);
1613
1614 if (copy_to_user(value, &result, sizeof(int)))
1615 return -EFAULT;
1616 return 0;
1617}
1618
1619static int get_serial_info(struct ATENINTL_port *ATEN2011_port,
1620 struct serial_struct __user *retinfo)
1621{
1622 struct serial_struct tmp;
1623
1624 if (ATEN2011_port == NULL)
1625 return -1;
1626
1627 if (!retinfo)
1628 return -EFAULT;
1629
1630 memset(&tmp, 0, sizeof(tmp));
1631
1632 tmp.type = PORT_16550A;
1633 tmp.line = ATEN2011_port->port->serial->minor;
1634 if (tmp.line == SERIAL_TTY_NO_MINOR)
1635 tmp.line = 0;
1636 tmp.port = ATEN2011_port->port->number;
1637 tmp.irq = 0;
1638 tmp.flags = ASYNC_SKIP_TEST | ASYNC_AUTO_IRQ;
1639 tmp.xmit_fifo_size = NUM_URBS * URB_TRANSFER_BUFFER_SIZE;
1640 tmp.baud_base = 9600;
1641 tmp.close_delay = 5 * HZ;
1642 tmp.closing_wait = 30 * HZ;
1643
1644 if (copy_to_user(retinfo, &tmp, sizeof(*retinfo)))
1645 return -EFAULT;
1646 return 0;
1647}
1648
1649static int ATEN2011_ioctl(struct tty_struct *tty, struct file *file,
1650 unsigned int cmd, unsigned long arg)
1651{
1652 struct usb_serial_port *port = tty->driver_data;
1653 struct ATENINTL_port *ATEN2011_port;
1654 struct async_icount cnow;
1655 struct async_icount cprev;
1656 struct serial_icounter_struct icount;
1657 int ATENret = 0;
1658 unsigned int __user *user_arg = (unsigned int __user *)arg;
1659
1660 ATEN2011_port = usb_get_serial_port_data(port);
1661
1662 if (ATEN2011_port == NULL)
1663 return -1;
1664
1665 dbg("%s - port %d, cmd = 0x%x", __func__, port->number, cmd);
1666
1667 switch (cmd) {
1668 /* return number of bytes available */
1669
1670 case TIOCINQ:
1671 dbg("%s (%d) TIOCINQ", __func__, port->number);
1672 return get_number_bytes_avail(tty, ATEN2011_port, user_arg);
1673 break;
1674
1675 case TIOCOUTQ:
1676 dbg("%s (%d) TIOCOUTQ", __func__, port->number);
1677 return put_user(ATEN2011_chars_in_buffer(tty), user_arg);
1678 break;
1679
1680 case TIOCSERGETLSR:
1681 dbg("%s (%d) TIOCSERGETLSR", __func__, port->number);
1682 return get_lsr_info(tty, ATEN2011_port, user_arg);
1683 return 0;
1684
1685 case TIOCMBIS:
1686 case TIOCMBIC:
1687 case TIOCMSET:
1688 dbg("%s (%d) TIOCMSET/TIOCMBIC/TIOCMSET", __func__,
1689 port->number);
1690 ATENret = set_modem_info(ATEN2011_port, cmd, user_arg);
1691 return ATENret;
1692
1693 case TIOCMGET:
1694 dbg("%s (%d) TIOCMGET", __func__, port->number);
1695 return get_modem_info(ATEN2011_port, user_arg);
1696
1697 case TIOCGSERIAL:
1698 dbg("%s (%d) TIOCGSERIAL", __func__, port->number);
1699 return get_serial_info(ATEN2011_port,
1700 (struct serial_struct __user *)arg);
1701
1702 case TIOCSSERIAL:
1703 dbg("%s (%d) TIOCSSERIAL", __func__, port->number);
1704 break;
1705
1706 case TIOCMIWAIT:
1707 dbg("%s (%d) TIOCMIWAIT", __func__, port->number);
1708 cprev = ATEN2011_port->icount;
1709 while (1) {
1710 /* see if a signal did it */
1711 if (signal_pending(current))
1712 return -ERESTARTSYS;
1713 cnow = ATEN2011_port->icount;
1714 if (cnow.rng == cprev.rng && cnow.dsr == cprev.dsr &&
1715 cnow.dcd == cprev.dcd && cnow.cts == cprev.cts)
1716 return -EIO; /* no change => error */
1717 if (((arg & TIOCM_RNG) && (cnow.rng != cprev.rng)) ||
1718 ((arg & TIOCM_DSR) && (cnow.dsr != cprev.dsr)) ||
1719 ((arg & TIOCM_CD) && (cnow.dcd != cprev.dcd)) ||
1720 ((arg & TIOCM_CTS) && (cnow.cts != cprev.cts))) {
1721 return 0;
1722 }
1723 cprev = cnow;
1724 }
1725 /* NOTREACHED */
1726 break;
1727
1728 case TIOCGICOUNT:
1729 cnow = ATEN2011_port->icount;
1730 icount.cts = cnow.cts;
1731 icount.dsr = cnow.dsr;
1732 icount.rng = cnow.rng;
1733 icount.dcd = cnow.dcd;
1734 icount.rx = cnow.rx;
1735 icount.tx = cnow.tx;
1736 icount.frame = cnow.frame;
1737 icount.overrun = cnow.overrun;
1738 icount.parity = cnow.parity;
1739 icount.brk = cnow.brk;
1740 icount.buf_overrun = cnow.buf_overrun;
1741
1742 dbg("%s (%d) TIOCGICOUNT RX=%d, TX=%d", __func__,
1743 port->number, icount.rx, icount.tx);
1744 if (copy_to_user((void __user *)arg, &icount, sizeof(icount)))
1745 return -EFAULT;
1746 return 0;
1747
1748 default:
1749 break;
1750 }
1751
1752 return -ENOIOCTLCMD;
1753}
1754
1755static int ATEN2011_calc_baud_rate_divisor(int baudRate, int *divisor,
1756 __u16 *clk_sel_val)
1757{
1758 dbg("%s - %d", __func__, baudRate);
1759
1760 if (baudRate <= 115200) {
1761 *divisor = 115200 / baudRate;
1762 *clk_sel_val = 0x0;
1763 }
1764 if ((baudRate > 115200) && (baudRate <= 230400)) {
1765 *divisor = 230400 / baudRate;
1766 *clk_sel_val = 0x10;
1767 } else if ((baudRate > 230400) && (baudRate <= 403200)) {
1768 *divisor = 403200 / baudRate;
1769 *clk_sel_val = 0x20;
1770 } else if ((baudRate > 403200) && (baudRate <= 460800)) {
1771 *divisor = 460800 / baudRate;
1772 *clk_sel_val = 0x30;
1773 } else if ((baudRate > 460800) && (baudRate <= 806400)) {
1774 *divisor = 806400 / baudRate;
1775 *clk_sel_val = 0x40;
1776 } else if ((baudRate > 806400) && (baudRate <= 921600)) {
1777 *divisor = 921600 / baudRate;
1778 *clk_sel_val = 0x50;
1779 } else if ((baudRate > 921600) && (baudRate <= 1572864)) {
1780 *divisor = 1572864 / baudRate;
1781 *clk_sel_val = 0x60;
1782 } else if ((baudRate > 1572864) && (baudRate <= 3145728)) {
1783 *divisor = 3145728 / baudRate;
1784 *clk_sel_val = 0x70;
1785 }
1786 return 0;
1787}
1788
1789static int ATEN2011_send_cmd_write_baud_rate(struct ATENINTL_port
1790 *ATEN2011_port, int baudRate)
1791{
1792 int divisor = 0;
1793 int status;
1794 __u16 Data;
1795 unsigned char number;
1796 __u16 clk_sel_val;
1797 struct usb_serial_port *port;
1798 int minor;
1799
1800 if (ATEN2011_port == NULL)
1801 return -1;
1802
1803 port = (struct usb_serial_port *)ATEN2011_port->port;
1804
1805 dbg("%s", "Entering .......... ");
1806
1807 minor = ATEN2011_port->port->serial->minor;
1808 if (minor == SERIAL_TTY_NO_MINOR)
1809 minor = 0;
1810 number = ATEN2011_port->port->number - minor;
1811
1812 dbg("%s - port = %d, baud = %d", __func__,
1813 ATEN2011_port->port->number, baudRate);
1814 /* reset clk_uart_sel in spregOffset */
1815 if (baudRate > 115200) {
1816#ifdef HW_flow_control
1817 /*
1818 * NOTE: need to see the pther register to modify
1819 * setting h/w flow control bit to 1;
1820 */
1821 /* Data = ATEN2011_port->shadowMCR; */
1822 Data = 0x2b;
1823 ATEN2011_port->shadowMCR = Data;
1824 status = set_uart_reg(port, MODEM_CONTROL_REGISTER, Data);
1825 if (status < 0) {
1826 dbg("Writing spreg failed in set_serial_baud");
1827 return -1;
1828 }
1829#endif
1830
1831 } else {
1832#ifdef HW_flow_control
1833 /* setting h/w flow control bit to 0; */
1834 /* Data = ATEN2011_port->shadowMCR; */
1835 Data = 0xb;
1836 ATEN2011_port->shadowMCR = Data;
1837 status = set_uart_reg(port, MODEM_CONTROL_REGISTER, Data);
1838 if (status < 0) {
1839 dbg("Writing spreg failed in set_serial_baud");
1840 return -1;
1841 }
1842#endif
1843
1844 }
1845
1846 if (1) /* baudRate <= 115200) */ {
1847 clk_sel_val = 0x0;
1848 Data = 0x0;
1849 status =
1850 ATEN2011_calc_baud_rate_divisor(baudRate, &divisor,
1851 &clk_sel_val);
1852 status = get_reg_sync(port, ATEN2011_port->SpRegOffset, &Data);
1853 if (status < 0) {
1854 dbg("reading spreg failed in set_serial_baud");
1855 return -1;
1856 }
1857 Data = (Data & 0x8f) | clk_sel_val;
1858 status = set_reg_sync(port, ATEN2011_port->SpRegOffset, Data);
1859 if (status < 0) {
1860 dbg("Writing spreg failed in set_serial_baud");
1861 return -1;
1862 }
1863 /* Calculate the Divisor */
1864
1865 if (status) {
1866 err("%s - bad baud rate", __func__);
1867 dbg("%s", "bad baud rate");
1868 return status;
1869 }
1870 /* Enable access to divisor latch */
1871 Data = ATEN2011_port->shadowLCR | SERIAL_LCR_DLAB;
1872 ATEN2011_port->shadowLCR = Data;
1873 set_uart_reg(port, LINE_CONTROL_REGISTER, Data);
1874
1875 /* Write the divisor */
1876 Data = (unsigned char)(divisor & 0xff);
1877 dbg("set_serial_baud Value to write DLL is %x", Data);
1878 set_uart_reg(port, DIVISOR_LATCH_LSB, Data);
1879
1880 Data = (unsigned char)((divisor & 0xff00) >> 8);
1881 dbg("set_serial_baud Value to write DLM is %x", Data);
1882 set_uart_reg(port, DIVISOR_LATCH_MSB, Data);
1883
1884 /* Disable access to divisor latch */
1885 Data = ATEN2011_port->shadowLCR & ~SERIAL_LCR_DLAB;
1886 ATEN2011_port->shadowLCR = Data;
1887 set_uart_reg(port, LINE_CONTROL_REGISTER, Data);
1888
1889 }
1890
1891 return status;
1892}
1893
1894static void ATEN2011_change_port_settings(struct tty_struct *tty,
1895 struct ATENINTL_port *ATEN2011_port,
1896 struct ktermios *old_termios)
1897{
1898 int baud;
1899 unsigned cflag;
1900 unsigned iflag;
1901 __u8 lData;
1902 __u8 lParity;
1903 __u8 lStop;
1904 int status;
1905 __u16 Data;
1906 struct usb_serial_port *port;
1907 struct usb_serial *serial;
1908
1909 if (ATEN2011_port == NULL)
1910 return;
1911
1912 port = (struct usb_serial_port *)ATEN2011_port->port;
1913
1914 serial = port->serial;
1915
1916 dbg("%s - port %d", __func__, ATEN2011_port->port->number);
1917
1918 if (!ATEN2011_port->open) {
1919 dbg("%s - port not opened", __func__);
1920 return;
1921 }
1922
1923 if ((!tty) || (!tty->termios)) {
1924 dbg("%s - no tty structures", __func__);
1925 return;
1926 }
1927
1928 dbg("%s", "Entering .......... ");
1929
1930 lData = LCR_BITS_8;
1931 lStop = LCR_STOP_1;
1932 lParity = LCR_PAR_NONE;
1933
1934 cflag = tty->termios->c_cflag;
1935 iflag = tty->termios->c_iflag;
1936
1937 /* Change the number of bits */
1938
1939 /* COMMENT1: the below Line"if(cflag & CSIZE)" is added for the errors we get for serial loop data test i.e serial_loopback.pl -v */
1940 /* if(cflag & CSIZE) */
1941 {
1942 switch (cflag & CSIZE) {
1943 case CS5:
1944 lData = LCR_BITS_5;
1945 break;
1946
1947 case CS6:
1948 lData = LCR_BITS_6;
1949 break;
1950
1951 case CS7:
1952 lData = LCR_BITS_7;
1953 break;
1954 default:
1955 case CS8:
1956 lData = LCR_BITS_8;
1957 break;
1958 }
1959 }
1960 /* Change the Parity bit */
1961 if (cflag & PARENB) {
1962 if (cflag & PARODD) {
1963 lParity = LCR_PAR_ODD;
1964 dbg("%s - parity = odd", __func__);
1965 } else {
1966 lParity = LCR_PAR_EVEN;
1967 dbg("%s - parity = even", __func__);
1968 }
1969
1970 } else {
1971 dbg("%s - parity = none", __func__);
1972 }
1973
1974 if (cflag & CMSPAR)
1975 lParity = lParity | 0x20;
1976
1977 /* Change the Stop bit */
1978 if (cflag & CSTOPB) {
1979 lStop = LCR_STOP_2;
1980 dbg("%s - stop bits = 2", __func__);
1981 } else {
1982 lStop = LCR_STOP_1;
1983 dbg("%s - stop bits = 1", __func__);
1984 }
1985
1986 /* Update the LCR with the correct value */
1987 ATEN2011_port->shadowLCR &=
1988 ~(LCR_BITS_MASK | LCR_STOP_MASK | LCR_PAR_MASK);
1989 ATEN2011_port->shadowLCR |= (lData | lParity | lStop);
1990
1991 dbg
1992 ("ATEN2011_change_port_settings ATEN2011_port->shadowLCR is %x",
1993 ATEN2011_port->shadowLCR);
1994 /* Disable Interrupts */
1995 Data = 0x00;
1996 set_uart_reg(port, INTERRUPT_ENABLE_REGISTER, Data);
1997
1998 Data = 0x00;
1999 set_uart_reg(port, FIFO_CONTROL_REGISTER, Data);
2000
2001 Data = 0xcf;
2002 set_uart_reg(port, FIFO_CONTROL_REGISTER, Data);
2003
2004 /* Send the updated LCR value to the ATEN2011 */
2005 Data = ATEN2011_port->shadowLCR;
2006
2007 set_uart_reg(port, LINE_CONTROL_REGISTER, Data);
2008
2009 Data = 0x00b;
2010 ATEN2011_port->shadowMCR = Data;
2011 set_uart_reg(port, MODEM_CONTROL_REGISTER, Data);
2012 Data = 0x00b;
2013 set_uart_reg(port, MODEM_CONTROL_REGISTER, Data);
2014
2015 /* set up the MCR register and send it to the ATEN2011 */
2016
2017 ATEN2011_port->shadowMCR = MCR_MASTER_IE;
2018 if (cflag & CBAUD)
2019 ATEN2011_port->shadowMCR |= (MCR_DTR | MCR_RTS);
2020
2021 if (cflag & CRTSCTS)
2022 ATEN2011_port->shadowMCR |= (MCR_XON_ANY);
2023 else
2024 ATEN2011_port->shadowMCR &= ~(MCR_XON_ANY);
2025
2026 Data = ATEN2011_port->shadowMCR;
2027 set_uart_reg(port, MODEM_CONTROL_REGISTER, Data);
2028
2029 /* Determine divisor based on baud rate */
2030 baud = tty_get_baud_rate(tty);
2031
2032 if (!baud) {
2033 /* pick a default, any default... */
2034 dbg("%s", "Picked default baud...");
2035 baud = 9600;
2036 }
2037
2038 dbg("%s - baud rate = %d", __func__, baud);
2039 status = ATEN2011_send_cmd_write_baud_rate(ATEN2011_port, baud);
2040
2041 /* Enable Interrupts */
2042 Data = 0x0c;
2043 set_uart_reg(port, INTERRUPT_ENABLE_REGISTER, Data);
2044
2045 if (ATEN2011_port->read_urb->status != -EINPROGRESS) {
2046 ATEN2011_port->read_urb->dev = serial->dev;
2047
2048 status = usb_submit_urb(ATEN2011_port->read_urb, GFP_ATOMIC);
2049
2050 if (status) {
2051 dbg
2052 (" usb_submit_urb(read bulk) failed, status = %d",
2053 status);
2054 }
2055 }
2056 dbg
2057 ("ATEN2011_change_port_settings ATEN2011_port->shadowLCR is End %x",
2058 ATEN2011_port->shadowLCR);
2059
2060 return;
2061}
2062
2063static int ATEN2011_calc_num_ports(struct usb_serial *serial)
2064{
2065
2066 __u16 Data = 0x00;
2067 int ret = 0;
2068 int ATEN2011_2or4ports;
2069 ret = usb_control_msg(serial->dev, usb_rcvctrlpipe(serial->dev, 0),
2070 ATEN_RDREQ, ATEN_RD_RTYPE, 0, GPIO_REGISTER,
2071 &Data, VENDOR_READ_LENGTH, ATEN_WDR_TIMEOUT);
2072
2073/* ghostgum: here is where the problem appears to bet */
2074/* Which of the following are needed? */
2075/* Greg used the serial->type->num_ports=2 */
2076/* But the code in the ATEN2011_open relies on serial->num_ports=2 */
2077 if ((Data & 0x01) == 0) {
2078 ATEN2011_2or4ports = 2;
2079 serial->type->num_ports = 2;
2080 serial->num_ports = 2;
2081 }
2082 /* else if(serial->interface->cur_altsetting->desc.bNumEndpoints == 9) */
2083 else {
2084 ATEN2011_2or4ports = 4;
2085 serial->type->num_ports = 4;
2086 serial->num_ports = 4;
2087
2088 }
2089
2090 return ATEN2011_2or4ports;
2091}
2092
2093static int ATEN2011_startup(struct usb_serial *serial)
2094{
2095 struct ATENINTL_serial *ATEN2011_serial;
2096 struct ATENINTL_port *ATEN2011_port;
2097 struct usb_device *dev;
2098 int i, status;
2099 int minor;
2100
2101 __u16 Data;
2102 dbg("%s", " ATEN2011_startup :entering..........");
2103
2104 if (!serial) {
2105 dbg("%s", "Invalid Handler");
2106 return -1;
2107 }
2108
2109 dev = serial->dev;
2110
2111 dbg("%s", "Entering...");
2112
2113 /* create our private serial structure */
2114 ATEN2011_serial = kzalloc(sizeof(struct ATENINTL_serial), GFP_KERNEL);
2115 if (ATEN2011_serial == NULL) {
2116 err("%s - Out of memory", __func__);
2117 return -ENOMEM;
2118 }
2119
2120 /* resetting the private structure field values to zero */
2121 memset(ATEN2011_serial, 0, sizeof(struct ATENINTL_serial));
2122
2123 ATEN2011_serial->serial = serial;
2124 /* initilize status polling flag to 0 */
2125 ATEN2011_serial->status_polling_started = 0;
2126
2127 usb_set_serial_data(serial, ATEN2011_serial);
2128 ATEN2011_serial->ATEN2011_spectrum_2or4ports =
2129 ATEN2011_calc_num_ports(serial);
2130 /* we set up the pointers to the endpoints in the ATEN2011_open *
2131 * function, as the structures aren't created yet. */
2132
2133 /* set up port private structures */
2134 for (i = 0; i < serial->num_ports; ++i) {
2135 ATEN2011_port =
2136 kmalloc(sizeof(struct ATENINTL_port), GFP_KERNEL);
2137 if (ATEN2011_port == NULL) {
2138 err("%s - Out of memory", __func__);
2139 usb_set_serial_data(serial, NULL);
2140 kfree(ATEN2011_serial);
2141 return -ENOMEM;
2142 }
2143 memset(ATEN2011_port, 0, sizeof(struct ATENINTL_port));
2144
2145 /*
2146 * Initialize all port interrupt end point to port 0
2147 * int endpoint. Our device has only one interrupt end point
2148 * comman to all port
2149 */
2150 /* serial->port[i]->interrupt_in_endpointAddress = serial->port[0]->interrupt_in_endpointAddress; */
2151
2152 ATEN2011_port->port = serial->port[i];
2153 usb_set_serial_port_data(serial->port[i], ATEN2011_port);
2154
2155 minor = serial->port[i]->serial->minor;
2156 if (minor == SERIAL_TTY_NO_MINOR)
2157 minor = 0;
2158 ATEN2011_port->port_num =
2159 ((serial->port[i]->number - minor) + 1);
2160
2161 if (ATEN2011_port->port_num == 1) {
2162 ATEN2011_port->SpRegOffset = 0x0;
2163 ATEN2011_port->ControlRegOffset = 0x1;
2164 ATEN2011_port->DcrRegOffset = 0x4;
2165 } else if ((ATEN2011_port->port_num == 2)
2166 && (ATEN2011_serial->ATEN2011_spectrum_2or4ports ==
2167 4)) {
2168 ATEN2011_port->SpRegOffset = 0x8;
2169 ATEN2011_port->ControlRegOffset = 0x9;
2170 ATEN2011_port->DcrRegOffset = 0x16;
2171 } else if ((ATEN2011_port->port_num == 2)
2172 && (ATEN2011_serial->ATEN2011_spectrum_2or4ports ==
2173 2)) {
2174 ATEN2011_port->SpRegOffset = 0xa;
2175 ATEN2011_port->ControlRegOffset = 0xb;
2176 ATEN2011_port->DcrRegOffset = 0x19;
2177 } else if ((ATEN2011_port->port_num == 3)
2178 && (ATEN2011_serial->ATEN2011_spectrum_2or4ports ==
2179 4)) {
2180 ATEN2011_port->SpRegOffset = 0xa;
2181 ATEN2011_port->ControlRegOffset = 0xb;
2182 ATEN2011_port->DcrRegOffset = 0x19;
2183 } else if ((ATEN2011_port->port_num == 4)
2184 && (ATEN2011_serial->ATEN2011_spectrum_2or4ports ==
2185 4)) {
2186 ATEN2011_port->SpRegOffset = 0xc;
2187 ATEN2011_port->ControlRegOffset = 0xd;
2188 ATEN2011_port->DcrRegOffset = 0x1c;
2189 }
2190
2191 usb_set_serial_port_data(serial->port[i], ATEN2011_port);
2192
2193 /* enable rx_disable bit in control register */
2194
2195 status = get_reg_sync(serial->port[i],
2196 ATEN2011_port->ControlRegOffset, &Data);
2197 if (status < 0) {
2198 dbg("Reading ControlReg failed status-0x%x",
2199 status);
2200 break;
2201 } else
2202 dbg
2203 ("ControlReg Reading success val is %x, status%d",
2204 Data, status);
2205 Data |= 0x08; /* setting driver done bit */
2206 Data |= 0x04; /* sp1_bit to have cts change reflect in modem status reg */
2207
2208 /* Data |= 0x20; */ /* rx_disable bit */
2209 status = set_reg_sync(serial->port[i],
2210 ATEN2011_port->ControlRegOffset, Data);
2211 if (status < 0) {
2212 dbg
2213 ("Writing ControlReg failed(rx_disable) status-0x%x",
2214 status);
2215 break;
2216 } else
2217 dbg
2218 ("ControlReg Writing success(rx_disable) status%d",
2219 status);
2220
2221 /*
2222 * Write default values in DCR (i.e 0x01 in DCR0, 0x05 in DCR2
2223 * and 0x24 in DCR3
2224 */
2225 Data = 0x01;
2226 status = set_reg_sync(serial->port[i],
2227 (__u16)(ATEN2011_port->DcrRegOffset + 0),
2228 Data);
2229 if (status < 0) {
2230 dbg("Writing DCR0 failed status-0x%x", status);
2231 break;
2232 } else
2233 dbg("DCR0 Writing success status%d", status);
2234
2235 Data = 0x05;
2236 status = set_reg_sync(serial->port[i],
2237 (__u16)(ATEN2011_port->DcrRegOffset + 1),
2238 Data);
2239 if (status < 0) {
2240 dbg("Writing DCR1 failed status-0x%x", status);
2241 break;
2242 } else
2243 dbg("DCR1 Writing success status%d", status);
2244
2245 Data = 0x24;
2246 status = set_reg_sync(serial->port[i],
2247 (__u16)(ATEN2011_port->DcrRegOffset + 2),
2248 Data);
2249 if (status < 0) {
2250 dbg("Writing DCR2 failed status-0x%x", status);
2251 break;
2252 } else
2253 dbg("DCR2 Writing success status%d", status);
2254
2255 /* write values in clkstart0x0 and clkmulti 0x20 */
2256 Data = 0x0;
2257 status = set_reg_sync(serial->port[i], CLK_START_VALUE_REGISTER,
2258 Data);
2259 if (status < 0) {
2260 dbg
2261 ("Writing CLK_START_VALUE_REGISTER failed status-0x%x",
2262 status);
2263 break;
2264 } else
2265 dbg
2266 ("CLK_START_VALUE_REGISTER Writing success status%d",
2267 status);
2268
2269 Data = 0x20;
2270 status = set_reg_sync(serial->port[i], CLK_MULTI_REGISTER,
2271 Data);
2272 if (status < 0) {
2273 dbg
2274 ("Writing CLK_MULTI_REGISTER failed status-0x%x",
2275 status);
2276 break;
2277 } else
2278 dbg("CLK_MULTI_REGISTER Writing success status%d",
2279 status);
2280
2281 /* Zero Length flag register */
2282 if ((ATEN2011_port->port_num != 1)
2283 && (ATEN2011_serial->ATEN2011_spectrum_2or4ports == 2)) {
2284
2285 Data = 0xff;
2286 status = set_reg_sync(serial->port[i],
2287 (__u16)(ZLP_REG1 + ((__u16)ATEN2011_port->port_num)),
2288 Data);
2289 dbg("ZLIP offset%x",
2290 (__u16) (ZLP_REG1 +
2291 ((__u16) ATEN2011_port->port_num)));
2292 if (status < 0) {
2293 dbg
2294 ("Writing ZLP_REG%d failed status-0x%x",
2295 i + 2, status);
2296 break;
2297 } else
2298 dbg("ZLP_REG%d Writing success status%d",
2299 i + 2, status);
2300 } else {
2301 Data = 0xff;
2302 status = set_reg_sync(serial->port[i],
2303 (__u16)(ZLP_REG1 + ((__u16)ATEN2011_port->port_num) - 0x1),
2304 Data);
2305 dbg("ZLIP offset%x",
2306 (__u16) (ZLP_REG1 +
2307 ((__u16) ATEN2011_port->port_num) -
2308 0x1));
2309 if (status < 0) {
2310 dbg
2311 ("Writing ZLP_REG%d failed status-0x%x",
2312 i + 1, status);
2313 break;
2314 } else
2315 dbg("ZLP_REG%d Writing success status%d",
2316 i + 1, status);
2317
2318 }
2319 ATEN2011_port->control_urb = usb_alloc_urb(0, GFP_ATOMIC);
2320 ATEN2011_port->ctrl_buf = kmalloc(16, GFP_KERNEL);
2321
2322 }
2323
2324 /* Zero Length flag enable */
2325 Data = 0x0f;
2326 status = set_reg_sync(serial->port[0], ZLP_REG5, Data);
2327 if (status < 0) {
2328 dbg("Writing ZLP_REG5 failed status-0x%x", status);
2329 return -1;
2330 } else
2331 dbg("ZLP_REG5 Writing success status%d", status);
2332
2333 /* setting configuration feature to one */
2334 usb_control_msg(serial->dev, usb_sndctrlpipe(serial->dev, 0),
2335 (__u8) 0x03, 0x00, 0x01, 0x00, NULL, 0x00, 5 * HZ);
2336 return 0;
2337}
2338
2339static void ATEN2011_release(struct usb_serial *serial)
2340{
2341 int i;
2342 struct ATENINTL_port *ATEN2011_port;
2343
2344 /* check for the ports to be closed,close the ports and disconnect */
2345
2346 /* free private structure allocated for serial port *
2347 * stop reads and writes on all ports */
2348
2349 for (i = 0; i < serial->num_ports; ++i) {
2350 ATEN2011_port = usb_get_serial_port_data(serial->port[i]);
2351 kfree(ATEN2011_port->ctrl_buf);
2352 usb_kill_urb(ATEN2011_port->control_urb);
2353 kfree(ATEN2011_port);
2354 usb_set_serial_port_data(serial->port[i], NULL);
2355 }
2356
2357 /* free private structure allocated for serial device */
2358
2359 kfree(usb_get_serial_data(serial));
2360 usb_set_serial_data(serial, NULL);
2361}
2362
2363static struct usb_serial_driver aten_serial_driver = {
2364 .driver = {
2365 .owner = THIS_MODULE,
2366 .name = "aten2011",
2367 },
2368 .description = DRIVER_DESC,
2369 .id_table = id_table,
2370 .open = ATEN2011_open,
2371 .close = ATEN2011_close,
2372 .write = ATEN2011_write,
2373 .write_room = ATEN2011_write_room,
2374 .chars_in_buffer = ATEN2011_chars_in_buffer,
2375 .throttle = ATEN2011_throttle,
2376 .unthrottle = ATEN2011_unthrottle,
2377 .calc_num_ports = ATEN2011_calc_num_ports,
2378
2379 .ioctl = ATEN2011_ioctl,
2380 .set_termios = ATEN2011_set_termios,
2381 .break_ctl = ATEN2011_break,
2382 .tiocmget = ATEN2011_tiocmget,
2383 .tiocmset = ATEN2011_tiocmset,
2384 .attach = ATEN2011_startup,
2385 .release = ATEN2011_release,
2386 .read_bulk_callback = ATEN2011_bulk_in_callback,
2387 .read_int_callback = ATEN2011_interrupt_callback,
2388};
2389
2390static struct usb_driver aten_driver = {
2391 .name = "aten2011",
2392 .probe = usb_serial_probe,
2393 .disconnect = usb_serial_disconnect,
2394 .id_table = id_table,
2395};
2396
2397static int __init aten_init(void)
2398{
2399 int retval;
2400
2401 /* Register with the usb serial */
2402 retval = usb_serial_register(&aten_serial_driver);
2403 if (retval)
2404 return retval;
2405
2406 printk(KERN_INFO KBUILD_MODNAME ":"
2407 DRIVER_DESC " " DRIVER_VERSION "\n");
2408
2409 /* Register with the usb */
2410 retval = usb_register(&aten_driver);
2411 if (retval)
2412 usb_serial_deregister(&aten_serial_driver);
2413
2414 return retval;
2415}
2416
2417static void __exit aten_exit(void)
2418{
2419 usb_deregister(&aten_driver);
2420 usb_serial_deregister(&aten_serial_driver);
2421}
2422
2423module_init(aten_init);
2424module_exit(aten_exit);
2425
2426/* Module information */
2427MODULE_DESCRIPTION(DRIVER_DESC);
2428MODULE_LICENSE("GPL");
2429
2430MODULE_PARM_DESC(debug, "Debug enabled or not");
diff --git a/drivers/staging/udlfb/udlfb.c b/drivers/staging/udlfb/udlfb.c
index 0ab9d15f3439..f5416af1e902 100644
--- a/drivers/staging/udlfb/udlfb.c
+++ b/drivers/staging/udlfb/udlfb.c
@@ -21,6 +21,7 @@
21#include <linux/mm.h> 21#include <linux/mm.h>
22#include <linux/fb.h> 22#include <linux/fb.h>
23#include <linux/mutex.h> 23#include <linux/mutex.h>
24#include <linux/vmalloc.h>
24 25
25#include "udlfb.h" 26#include "udlfb.h"
26 27
diff --git a/drivers/usb/core/config.c b/drivers/usb/core/config.c
index 24dfb33f90cb..a16c538d0132 100644
--- a/drivers/usb/core/config.c
+++ b/drivers/usb/core/config.c
@@ -80,38 +80,18 @@ static int usb_parse_ss_endpoint_companion(struct device *ddev, int cfgno,
80 int max_tx; 80 int max_tx;
81 int i; 81 int i;
82 82
83 /* Allocate space for the SS endpoint companion descriptor */
84 ep->ss_ep_comp = kzalloc(sizeof(struct usb_host_ss_ep_comp),
85 GFP_KERNEL);
86 if (!ep->ss_ep_comp)
87 return -ENOMEM;
88 desc = (struct usb_ss_ep_comp_descriptor *) buffer; 83 desc = (struct usb_ss_ep_comp_descriptor *) buffer;
89 if (desc->bDescriptorType != USB_DT_SS_ENDPOINT_COMP) { 84 if (desc->bDescriptorType != USB_DT_SS_ENDPOINT_COMP) {
90 dev_warn(ddev, "No SuperSpeed endpoint companion for config %d " 85 dev_warn(ddev, "No SuperSpeed endpoint companion for config %d "
91 " interface %d altsetting %d ep %d: " 86 " interface %d altsetting %d ep %d: "
92 "using minimum values\n", 87 "using minimum values\n",
93 cfgno, inum, asnum, ep->desc.bEndpointAddress); 88 cfgno, inum, asnum, ep->desc.bEndpointAddress);
94 ep->ss_ep_comp->desc.bLength = USB_DT_SS_EP_COMP_SIZE;
95 ep->ss_ep_comp->desc.bDescriptorType = USB_DT_SS_ENDPOINT_COMP;
96 ep->ss_ep_comp->desc.bMaxBurst = 0;
97 /*
98 * Leave bmAttributes as zero, which will mean no streams for
99 * bulk, and isoc won't support multiple bursts of packets.
100 * With bursts of only one packet, and a Mult of 1, the max
101 * amount of data moved per endpoint service interval is one
102 * packet.
103 */
104 if (usb_endpoint_xfer_isoc(&ep->desc) ||
105 usb_endpoint_xfer_int(&ep->desc))
106 ep->ss_ep_comp->desc.wBytesPerInterval =
107 ep->desc.wMaxPacketSize;
108 /* 89 /*
109 * The next descriptor is for an Endpoint or Interface, 90 * The next descriptor is for an Endpoint or Interface,
110 * no extra descriptors to copy into the companion structure, 91 * no extra descriptors to copy into the companion structure,
111 * and we didn't eat up any of the buffer. 92 * and we didn't eat up any of the buffer.
112 */ 93 */
113 retval = 0; 94 return 0;
114 goto valid;
115 } 95 }
116 memcpy(&ep->ss_ep_comp->desc, desc, USB_DT_SS_EP_COMP_SIZE); 96 memcpy(&ep->ss_ep_comp->desc, desc, USB_DT_SS_EP_COMP_SIZE);
117 desc = &ep->ss_ep_comp->desc; 97 desc = &ep->ss_ep_comp->desc;
@@ -320,6 +300,28 @@ static int usb_parse_endpoint(struct device *ddev, int cfgno, int inum,
320 buffer += i; 300 buffer += i;
321 size -= i; 301 size -= i;
322 302
303 /* Allocate space for the SS endpoint companion descriptor */
304 endpoint->ss_ep_comp = kzalloc(sizeof(struct usb_host_ss_ep_comp),
305 GFP_KERNEL);
306 if (!endpoint->ss_ep_comp)
307 return -ENOMEM;
308
309 /* Fill in some default values (may be overwritten later) */
310 endpoint->ss_ep_comp->desc.bLength = USB_DT_SS_EP_COMP_SIZE;
311 endpoint->ss_ep_comp->desc.bDescriptorType = USB_DT_SS_ENDPOINT_COMP;
312 endpoint->ss_ep_comp->desc.bMaxBurst = 0;
313 /*
314 * Leave bmAttributes as zero, which will mean no streams for
315 * bulk, and isoc won't support multiple bursts of packets.
316 * With bursts of only one packet, and a Mult of 1, the max
317 * amount of data moved per endpoint service interval is one
318 * packet.
319 */
320 if (usb_endpoint_xfer_isoc(&endpoint->desc) ||
321 usb_endpoint_xfer_int(&endpoint->desc))
322 endpoint->ss_ep_comp->desc.wBytesPerInterval =
323 endpoint->desc.wMaxPacketSize;
324
323 if (size > 0) { 325 if (size > 0) {
324 retval = usb_parse_ss_endpoint_companion(ddev, cfgno, 326 retval = usb_parse_ss_endpoint_companion(ddev, cfgno,
325 inum, asnum, endpoint, num_ep, buffer, 327 inum, asnum, endpoint, num_ep, buffer,
@@ -329,6 +331,10 @@ static int usb_parse_endpoint(struct device *ddev, int cfgno, int inum,
329 retval = buffer - buffer0; 331 retval = buffer - buffer0;
330 } 332 }
331 } else { 333 } else {
334 dev_warn(ddev, "config %d interface %d altsetting %d "
335 "endpoint 0x%X has no "
336 "SuperSpeed companion descriptor\n",
337 cfgno, inum, asnum, d->bEndpointAddress);
332 retval = buffer - buffer0; 338 retval = buffer - buffer0;
333 } 339 }
334 } else { 340 } else {
diff --git a/drivers/usb/host/ehci-orion.c b/drivers/usb/host/ehci-orion.c
index dc2ac613a9d1..1d283e1b2b8d 100644
--- a/drivers/usb/host/ehci-orion.c
+++ b/drivers/usb/host/ehci-orion.c
@@ -105,6 +105,7 @@ static int ehci_orion_setup(struct usb_hcd *hcd)
105 struct ehci_hcd *ehci = hcd_to_ehci(hcd); 105 struct ehci_hcd *ehci = hcd_to_ehci(hcd);
106 int retval; 106 int retval;
107 107
108 ehci_reset(ehci);
108 retval = ehci_halt(ehci); 109 retval = ehci_halt(ehci);
109 if (retval) 110 if (retval)
110 return retval; 111 return retval;
@@ -118,7 +119,6 @@ static int ehci_orion_setup(struct usb_hcd *hcd)
118 119
119 hcd->has_tt = 1; 120 hcd->has_tt = 1;
120 121
121 ehci_reset(ehci);
122 ehci_port_power(ehci, 0); 122 ehci_port_power(ehci, 0);
123 123
124 return retval; 124 return retval;
diff --git a/drivers/usb/host/ohci-omap.c b/drivers/usb/host/ohci-omap.c
index f3aaba35e912..83cbecd2a1ed 100644
--- a/drivers/usb/host/ohci-omap.c
+++ b/drivers/usb/host/ohci-omap.c
@@ -282,6 +282,7 @@ static int ohci_omap_init(struct usb_hcd *hcd)
282static void ohci_omap_stop(struct usb_hcd *hcd) 282static void ohci_omap_stop(struct usb_hcd *hcd)
283{ 283{
284 dev_dbg(hcd->self.controller, "stopping USB Controller\n"); 284 dev_dbg(hcd->self.controller, "stopping USB Controller\n");
285 ohci_stop(hcd);
285 omap_ohci_clock_power(0); 286 omap_ohci_clock_power(0);
286} 287}
287 288
diff --git a/drivers/usb/host/xhci-dbg.c b/drivers/usb/host/xhci-dbg.c
index 2501c571f855..705e34324156 100644
--- a/drivers/usb/host/xhci-dbg.c
+++ b/drivers/usb/host/xhci-dbg.c
@@ -173,6 +173,7 @@ void xhci_print_ir_set(struct xhci_hcd *xhci, struct xhci_intr_reg *ir_set, int
173{ 173{
174 void *addr; 174 void *addr;
175 u32 temp; 175 u32 temp;
176 u64 temp_64;
176 177
177 addr = &ir_set->irq_pending; 178 addr = &ir_set->irq_pending;
178 temp = xhci_readl(xhci, addr); 179 temp = xhci_readl(xhci, addr);
@@ -200,25 +201,15 @@ void xhci_print_ir_set(struct xhci_hcd *xhci, struct xhci_intr_reg *ir_set, int
200 xhci_dbg(xhci, " WARN: %p: ir_set.rsvd = 0x%x\n", 201 xhci_dbg(xhci, " WARN: %p: ir_set.rsvd = 0x%x\n",
201 addr, (unsigned int)temp); 202 addr, (unsigned int)temp);
202 203
203 addr = &ir_set->erst_base[0]; 204 addr = &ir_set->erst_base;
204 temp = xhci_readl(xhci, addr); 205 temp_64 = xhci_read_64(xhci, addr);
205 xhci_dbg(xhci, " %p: ir_set.erst_base[0] = 0x%x\n", 206 xhci_dbg(xhci, " %p: ir_set.erst_base = @%08llx\n",
206 addr, (unsigned int) temp); 207 addr, temp_64);
207
208 addr = &ir_set->erst_base[1];
209 temp = xhci_readl(xhci, addr);
210 xhci_dbg(xhci, " %p: ir_set.erst_base[1] = 0x%x\n",
211 addr, (unsigned int) temp);
212 208
213 addr = &ir_set->erst_dequeue[0]; 209 addr = &ir_set->erst_dequeue;
214 temp = xhci_readl(xhci, addr); 210 temp_64 = xhci_read_64(xhci, addr);
215 xhci_dbg(xhci, " %p: ir_set.erst_dequeue[0] = 0x%x\n", 211 xhci_dbg(xhci, " %p: ir_set.erst_dequeue = @%08llx\n",
216 addr, (unsigned int) temp); 212 addr, temp_64);
217
218 addr = &ir_set->erst_dequeue[1];
219 temp = xhci_readl(xhci, addr);
220 xhci_dbg(xhci, " %p: ir_set.erst_dequeue[1] = 0x%x\n",
221 addr, (unsigned int) temp);
222} 213}
223 214
224void xhci_print_run_regs(struct xhci_hcd *xhci) 215void xhci_print_run_regs(struct xhci_hcd *xhci)
@@ -268,8 +259,7 @@ void xhci_debug_trb(struct xhci_hcd *xhci, union xhci_trb *trb)
268 xhci_dbg(xhci, "Link TRB:\n"); 259 xhci_dbg(xhci, "Link TRB:\n");
269 xhci_print_trb_offsets(xhci, trb); 260 xhci_print_trb_offsets(xhci, trb);
270 261
271 address = trb->link.segment_ptr[0] + 262 address = trb->link.segment_ptr;
272 (((u64) trb->link.segment_ptr[1]) << 32);
273 xhci_dbg(xhci, "Next ring segment DMA address = 0x%llx\n", address); 263 xhci_dbg(xhci, "Next ring segment DMA address = 0x%llx\n", address);
274 264
275 xhci_dbg(xhci, "Interrupter target = 0x%x\n", 265 xhci_dbg(xhci, "Interrupter target = 0x%x\n",
@@ -282,8 +272,7 @@ void xhci_debug_trb(struct xhci_hcd *xhci, union xhci_trb *trb)
282 (unsigned int) (trb->link.control & TRB_NO_SNOOP)); 272 (unsigned int) (trb->link.control & TRB_NO_SNOOP));
283 break; 273 break;
284 case TRB_TYPE(TRB_TRANSFER): 274 case TRB_TYPE(TRB_TRANSFER):
285 address = trb->trans_event.buffer[0] + 275 address = trb->trans_event.buffer;
286 (((u64) trb->trans_event.buffer[1]) << 32);
287 /* 276 /*
288 * FIXME: look at flags to figure out if it's an address or if 277 * FIXME: look at flags to figure out if it's an address or if
289 * the data is directly in the buffer field. 278 * the data is directly in the buffer field.
@@ -291,8 +280,7 @@ void xhci_debug_trb(struct xhci_hcd *xhci, union xhci_trb *trb)
291 xhci_dbg(xhci, "DMA address or buffer contents= %llu\n", address); 280 xhci_dbg(xhci, "DMA address or buffer contents= %llu\n", address);
292 break; 281 break;
293 case TRB_TYPE(TRB_COMPLETION): 282 case TRB_TYPE(TRB_COMPLETION):
294 address = trb->event_cmd.cmd_trb[0] + 283 address = trb->event_cmd.cmd_trb;
295 (((u64) trb->event_cmd.cmd_trb[1]) << 32);
296 xhci_dbg(xhci, "Command TRB pointer = %llu\n", address); 284 xhci_dbg(xhci, "Command TRB pointer = %llu\n", address);
297 xhci_dbg(xhci, "Completion status = %u\n", 285 xhci_dbg(xhci, "Completion status = %u\n",
298 (unsigned int) GET_COMP_CODE(trb->event_cmd.status)); 286 (unsigned int) GET_COMP_CODE(trb->event_cmd.status));
@@ -328,8 +316,8 @@ void xhci_debug_segment(struct xhci_hcd *xhci, struct xhci_segment *seg)
328 for (i = 0; i < TRBS_PER_SEGMENT; ++i) { 316 for (i = 0; i < TRBS_PER_SEGMENT; ++i) {
329 trb = &seg->trbs[i]; 317 trb = &seg->trbs[i];
330 xhci_dbg(xhci, "@%08x %08x %08x %08x %08x\n", addr, 318 xhci_dbg(xhci, "@%08x %08x %08x %08x %08x\n", addr,
331 (unsigned int) trb->link.segment_ptr[0], 319 lower_32_bits(trb->link.segment_ptr),
332 (unsigned int) trb->link.segment_ptr[1], 320 upper_32_bits(trb->link.segment_ptr),
333 (unsigned int) trb->link.intr_target, 321 (unsigned int) trb->link.intr_target,
334 (unsigned int) trb->link.control); 322 (unsigned int) trb->link.control);
335 addr += sizeof(*trb); 323 addr += sizeof(*trb);
@@ -386,8 +374,8 @@ void xhci_dbg_erst(struct xhci_hcd *xhci, struct xhci_erst *erst)
386 entry = &erst->entries[i]; 374 entry = &erst->entries[i];
387 xhci_dbg(xhci, "@%08x %08x %08x %08x %08x\n", 375 xhci_dbg(xhci, "@%08x %08x %08x %08x %08x\n",
388 (unsigned int) addr, 376 (unsigned int) addr,
389 (unsigned int) entry->seg_addr[0], 377 lower_32_bits(entry->seg_addr),
390 (unsigned int) entry->seg_addr[1], 378 upper_32_bits(entry->seg_addr),
391 (unsigned int) entry->seg_size, 379 (unsigned int) entry->seg_size,
392 (unsigned int) entry->rsvd); 380 (unsigned int) entry->rsvd);
393 addr += sizeof(*entry); 381 addr += sizeof(*entry);
@@ -396,90 +384,147 @@ void xhci_dbg_erst(struct xhci_hcd *xhci, struct xhci_erst *erst)
396 384
397void xhci_dbg_cmd_ptrs(struct xhci_hcd *xhci) 385void xhci_dbg_cmd_ptrs(struct xhci_hcd *xhci)
398{ 386{
399 u32 val; 387 u64 val;
400 388
401 val = xhci_readl(xhci, &xhci->op_regs->cmd_ring[0]); 389 val = xhci_read_64(xhci, &xhci->op_regs->cmd_ring);
402 xhci_dbg(xhci, "// xHC command ring deq ptr low bits + flags = 0x%x\n", val); 390 xhci_dbg(xhci, "// xHC command ring deq ptr low bits + flags = @%08x\n",
403 val = xhci_readl(xhci, &xhci->op_regs->cmd_ring[1]); 391 lower_32_bits(val));
404 xhci_dbg(xhci, "// xHC command ring deq ptr high bits = 0x%x\n", val); 392 xhci_dbg(xhci, "// xHC command ring deq ptr high bits = @%08x\n",
393 upper_32_bits(val));
405} 394}
406 395
407void xhci_dbg_ctx(struct xhci_hcd *xhci, struct xhci_device_control *ctx, dma_addr_t dma, unsigned int last_ep) 396/* Print the last 32 bytes for 64-byte contexts */
397static void dbg_rsvd64(struct xhci_hcd *xhci, u64 *ctx, dma_addr_t dma)
398{
399 int i;
400 for (i = 0; i < 4; ++i) {
401 xhci_dbg(xhci, "@%p (virt) @%08llx "
402 "(dma) %#08llx - rsvd64[%d]\n",
403 &ctx[4 + i], (unsigned long long)dma,
404 ctx[4 + i], i);
405 dma += 8;
406 }
407}
408
409void xhci_dbg_slot_ctx(struct xhci_hcd *xhci, struct xhci_container_ctx *ctx)
408{ 410{
409 int i, j;
410 int last_ep_ctx = 31;
411 /* Fields are 32 bits wide, DMA addresses are in bytes */ 411 /* Fields are 32 bits wide, DMA addresses are in bytes */
412 int field_size = 32 / 8; 412 int field_size = 32 / 8;
413 int i;
413 414
414 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - drop flags\n", 415 struct xhci_slot_ctx *slot_ctx = xhci_get_slot_ctx(xhci, ctx);
415 &ctx->drop_flags, (unsigned long long)dma, 416 dma_addr_t dma = ctx->dma + ((unsigned long)slot_ctx - (unsigned long)ctx);
416 ctx->drop_flags); 417 int csz = HCC_64BYTE_CONTEXT(xhci->hcc_params);
417 dma += field_size;
418 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - add flags\n",
419 &ctx->add_flags, (unsigned long long)dma,
420 ctx->add_flags);
421 dma += field_size;
422 for (i = 0; i > 6; ++i) {
423 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - rsvd[%d]\n",
424 &ctx->rsvd[i], (unsigned long long)dma,
425 ctx->rsvd[i], i);
426 dma += field_size;
427 }
428 418
429 xhci_dbg(xhci, "Slot Context:\n"); 419 xhci_dbg(xhci, "Slot Context:\n");
430 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - dev_info\n", 420 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - dev_info\n",
431 &ctx->slot.dev_info, 421 &slot_ctx->dev_info,
432 (unsigned long long)dma, ctx->slot.dev_info); 422 (unsigned long long)dma, slot_ctx->dev_info);
433 dma += field_size; 423 dma += field_size;
434 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - dev_info2\n", 424 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - dev_info2\n",
435 &ctx->slot.dev_info2, 425 &slot_ctx->dev_info2,
436 (unsigned long long)dma, ctx->slot.dev_info2); 426 (unsigned long long)dma, slot_ctx->dev_info2);
437 dma += field_size; 427 dma += field_size;
438 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - tt_info\n", 428 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - tt_info\n",
439 &ctx->slot.tt_info, 429 &slot_ctx->tt_info,
440 (unsigned long long)dma, ctx->slot.tt_info); 430 (unsigned long long)dma, slot_ctx->tt_info);
441 dma += field_size; 431 dma += field_size;
442 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - dev_state\n", 432 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - dev_state\n",
443 &ctx->slot.dev_state, 433 &slot_ctx->dev_state,
444 (unsigned long long)dma, ctx->slot.dev_state); 434 (unsigned long long)dma, slot_ctx->dev_state);
445 dma += field_size; 435 dma += field_size;
446 for (i = 0; i > 4; ++i) { 436 for (i = 0; i < 4; ++i) {
447 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - rsvd[%d]\n", 437 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - rsvd[%d]\n",
448 &ctx->slot.reserved[i], (unsigned long long)dma, 438 &slot_ctx->reserved[i], (unsigned long long)dma,
449 ctx->slot.reserved[i], i); 439 slot_ctx->reserved[i], i);
450 dma += field_size; 440 dma += field_size;
451 } 441 }
452 442
443 if (csz)
444 dbg_rsvd64(xhci, (u64 *)slot_ctx, dma);
445}
446
447void xhci_dbg_ep_ctx(struct xhci_hcd *xhci,
448 struct xhci_container_ctx *ctx,
449 unsigned int last_ep)
450{
451 int i, j;
452 int last_ep_ctx = 31;
453 /* Fields are 32 bits wide, DMA addresses are in bytes */
454 int field_size = 32 / 8;
455 int csz = HCC_64BYTE_CONTEXT(xhci->hcc_params);
456
453 if (last_ep < 31) 457 if (last_ep < 31)
454 last_ep_ctx = last_ep + 1; 458 last_ep_ctx = last_ep + 1;
455 for (i = 0; i < last_ep_ctx; ++i) { 459 for (i = 0; i < last_ep_ctx; ++i) {
460 struct xhci_ep_ctx *ep_ctx = xhci_get_ep_ctx(xhci, ctx, i);
461 dma_addr_t dma = ctx->dma +
462 ((unsigned long)ep_ctx - (unsigned long)ctx);
463
456 xhci_dbg(xhci, "Endpoint %02d Context:\n", i); 464 xhci_dbg(xhci, "Endpoint %02d Context:\n", i);
457 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - ep_info\n", 465 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - ep_info\n",
458 &ctx->ep[i].ep_info, 466 &ep_ctx->ep_info,
459 (unsigned long long)dma, ctx->ep[i].ep_info); 467 (unsigned long long)dma, ep_ctx->ep_info);
460 dma += field_size; 468 dma += field_size;
461 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - ep_info2\n", 469 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - ep_info2\n",
462 &ctx->ep[i].ep_info2, 470 &ep_ctx->ep_info2,
463 (unsigned long long)dma, ctx->ep[i].ep_info2); 471 (unsigned long long)dma, ep_ctx->ep_info2);
464 dma += field_size;
465 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - deq[0]\n",
466 &ctx->ep[i].deq[0],
467 (unsigned long long)dma, ctx->ep[i].deq[0]);
468 dma += field_size;
469 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - deq[1]\n",
470 &ctx->ep[i].deq[1],
471 (unsigned long long)dma, ctx->ep[i].deq[1]);
472 dma += field_size; 472 dma += field_size;
473 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08llx - deq\n",
474 &ep_ctx->deq,
475 (unsigned long long)dma, ep_ctx->deq);
476 dma += 2*field_size;
473 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - tx_info\n", 477 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - tx_info\n",
474 &ctx->ep[i].tx_info, 478 &ep_ctx->tx_info,
475 (unsigned long long)dma, ctx->ep[i].tx_info); 479 (unsigned long long)dma, ep_ctx->tx_info);
476 dma += field_size; 480 dma += field_size;
477 for (j = 0; j < 3; ++j) { 481 for (j = 0; j < 3; ++j) {
478 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - rsvd[%d]\n", 482 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - rsvd[%d]\n",
479 &ctx->ep[i].reserved[j], 483 &ep_ctx->reserved[j],
480 (unsigned long long)dma, 484 (unsigned long long)dma,
481 ctx->ep[i].reserved[j], j); 485 ep_ctx->reserved[j], j);
486 dma += field_size;
487 }
488
489 if (csz)
490 dbg_rsvd64(xhci, (u64 *)ep_ctx, dma);
491 }
492}
493
494void xhci_dbg_ctx(struct xhci_hcd *xhci,
495 struct xhci_container_ctx *ctx,
496 unsigned int last_ep)
497{
498 int i;
499 /* Fields are 32 bits wide, DMA addresses are in bytes */
500 int field_size = 32 / 8;
501 struct xhci_slot_ctx *slot_ctx;
502 dma_addr_t dma = ctx->dma;
503 int csz = HCC_64BYTE_CONTEXT(xhci->hcc_params);
504
505 if (ctx->type == XHCI_CTX_TYPE_INPUT) {
506 struct xhci_input_control_ctx *ctrl_ctx =
507 xhci_get_input_control_ctx(xhci, ctx);
508 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - drop flags\n",
509 &ctrl_ctx->drop_flags, (unsigned long long)dma,
510 ctrl_ctx->drop_flags);
511 dma += field_size;
512 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - add flags\n",
513 &ctrl_ctx->add_flags, (unsigned long long)dma,
514 ctrl_ctx->add_flags);
515 dma += field_size;
516 for (i = 0; i < 6; ++i) {
517 xhci_dbg(xhci, "@%p (virt) @%08llx (dma) %#08x - rsvd2[%d]\n",
518 &ctrl_ctx->rsvd2[i], (unsigned long long)dma,
519 ctrl_ctx->rsvd2[i], i);
482 dma += field_size; 520 dma += field_size;
483 } 521 }
522
523 if (csz)
524 dbg_rsvd64(xhci, (u64 *)ctrl_ctx, dma);
484 } 525 }
526
527 slot_ctx = xhci_get_slot_ctx(xhci, ctx);
528 xhci_dbg_slot_ctx(xhci, ctx);
529 xhci_dbg_ep_ctx(xhci, ctx, last_ep);
485} 530}
diff --git a/drivers/usb/host/xhci-hcd.c b/drivers/usb/host/xhci-hcd.c
index dba3e07ccd09..816c39caca1c 100644
--- a/drivers/usb/host/xhci-hcd.c
+++ b/drivers/usb/host/xhci-hcd.c
@@ -103,7 +103,10 @@ int xhci_reset(struct xhci_hcd *xhci)
103 u32 state; 103 u32 state;
104 104
105 state = xhci_readl(xhci, &xhci->op_regs->status); 105 state = xhci_readl(xhci, &xhci->op_regs->status);
106 BUG_ON((state & STS_HALT) == 0); 106 if ((state & STS_HALT) == 0) {
107 xhci_warn(xhci, "Host controller not halted, aborting reset.\n");
108 return 0;
109 }
107 110
108 xhci_dbg(xhci, "// Reset the HC\n"); 111 xhci_dbg(xhci, "// Reset the HC\n");
109 command = xhci_readl(xhci, &xhci->op_regs->command); 112 command = xhci_readl(xhci, &xhci->op_regs->command);
@@ -226,6 +229,7 @@ int xhci_init(struct usb_hcd *hcd)
226static void xhci_work(struct xhci_hcd *xhci) 229static void xhci_work(struct xhci_hcd *xhci)
227{ 230{
228 u32 temp; 231 u32 temp;
232 u64 temp_64;
229 233
230 /* 234 /*
231 * Clear the op reg interrupt status first, 235 * Clear the op reg interrupt status first,
@@ -248,9 +252,9 @@ static void xhci_work(struct xhci_hcd *xhci)
248 /* FIXME this should be a delayed service routine that clears the EHB */ 252 /* FIXME this should be a delayed service routine that clears the EHB */
249 xhci_handle_event(xhci); 253 xhci_handle_event(xhci);
250 254
251 /* Clear the event handler busy flag; the event ring should be empty. */ 255 /* Clear the event handler busy flag (RW1C); the event ring should be empty. */
252 temp = xhci_readl(xhci, &xhci->ir_set->erst_dequeue[0]); 256 temp_64 = xhci_read_64(xhci, &xhci->ir_set->erst_dequeue);
253 xhci_writel(xhci, temp & ~ERST_EHB, &xhci->ir_set->erst_dequeue[0]); 257 xhci_write_64(xhci, temp_64 | ERST_EHB, &xhci->ir_set->erst_dequeue);
254 /* Flush posted writes -- FIXME is this necessary? */ 258 /* Flush posted writes -- FIXME is this necessary? */
255 xhci_readl(xhci, &xhci->ir_set->irq_pending); 259 xhci_readl(xhci, &xhci->ir_set->irq_pending);
256} 260}
@@ -266,19 +270,34 @@ irqreturn_t xhci_irq(struct usb_hcd *hcd)
266{ 270{
267 struct xhci_hcd *xhci = hcd_to_xhci(hcd); 271 struct xhci_hcd *xhci = hcd_to_xhci(hcd);
268 u32 temp, temp2; 272 u32 temp, temp2;
273 union xhci_trb *trb;
269 274
270 spin_lock(&xhci->lock); 275 spin_lock(&xhci->lock);
276 trb = xhci->event_ring->dequeue;
271 /* Check if the xHC generated the interrupt, or the irq is shared */ 277 /* Check if the xHC generated the interrupt, or the irq is shared */
272 temp = xhci_readl(xhci, &xhci->op_regs->status); 278 temp = xhci_readl(xhci, &xhci->op_regs->status);
273 temp2 = xhci_readl(xhci, &xhci->ir_set->irq_pending); 279 temp2 = xhci_readl(xhci, &xhci->ir_set->irq_pending);
280 if (temp == 0xffffffff && temp2 == 0xffffffff)
281 goto hw_died;
282
274 if (!(temp & STS_EINT) && !ER_IRQ_PENDING(temp2)) { 283 if (!(temp & STS_EINT) && !ER_IRQ_PENDING(temp2)) {
275 spin_unlock(&xhci->lock); 284 spin_unlock(&xhci->lock);
276 return IRQ_NONE; 285 return IRQ_NONE;
277 } 286 }
287 xhci_dbg(xhci, "op reg status = %08x\n", temp);
288 xhci_dbg(xhci, "ir set irq_pending = %08x\n", temp2);
289 xhci_dbg(xhci, "Event ring dequeue ptr:\n");
290 xhci_dbg(xhci, "@%llx %08x %08x %08x %08x\n",
291 (unsigned long long)xhci_trb_virt_to_dma(xhci->event_ring->deq_seg, trb),
292 lower_32_bits(trb->link.segment_ptr),
293 upper_32_bits(trb->link.segment_ptr),
294 (unsigned int) trb->link.intr_target,
295 (unsigned int) trb->link.control);
278 296
279 if (temp & STS_FATAL) { 297 if (temp & STS_FATAL) {
280 xhci_warn(xhci, "WARNING: Host System Error\n"); 298 xhci_warn(xhci, "WARNING: Host System Error\n");
281 xhci_halt(xhci); 299 xhci_halt(xhci);
300hw_died:
282 xhci_to_hcd(xhci)->state = HC_STATE_HALT; 301 xhci_to_hcd(xhci)->state = HC_STATE_HALT;
283 spin_unlock(&xhci->lock); 302 spin_unlock(&xhci->lock);
284 return -ESHUTDOWN; 303 return -ESHUTDOWN;
@@ -295,6 +314,7 @@ void xhci_event_ring_work(unsigned long arg)
295{ 314{
296 unsigned long flags; 315 unsigned long flags;
297 int temp; 316 int temp;
317 u64 temp_64;
298 struct xhci_hcd *xhci = (struct xhci_hcd *) arg; 318 struct xhci_hcd *xhci = (struct xhci_hcd *) arg;
299 int i, j; 319 int i, j;
300 320
@@ -311,9 +331,9 @@ void xhci_event_ring_work(unsigned long arg)
311 xhci_dbg(xhci, "Event ring:\n"); 331 xhci_dbg(xhci, "Event ring:\n");
312 xhci_debug_segment(xhci, xhci->event_ring->deq_seg); 332 xhci_debug_segment(xhci, xhci->event_ring->deq_seg);
313 xhci_dbg_ring_ptrs(xhci, xhci->event_ring); 333 xhci_dbg_ring_ptrs(xhci, xhci->event_ring);
314 temp = xhci_readl(xhci, &xhci->ir_set->erst_dequeue[0]); 334 temp_64 = xhci_read_64(xhci, &xhci->ir_set->erst_dequeue);
315 temp &= ERST_PTR_MASK; 335 temp_64 &= ~ERST_PTR_MASK;
316 xhci_dbg(xhci, "ERST deq = 0x%x\n", temp); 336 xhci_dbg(xhci, "ERST deq = 64'h%0lx\n", (long unsigned int) temp_64);
317 xhci_dbg(xhci, "Command ring:\n"); 337 xhci_dbg(xhci, "Command ring:\n");
318 xhci_debug_segment(xhci, xhci->cmd_ring->deq_seg); 338 xhci_debug_segment(xhci, xhci->cmd_ring->deq_seg);
319 xhci_dbg_ring_ptrs(xhci, xhci->cmd_ring); 339 xhci_dbg_ring_ptrs(xhci, xhci->cmd_ring);
@@ -356,6 +376,7 @@ void xhci_event_ring_work(unsigned long arg)
356int xhci_run(struct usb_hcd *hcd) 376int xhci_run(struct usb_hcd *hcd)
357{ 377{
358 u32 temp; 378 u32 temp;
379 u64 temp_64;
359 struct xhci_hcd *xhci = hcd_to_xhci(hcd); 380 struct xhci_hcd *xhci = hcd_to_xhci(hcd);
360 void (*doorbell)(struct xhci_hcd *) = NULL; 381 void (*doorbell)(struct xhci_hcd *) = NULL;
361 382
@@ -382,6 +403,20 @@ int xhci_run(struct usb_hcd *hcd)
382 add_timer(&xhci->event_ring_timer); 403 add_timer(&xhci->event_ring_timer);
383#endif 404#endif
384 405
406 xhci_dbg(xhci, "Command ring memory map follows:\n");
407 xhci_debug_ring(xhci, xhci->cmd_ring);
408 xhci_dbg_ring_ptrs(xhci, xhci->cmd_ring);
409 xhci_dbg_cmd_ptrs(xhci);
410
411 xhci_dbg(xhci, "ERST memory map follows:\n");
412 xhci_dbg_erst(xhci, &xhci->erst);
413 xhci_dbg(xhci, "Event ring:\n");
414 xhci_debug_ring(xhci, xhci->event_ring);
415 xhci_dbg_ring_ptrs(xhci, xhci->event_ring);
416 temp_64 = xhci_read_64(xhci, &xhci->ir_set->erst_dequeue);
417 temp_64 &= ~ERST_PTR_MASK;
418 xhci_dbg(xhci, "ERST deq = 64'h%0lx\n", (long unsigned int) temp_64);
419
385 xhci_dbg(xhci, "// Set the interrupt modulation register\n"); 420 xhci_dbg(xhci, "// Set the interrupt modulation register\n");
386 temp = xhci_readl(xhci, &xhci->ir_set->irq_control); 421 temp = xhci_readl(xhci, &xhci->ir_set->irq_control);
387 temp &= ~ER_IRQ_INTERVAL_MASK; 422 temp &= ~ER_IRQ_INTERVAL_MASK;
@@ -406,22 +441,6 @@ int xhci_run(struct usb_hcd *hcd)
406 if (NUM_TEST_NOOPS > 0) 441 if (NUM_TEST_NOOPS > 0)
407 doorbell = xhci_setup_one_noop(xhci); 442 doorbell = xhci_setup_one_noop(xhci);
408 443
409 xhci_dbg(xhci, "Command ring memory map follows:\n");
410 xhci_debug_ring(xhci, xhci->cmd_ring);
411 xhci_dbg_ring_ptrs(xhci, xhci->cmd_ring);
412 xhci_dbg_cmd_ptrs(xhci);
413
414 xhci_dbg(xhci, "ERST memory map follows:\n");
415 xhci_dbg_erst(xhci, &xhci->erst);
416 xhci_dbg(xhci, "Event ring:\n");
417 xhci_debug_ring(xhci, xhci->event_ring);
418 xhci_dbg_ring_ptrs(xhci, xhci->event_ring);
419 temp = xhci_readl(xhci, &xhci->ir_set->erst_dequeue[0]);
420 temp &= ERST_PTR_MASK;
421 xhci_dbg(xhci, "ERST deq = 0x%x\n", temp);
422 temp = xhci_readl(xhci, &xhci->ir_set->erst_dequeue[1]);
423 xhci_dbg(xhci, "ERST deq upper = 0x%x\n", temp);
424
425 temp = xhci_readl(xhci, &xhci->op_regs->command); 444 temp = xhci_readl(xhci, &xhci->op_regs->command);
426 temp |= (CMD_RUN); 445 temp |= (CMD_RUN);
427 xhci_dbg(xhci, "// Turn on HC, cmd = 0x%x.\n", 446 xhci_dbg(xhci, "// Turn on HC, cmd = 0x%x.\n",
@@ -601,10 +620,13 @@ int xhci_urb_enqueue(struct usb_hcd *hcd, struct urb *urb, gfp_t mem_flags)
601 goto exit; 620 goto exit;
602 } 621 }
603 if (usb_endpoint_xfer_control(&urb->ep->desc)) 622 if (usb_endpoint_xfer_control(&urb->ep->desc))
604 ret = xhci_queue_ctrl_tx(xhci, mem_flags, urb, 623 /* We have a spinlock and interrupts disabled, so we must pass
624 * atomic context to this function, which may allocate memory.
625 */
626 ret = xhci_queue_ctrl_tx(xhci, GFP_ATOMIC, urb,
605 slot_id, ep_index); 627 slot_id, ep_index);
606 else if (usb_endpoint_xfer_bulk(&urb->ep->desc)) 628 else if (usb_endpoint_xfer_bulk(&urb->ep->desc))
607 ret = xhci_queue_bulk_tx(xhci, mem_flags, urb, 629 ret = xhci_queue_bulk_tx(xhci, GFP_ATOMIC, urb,
608 slot_id, ep_index); 630 slot_id, ep_index);
609 else 631 else
610 ret = -EINVAL; 632 ret = -EINVAL;
@@ -661,8 +683,12 @@ int xhci_urb_dequeue(struct usb_hcd *hcd, struct urb *urb, int status)
661 goto done; 683 goto done;
662 684
663 xhci_dbg(xhci, "Cancel URB %p\n", urb); 685 xhci_dbg(xhci, "Cancel URB %p\n", urb);
686 xhci_dbg(xhci, "Event ring:\n");
687 xhci_debug_ring(xhci, xhci->event_ring);
664 ep_index = xhci_get_endpoint_index(&urb->ep->desc); 688 ep_index = xhci_get_endpoint_index(&urb->ep->desc);
665 ep_ring = xhci->devs[urb->dev->slot_id]->ep_rings[ep_index]; 689 ep_ring = xhci->devs[urb->dev->slot_id]->ep_rings[ep_index];
690 xhci_dbg(xhci, "Endpoint ring:\n");
691 xhci_debug_ring(xhci, ep_ring);
666 td = (struct xhci_td *) urb->hcpriv; 692 td = (struct xhci_td *) urb->hcpriv;
667 693
668 ep_ring->cancels_pending++; 694 ep_ring->cancels_pending++;
@@ -696,7 +722,9 @@ int xhci_drop_endpoint(struct usb_hcd *hcd, struct usb_device *udev,
696 struct usb_host_endpoint *ep) 722 struct usb_host_endpoint *ep)
697{ 723{
698 struct xhci_hcd *xhci; 724 struct xhci_hcd *xhci;
699 struct xhci_device_control *in_ctx; 725 struct xhci_container_ctx *in_ctx, *out_ctx;
726 struct xhci_input_control_ctx *ctrl_ctx;
727 struct xhci_slot_ctx *slot_ctx;
700 unsigned int last_ctx; 728 unsigned int last_ctx;
701 unsigned int ep_index; 729 unsigned int ep_index;
702 struct xhci_ep_ctx *ep_ctx; 730 struct xhci_ep_ctx *ep_ctx;
@@ -724,31 +752,34 @@ int xhci_drop_endpoint(struct usb_hcd *hcd, struct usb_device *udev,
724 } 752 }
725 753
726 in_ctx = xhci->devs[udev->slot_id]->in_ctx; 754 in_ctx = xhci->devs[udev->slot_id]->in_ctx;
755 out_ctx = xhci->devs[udev->slot_id]->out_ctx;
756 ctrl_ctx = xhci_get_input_control_ctx(xhci, in_ctx);
727 ep_index = xhci_get_endpoint_index(&ep->desc); 757 ep_index = xhci_get_endpoint_index(&ep->desc);
728 ep_ctx = &xhci->devs[udev->slot_id]->out_ctx->ep[ep_index]; 758 ep_ctx = xhci_get_ep_ctx(xhci, out_ctx, ep_index);
729 /* If the HC already knows the endpoint is disabled, 759 /* If the HC already knows the endpoint is disabled,
730 * or the HCD has noted it is disabled, ignore this request 760 * or the HCD has noted it is disabled, ignore this request
731 */ 761 */
732 if ((ep_ctx->ep_info & EP_STATE_MASK) == EP_STATE_DISABLED || 762 if ((ep_ctx->ep_info & EP_STATE_MASK) == EP_STATE_DISABLED ||
733 in_ctx->drop_flags & xhci_get_endpoint_flag(&ep->desc)) { 763 ctrl_ctx->drop_flags & xhci_get_endpoint_flag(&ep->desc)) {
734 xhci_warn(xhci, "xHCI %s called with disabled ep %p\n", 764 xhci_warn(xhci, "xHCI %s called with disabled ep %p\n",
735 __func__, ep); 765 __func__, ep);
736 return 0; 766 return 0;
737 } 767 }
738 768
739 in_ctx->drop_flags |= drop_flag; 769 ctrl_ctx->drop_flags |= drop_flag;
740 new_drop_flags = in_ctx->drop_flags; 770 new_drop_flags = ctrl_ctx->drop_flags;
741 771
742 in_ctx->add_flags = ~drop_flag; 772 ctrl_ctx->add_flags = ~drop_flag;
743 new_add_flags = in_ctx->add_flags; 773 new_add_flags = ctrl_ctx->add_flags;
744 774
745 last_ctx = xhci_last_valid_endpoint(in_ctx->add_flags); 775 last_ctx = xhci_last_valid_endpoint(ctrl_ctx->add_flags);
776 slot_ctx = xhci_get_slot_ctx(xhci, in_ctx);
746 /* Update the last valid endpoint context, if we deleted the last one */ 777 /* Update the last valid endpoint context, if we deleted the last one */
747 if ((in_ctx->slot.dev_info & LAST_CTX_MASK) > LAST_CTX(last_ctx)) { 778 if ((slot_ctx->dev_info & LAST_CTX_MASK) > LAST_CTX(last_ctx)) {
748 in_ctx->slot.dev_info &= ~LAST_CTX_MASK; 779 slot_ctx->dev_info &= ~LAST_CTX_MASK;
749 in_ctx->slot.dev_info |= LAST_CTX(last_ctx); 780 slot_ctx->dev_info |= LAST_CTX(last_ctx);
750 } 781 }
751 new_slot_info = in_ctx->slot.dev_info; 782 new_slot_info = slot_ctx->dev_info;
752 783
753 xhci_endpoint_zero(xhci, xhci->devs[udev->slot_id], ep); 784 xhci_endpoint_zero(xhci, xhci->devs[udev->slot_id], ep);
754 785
@@ -778,17 +809,22 @@ int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev,
778 struct usb_host_endpoint *ep) 809 struct usb_host_endpoint *ep)
779{ 810{
780 struct xhci_hcd *xhci; 811 struct xhci_hcd *xhci;
781 struct xhci_device_control *in_ctx; 812 struct xhci_container_ctx *in_ctx, *out_ctx;
782 unsigned int ep_index; 813 unsigned int ep_index;
783 struct xhci_ep_ctx *ep_ctx; 814 struct xhci_ep_ctx *ep_ctx;
815 struct xhci_slot_ctx *slot_ctx;
816 struct xhci_input_control_ctx *ctrl_ctx;
784 u32 added_ctxs; 817 u32 added_ctxs;
785 unsigned int last_ctx; 818 unsigned int last_ctx;
786 u32 new_add_flags, new_drop_flags, new_slot_info; 819 u32 new_add_flags, new_drop_flags, new_slot_info;
787 int ret = 0; 820 int ret = 0;
788 821
789 ret = xhci_check_args(hcd, udev, ep, 1, __func__); 822 ret = xhci_check_args(hcd, udev, ep, 1, __func__);
790 if (ret <= 0) 823 if (ret <= 0) {
824 /* So we won't queue a reset ep command for a root hub */
825 ep->hcpriv = NULL;
791 return ret; 826 return ret;
827 }
792 xhci = hcd_to_xhci(hcd); 828 xhci = hcd_to_xhci(hcd);
793 829
794 added_ctxs = xhci_get_endpoint_flag(&ep->desc); 830 added_ctxs = xhci_get_endpoint_flag(&ep->desc);
@@ -810,12 +846,14 @@ int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev,
810 } 846 }
811 847
812 in_ctx = xhci->devs[udev->slot_id]->in_ctx; 848 in_ctx = xhci->devs[udev->slot_id]->in_ctx;
849 out_ctx = xhci->devs[udev->slot_id]->out_ctx;
850 ctrl_ctx = xhci_get_input_control_ctx(xhci, in_ctx);
813 ep_index = xhci_get_endpoint_index(&ep->desc); 851 ep_index = xhci_get_endpoint_index(&ep->desc);
814 ep_ctx = &xhci->devs[udev->slot_id]->out_ctx->ep[ep_index]; 852 ep_ctx = xhci_get_ep_ctx(xhci, out_ctx, ep_index);
815 /* If the HCD has already noted the endpoint is enabled, 853 /* If the HCD has already noted the endpoint is enabled,
816 * ignore this request. 854 * ignore this request.
817 */ 855 */
818 if (in_ctx->add_flags & xhci_get_endpoint_flag(&ep->desc)) { 856 if (ctrl_ctx->add_flags & xhci_get_endpoint_flag(&ep->desc)) {
819 xhci_warn(xhci, "xHCI %s called with enabled ep %p\n", 857 xhci_warn(xhci, "xHCI %s called with enabled ep %p\n",
820 __func__, ep); 858 __func__, ep);
821 return 0; 859 return 0;
@@ -833,8 +871,8 @@ int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev,
833 return -ENOMEM; 871 return -ENOMEM;
834 } 872 }
835 873
836 in_ctx->add_flags |= added_ctxs; 874 ctrl_ctx->add_flags |= added_ctxs;
837 new_add_flags = in_ctx->add_flags; 875 new_add_flags = ctrl_ctx->add_flags;
838 876
839 /* If xhci_endpoint_disable() was called for this endpoint, but the 877 /* If xhci_endpoint_disable() was called for this endpoint, but the
840 * xHC hasn't been notified yet through the check_bandwidth() call, 878 * xHC hasn't been notified yet through the check_bandwidth() call,
@@ -842,14 +880,18 @@ int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev,
842 * descriptors. We must drop and re-add this endpoint, so we leave the 880 * descriptors. We must drop and re-add this endpoint, so we leave the
843 * drop flags alone. 881 * drop flags alone.
844 */ 882 */
845 new_drop_flags = in_ctx->drop_flags; 883 new_drop_flags = ctrl_ctx->drop_flags;
846 884
885 slot_ctx = xhci_get_slot_ctx(xhci, in_ctx);
847 /* Update the last valid endpoint context, if we just added one past */ 886 /* Update the last valid endpoint context, if we just added one past */
848 if ((in_ctx->slot.dev_info & LAST_CTX_MASK) < LAST_CTX(last_ctx)) { 887 if ((slot_ctx->dev_info & LAST_CTX_MASK) < LAST_CTX(last_ctx)) {
849 in_ctx->slot.dev_info &= ~LAST_CTX_MASK; 888 slot_ctx->dev_info &= ~LAST_CTX_MASK;
850 in_ctx->slot.dev_info |= LAST_CTX(last_ctx); 889 slot_ctx->dev_info |= LAST_CTX(last_ctx);
851 } 890 }
852 new_slot_info = in_ctx->slot.dev_info; 891 new_slot_info = slot_ctx->dev_info;
892
893 /* Store the usb_device pointer for later use */
894 ep->hcpriv = udev;
853 895
854 xhci_dbg(xhci, "add ep 0x%x, slot id %d, new drop flags = %#x, new add flags = %#x, new slot info = %#x\n", 896 xhci_dbg(xhci, "add ep 0x%x, slot id %d, new drop flags = %#x, new add flags = %#x, new slot info = %#x\n",
855 (unsigned int) ep->desc.bEndpointAddress, 897 (unsigned int) ep->desc.bEndpointAddress,
@@ -860,9 +902,11 @@ int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev,
860 return 0; 902 return 0;
861} 903}
862 904
863static void xhci_zero_in_ctx(struct xhci_virt_device *virt_dev) 905static void xhci_zero_in_ctx(struct xhci_hcd *xhci, struct xhci_virt_device *virt_dev)
864{ 906{
907 struct xhci_input_control_ctx *ctrl_ctx;
865 struct xhci_ep_ctx *ep_ctx; 908 struct xhci_ep_ctx *ep_ctx;
909 struct xhci_slot_ctx *slot_ctx;
866 int i; 910 int i;
867 911
868 /* When a device's add flag and drop flag are zero, any subsequent 912 /* When a device's add flag and drop flag are zero, any subsequent
@@ -870,17 +914,18 @@ static void xhci_zero_in_ctx(struct xhci_virt_device *virt_dev)
870 * untouched. Make sure we don't leave any old state in the input 914 * untouched. Make sure we don't leave any old state in the input
871 * endpoint contexts. 915 * endpoint contexts.
872 */ 916 */
873 virt_dev->in_ctx->drop_flags = 0; 917 ctrl_ctx = xhci_get_input_control_ctx(xhci, virt_dev->in_ctx);
874 virt_dev->in_ctx->add_flags = 0; 918 ctrl_ctx->drop_flags = 0;
875 virt_dev->in_ctx->slot.dev_info &= ~LAST_CTX_MASK; 919 ctrl_ctx->add_flags = 0;
920 slot_ctx = xhci_get_slot_ctx(xhci, virt_dev->in_ctx);
921 slot_ctx->dev_info &= ~LAST_CTX_MASK;
876 /* Endpoint 0 is always valid */ 922 /* Endpoint 0 is always valid */
877 virt_dev->in_ctx->slot.dev_info |= LAST_CTX(1); 923 slot_ctx->dev_info |= LAST_CTX(1);
878 for (i = 1; i < 31; ++i) { 924 for (i = 1; i < 31; ++i) {
879 ep_ctx = &virt_dev->in_ctx->ep[i]; 925 ep_ctx = xhci_get_ep_ctx(xhci, virt_dev->in_ctx, i);
880 ep_ctx->ep_info = 0; 926 ep_ctx->ep_info = 0;
881 ep_ctx->ep_info2 = 0; 927 ep_ctx->ep_info2 = 0;
882 ep_ctx->deq[0] = 0; 928 ep_ctx->deq = 0;
883 ep_ctx->deq[1] = 0;
884 ep_ctx->tx_info = 0; 929 ep_ctx->tx_info = 0;
885 } 930 }
886} 931}
@@ -903,6 +948,8 @@ int xhci_check_bandwidth(struct usb_hcd *hcd, struct usb_device *udev)
903 unsigned long flags; 948 unsigned long flags;
904 struct xhci_hcd *xhci; 949 struct xhci_hcd *xhci;
905 struct xhci_virt_device *virt_dev; 950 struct xhci_virt_device *virt_dev;
951 struct xhci_input_control_ctx *ctrl_ctx;
952 struct xhci_slot_ctx *slot_ctx;
906 953
907 ret = xhci_check_args(hcd, udev, NULL, 0, __func__); 954 ret = xhci_check_args(hcd, udev, NULL, 0, __func__);
908 if (ret <= 0) 955 if (ret <= 0)
@@ -918,16 +965,18 @@ int xhci_check_bandwidth(struct usb_hcd *hcd, struct usb_device *udev)
918 virt_dev = xhci->devs[udev->slot_id]; 965 virt_dev = xhci->devs[udev->slot_id];
919 966
920 /* See section 4.6.6 - A0 = 1; A1 = D0 = D1 = 0 */ 967 /* See section 4.6.6 - A0 = 1; A1 = D0 = D1 = 0 */
921 virt_dev->in_ctx->add_flags |= SLOT_FLAG; 968 ctrl_ctx = xhci_get_input_control_ctx(xhci, virt_dev->in_ctx);
922 virt_dev->in_ctx->add_flags &= ~EP0_FLAG; 969 ctrl_ctx->add_flags |= SLOT_FLAG;
923 virt_dev->in_ctx->drop_flags &= ~SLOT_FLAG; 970 ctrl_ctx->add_flags &= ~EP0_FLAG;
924 virt_dev->in_ctx->drop_flags &= ~EP0_FLAG; 971 ctrl_ctx->drop_flags &= ~SLOT_FLAG;
972 ctrl_ctx->drop_flags &= ~EP0_FLAG;
925 xhci_dbg(xhci, "New Input Control Context:\n"); 973 xhci_dbg(xhci, "New Input Control Context:\n");
926 xhci_dbg_ctx(xhci, virt_dev->in_ctx, virt_dev->in_ctx_dma, 974 slot_ctx = xhci_get_slot_ctx(xhci, virt_dev->in_ctx);
927 LAST_CTX_TO_EP_NUM(virt_dev->in_ctx->slot.dev_info)); 975 xhci_dbg_ctx(xhci, virt_dev->in_ctx,
976 LAST_CTX_TO_EP_NUM(slot_ctx->dev_info));
928 977
929 spin_lock_irqsave(&xhci->lock, flags); 978 spin_lock_irqsave(&xhci->lock, flags);
930 ret = xhci_queue_configure_endpoint(xhci, virt_dev->in_ctx_dma, 979 ret = xhci_queue_configure_endpoint(xhci, virt_dev->in_ctx->dma,
931 udev->slot_id); 980 udev->slot_id);
932 if (ret < 0) { 981 if (ret < 0) {
933 spin_unlock_irqrestore(&xhci->lock, flags); 982 spin_unlock_irqrestore(&xhci->lock, flags);
@@ -982,10 +1031,10 @@ int xhci_check_bandwidth(struct usb_hcd *hcd, struct usb_device *udev)
982 } 1031 }
983 1032
984 xhci_dbg(xhci, "Output context after successful config ep cmd:\n"); 1033 xhci_dbg(xhci, "Output context after successful config ep cmd:\n");
985 xhci_dbg_ctx(xhci, virt_dev->out_ctx, virt_dev->out_ctx_dma, 1034 xhci_dbg_ctx(xhci, virt_dev->out_ctx,
986 LAST_CTX_TO_EP_NUM(virt_dev->in_ctx->slot.dev_info)); 1035 LAST_CTX_TO_EP_NUM(slot_ctx->dev_info));
987 1036
988 xhci_zero_in_ctx(virt_dev); 1037 xhci_zero_in_ctx(xhci, virt_dev);
989 /* Free any old rings */ 1038 /* Free any old rings */
990 for (i = 1; i < 31; ++i) { 1039 for (i = 1; i < 31; ++i) {
991 if (virt_dev->new_ep_rings[i]) { 1040 if (virt_dev->new_ep_rings[i]) {
@@ -1023,7 +1072,67 @@ void xhci_reset_bandwidth(struct usb_hcd *hcd, struct usb_device *udev)
1023 virt_dev->new_ep_rings[i] = NULL; 1072 virt_dev->new_ep_rings[i] = NULL;
1024 } 1073 }
1025 } 1074 }
1026 xhci_zero_in_ctx(virt_dev); 1075 xhci_zero_in_ctx(xhci, virt_dev);
1076}
1077
1078/* Deal with stalled endpoints. The core should have sent the control message
1079 * to clear the halt condition. However, we need to make the xHCI hardware
1080 * reset its sequence number, since a device will expect a sequence number of
1081 * zero after the halt condition is cleared.
1082 * Context: in_interrupt
1083 */
1084void xhci_endpoint_reset(struct usb_hcd *hcd,
1085 struct usb_host_endpoint *ep)
1086{
1087 struct xhci_hcd *xhci;
1088 struct usb_device *udev;
1089 unsigned int ep_index;
1090 unsigned long flags;
1091 int ret;
1092 struct xhci_dequeue_state deq_state;
1093 struct xhci_ring *ep_ring;
1094
1095 xhci = hcd_to_xhci(hcd);
1096 udev = (struct usb_device *) ep->hcpriv;
1097 /* Called with a root hub endpoint (or an endpoint that wasn't added
1098 * with xhci_add_endpoint()
1099 */
1100 if (!ep->hcpriv)
1101 return;
1102 ep_index = xhci_get_endpoint_index(&ep->desc);
1103 ep_ring = xhci->devs[udev->slot_id]->ep_rings[ep_index];
1104 if (!ep_ring->stopped_td) {
1105 xhci_dbg(xhci, "Endpoint 0x%x not halted, refusing to reset.\n",
1106 ep->desc.bEndpointAddress);
1107 return;
1108 }
1109
1110 xhci_dbg(xhci, "Queueing reset endpoint command\n");
1111 spin_lock_irqsave(&xhci->lock, flags);
1112 ret = xhci_queue_reset_ep(xhci, udev->slot_id, ep_index);
1113 /*
1114 * Can't change the ring dequeue pointer until it's transitioned to the
1115 * stopped state, which is only upon a successful reset endpoint
1116 * command. Better hope that last command worked!
1117 */
1118 if (!ret) {
1119 xhci_dbg(xhci, "Cleaning up stalled endpoint ring\n");
1120 /* We need to move the HW's dequeue pointer past this TD,
1121 * or it will attempt to resend it on the next doorbell ring.
1122 */
1123 xhci_find_new_dequeue_state(xhci, udev->slot_id,
1124 ep_index, ep_ring->stopped_td, &deq_state);
1125 xhci_dbg(xhci, "Queueing new dequeue state\n");
1126 xhci_queue_new_dequeue_state(xhci, ep_ring,
1127 udev->slot_id,
1128 ep_index, &deq_state);
1129 kfree(ep_ring->stopped_td);
1130 xhci_ring_cmd_db(xhci);
1131 }
1132 spin_unlock_irqrestore(&xhci->lock, flags);
1133
1134 if (ret)
1135 xhci_warn(xhci, "FIXME allocate a new ring segment\n");
1027} 1136}
1028 1137
1029/* 1138/*
@@ -1120,7 +1229,9 @@ int xhci_address_device(struct usb_hcd *hcd, struct usb_device *udev)
1120 struct xhci_virt_device *virt_dev; 1229 struct xhci_virt_device *virt_dev;
1121 int ret = 0; 1230 int ret = 0;
1122 struct xhci_hcd *xhci = hcd_to_xhci(hcd); 1231 struct xhci_hcd *xhci = hcd_to_xhci(hcd);
1123 u32 temp; 1232 struct xhci_slot_ctx *slot_ctx;
1233 struct xhci_input_control_ctx *ctrl_ctx;
1234 u64 temp_64;
1124 1235
1125 if (!udev->slot_id) { 1236 if (!udev->slot_id) {
1126 xhci_dbg(xhci, "Bad Slot ID %d\n", udev->slot_id); 1237 xhci_dbg(xhci, "Bad Slot ID %d\n", udev->slot_id);
@@ -1133,10 +1244,12 @@ int xhci_address_device(struct usb_hcd *hcd, struct usb_device *udev)
1133 if (!udev->config) 1244 if (!udev->config)
1134 xhci_setup_addressable_virt_dev(xhci, udev); 1245 xhci_setup_addressable_virt_dev(xhci, udev);
1135 /* Otherwise, assume the core has the device configured how it wants */ 1246 /* Otherwise, assume the core has the device configured how it wants */
1247 xhci_dbg(xhci, "Slot ID %d Input Context:\n", udev->slot_id);
1248 xhci_dbg_ctx(xhci, virt_dev->in_ctx, 2);
1136 1249
1137 spin_lock_irqsave(&xhci->lock, flags); 1250 spin_lock_irqsave(&xhci->lock, flags);
1138 ret = xhci_queue_address_device(xhci, virt_dev->in_ctx_dma, 1251 ret = xhci_queue_address_device(xhci, virt_dev->in_ctx->dma,
1139 udev->slot_id); 1252 udev->slot_id);
1140 if (ret) { 1253 if (ret) {
1141 spin_unlock_irqrestore(&xhci->lock, flags); 1254 spin_unlock_irqrestore(&xhci->lock, flags);
1142 xhci_dbg(xhci, "FIXME: allocate a command ring segment\n"); 1255 xhci_dbg(xhci, "FIXME: allocate a command ring segment\n");
@@ -1176,41 +1289,37 @@ int xhci_address_device(struct usb_hcd *hcd, struct usb_device *udev)
1176 default: 1289 default:
1177 xhci_err(xhci, "ERROR: unexpected command completion " 1290 xhci_err(xhci, "ERROR: unexpected command completion "
1178 "code 0x%x.\n", virt_dev->cmd_status); 1291 "code 0x%x.\n", virt_dev->cmd_status);
1292 xhci_dbg(xhci, "Slot ID %d Output Context:\n", udev->slot_id);
1293 xhci_dbg_ctx(xhci, virt_dev->out_ctx, 2);
1179 ret = -EINVAL; 1294 ret = -EINVAL;
1180 break; 1295 break;
1181 } 1296 }
1182 if (ret) { 1297 if (ret) {
1183 return ret; 1298 return ret;
1184 } 1299 }
1185 temp = xhci_readl(xhci, &xhci->op_regs->dcbaa_ptr[0]); 1300 temp_64 = xhci_read_64(xhci, &xhci->op_regs->dcbaa_ptr);
1186 xhci_dbg(xhci, "Op regs DCBAA ptr[0] = %#08x\n", temp); 1301 xhci_dbg(xhci, "Op regs DCBAA ptr = %#016llx\n", temp_64);
1187 temp = xhci_readl(xhci, &xhci->op_regs->dcbaa_ptr[1]); 1302 xhci_dbg(xhci, "Slot ID %d dcbaa entry @%p = %#016llx\n",
1188 xhci_dbg(xhci, "Op regs DCBAA ptr[1] = %#08x\n", temp);
1189 xhci_dbg(xhci, "Slot ID %d dcbaa entry[0] @%p = %#08x\n",
1190 udev->slot_id,
1191 &xhci->dcbaa->dev_context_ptrs[2*udev->slot_id],
1192 xhci->dcbaa->dev_context_ptrs[2*udev->slot_id]);
1193 xhci_dbg(xhci, "Slot ID %d dcbaa entry[1] @%p = %#08x\n",
1194 udev->slot_id, 1303 udev->slot_id,
1195 &xhci->dcbaa->dev_context_ptrs[2*udev->slot_id+1], 1304 &xhci->dcbaa->dev_context_ptrs[udev->slot_id],
1196 xhci->dcbaa->dev_context_ptrs[2*udev->slot_id+1]); 1305 (unsigned long long)
1306 xhci->dcbaa->dev_context_ptrs[udev->slot_id]);
1197 xhci_dbg(xhci, "Output Context DMA address = %#08llx\n", 1307 xhci_dbg(xhci, "Output Context DMA address = %#08llx\n",
1198 (unsigned long long)virt_dev->out_ctx_dma); 1308 (unsigned long long)virt_dev->out_ctx->dma);
1199 xhci_dbg(xhci, "Slot ID %d Input Context:\n", udev->slot_id); 1309 xhci_dbg(xhci, "Slot ID %d Input Context:\n", udev->slot_id);
1200 xhci_dbg_ctx(xhci, virt_dev->in_ctx, virt_dev->in_ctx_dma, 2); 1310 xhci_dbg_ctx(xhci, virt_dev->in_ctx, 2);
1201 xhci_dbg(xhci, "Slot ID %d Output Context:\n", udev->slot_id); 1311 xhci_dbg(xhci, "Slot ID %d Output Context:\n", udev->slot_id);
1202 xhci_dbg_ctx(xhci, virt_dev->out_ctx, virt_dev->out_ctx_dma, 2); 1312 xhci_dbg_ctx(xhci, virt_dev->out_ctx, 2);
1203 /* 1313 /*
1204 * USB core uses address 1 for the roothubs, so we add one to the 1314 * USB core uses address 1 for the roothubs, so we add one to the
1205 * address given back to us by the HC. 1315 * address given back to us by the HC.
1206 */ 1316 */
1207 udev->devnum = (virt_dev->out_ctx->slot.dev_state & DEV_ADDR_MASK) + 1; 1317 slot_ctx = xhci_get_slot_ctx(xhci, virt_dev->out_ctx);
1318 udev->devnum = (slot_ctx->dev_state & DEV_ADDR_MASK) + 1;
1208 /* Zero the input context control for later use */ 1319 /* Zero the input context control for later use */
1209 virt_dev->in_ctx->add_flags = 0; 1320 ctrl_ctx = xhci_get_input_control_ctx(xhci, virt_dev->in_ctx);
1210 virt_dev->in_ctx->drop_flags = 0; 1321 ctrl_ctx->add_flags = 0;
1211 /* Mirror flags in the output context for future ep enable/disable */ 1322 ctrl_ctx->drop_flags = 0;
1212 virt_dev->out_ctx->add_flags = SLOT_FLAG | EP0_FLAG;
1213 virt_dev->out_ctx->drop_flags = 0;
1214 1323
1215 xhci_dbg(xhci, "Device address = %d\n", udev->devnum); 1324 xhci_dbg(xhci, "Device address = %d\n", udev->devnum);
1216 /* XXX Meh, not sure if anyone else but choose_address uses this. */ 1325 /* XXX Meh, not sure if anyone else but choose_address uses this. */
@@ -1252,7 +1361,6 @@ static int __init xhci_hcd_init(void)
1252 /* xhci_device_control has eight fields, and also 1361 /* xhci_device_control has eight fields, and also
1253 * embeds one xhci_slot_ctx and 31 xhci_ep_ctx 1362 * embeds one xhci_slot_ctx and 31 xhci_ep_ctx
1254 */ 1363 */
1255 BUILD_BUG_ON(sizeof(struct xhci_device_control) != (8+8+8*31)*32/8);
1256 BUILD_BUG_ON(sizeof(struct xhci_stream_ctx) != 4*32/8); 1364 BUILD_BUG_ON(sizeof(struct xhci_stream_ctx) != 4*32/8);
1257 BUILD_BUG_ON(sizeof(union xhci_trb) != 4*32/8); 1365 BUILD_BUG_ON(sizeof(union xhci_trb) != 4*32/8);
1258 BUILD_BUG_ON(sizeof(struct xhci_erst_entry) != 4*32/8); 1366 BUILD_BUG_ON(sizeof(struct xhci_erst_entry) != 4*32/8);
diff --git a/drivers/usb/host/xhci-mem.c b/drivers/usb/host/xhci-mem.c
index c8a72de1c508..e6b9a1c6002d 100644
--- a/drivers/usb/host/xhci-mem.c
+++ b/drivers/usb/host/xhci-mem.c
@@ -88,7 +88,7 @@ static void xhci_link_segments(struct xhci_hcd *xhci, struct xhci_segment *prev,
88 return; 88 return;
89 prev->next = next; 89 prev->next = next;
90 if (link_trbs) { 90 if (link_trbs) {
91 prev->trbs[TRBS_PER_SEGMENT-1].link.segment_ptr[0] = next->dma; 91 prev->trbs[TRBS_PER_SEGMENT-1].link.segment_ptr = next->dma;
92 92
93 /* Set the last TRB in the segment to have a TRB type ID of Link TRB */ 93 /* Set the last TRB in the segment to have a TRB type ID of Link TRB */
94 val = prev->trbs[TRBS_PER_SEGMENT-1].link.control; 94 val = prev->trbs[TRBS_PER_SEGMENT-1].link.control;
@@ -189,6 +189,63 @@ fail:
189 return 0; 189 return 0;
190} 190}
191 191
192#define CTX_SIZE(_hcc) (HCC_64BYTE_CONTEXT(_hcc) ? 64 : 32)
193
194struct xhci_container_ctx *xhci_alloc_container_ctx(struct xhci_hcd *xhci,
195 int type, gfp_t flags)
196{
197 struct xhci_container_ctx *ctx = kzalloc(sizeof(*ctx), flags);
198 if (!ctx)
199 return NULL;
200
201 BUG_ON((type != XHCI_CTX_TYPE_DEVICE) && (type != XHCI_CTX_TYPE_INPUT));
202 ctx->type = type;
203 ctx->size = HCC_64BYTE_CONTEXT(xhci->hcc_params) ? 2048 : 1024;
204 if (type == XHCI_CTX_TYPE_INPUT)
205 ctx->size += CTX_SIZE(xhci->hcc_params);
206
207 ctx->bytes = dma_pool_alloc(xhci->device_pool, flags, &ctx->dma);
208 memset(ctx->bytes, 0, ctx->size);
209 return ctx;
210}
211
212void xhci_free_container_ctx(struct xhci_hcd *xhci,
213 struct xhci_container_ctx *ctx)
214{
215 dma_pool_free(xhci->device_pool, ctx->bytes, ctx->dma);
216 kfree(ctx);
217}
218
219struct xhci_input_control_ctx *xhci_get_input_control_ctx(struct xhci_hcd *xhci,
220 struct xhci_container_ctx *ctx)
221{
222 BUG_ON(ctx->type != XHCI_CTX_TYPE_INPUT);
223 return (struct xhci_input_control_ctx *)ctx->bytes;
224}
225
226struct xhci_slot_ctx *xhci_get_slot_ctx(struct xhci_hcd *xhci,
227 struct xhci_container_ctx *ctx)
228{
229 if (ctx->type == XHCI_CTX_TYPE_DEVICE)
230 return (struct xhci_slot_ctx *)ctx->bytes;
231
232 return (struct xhci_slot_ctx *)
233 (ctx->bytes + CTX_SIZE(xhci->hcc_params));
234}
235
236struct xhci_ep_ctx *xhci_get_ep_ctx(struct xhci_hcd *xhci,
237 struct xhci_container_ctx *ctx,
238 unsigned int ep_index)
239{
240 /* increment ep index by offset of start of ep ctx array */
241 ep_index++;
242 if (ctx->type == XHCI_CTX_TYPE_INPUT)
243 ep_index++;
244
245 return (struct xhci_ep_ctx *)
246 (ctx->bytes + (ep_index * CTX_SIZE(xhci->hcc_params)));
247}
248
192/* All the xhci_tds in the ring's TD list should be freed at this point */ 249/* All the xhci_tds in the ring's TD list should be freed at this point */
193void xhci_free_virt_device(struct xhci_hcd *xhci, int slot_id) 250void xhci_free_virt_device(struct xhci_hcd *xhci, int slot_id)
194{ 251{
@@ -200,8 +257,7 @@ void xhci_free_virt_device(struct xhci_hcd *xhci, int slot_id)
200 return; 257 return;
201 258
202 dev = xhci->devs[slot_id]; 259 dev = xhci->devs[slot_id];
203 xhci->dcbaa->dev_context_ptrs[2*slot_id] = 0; 260 xhci->dcbaa->dev_context_ptrs[slot_id] = 0;
204 xhci->dcbaa->dev_context_ptrs[2*slot_id + 1] = 0;
205 if (!dev) 261 if (!dev)
206 return; 262 return;
207 263
@@ -210,11 +266,10 @@ void xhci_free_virt_device(struct xhci_hcd *xhci, int slot_id)
210 xhci_ring_free(xhci, dev->ep_rings[i]); 266 xhci_ring_free(xhci, dev->ep_rings[i]);
211 267
212 if (dev->in_ctx) 268 if (dev->in_ctx)
213 dma_pool_free(xhci->device_pool, 269 xhci_free_container_ctx(xhci, dev->in_ctx);
214 dev->in_ctx, dev->in_ctx_dma);
215 if (dev->out_ctx) 270 if (dev->out_ctx)
216 dma_pool_free(xhci->device_pool, 271 xhci_free_container_ctx(xhci, dev->out_ctx);
217 dev->out_ctx, dev->out_ctx_dma); 272
218 kfree(xhci->devs[slot_id]); 273 kfree(xhci->devs[slot_id]);
219 xhci->devs[slot_id] = 0; 274 xhci->devs[slot_id] = 0;
220} 275}
@@ -222,7 +277,6 @@ void xhci_free_virt_device(struct xhci_hcd *xhci, int slot_id)
222int xhci_alloc_virt_device(struct xhci_hcd *xhci, int slot_id, 277int xhci_alloc_virt_device(struct xhci_hcd *xhci, int slot_id,
223 struct usb_device *udev, gfp_t flags) 278 struct usb_device *udev, gfp_t flags)
224{ 279{
225 dma_addr_t dma;
226 struct xhci_virt_device *dev; 280 struct xhci_virt_device *dev;
227 281
228 /* Slot ID 0 is reserved */ 282 /* Slot ID 0 is reserved */
@@ -236,23 +290,21 @@ int xhci_alloc_virt_device(struct xhci_hcd *xhci, int slot_id,
236 return 0; 290 return 0;
237 dev = xhci->devs[slot_id]; 291 dev = xhci->devs[slot_id];
238 292
239 /* Allocate the (output) device context that will be used in the HC */ 293 /* Allocate the (output) device context that will be used in the HC. */
240 dev->out_ctx = dma_pool_alloc(xhci->device_pool, flags, &dma); 294 dev->out_ctx = xhci_alloc_container_ctx(xhci, XHCI_CTX_TYPE_DEVICE, flags);
241 if (!dev->out_ctx) 295 if (!dev->out_ctx)
242 goto fail; 296 goto fail;
243 dev->out_ctx_dma = dma; 297
244 xhci_dbg(xhci, "Slot %d output ctx = 0x%llx (dma)\n", slot_id, 298 xhci_dbg(xhci, "Slot %d output ctx = 0x%llx (dma)\n", slot_id,
245 (unsigned long long)dma); 299 (unsigned long long)dev->out_ctx->dma);
246 memset(dev->out_ctx, 0, sizeof(*dev->out_ctx));
247 300
248 /* Allocate the (input) device context for address device command */ 301 /* Allocate the (input) device context for address device command */
249 dev->in_ctx = dma_pool_alloc(xhci->device_pool, flags, &dma); 302 dev->in_ctx = xhci_alloc_container_ctx(xhci, XHCI_CTX_TYPE_INPUT, flags);
250 if (!dev->in_ctx) 303 if (!dev->in_ctx)
251 goto fail; 304 goto fail;
252 dev->in_ctx_dma = dma; 305
253 xhci_dbg(xhci, "Slot %d input ctx = 0x%llx (dma)\n", slot_id, 306 xhci_dbg(xhci, "Slot %d input ctx = 0x%llx (dma)\n", slot_id,
254 (unsigned long long)dma); 307 (unsigned long long)dev->in_ctx->dma);
255 memset(dev->in_ctx, 0, sizeof(*dev->in_ctx));
256 308
257 /* Allocate endpoint 0 ring */ 309 /* Allocate endpoint 0 ring */
258 dev->ep_rings[0] = xhci_ring_alloc(xhci, 1, true, flags); 310 dev->ep_rings[0] = xhci_ring_alloc(xhci, 1, true, flags);
@@ -261,17 +313,12 @@ int xhci_alloc_virt_device(struct xhci_hcd *xhci, int slot_id,
261 313
262 init_completion(&dev->cmd_completion); 314 init_completion(&dev->cmd_completion);
263 315
264 /* 316 /* Point to output device context in dcbaa. */
265 * Point to output device context in dcbaa; skip the output control 317 xhci->dcbaa->dev_context_ptrs[slot_id] = dev->out_ctx->dma;
266 * context, which is eight 32 bit fields (or 32 bytes long)
267 */
268 xhci->dcbaa->dev_context_ptrs[2*slot_id] =
269 (u32) dev->out_ctx_dma + (32);
270 xhci_dbg(xhci, "Set slot id %d dcbaa entry %p to 0x%llx\n", 318 xhci_dbg(xhci, "Set slot id %d dcbaa entry %p to 0x%llx\n",
271 slot_id, 319 slot_id,
272 &xhci->dcbaa->dev_context_ptrs[2*slot_id], 320 &xhci->dcbaa->dev_context_ptrs[slot_id],
273 (unsigned long long)dev->out_ctx_dma); 321 (unsigned long long) xhci->dcbaa->dev_context_ptrs[slot_id]);
274 xhci->dcbaa->dev_context_ptrs[2*slot_id + 1] = 0;
275 322
276 return 1; 323 return 1;
277fail: 324fail:
@@ -285,6 +332,8 @@ int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *ud
285 struct xhci_virt_device *dev; 332 struct xhci_virt_device *dev;
286 struct xhci_ep_ctx *ep0_ctx; 333 struct xhci_ep_ctx *ep0_ctx;
287 struct usb_device *top_dev; 334 struct usb_device *top_dev;
335 struct xhci_slot_ctx *slot_ctx;
336 struct xhci_input_control_ctx *ctrl_ctx;
288 337
289 dev = xhci->devs[udev->slot_id]; 338 dev = xhci->devs[udev->slot_id];
290 /* Slot ID 0 is reserved */ 339 /* Slot ID 0 is reserved */
@@ -293,27 +342,29 @@ int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *ud
293 udev->slot_id); 342 udev->slot_id);
294 return -EINVAL; 343 return -EINVAL;
295 } 344 }
296 ep0_ctx = &dev->in_ctx->ep[0]; 345 ep0_ctx = xhci_get_ep_ctx(xhci, dev->in_ctx, 0);
346 ctrl_ctx = xhci_get_input_control_ctx(xhci, dev->in_ctx);
347 slot_ctx = xhci_get_slot_ctx(xhci, dev->in_ctx);
297 348
298 /* 2) New slot context and endpoint 0 context are valid*/ 349 /* 2) New slot context and endpoint 0 context are valid*/
299 dev->in_ctx->add_flags = SLOT_FLAG | EP0_FLAG; 350 ctrl_ctx->add_flags = SLOT_FLAG | EP0_FLAG;
300 351
301 /* 3) Only the control endpoint is valid - one endpoint context */ 352 /* 3) Only the control endpoint is valid - one endpoint context */
302 dev->in_ctx->slot.dev_info |= LAST_CTX(1); 353 slot_ctx->dev_info |= LAST_CTX(1);
303 354
304 switch (udev->speed) { 355 switch (udev->speed) {
305 case USB_SPEED_SUPER: 356 case USB_SPEED_SUPER:
306 dev->in_ctx->slot.dev_info |= (u32) udev->route; 357 slot_ctx->dev_info |= (u32) udev->route;
307 dev->in_ctx->slot.dev_info |= (u32) SLOT_SPEED_SS; 358 slot_ctx->dev_info |= (u32) SLOT_SPEED_SS;
308 break; 359 break;
309 case USB_SPEED_HIGH: 360 case USB_SPEED_HIGH:
310 dev->in_ctx->slot.dev_info |= (u32) SLOT_SPEED_HS; 361 slot_ctx->dev_info |= (u32) SLOT_SPEED_HS;
311 break; 362 break;
312 case USB_SPEED_FULL: 363 case USB_SPEED_FULL:
313 dev->in_ctx->slot.dev_info |= (u32) SLOT_SPEED_FS; 364 slot_ctx->dev_info |= (u32) SLOT_SPEED_FS;
314 break; 365 break;
315 case USB_SPEED_LOW: 366 case USB_SPEED_LOW:
316 dev->in_ctx->slot.dev_info |= (u32) SLOT_SPEED_LS; 367 slot_ctx->dev_info |= (u32) SLOT_SPEED_LS;
317 break; 368 break;
318 case USB_SPEED_VARIABLE: 369 case USB_SPEED_VARIABLE:
319 xhci_dbg(xhci, "FIXME xHCI doesn't support wireless speeds\n"); 370 xhci_dbg(xhci, "FIXME xHCI doesn't support wireless speeds\n");
@@ -327,7 +378,7 @@ int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *ud
327 for (top_dev = udev; top_dev->parent && top_dev->parent->parent; 378 for (top_dev = udev; top_dev->parent && top_dev->parent->parent;
328 top_dev = top_dev->parent) 379 top_dev = top_dev->parent)
329 /* Found device below root hub */; 380 /* Found device below root hub */;
330 dev->in_ctx->slot.dev_info2 |= (u32) ROOT_HUB_PORT(top_dev->portnum); 381 slot_ctx->dev_info2 |= (u32) ROOT_HUB_PORT(top_dev->portnum);
331 xhci_dbg(xhci, "Set root hub portnum to %d\n", top_dev->portnum); 382 xhci_dbg(xhci, "Set root hub portnum to %d\n", top_dev->portnum);
332 383
333 /* Is this a LS/FS device under a HS hub? */ 384 /* Is this a LS/FS device under a HS hub? */
@@ -337,8 +388,8 @@ int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *ud
337 */ 388 */
338 if ((udev->speed == USB_SPEED_LOW || udev->speed == USB_SPEED_FULL) && 389 if ((udev->speed == USB_SPEED_LOW || udev->speed == USB_SPEED_FULL) &&
339 udev->tt) { 390 udev->tt) {
340 dev->in_ctx->slot.tt_info = udev->tt->hub->slot_id; 391 slot_ctx->tt_info = udev->tt->hub->slot_id;
341 dev->in_ctx->slot.tt_info |= udev->ttport << 8; 392 slot_ctx->tt_info |= udev->ttport << 8;
342 } 393 }
343 xhci_dbg(xhci, "udev->tt = %p\n", udev->tt); 394 xhci_dbg(xhci, "udev->tt = %p\n", udev->tt);
344 xhci_dbg(xhci, "udev->ttport = 0x%x\n", udev->ttport); 395 xhci_dbg(xhci, "udev->ttport = 0x%x\n", udev->ttport);
@@ -360,10 +411,9 @@ int xhci_setup_addressable_virt_dev(struct xhci_hcd *xhci, struct usb_device *ud
360 ep0_ctx->ep_info2 |= MAX_BURST(0); 411 ep0_ctx->ep_info2 |= MAX_BURST(0);
361 ep0_ctx->ep_info2 |= ERROR_COUNT(3); 412 ep0_ctx->ep_info2 |= ERROR_COUNT(3);
362 413
363 ep0_ctx->deq[0] = 414 ep0_ctx->deq =
364 dev->ep_rings[0]->first_seg->dma; 415 dev->ep_rings[0]->first_seg->dma;
365 ep0_ctx->deq[0] |= dev->ep_rings[0]->cycle_state; 416 ep0_ctx->deq |= dev->ep_rings[0]->cycle_state;
366 ep0_ctx->deq[1] = 0;
367 417
368 /* Steps 7 and 8 were done in xhci_alloc_virt_device() */ 418 /* Steps 7 and 8 were done in xhci_alloc_virt_device() */
369 419
@@ -470,25 +520,26 @@ int xhci_endpoint_init(struct xhci_hcd *xhci,
470 unsigned int max_burst; 520 unsigned int max_burst;
471 521
472 ep_index = xhci_get_endpoint_index(&ep->desc); 522 ep_index = xhci_get_endpoint_index(&ep->desc);
473 ep_ctx = &virt_dev->in_ctx->ep[ep_index]; 523 ep_ctx = xhci_get_ep_ctx(xhci, virt_dev->in_ctx, ep_index);
474 524
475 /* Set up the endpoint ring */ 525 /* Set up the endpoint ring */
476 virt_dev->new_ep_rings[ep_index] = xhci_ring_alloc(xhci, 1, true, mem_flags); 526 virt_dev->new_ep_rings[ep_index] = xhci_ring_alloc(xhci, 1, true, mem_flags);
477 if (!virt_dev->new_ep_rings[ep_index]) 527 if (!virt_dev->new_ep_rings[ep_index])
478 return -ENOMEM; 528 return -ENOMEM;
479 ep_ring = virt_dev->new_ep_rings[ep_index]; 529 ep_ring = virt_dev->new_ep_rings[ep_index];
480 ep_ctx->deq[0] = ep_ring->first_seg->dma | ep_ring->cycle_state; 530 ep_ctx->deq = ep_ring->first_seg->dma | ep_ring->cycle_state;
481 ep_ctx->deq[1] = 0;
482 531
483 ep_ctx->ep_info = xhci_get_endpoint_interval(udev, ep); 532 ep_ctx->ep_info = xhci_get_endpoint_interval(udev, ep);
484 533
485 /* FIXME dig Mult and streams info out of ep companion desc */ 534 /* FIXME dig Mult and streams info out of ep companion desc */
486 535
487 /* Allow 3 retries for everything but isoc */ 536 /* Allow 3 retries for everything but isoc;
537 * error count = 0 means infinite retries.
538 */
488 if (!usb_endpoint_xfer_isoc(&ep->desc)) 539 if (!usb_endpoint_xfer_isoc(&ep->desc))
489 ep_ctx->ep_info2 = ERROR_COUNT(3); 540 ep_ctx->ep_info2 = ERROR_COUNT(3);
490 else 541 else
491 ep_ctx->ep_info2 = ERROR_COUNT(0); 542 ep_ctx->ep_info2 = ERROR_COUNT(1);
492 543
493 ep_ctx->ep_info2 |= xhci_get_endpoint_type(udev, ep); 544 ep_ctx->ep_info2 |= xhci_get_endpoint_type(udev, ep);
494 545
@@ -498,7 +549,12 @@ int xhci_endpoint_init(struct xhci_hcd *xhci,
498 max_packet = ep->desc.wMaxPacketSize; 549 max_packet = ep->desc.wMaxPacketSize;
499 ep_ctx->ep_info2 |= MAX_PACKET(max_packet); 550 ep_ctx->ep_info2 |= MAX_PACKET(max_packet);
500 /* dig out max burst from ep companion desc */ 551 /* dig out max burst from ep companion desc */
501 max_packet = ep->ss_ep_comp->desc.bMaxBurst; 552 if (!ep->ss_ep_comp) {
553 xhci_warn(xhci, "WARN no SS endpoint companion descriptor.\n");
554 max_packet = 0;
555 } else {
556 max_packet = ep->ss_ep_comp->desc.bMaxBurst;
557 }
502 ep_ctx->ep_info2 |= MAX_BURST(max_packet); 558 ep_ctx->ep_info2 |= MAX_BURST(max_packet);
503 break; 559 break;
504 case USB_SPEED_HIGH: 560 case USB_SPEED_HIGH:
@@ -531,18 +587,114 @@ void xhci_endpoint_zero(struct xhci_hcd *xhci,
531 struct xhci_ep_ctx *ep_ctx; 587 struct xhci_ep_ctx *ep_ctx;
532 588
533 ep_index = xhci_get_endpoint_index(&ep->desc); 589 ep_index = xhci_get_endpoint_index(&ep->desc);
534 ep_ctx = &virt_dev->in_ctx->ep[ep_index]; 590 ep_ctx = xhci_get_ep_ctx(xhci, virt_dev->in_ctx, ep_index);
535 591
536 ep_ctx->ep_info = 0; 592 ep_ctx->ep_info = 0;
537 ep_ctx->ep_info2 = 0; 593 ep_ctx->ep_info2 = 0;
538 ep_ctx->deq[0] = 0; 594 ep_ctx->deq = 0;
539 ep_ctx->deq[1] = 0;
540 ep_ctx->tx_info = 0; 595 ep_ctx->tx_info = 0;
541 /* Don't free the endpoint ring until the set interface or configuration 596 /* Don't free the endpoint ring until the set interface or configuration
542 * request succeeds. 597 * request succeeds.
543 */ 598 */
544} 599}
545 600
601/* Set up the scratchpad buffer array and scratchpad buffers, if needed. */
602static int scratchpad_alloc(struct xhci_hcd *xhci, gfp_t flags)
603{
604 int i;
605 struct device *dev = xhci_to_hcd(xhci)->self.controller;
606 int num_sp = HCS_MAX_SCRATCHPAD(xhci->hcs_params2);
607
608 xhci_dbg(xhci, "Allocating %d scratchpad buffers\n", num_sp);
609
610 if (!num_sp)
611 return 0;
612
613 xhci->scratchpad = kzalloc(sizeof(*xhci->scratchpad), flags);
614 if (!xhci->scratchpad)
615 goto fail_sp;
616
617 xhci->scratchpad->sp_array =
618 pci_alloc_consistent(to_pci_dev(dev),
619 num_sp * sizeof(u64),
620 &xhci->scratchpad->sp_dma);
621 if (!xhci->scratchpad->sp_array)
622 goto fail_sp2;
623
624 xhci->scratchpad->sp_buffers = kzalloc(sizeof(void *) * num_sp, flags);
625 if (!xhci->scratchpad->sp_buffers)
626 goto fail_sp3;
627
628 xhci->scratchpad->sp_dma_buffers =
629 kzalloc(sizeof(dma_addr_t) * num_sp, flags);
630
631 if (!xhci->scratchpad->sp_dma_buffers)
632 goto fail_sp4;
633
634 xhci->dcbaa->dev_context_ptrs[0] = xhci->scratchpad->sp_dma;
635 for (i = 0; i < num_sp; i++) {
636 dma_addr_t dma;
637 void *buf = pci_alloc_consistent(to_pci_dev(dev),
638 xhci->page_size, &dma);
639 if (!buf)
640 goto fail_sp5;
641
642 xhci->scratchpad->sp_array[i] = dma;
643 xhci->scratchpad->sp_buffers[i] = buf;
644 xhci->scratchpad->sp_dma_buffers[i] = dma;
645 }
646
647 return 0;
648
649 fail_sp5:
650 for (i = i - 1; i >= 0; i--) {
651 pci_free_consistent(to_pci_dev(dev), xhci->page_size,
652 xhci->scratchpad->sp_buffers[i],
653 xhci->scratchpad->sp_dma_buffers[i]);
654 }
655 kfree(xhci->scratchpad->sp_dma_buffers);
656
657 fail_sp4:
658 kfree(xhci->scratchpad->sp_buffers);
659
660 fail_sp3:
661 pci_free_consistent(to_pci_dev(dev), num_sp * sizeof(u64),
662 xhci->scratchpad->sp_array,
663 xhci->scratchpad->sp_dma);
664
665 fail_sp2:
666 kfree(xhci->scratchpad);
667 xhci->scratchpad = NULL;
668
669 fail_sp:
670 return -ENOMEM;
671}
672
673static void scratchpad_free(struct xhci_hcd *xhci)
674{
675 int num_sp;
676 int i;
677 struct pci_dev *pdev = to_pci_dev(xhci_to_hcd(xhci)->self.controller);
678
679 if (!xhci->scratchpad)
680 return;
681
682 num_sp = HCS_MAX_SCRATCHPAD(xhci->hcs_params2);
683
684 for (i = 0; i < num_sp; i++) {
685 pci_free_consistent(pdev, xhci->page_size,
686 xhci->scratchpad->sp_buffers[i],
687 xhci->scratchpad->sp_dma_buffers[i]);
688 }
689 kfree(xhci->scratchpad->sp_dma_buffers);
690 kfree(xhci->scratchpad->sp_buffers);
691 pci_free_consistent(pdev, num_sp * sizeof(u64),
692 xhci->scratchpad->sp_array,
693 xhci->scratchpad->sp_dma);
694 kfree(xhci->scratchpad);
695 xhci->scratchpad = NULL;
696}
697
546void xhci_mem_cleanup(struct xhci_hcd *xhci) 698void xhci_mem_cleanup(struct xhci_hcd *xhci)
547{ 699{
548 struct pci_dev *pdev = to_pci_dev(xhci_to_hcd(xhci)->self.controller); 700 struct pci_dev *pdev = to_pci_dev(xhci_to_hcd(xhci)->self.controller);
@@ -551,10 +703,8 @@ void xhci_mem_cleanup(struct xhci_hcd *xhci)
551 703
552 /* Free the Event Ring Segment Table and the actual Event Ring */ 704 /* Free the Event Ring Segment Table and the actual Event Ring */
553 xhci_writel(xhci, 0, &xhci->ir_set->erst_size); 705 xhci_writel(xhci, 0, &xhci->ir_set->erst_size);
554 xhci_writel(xhci, 0, &xhci->ir_set->erst_base[0]); 706 xhci_write_64(xhci, 0, &xhci->ir_set->erst_base);
555 xhci_writel(xhci, 0, &xhci->ir_set->erst_base[1]); 707 xhci_write_64(xhci, 0, &xhci->ir_set->erst_dequeue);
556 xhci_writel(xhci, 0, &xhci->ir_set->erst_dequeue[0]);
557 xhci_writel(xhci, 0, &xhci->ir_set->erst_dequeue[1]);
558 size = sizeof(struct xhci_erst_entry)*(xhci->erst.num_entries); 708 size = sizeof(struct xhci_erst_entry)*(xhci->erst.num_entries);
559 if (xhci->erst.entries) 709 if (xhci->erst.entries)
560 pci_free_consistent(pdev, size, 710 pci_free_consistent(pdev, size,
@@ -566,8 +716,7 @@ void xhci_mem_cleanup(struct xhci_hcd *xhci)
566 xhci->event_ring = NULL; 716 xhci->event_ring = NULL;
567 xhci_dbg(xhci, "Freed event ring\n"); 717 xhci_dbg(xhci, "Freed event ring\n");
568 718
569 xhci_writel(xhci, 0, &xhci->op_regs->cmd_ring[0]); 719 xhci_write_64(xhci, 0, &xhci->op_regs->cmd_ring);
570 xhci_writel(xhci, 0, &xhci->op_regs->cmd_ring[1]);
571 if (xhci->cmd_ring) 720 if (xhci->cmd_ring)
572 xhci_ring_free(xhci, xhci->cmd_ring); 721 xhci_ring_free(xhci, xhci->cmd_ring);
573 xhci->cmd_ring = NULL; 722 xhci->cmd_ring = NULL;
@@ -586,8 +735,7 @@ void xhci_mem_cleanup(struct xhci_hcd *xhci)
586 xhci->device_pool = NULL; 735 xhci->device_pool = NULL;
587 xhci_dbg(xhci, "Freed device context pool\n"); 736 xhci_dbg(xhci, "Freed device context pool\n");
588 737
589 xhci_writel(xhci, 0, &xhci->op_regs->dcbaa_ptr[0]); 738 xhci_write_64(xhci, 0, &xhci->op_regs->dcbaa_ptr);
590 xhci_writel(xhci, 0, &xhci->op_regs->dcbaa_ptr[1]);
591 if (xhci->dcbaa) 739 if (xhci->dcbaa)
592 pci_free_consistent(pdev, sizeof(*xhci->dcbaa), 740 pci_free_consistent(pdev, sizeof(*xhci->dcbaa),
593 xhci->dcbaa, xhci->dcbaa->dma); 741 xhci->dcbaa, xhci->dcbaa->dma);
@@ -595,6 +743,7 @@ void xhci_mem_cleanup(struct xhci_hcd *xhci)
595 743
596 xhci->page_size = 0; 744 xhci->page_size = 0;
597 xhci->page_shift = 0; 745 xhci->page_shift = 0;
746 scratchpad_free(xhci);
598} 747}
599 748
600int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags) 749int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags)
@@ -602,6 +751,7 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags)
602 dma_addr_t dma; 751 dma_addr_t dma;
603 struct device *dev = xhci_to_hcd(xhci)->self.controller; 752 struct device *dev = xhci_to_hcd(xhci)->self.controller;
604 unsigned int val, val2; 753 unsigned int val, val2;
754 u64 val_64;
605 struct xhci_segment *seg; 755 struct xhci_segment *seg;
606 u32 page_size; 756 u32 page_size;
607 int i; 757 int i;
@@ -647,8 +797,7 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags)
647 xhci->dcbaa->dma = dma; 797 xhci->dcbaa->dma = dma;
648 xhci_dbg(xhci, "// Device context base array address = 0x%llx (DMA), %p (virt)\n", 798 xhci_dbg(xhci, "// Device context base array address = 0x%llx (DMA), %p (virt)\n",
649 (unsigned long long)xhci->dcbaa->dma, xhci->dcbaa); 799 (unsigned long long)xhci->dcbaa->dma, xhci->dcbaa);
650 xhci_writel(xhci, dma, &xhci->op_regs->dcbaa_ptr[0]); 800 xhci_write_64(xhci, dma, &xhci->op_regs->dcbaa_ptr);
651 xhci_writel(xhci, (u32) 0, &xhci->op_regs->dcbaa_ptr[1]);
652 801
653 /* 802 /*
654 * Initialize the ring segment pool. The ring must be a contiguous 803 * Initialize the ring segment pool. The ring must be a contiguous
@@ -658,11 +807,10 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags)
658 */ 807 */
659 xhci->segment_pool = dma_pool_create("xHCI ring segments", dev, 808 xhci->segment_pool = dma_pool_create("xHCI ring segments", dev,
660 SEGMENT_SIZE, 64, xhci->page_size); 809 SEGMENT_SIZE, 64, xhci->page_size);
810
661 /* See Table 46 and Note on Figure 55 */ 811 /* See Table 46 and Note on Figure 55 */
662 /* FIXME support 64-byte contexts */
663 xhci->device_pool = dma_pool_create("xHCI input/output contexts", dev, 812 xhci->device_pool = dma_pool_create("xHCI input/output contexts", dev,
664 sizeof(struct xhci_device_control), 813 2112, 64, xhci->page_size);
665 64, xhci->page_size);
666 if (!xhci->segment_pool || !xhci->device_pool) 814 if (!xhci->segment_pool || !xhci->device_pool)
667 goto fail; 815 goto fail;
668 816
@@ -675,14 +823,12 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags)
675 (unsigned long long)xhci->cmd_ring->first_seg->dma); 823 (unsigned long long)xhci->cmd_ring->first_seg->dma);
676 824
677 /* Set the address in the Command Ring Control register */ 825 /* Set the address in the Command Ring Control register */
678 val = xhci_readl(xhci, &xhci->op_regs->cmd_ring[0]); 826 val_64 = xhci_read_64(xhci, &xhci->op_regs->cmd_ring);
679 val = (val & ~CMD_RING_ADDR_MASK) | 827 val_64 = (val_64 & (u64) CMD_RING_RSVD_BITS) |
680 (xhci->cmd_ring->first_seg->dma & CMD_RING_ADDR_MASK) | 828 (xhci->cmd_ring->first_seg->dma & (u64) ~CMD_RING_RSVD_BITS) |
681 xhci->cmd_ring->cycle_state; 829 xhci->cmd_ring->cycle_state;
682 xhci_dbg(xhci, "// Setting command ring address low bits to 0x%x\n", val); 830 xhci_dbg(xhci, "// Setting command ring address to 0x%x\n", val);
683 xhci_writel(xhci, val, &xhci->op_regs->cmd_ring[0]); 831 xhci_write_64(xhci, val_64, &xhci->op_regs->cmd_ring);
684 xhci_dbg(xhci, "// Setting command ring address high bits to 0x0\n");
685 xhci_writel(xhci, (u32) 0, &xhci->op_regs->cmd_ring[1]);
686 xhci_dbg_cmd_ptrs(xhci); 832 xhci_dbg_cmd_ptrs(xhci);
687 833
688 val = xhci_readl(xhci, &xhci->cap_regs->db_off); 834 val = xhci_readl(xhci, &xhci->cap_regs->db_off);
@@ -722,8 +868,7 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags)
722 /* set ring base address and size for each segment table entry */ 868 /* set ring base address and size for each segment table entry */
723 for (val = 0, seg = xhci->event_ring->first_seg; val < ERST_NUM_SEGS; val++) { 869 for (val = 0, seg = xhci->event_ring->first_seg; val < ERST_NUM_SEGS; val++) {
724 struct xhci_erst_entry *entry = &xhci->erst.entries[val]; 870 struct xhci_erst_entry *entry = &xhci->erst.entries[val];
725 entry->seg_addr[0] = seg->dma; 871 entry->seg_addr = seg->dma;
726 entry->seg_addr[1] = 0;
727 entry->seg_size = TRBS_PER_SEGMENT; 872 entry->seg_size = TRBS_PER_SEGMENT;
728 entry->rsvd = 0; 873 entry->rsvd = 0;
729 seg = seg->next; 874 seg = seg->next;
@@ -741,11 +886,10 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags)
741 /* set the segment table base address */ 886 /* set the segment table base address */
742 xhci_dbg(xhci, "// Set ERST base address for ir_set 0 = 0x%llx\n", 887 xhci_dbg(xhci, "// Set ERST base address for ir_set 0 = 0x%llx\n",
743 (unsigned long long)xhci->erst.erst_dma_addr); 888 (unsigned long long)xhci->erst.erst_dma_addr);
744 val = xhci_readl(xhci, &xhci->ir_set->erst_base[0]); 889 val_64 = xhci_read_64(xhci, &xhci->ir_set->erst_base);
745 val &= ERST_PTR_MASK; 890 val_64 &= ERST_PTR_MASK;
746 val |= (xhci->erst.erst_dma_addr & ~ERST_PTR_MASK); 891 val_64 |= (xhci->erst.erst_dma_addr & (u64) ~ERST_PTR_MASK);
747 xhci_writel(xhci, val, &xhci->ir_set->erst_base[0]); 892 xhci_write_64(xhci, val_64, &xhci->ir_set->erst_base);
748 xhci_writel(xhci, 0, &xhci->ir_set->erst_base[1]);
749 893
750 /* Set the event ring dequeue address */ 894 /* Set the event ring dequeue address */
751 xhci_set_hc_event_deq(xhci); 895 xhci_set_hc_event_deq(xhci);
@@ -761,7 +905,11 @@ int xhci_mem_init(struct xhci_hcd *xhci, gfp_t flags)
761 for (i = 0; i < MAX_HC_SLOTS; ++i) 905 for (i = 0; i < MAX_HC_SLOTS; ++i)
762 xhci->devs[i] = 0; 906 xhci->devs[i] = 0;
763 907
908 if (scratchpad_alloc(xhci, flags))
909 goto fail;
910
764 return 0; 911 return 0;
912
765fail: 913fail:
766 xhci_warn(xhci, "Couldn't initialize memory\n"); 914 xhci_warn(xhci, "Couldn't initialize memory\n");
767 xhci_mem_cleanup(xhci); 915 xhci_mem_cleanup(xhci);
diff --git a/drivers/usb/host/xhci-pci.c b/drivers/usb/host/xhci-pci.c
index 1462709e26c0..592fe7e623f7 100644
--- a/drivers/usb/host/xhci-pci.c
+++ b/drivers/usb/host/xhci-pci.c
@@ -117,6 +117,7 @@ static const struct hc_driver xhci_pci_hc_driver = {
117 .free_dev = xhci_free_dev, 117 .free_dev = xhci_free_dev,
118 .add_endpoint = xhci_add_endpoint, 118 .add_endpoint = xhci_add_endpoint,
119 .drop_endpoint = xhci_drop_endpoint, 119 .drop_endpoint = xhci_drop_endpoint,
120 .endpoint_reset = xhci_endpoint_reset,
120 .check_bandwidth = xhci_check_bandwidth, 121 .check_bandwidth = xhci_check_bandwidth,
121 .reset_bandwidth = xhci_reset_bandwidth, 122 .reset_bandwidth = xhci_reset_bandwidth,
122 .address_device = xhci_address_device, 123 .address_device = xhci_address_device,
diff --git a/drivers/usb/host/xhci-ring.c b/drivers/usb/host/xhci-ring.c
index 02d81985c454..aa88a067148b 100644
--- a/drivers/usb/host/xhci-ring.c
+++ b/drivers/usb/host/xhci-ring.c
@@ -135,6 +135,7 @@ static void next_trb(struct xhci_hcd *xhci,
135static void inc_deq(struct xhci_hcd *xhci, struct xhci_ring *ring, bool consumer) 135static void inc_deq(struct xhci_hcd *xhci, struct xhci_ring *ring, bool consumer)
136{ 136{
137 union xhci_trb *next = ++(ring->dequeue); 137 union xhci_trb *next = ++(ring->dequeue);
138 unsigned long long addr;
138 139
139 ring->deq_updates++; 140 ring->deq_updates++;
140 /* Update the dequeue pointer further if that was a link TRB or we're at 141 /* Update the dequeue pointer further if that was a link TRB or we're at
@@ -152,6 +153,13 @@ static void inc_deq(struct xhci_hcd *xhci, struct xhci_ring *ring, bool consumer
152 ring->dequeue = ring->deq_seg->trbs; 153 ring->dequeue = ring->deq_seg->trbs;
153 next = ring->dequeue; 154 next = ring->dequeue;
154 } 155 }
156 addr = (unsigned long long) xhci_trb_virt_to_dma(ring->deq_seg, ring->dequeue);
157 if (ring == xhci->event_ring)
158 xhci_dbg(xhci, "Event ring deq = 0x%llx (DMA)\n", addr);
159 else if (ring == xhci->cmd_ring)
160 xhci_dbg(xhci, "Command ring deq = 0x%llx (DMA)\n", addr);
161 else
162 xhci_dbg(xhci, "Ring deq = 0x%llx (DMA)\n", addr);
155} 163}
156 164
157/* 165/*
@@ -171,6 +179,7 @@ static void inc_enq(struct xhci_hcd *xhci, struct xhci_ring *ring, bool consumer
171{ 179{
172 u32 chain; 180 u32 chain;
173 union xhci_trb *next; 181 union xhci_trb *next;
182 unsigned long long addr;
174 183
175 chain = ring->enqueue->generic.field[3] & TRB_CHAIN; 184 chain = ring->enqueue->generic.field[3] & TRB_CHAIN;
176 next = ++(ring->enqueue); 185 next = ++(ring->enqueue);
@@ -204,6 +213,13 @@ static void inc_enq(struct xhci_hcd *xhci, struct xhci_ring *ring, bool consumer
204 ring->enqueue = ring->enq_seg->trbs; 213 ring->enqueue = ring->enq_seg->trbs;
205 next = ring->enqueue; 214 next = ring->enqueue;
206 } 215 }
216 addr = (unsigned long long) xhci_trb_virt_to_dma(ring->enq_seg, ring->enqueue);
217 if (ring == xhci->event_ring)
218 xhci_dbg(xhci, "Event ring enq = 0x%llx (DMA)\n", addr);
219 else if (ring == xhci->cmd_ring)
220 xhci_dbg(xhci, "Command ring enq = 0x%llx (DMA)\n", addr);
221 else
222 xhci_dbg(xhci, "Ring enq = 0x%llx (DMA)\n", addr);
207} 223}
208 224
209/* 225/*
@@ -237,7 +253,7 @@ static int room_on_ring(struct xhci_hcd *xhci, struct xhci_ring *ring,
237 253
238void xhci_set_hc_event_deq(struct xhci_hcd *xhci) 254void xhci_set_hc_event_deq(struct xhci_hcd *xhci)
239{ 255{
240 u32 temp; 256 u64 temp;
241 dma_addr_t deq; 257 dma_addr_t deq;
242 258
243 deq = xhci_trb_virt_to_dma(xhci->event_ring->deq_seg, 259 deq = xhci_trb_virt_to_dma(xhci->event_ring->deq_seg,
@@ -246,13 +262,15 @@ void xhci_set_hc_event_deq(struct xhci_hcd *xhci)
246 xhci_warn(xhci, "WARN something wrong with SW event ring " 262 xhci_warn(xhci, "WARN something wrong with SW event ring "
247 "dequeue ptr.\n"); 263 "dequeue ptr.\n");
248 /* Update HC event ring dequeue pointer */ 264 /* Update HC event ring dequeue pointer */
249 temp = xhci_readl(xhci, &xhci->ir_set->erst_dequeue[0]); 265 temp = xhci_read_64(xhci, &xhci->ir_set->erst_dequeue);
250 temp &= ERST_PTR_MASK; 266 temp &= ERST_PTR_MASK;
251 if (!in_interrupt()) 267 /* Don't clear the EHB bit (which is RW1C) because
252 xhci_dbg(xhci, "// Write event ring dequeue pointer\n"); 268 * there might be more events to service.
253 xhci_writel(xhci, 0, &xhci->ir_set->erst_dequeue[1]); 269 */
254 xhci_writel(xhci, (deq & ~ERST_PTR_MASK) | temp, 270 temp &= ~ERST_EHB;
255 &xhci->ir_set->erst_dequeue[0]); 271 xhci_dbg(xhci, "// Write event ring dequeue pointer, preserving EHB bit\n");
272 xhci_write_64(xhci, ((u64) deq & (u64) ~ERST_PTR_MASK) | temp,
273 &xhci->ir_set->erst_dequeue);
256} 274}
257 275
258/* Ring the host controller doorbell after placing a command on the ring */ 276/* Ring the host controller doorbell after placing a command on the ring */
@@ -279,7 +297,8 @@ static void ring_ep_doorbell(struct xhci_hcd *xhci,
279 /* Don't ring the doorbell for this endpoint if there are pending 297 /* Don't ring the doorbell for this endpoint if there are pending
280 * cancellations because the we don't want to interrupt processing. 298 * cancellations because the we don't want to interrupt processing.
281 */ 299 */
282 if (!ep_ring->cancels_pending && !(ep_ring->state & SET_DEQ_PENDING)) { 300 if (!ep_ring->cancels_pending && !(ep_ring->state & SET_DEQ_PENDING)
301 && !(ep_ring->state & EP_HALTED)) {
283 field = xhci_readl(xhci, db_addr) & DB_MASK; 302 field = xhci_readl(xhci, db_addr) & DB_MASK;
284 xhci_writel(xhci, field | EPI_TO_DB(ep_index), db_addr); 303 xhci_writel(xhci, field | EPI_TO_DB(ep_index), db_addr);
285 /* Flush PCI posted writes - FIXME Matthew Wilcox says this 304 /* Flush PCI posted writes - FIXME Matthew Wilcox says this
@@ -316,12 +335,6 @@ static struct xhci_segment *find_trb_seg(
316 return cur_seg; 335 return cur_seg;
317} 336}
318 337
319struct dequeue_state {
320 struct xhci_segment *new_deq_seg;
321 union xhci_trb *new_deq_ptr;
322 int new_cycle_state;
323};
324
325/* 338/*
326 * Move the xHC's endpoint ring dequeue pointer past cur_td. 339 * Move the xHC's endpoint ring dequeue pointer past cur_td.
327 * Record the new state of the xHC's endpoint ring dequeue segment, 340 * Record the new state of the xHC's endpoint ring dequeue segment,
@@ -336,24 +349,30 @@ struct dequeue_state {
336 * - Finally we move the dequeue state one TRB further, toggling the cycle bit 349 * - Finally we move the dequeue state one TRB further, toggling the cycle bit
337 * if we've moved it past a link TRB with the toggle cycle bit set. 350 * if we've moved it past a link TRB with the toggle cycle bit set.
338 */ 351 */
339static void find_new_dequeue_state(struct xhci_hcd *xhci, 352void xhci_find_new_dequeue_state(struct xhci_hcd *xhci,
340 unsigned int slot_id, unsigned int ep_index, 353 unsigned int slot_id, unsigned int ep_index,
341 struct xhci_td *cur_td, struct dequeue_state *state) 354 struct xhci_td *cur_td, struct xhci_dequeue_state *state)
342{ 355{
343 struct xhci_virt_device *dev = xhci->devs[slot_id]; 356 struct xhci_virt_device *dev = xhci->devs[slot_id];
344 struct xhci_ring *ep_ring = dev->ep_rings[ep_index]; 357 struct xhci_ring *ep_ring = dev->ep_rings[ep_index];
345 struct xhci_generic_trb *trb; 358 struct xhci_generic_trb *trb;
359 struct xhci_ep_ctx *ep_ctx;
360 dma_addr_t addr;
346 361
347 state->new_cycle_state = 0; 362 state->new_cycle_state = 0;
363 xhci_dbg(xhci, "Finding segment containing stopped TRB.\n");
348 state->new_deq_seg = find_trb_seg(cur_td->start_seg, 364 state->new_deq_seg = find_trb_seg(cur_td->start_seg,
349 ep_ring->stopped_trb, 365 ep_ring->stopped_trb,
350 &state->new_cycle_state); 366 &state->new_cycle_state);
351 if (!state->new_deq_seg) 367 if (!state->new_deq_seg)
352 BUG(); 368 BUG();
353 /* Dig out the cycle state saved by the xHC during the stop ep cmd */ 369 /* Dig out the cycle state saved by the xHC during the stop ep cmd */
354 state->new_cycle_state = 0x1 & dev->out_ctx->ep[ep_index].deq[0]; 370 xhci_dbg(xhci, "Finding endpoint context\n");
371 ep_ctx = xhci_get_ep_ctx(xhci, dev->out_ctx, ep_index);
372 state->new_cycle_state = 0x1 & ep_ctx->deq;
355 373
356 state->new_deq_ptr = cur_td->last_trb; 374 state->new_deq_ptr = cur_td->last_trb;
375 xhci_dbg(xhci, "Finding segment containing last TRB in TD.\n");
357 state->new_deq_seg = find_trb_seg(state->new_deq_seg, 376 state->new_deq_seg = find_trb_seg(state->new_deq_seg,
358 state->new_deq_ptr, 377 state->new_deq_ptr,
359 &state->new_cycle_state); 378 &state->new_cycle_state);
@@ -367,6 +386,12 @@ static void find_new_dequeue_state(struct xhci_hcd *xhci,
367 next_trb(xhci, ep_ring, &state->new_deq_seg, &state->new_deq_ptr); 386 next_trb(xhci, ep_ring, &state->new_deq_seg, &state->new_deq_ptr);
368 387
369 /* Don't update the ring cycle state for the producer (us). */ 388 /* Don't update the ring cycle state for the producer (us). */
389 xhci_dbg(xhci, "New dequeue segment = %p (virtual)\n",
390 state->new_deq_seg);
391 addr = xhci_trb_virt_to_dma(state->new_deq_seg, state->new_deq_ptr);
392 xhci_dbg(xhci, "New dequeue pointer = 0x%llx (DMA)\n",
393 (unsigned long long) addr);
394 xhci_dbg(xhci, "Setting dequeue pointer in internal ring state.\n");
370 ep_ring->dequeue = state->new_deq_ptr; 395 ep_ring->dequeue = state->new_deq_ptr;
371 ep_ring->deq_seg = state->new_deq_seg; 396 ep_ring->deq_seg = state->new_deq_seg;
372} 397}
@@ -416,6 +441,30 @@ static int queue_set_tr_deq(struct xhci_hcd *xhci, int slot_id,
416 unsigned int ep_index, struct xhci_segment *deq_seg, 441 unsigned int ep_index, struct xhci_segment *deq_seg,
417 union xhci_trb *deq_ptr, u32 cycle_state); 442 union xhci_trb *deq_ptr, u32 cycle_state);
418 443
444void xhci_queue_new_dequeue_state(struct xhci_hcd *xhci,
445 struct xhci_ring *ep_ring, unsigned int slot_id,
446 unsigned int ep_index, struct xhci_dequeue_state *deq_state)
447{
448 xhci_dbg(xhci, "Set TR Deq Ptr cmd, new deq seg = %p (0x%llx dma), "
449 "new deq ptr = %p (0x%llx dma), new cycle = %u\n",
450 deq_state->new_deq_seg,
451 (unsigned long long)deq_state->new_deq_seg->dma,
452 deq_state->new_deq_ptr,
453 (unsigned long long)xhci_trb_virt_to_dma(deq_state->new_deq_seg, deq_state->new_deq_ptr),
454 deq_state->new_cycle_state);
455 queue_set_tr_deq(xhci, slot_id, ep_index,
456 deq_state->new_deq_seg,
457 deq_state->new_deq_ptr,
458 (u32) deq_state->new_cycle_state);
459 /* Stop the TD queueing code from ringing the doorbell until
460 * this command completes. The HC won't set the dequeue pointer
461 * if the ring is running, and ringing the doorbell starts the
462 * ring running.
463 */
464 ep_ring->state |= SET_DEQ_PENDING;
465 xhci_ring_cmd_db(xhci);
466}
467
419/* 468/*
420 * When we get a command completion for a Stop Endpoint Command, we need to 469 * When we get a command completion for a Stop Endpoint Command, we need to
421 * unlink any cancelled TDs from the ring. There are two ways to do that: 470 * unlink any cancelled TDs from the ring. There are two ways to do that:
@@ -436,7 +485,7 @@ static void handle_stopped_endpoint(struct xhci_hcd *xhci,
436 struct xhci_td *cur_td = 0; 485 struct xhci_td *cur_td = 0;
437 struct xhci_td *last_unlinked_td; 486 struct xhci_td *last_unlinked_td;
438 487
439 struct dequeue_state deq_state; 488 struct xhci_dequeue_state deq_state;
440#ifdef CONFIG_USB_HCD_STAT 489#ifdef CONFIG_USB_HCD_STAT
441 ktime_t stop_time = ktime_get(); 490 ktime_t stop_time = ktime_get();
442#endif 491#endif
@@ -464,7 +513,7 @@ static void handle_stopped_endpoint(struct xhci_hcd *xhci,
464 * move the xHC endpoint ring dequeue pointer past this TD. 513 * move the xHC endpoint ring dequeue pointer past this TD.
465 */ 514 */
466 if (cur_td == ep_ring->stopped_td) 515 if (cur_td == ep_ring->stopped_td)
467 find_new_dequeue_state(xhci, slot_id, ep_index, cur_td, 516 xhci_find_new_dequeue_state(xhci, slot_id, ep_index, cur_td,
468 &deq_state); 517 &deq_state);
469 else 518 else
470 td_to_noop(xhci, ep_ring, cur_td); 519 td_to_noop(xhci, ep_ring, cur_td);
@@ -480,24 +529,8 @@ static void handle_stopped_endpoint(struct xhci_hcd *xhci,
480 529
481 /* If necessary, queue a Set Transfer Ring Dequeue Pointer command */ 530 /* If necessary, queue a Set Transfer Ring Dequeue Pointer command */
482 if (deq_state.new_deq_ptr && deq_state.new_deq_seg) { 531 if (deq_state.new_deq_ptr && deq_state.new_deq_seg) {
483 xhci_dbg(xhci, "Set TR Deq Ptr cmd, new deq seg = %p (0x%llx dma), " 532 xhci_queue_new_dequeue_state(xhci, ep_ring,
484 "new deq ptr = %p (0x%llx dma), new cycle = %u\n", 533 slot_id, ep_index, &deq_state);
485 deq_state.new_deq_seg,
486 (unsigned long long)deq_state.new_deq_seg->dma,
487 deq_state.new_deq_ptr,
488 (unsigned long long)xhci_trb_virt_to_dma(deq_state.new_deq_seg, deq_state.new_deq_ptr),
489 deq_state.new_cycle_state);
490 queue_set_tr_deq(xhci, slot_id, ep_index,
491 deq_state.new_deq_seg,
492 deq_state.new_deq_ptr,
493 (u32) deq_state.new_cycle_state);
494 /* Stop the TD queueing code from ringing the doorbell until
495 * this command completes. The HC won't set the dequeue pointer
496 * if the ring is running, and ringing the doorbell starts the
497 * ring running.
498 */
499 ep_ring->state |= SET_DEQ_PENDING;
500 xhci_ring_cmd_db(xhci);
501 } else { 534 } else {
502 /* Otherwise just ring the doorbell to restart the ring */ 535 /* Otherwise just ring the doorbell to restart the ring */
503 ring_ep_doorbell(xhci, slot_id, ep_index); 536 ring_ep_doorbell(xhci, slot_id, ep_index);
@@ -551,11 +584,15 @@ static void handle_set_deq_completion(struct xhci_hcd *xhci,
551 unsigned int ep_index; 584 unsigned int ep_index;
552 struct xhci_ring *ep_ring; 585 struct xhci_ring *ep_ring;
553 struct xhci_virt_device *dev; 586 struct xhci_virt_device *dev;
587 struct xhci_ep_ctx *ep_ctx;
588 struct xhci_slot_ctx *slot_ctx;
554 589
555 slot_id = TRB_TO_SLOT_ID(trb->generic.field[3]); 590 slot_id = TRB_TO_SLOT_ID(trb->generic.field[3]);
556 ep_index = TRB_TO_EP_INDEX(trb->generic.field[3]); 591 ep_index = TRB_TO_EP_INDEX(trb->generic.field[3]);
557 dev = xhci->devs[slot_id]; 592 dev = xhci->devs[slot_id];
558 ep_ring = dev->ep_rings[ep_index]; 593 ep_ring = dev->ep_rings[ep_index];
594 ep_ctx = xhci_get_ep_ctx(xhci, dev->out_ctx, ep_index);
595 slot_ctx = xhci_get_slot_ctx(xhci, dev->out_ctx);
559 596
560 if (GET_COMP_CODE(event->status) != COMP_SUCCESS) { 597 if (GET_COMP_CODE(event->status) != COMP_SUCCESS) {
561 unsigned int ep_state; 598 unsigned int ep_state;
@@ -569,9 +606,9 @@ static void handle_set_deq_completion(struct xhci_hcd *xhci,
569 case COMP_CTX_STATE: 606 case COMP_CTX_STATE:
570 xhci_warn(xhci, "WARN Set TR Deq Ptr cmd failed due " 607 xhci_warn(xhci, "WARN Set TR Deq Ptr cmd failed due "
571 "to incorrect slot or ep state.\n"); 608 "to incorrect slot or ep state.\n");
572 ep_state = dev->out_ctx->ep[ep_index].ep_info; 609 ep_state = ep_ctx->ep_info;
573 ep_state &= EP_STATE_MASK; 610 ep_state &= EP_STATE_MASK;
574 slot_state = dev->out_ctx->slot.dev_state; 611 slot_state = slot_ctx->dev_state;
575 slot_state = GET_SLOT_STATE(slot_state); 612 slot_state = GET_SLOT_STATE(slot_state);
576 xhci_dbg(xhci, "Slot state = %u, EP state = %u\n", 613 xhci_dbg(xhci, "Slot state = %u, EP state = %u\n",
577 slot_state, ep_state); 614 slot_state, ep_state);
@@ -593,16 +630,33 @@ static void handle_set_deq_completion(struct xhci_hcd *xhci,
593 * cancelling URBs, which might not be an error... 630 * cancelling URBs, which might not be an error...
594 */ 631 */
595 } else { 632 } else {
596 xhci_dbg(xhci, "Successful Set TR Deq Ptr cmd, deq[0] = 0x%x, " 633 xhci_dbg(xhci, "Successful Set TR Deq Ptr cmd, deq = @%08llx\n",
597 "deq[1] = 0x%x.\n", 634 ep_ctx->deq);
598 dev->out_ctx->ep[ep_index].deq[0],
599 dev->out_ctx->ep[ep_index].deq[1]);
600 } 635 }
601 636
602 ep_ring->state &= ~SET_DEQ_PENDING; 637 ep_ring->state &= ~SET_DEQ_PENDING;
603 ring_ep_doorbell(xhci, slot_id, ep_index); 638 ring_ep_doorbell(xhci, slot_id, ep_index);
604} 639}
605 640
641static void handle_reset_ep_completion(struct xhci_hcd *xhci,
642 struct xhci_event_cmd *event,
643 union xhci_trb *trb)
644{
645 int slot_id;
646 unsigned int ep_index;
647
648 slot_id = TRB_TO_SLOT_ID(trb->generic.field[3]);
649 ep_index = TRB_TO_EP_INDEX(trb->generic.field[3]);
650 /* This command will only fail if the endpoint wasn't halted,
651 * but we don't care.
652 */
653 xhci_dbg(xhci, "Ignoring reset ep completion code of %u\n",
654 (unsigned int) GET_COMP_CODE(event->status));
655
656 /* Clear our internal halted state and restart the ring */
657 xhci->devs[slot_id]->ep_rings[ep_index]->state &= ~EP_HALTED;
658 ring_ep_doorbell(xhci, slot_id, ep_index);
659}
606 660
607static void handle_cmd_completion(struct xhci_hcd *xhci, 661static void handle_cmd_completion(struct xhci_hcd *xhci,
608 struct xhci_event_cmd *event) 662 struct xhci_event_cmd *event)
@@ -611,7 +665,7 @@ static void handle_cmd_completion(struct xhci_hcd *xhci,
611 u64 cmd_dma; 665 u64 cmd_dma;
612 dma_addr_t cmd_dequeue_dma; 666 dma_addr_t cmd_dequeue_dma;
613 667
614 cmd_dma = (((u64) event->cmd_trb[1]) << 32) + event->cmd_trb[0]; 668 cmd_dma = event->cmd_trb;
615 cmd_dequeue_dma = xhci_trb_virt_to_dma(xhci->cmd_ring->deq_seg, 669 cmd_dequeue_dma = xhci_trb_virt_to_dma(xhci->cmd_ring->deq_seg,
616 xhci->cmd_ring->dequeue); 670 xhci->cmd_ring->dequeue);
617 /* Is the command ring deq ptr out of sync with the deq seg ptr? */ 671 /* Is the command ring deq ptr out of sync with the deq seg ptr? */
@@ -653,6 +707,9 @@ static void handle_cmd_completion(struct xhci_hcd *xhci,
653 case TRB_TYPE(TRB_CMD_NOOP): 707 case TRB_TYPE(TRB_CMD_NOOP):
654 ++xhci->noops_handled; 708 ++xhci->noops_handled;
655 break; 709 break;
710 case TRB_TYPE(TRB_RESET_EP):
711 handle_reset_ep_completion(xhci, event, xhci->cmd_ring->dequeue);
712 break;
656 default: 713 default:
657 /* Skip over unknown commands on the event ring */ 714 /* Skip over unknown commands on the event ring */
658 xhci->error_bitmask |= 1 << 6; 715 xhci->error_bitmask |= 1 << 6;
@@ -756,7 +813,9 @@ static int handle_tx_event(struct xhci_hcd *xhci,
756 union xhci_trb *event_trb; 813 union xhci_trb *event_trb;
757 struct urb *urb = 0; 814 struct urb *urb = 0;
758 int status = -EINPROGRESS; 815 int status = -EINPROGRESS;
816 struct xhci_ep_ctx *ep_ctx;
759 817
818 xhci_dbg(xhci, "In %s\n", __func__);
760 xdev = xhci->devs[TRB_TO_SLOT_ID(event->flags)]; 819 xdev = xhci->devs[TRB_TO_SLOT_ID(event->flags)];
761 if (!xdev) { 820 if (!xdev) {
762 xhci_err(xhci, "ERROR Transfer event pointed to bad slot\n"); 821 xhci_err(xhci, "ERROR Transfer event pointed to bad slot\n");
@@ -765,17 +824,17 @@ static int handle_tx_event(struct xhci_hcd *xhci,
765 824
766 /* Endpoint ID is 1 based, our index is zero based */ 825 /* Endpoint ID is 1 based, our index is zero based */
767 ep_index = TRB_TO_EP_ID(event->flags) - 1; 826 ep_index = TRB_TO_EP_ID(event->flags) - 1;
827 xhci_dbg(xhci, "%s - ep index = %d\n", __func__, ep_index);
768 ep_ring = xdev->ep_rings[ep_index]; 828 ep_ring = xdev->ep_rings[ep_index];
769 if (!ep_ring || (xdev->out_ctx->ep[ep_index].ep_info & EP_STATE_MASK) == EP_STATE_DISABLED) { 829 ep_ctx = xhci_get_ep_ctx(xhci, xdev->out_ctx, ep_index);
830 if (!ep_ring || (ep_ctx->ep_info & EP_STATE_MASK) == EP_STATE_DISABLED) {
770 xhci_err(xhci, "ERROR Transfer event pointed to disabled endpoint\n"); 831 xhci_err(xhci, "ERROR Transfer event pointed to disabled endpoint\n");
771 return -ENODEV; 832 return -ENODEV;
772 } 833 }
773 834
774 event_dma = event->buffer[0]; 835 event_dma = event->buffer;
775 if (event->buffer[1] != 0)
776 xhci_warn(xhci, "WARN ignoring upper 32-bits of 64-bit TRB dma address\n");
777
778 /* This TRB should be in the TD at the head of this ring's TD list */ 836 /* This TRB should be in the TD at the head of this ring's TD list */
837 xhci_dbg(xhci, "%s - checking for list empty\n", __func__);
779 if (list_empty(&ep_ring->td_list)) { 838 if (list_empty(&ep_ring->td_list)) {
780 xhci_warn(xhci, "WARN Event TRB for slot %d ep %d with no TDs queued?\n", 839 xhci_warn(xhci, "WARN Event TRB for slot %d ep %d with no TDs queued?\n",
781 TRB_TO_SLOT_ID(event->flags), ep_index); 840 TRB_TO_SLOT_ID(event->flags), ep_index);
@@ -785,11 +844,14 @@ static int handle_tx_event(struct xhci_hcd *xhci,
785 urb = NULL; 844 urb = NULL;
786 goto cleanup; 845 goto cleanup;
787 } 846 }
847 xhci_dbg(xhci, "%s - getting list entry\n", __func__);
788 td = list_entry(ep_ring->td_list.next, struct xhci_td, td_list); 848 td = list_entry(ep_ring->td_list.next, struct xhci_td, td_list);
789 849
790 /* Is this a TRB in the currently executing TD? */ 850 /* Is this a TRB in the currently executing TD? */
851 xhci_dbg(xhci, "%s - looking for TD\n", __func__);
791 event_seg = trb_in_td(ep_ring->deq_seg, ep_ring->dequeue, 852 event_seg = trb_in_td(ep_ring->deq_seg, ep_ring->dequeue,
792 td->last_trb, event_dma); 853 td->last_trb, event_dma);
854 xhci_dbg(xhci, "%s - found event_seg = %p\n", __func__, event_seg);
793 if (!event_seg) { 855 if (!event_seg) {
794 /* HC is busted, give up! */ 856 /* HC is busted, give up! */
795 xhci_err(xhci, "ERROR Transfer event TRB DMA ptr not part of current TD\n"); 857 xhci_err(xhci, "ERROR Transfer event TRB DMA ptr not part of current TD\n");
@@ -798,10 +860,10 @@ static int handle_tx_event(struct xhci_hcd *xhci,
798 event_trb = &event_seg->trbs[(event_dma - event_seg->dma) / sizeof(*event_trb)]; 860 event_trb = &event_seg->trbs[(event_dma - event_seg->dma) / sizeof(*event_trb)];
799 xhci_dbg(xhci, "Event TRB with TRB type ID %u\n", 861 xhci_dbg(xhci, "Event TRB with TRB type ID %u\n",
800 (unsigned int) (event->flags & TRB_TYPE_BITMASK)>>10); 862 (unsigned int) (event->flags & TRB_TYPE_BITMASK)>>10);
801 xhci_dbg(xhci, "Offset 0x00 (buffer[0]) = 0x%x\n", 863 xhci_dbg(xhci, "Offset 0x00 (buffer lo) = 0x%x\n",
802 (unsigned int) event->buffer[0]); 864 lower_32_bits(event->buffer));
803 xhci_dbg(xhci, "Offset 0x04 (buffer[0]) = 0x%x\n", 865 xhci_dbg(xhci, "Offset 0x04 (buffer hi) = 0x%x\n",
804 (unsigned int) event->buffer[1]); 866 upper_32_bits(event->buffer));
805 xhci_dbg(xhci, "Offset 0x08 (transfer length) = 0x%x\n", 867 xhci_dbg(xhci, "Offset 0x08 (transfer length) = 0x%x\n",
806 (unsigned int) event->transfer_len); 868 (unsigned int) event->transfer_len);
807 xhci_dbg(xhci, "Offset 0x0C (flags) = 0x%x\n", 869 xhci_dbg(xhci, "Offset 0x0C (flags) = 0x%x\n",
@@ -823,6 +885,7 @@ static int handle_tx_event(struct xhci_hcd *xhci,
823 break; 885 break;
824 case COMP_STALL: 886 case COMP_STALL:
825 xhci_warn(xhci, "WARN: Stalled endpoint\n"); 887 xhci_warn(xhci, "WARN: Stalled endpoint\n");
888 ep_ring->state |= EP_HALTED;
826 status = -EPIPE; 889 status = -EPIPE;
827 break; 890 break;
828 case COMP_TRB_ERR: 891 case COMP_TRB_ERR:
@@ -833,6 +896,10 @@ static int handle_tx_event(struct xhci_hcd *xhci,
833 xhci_warn(xhci, "WARN: transfer error on endpoint\n"); 896 xhci_warn(xhci, "WARN: transfer error on endpoint\n");
834 status = -EPROTO; 897 status = -EPROTO;
835 break; 898 break;
899 case COMP_BABBLE:
900 xhci_warn(xhci, "WARN: babble error on endpoint\n");
901 status = -EOVERFLOW;
902 break;
836 case COMP_DB_ERR: 903 case COMP_DB_ERR:
837 xhci_warn(xhci, "WARN: HC couldn't access mem fast enough\n"); 904 xhci_warn(xhci, "WARN: HC couldn't access mem fast enough\n");
838 status = -ENOSR; 905 status = -ENOSR;
@@ -874,15 +941,26 @@ static int handle_tx_event(struct xhci_hcd *xhci,
874 if (event_trb != ep_ring->dequeue) { 941 if (event_trb != ep_ring->dequeue) {
875 /* The event was for the status stage */ 942 /* The event was for the status stage */
876 if (event_trb == td->last_trb) { 943 if (event_trb == td->last_trb) {
877 td->urb->actual_length = 944 if (td->urb->actual_length != 0) {
878 td->urb->transfer_buffer_length; 945 /* Don't overwrite a previously set error code */
946 if (status == -EINPROGRESS || status == 0)
947 /* Did we already see a short data stage? */
948 status = -EREMOTEIO;
949 } else {
950 td->urb->actual_length =
951 td->urb->transfer_buffer_length;
952 }
879 } else { 953 } else {
880 /* Maybe the event was for the data stage? */ 954 /* Maybe the event was for the data stage? */
881 if (GET_COMP_CODE(event->transfer_len) != COMP_STOP_INVAL) 955 if (GET_COMP_CODE(event->transfer_len) != COMP_STOP_INVAL) {
882 /* We didn't stop on a link TRB in the middle */ 956 /* We didn't stop on a link TRB in the middle */
883 td->urb->actual_length = 957 td->urb->actual_length =
884 td->urb->transfer_buffer_length - 958 td->urb->transfer_buffer_length -
885 TRB_LEN(event->transfer_len); 959 TRB_LEN(event->transfer_len);
960 xhci_dbg(xhci, "Waiting for status stage event\n");
961 urb = NULL;
962 goto cleanup;
963 }
886 } 964 }
887 } 965 }
888 } else { 966 } else {
@@ -929,16 +1007,20 @@ static int handle_tx_event(struct xhci_hcd *xhci,
929 TRB_LEN(event->transfer_len)); 1007 TRB_LEN(event->transfer_len));
930 td->urb->actual_length = 0; 1008 td->urb->actual_length = 0;
931 } 1009 }
932 if (td->urb->transfer_flags & URB_SHORT_NOT_OK) 1010 /* Don't overwrite a previously set error code */
933 status = -EREMOTEIO; 1011 if (status == -EINPROGRESS) {
934 else 1012 if (td->urb->transfer_flags & URB_SHORT_NOT_OK)
935 status = 0; 1013 status = -EREMOTEIO;
1014 else
1015 status = 0;
1016 }
936 } else { 1017 } else {
937 td->urb->actual_length = td->urb->transfer_buffer_length; 1018 td->urb->actual_length = td->urb->transfer_buffer_length;
938 /* Ignore a short packet completion if the 1019 /* Ignore a short packet completion if the
939 * untransferred length was zero. 1020 * untransferred length was zero.
940 */ 1021 */
941 status = 0; 1022 if (status == -EREMOTEIO)
1023 status = 0;
942 } 1024 }
943 } else { 1025 } else {
944 /* Slow path - walk the list, starting from the dequeue 1026 /* Slow path - walk the list, starting from the dequeue
@@ -965,19 +1047,30 @@ static int handle_tx_event(struct xhci_hcd *xhci,
965 TRB_LEN(event->transfer_len); 1047 TRB_LEN(event->transfer_len);
966 } 1048 }
967 } 1049 }
968 /* The Endpoint Stop Command completion will take care of
969 * any stopped TDs. A stopped TD may be restarted, so don't update the
970 * ring dequeue pointer or take this TD off any lists yet.
971 */
972 if (GET_COMP_CODE(event->transfer_len) == COMP_STOP_INVAL || 1050 if (GET_COMP_CODE(event->transfer_len) == COMP_STOP_INVAL ||
973 GET_COMP_CODE(event->transfer_len) == COMP_STOP) { 1051 GET_COMP_CODE(event->transfer_len) == COMP_STOP) {
1052 /* The Endpoint Stop Command completion will take care of any
1053 * stopped TDs. A stopped TD may be restarted, so don't update
1054 * the ring dequeue pointer or take this TD off any lists yet.
1055 */
974 ep_ring->stopped_td = td; 1056 ep_ring->stopped_td = td;
975 ep_ring->stopped_trb = event_trb; 1057 ep_ring->stopped_trb = event_trb;
976 } else { 1058 } else {
977 /* Update ring dequeue pointer */ 1059 if (GET_COMP_CODE(event->transfer_len) == COMP_STALL) {
978 while (ep_ring->dequeue != td->last_trb) 1060 /* The transfer is completed from the driver's
1061 * perspective, but we need to issue a set dequeue
1062 * command for this stalled endpoint to move the dequeue
1063 * pointer past the TD. We can't do that here because
1064 * the halt condition must be cleared first.
1065 */
1066 ep_ring->stopped_td = td;
1067 ep_ring->stopped_trb = event_trb;
1068 } else {
1069 /* Update ring dequeue pointer */
1070 while (ep_ring->dequeue != td->last_trb)
1071 inc_deq(xhci, ep_ring, false);
979 inc_deq(xhci, ep_ring, false); 1072 inc_deq(xhci, ep_ring, false);
980 inc_deq(xhci, ep_ring, false); 1073 }
981 1074
982 /* Clean up the endpoint's TD list */ 1075 /* Clean up the endpoint's TD list */
983 urb = td->urb; 1076 urb = td->urb;
@@ -987,7 +1080,10 @@ static int handle_tx_event(struct xhci_hcd *xhci,
987 list_del(&td->cancelled_td_list); 1080 list_del(&td->cancelled_td_list);
988 ep_ring->cancels_pending--; 1081 ep_ring->cancels_pending--;
989 } 1082 }
990 kfree(td); 1083 /* Leave the TD around for the reset endpoint function to use */
1084 if (GET_COMP_CODE(event->transfer_len) != COMP_STALL) {
1085 kfree(td);
1086 }
991 urb->hcpriv = NULL; 1087 urb->hcpriv = NULL;
992 } 1088 }
993cleanup: 1089cleanup:
@@ -997,6 +1093,8 @@ cleanup:
997 /* FIXME for multi-TD URBs (who have buffers bigger than 64MB) */ 1093 /* FIXME for multi-TD URBs (who have buffers bigger than 64MB) */
998 if (urb) { 1094 if (urb) {
999 usb_hcd_unlink_urb_from_ep(xhci_to_hcd(xhci), urb); 1095 usb_hcd_unlink_urb_from_ep(xhci_to_hcd(xhci), urb);
1096 xhci_dbg(xhci, "Giveback URB %p, len = %d, status = %d\n",
1097 urb, td->urb->actual_length, status);
1000 spin_unlock(&xhci->lock); 1098 spin_unlock(&xhci->lock);
1001 usb_hcd_giveback_urb(xhci_to_hcd(xhci), urb, status); 1099 usb_hcd_giveback_urb(xhci_to_hcd(xhci), urb, status);
1002 spin_lock(&xhci->lock); 1100 spin_lock(&xhci->lock);
@@ -1014,6 +1112,7 @@ void xhci_handle_event(struct xhci_hcd *xhci)
1014 int update_ptrs = 1; 1112 int update_ptrs = 1;
1015 int ret; 1113 int ret;
1016 1114
1115 xhci_dbg(xhci, "In %s\n", __func__);
1017 if (!xhci->event_ring || !xhci->event_ring->dequeue) { 1116 if (!xhci->event_ring || !xhci->event_ring->dequeue) {
1018 xhci->error_bitmask |= 1 << 1; 1117 xhci->error_bitmask |= 1 << 1;
1019 return; 1118 return;
@@ -1026,18 +1125,25 @@ void xhci_handle_event(struct xhci_hcd *xhci)
1026 xhci->error_bitmask |= 1 << 2; 1125 xhci->error_bitmask |= 1 << 2;
1027 return; 1126 return;
1028 } 1127 }
1128 xhci_dbg(xhci, "%s - OS owns TRB\n", __func__);
1029 1129
1030 /* FIXME: Handle more event types. */ 1130 /* FIXME: Handle more event types. */
1031 switch ((event->event_cmd.flags & TRB_TYPE_BITMASK)) { 1131 switch ((event->event_cmd.flags & TRB_TYPE_BITMASK)) {
1032 case TRB_TYPE(TRB_COMPLETION): 1132 case TRB_TYPE(TRB_COMPLETION):
1133 xhci_dbg(xhci, "%s - calling handle_cmd_completion\n", __func__);
1033 handle_cmd_completion(xhci, &event->event_cmd); 1134 handle_cmd_completion(xhci, &event->event_cmd);
1135 xhci_dbg(xhci, "%s - returned from handle_cmd_completion\n", __func__);
1034 break; 1136 break;
1035 case TRB_TYPE(TRB_PORT_STATUS): 1137 case TRB_TYPE(TRB_PORT_STATUS):
1138 xhci_dbg(xhci, "%s - calling handle_port_status\n", __func__);
1036 handle_port_status(xhci, event); 1139 handle_port_status(xhci, event);
1140 xhci_dbg(xhci, "%s - returned from handle_port_status\n", __func__);
1037 update_ptrs = 0; 1141 update_ptrs = 0;
1038 break; 1142 break;
1039 case TRB_TYPE(TRB_TRANSFER): 1143 case TRB_TYPE(TRB_TRANSFER):
1144 xhci_dbg(xhci, "%s - calling handle_tx_event\n", __func__);
1040 ret = handle_tx_event(xhci, &event->trans_event); 1145 ret = handle_tx_event(xhci, &event->trans_event);
1146 xhci_dbg(xhci, "%s - returned from handle_tx_event\n", __func__);
1041 if (ret < 0) 1147 if (ret < 0)
1042 xhci->error_bitmask |= 1 << 9; 1148 xhci->error_bitmask |= 1 << 9;
1043 else 1149 else
@@ -1093,13 +1199,13 @@ static int prepare_ring(struct xhci_hcd *xhci, struct xhci_ring *ep_ring,
1093 */ 1199 */
1094 xhci_warn(xhci, "WARN urb submitted to disabled ep\n"); 1200 xhci_warn(xhci, "WARN urb submitted to disabled ep\n");
1095 return -ENOENT; 1201 return -ENOENT;
1096 case EP_STATE_HALTED:
1097 case EP_STATE_ERROR: 1202 case EP_STATE_ERROR:
1098 xhci_warn(xhci, "WARN waiting for halt or error on ep " 1203 xhci_warn(xhci, "WARN waiting for error on ep to be cleared\n");
1099 "to be cleared\n");
1100 /* FIXME event handling code for error needs to clear it */ 1204 /* FIXME event handling code for error needs to clear it */
1101 /* XXX not sure if this should be -ENOENT or not */ 1205 /* XXX not sure if this should be -ENOENT or not */
1102 return -EINVAL; 1206 return -EINVAL;
1207 case EP_STATE_HALTED:
1208 xhci_dbg(xhci, "WARN halted endpoint, queueing URB anyway.\n");
1103 case EP_STATE_STOPPED: 1209 case EP_STATE_STOPPED:
1104 case EP_STATE_RUNNING: 1210 case EP_STATE_RUNNING:
1105 break; 1211 break;
@@ -1128,9 +1234,9 @@ static int prepare_transfer(struct xhci_hcd *xhci,
1128 gfp_t mem_flags) 1234 gfp_t mem_flags)
1129{ 1235{
1130 int ret; 1236 int ret;
1131 1237 struct xhci_ep_ctx *ep_ctx = xhci_get_ep_ctx(xhci, xdev->out_ctx, ep_index);
1132 ret = prepare_ring(xhci, xdev->ep_rings[ep_index], 1238 ret = prepare_ring(xhci, xdev->ep_rings[ep_index],
1133 xdev->out_ctx->ep[ep_index].ep_info & EP_STATE_MASK, 1239 ep_ctx->ep_info & EP_STATE_MASK,
1134 num_trbs, mem_flags); 1240 num_trbs, mem_flags);
1135 if (ret) 1241 if (ret)
1136 return ret; 1242 return ret;
@@ -1285,6 +1391,7 @@ static int queue_bulk_sg_tx(struct xhci_hcd *xhci, gfp_t mem_flags,
1285 /* Queue the first TRB, even if it's zero-length */ 1391 /* Queue the first TRB, even if it's zero-length */
1286 do { 1392 do {
1287 u32 field = 0; 1393 u32 field = 0;
1394 u32 length_field = 0;
1288 1395
1289 /* Don't change the cycle bit of the first TRB until later */ 1396 /* Don't change the cycle bit of the first TRB until later */
1290 if (first_trb) 1397 if (first_trb)
@@ -1314,10 +1421,13 @@ static int queue_bulk_sg_tx(struct xhci_hcd *xhci, gfp_t mem_flags,
1314 (unsigned int) (addr + TRB_MAX_BUFF_SIZE) & ~(TRB_MAX_BUFF_SIZE - 1), 1421 (unsigned int) (addr + TRB_MAX_BUFF_SIZE) & ~(TRB_MAX_BUFF_SIZE - 1),
1315 (unsigned int) addr + trb_buff_len); 1422 (unsigned int) addr + trb_buff_len);
1316 } 1423 }
1424 length_field = TRB_LEN(trb_buff_len) |
1425 TD_REMAINDER(urb->transfer_buffer_length - running_total) |
1426 TRB_INTR_TARGET(0);
1317 queue_trb(xhci, ep_ring, false, 1427 queue_trb(xhci, ep_ring, false,
1318 (u32) addr, 1428 lower_32_bits(addr),
1319 (u32) ((u64) addr >> 32), 1429 upper_32_bits(addr),
1320 TRB_LEN(trb_buff_len) | TRB_INTR_TARGET(0), 1430 length_field,
1321 /* We always want to know if the TRB was short, 1431 /* We always want to know if the TRB was short,
1322 * or we won't get an event when it completes. 1432 * or we won't get an event when it completes.
1323 * (Unless we use event data TRBs, which are a 1433 * (Unless we use event data TRBs, which are a
@@ -1365,7 +1475,7 @@ int xhci_queue_bulk_tx(struct xhci_hcd *xhci, gfp_t mem_flags,
1365 struct xhci_generic_trb *start_trb; 1475 struct xhci_generic_trb *start_trb;
1366 bool first_trb; 1476 bool first_trb;
1367 int start_cycle; 1477 int start_cycle;
1368 u32 field; 1478 u32 field, length_field;
1369 1479
1370 int running_total, trb_buff_len, ret; 1480 int running_total, trb_buff_len, ret;
1371 u64 addr; 1481 u64 addr;
@@ -1443,10 +1553,13 @@ int xhci_queue_bulk_tx(struct xhci_hcd *xhci, gfp_t mem_flags,
1443 td->last_trb = ep_ring->enqueue; 1553 td->last_trb = ep_ring->enqueue;
1444 field |= TRB_IOC; 1554 field |= TRB_IOC;
1445 } 1555 }
1556 length_field = TRB_LEN(trb_buff_len) |
1557 TD_REMAINDER(urb->transfer_buffer_length - running_total) |
1558 TRB_INTR_TARGET(0);
1446 queue_trb(xhci, ep_ring, false, 1559 queue_trb(xhci, ep_ring, false,
1447 (u32) addr, 1560 lower_32_bits(addr),
1448 (u32) ((u64) addr >> 32), 1561 upper_32_bits(addr),
1449 TRB_LEN(trb_buff_len) | TRB_INTR_TARGET(0), 1562 length_field,
1450 /* We always want to know if the TRB was short, 1563 /* We always want to know if the TRB was short,
1451 * or we won't get an event when it completes. 1564 * or we won't get an event when it completes.
1452 * (Unless we use event data TRBs, which are a 1565 * (Unless we use event data TRBs, which are a
@@ -1478,7 +1591,7 @@ int xhci_queue_ctrl_tx(struct xhci_hcd *xhci, gfp_t mem_flags,
1478 struct usb_ctrlrequest *setup; 1591 struct usb_ctrlrequest *setup;
1479 struct xhci_generic_trb *start_trb; 1592 struct xhci_generic_trb *start_trb;
1480 int start_cycle; 1593 int start_cycle;
1481 u32 field; 1594 u32 field, length_field;
1482 struct xhci_td *td; 1595 struct xhci_td *td;
1483 1596
1484 ep_ring = xhci->devs[slot_id]->ep_rings[ep_index]; 1597 ep_ring = xhci->devs[slot_id]->ep_rings[ep_index];
@@ -1528,13 +1641,16 @@ int xhci_queue_ctrl_tx(struct xhci_hcd *xhci, gfp_t mem_flags,
1528 1641
1529 /* If there's data, queue data TRBs */ 1642 /* If there's data, queue data TRBs */
1530 field = 0; 1643 field = 0;
1644 length_field = TRB_LEN(urb->transfer_buffer_length) |
1645 TD_REMAINDER(urb->transfer_buffer_length) |
1646 TRB_INTR_TARGET(0);
1531 if (urb->transfer_buffer_length > 0) { 1647 if (urb->transfer_buffer_length > 0) {
1532 if (setup->bRequestType & USB_DIR_IN) 1648 if (setup->bRequestType & USB_DIR_IN)
1533 field |= TRB_DIR_IN; 1649 field |= TRB_DIR_IN;
1534 queue_trb(xhci, ep_ring, false, 1650 queue_trb(xhci, ep_ring, false,
1535 lower_32_bits(urb->transfer_dma), 1651 lower_32_bits(urb->transfer_dma),
1536 upper_32_bits(urb->transfer_dma), 1652 upper_32_bits(urb->transfer_dma),
1537 TRB_LEN(urb->transfer_buffer_length) | TRB_INTR_TARGET(0), 1653 length_field,
1538 /* Event on short tx */ 1654 /* Event on short tx */
1539 field | TRB_ISP | TRB_TYPE(TRB_DATA) | ep_ring->cycle_state); 1655 field | TRB_ISP | TRB_TYPE(TRB_DATA) | ep_ring->cycle_state);
1540 } 1656 }
@@ -1603,7 +1719,8 @@ int xhci_queue_slot_control(struct xhci_hcd *xhci, u32 trb_type, u32 slot_id)
1603int xhci_queue_address_device(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr, 1719int xhci_queue_address_device(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr,
1604 u32 slot_id) 1720 u32 slot_id)
1605{ 1721{
1606 return queue_command(xhci, in_ctx_ptr, 0, 0, 1722 return queue_command(xhci, lower_32_bits(in_ctx_ptr),
1723 upper_32_bits(in_ctx_ptr), 0,
1607 TRB_TYPE(TRB_ADDR_DEV) | SLOT_ID_FOR_TRB(slot_id)); 1724 TRB_TYPE(TRB_ADDR_DEV) | SLOT_ID_FOR_TRB(slot_id));
1608} 1725}
1609 1726
@@ -1611,7 +1728,8 @@ int xhci_queue_address_device(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr,
1611int xhci_queue_configure_endpoint(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr, 1728int xhci_queue_configure_endpoint(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr,
1612 u32 slot_id) 1729 u32 slot_id)
1613{ 1730{
1614 return queue_command(xhci, in_ctx_ptr, 0, 0, 1731 return queue_command(xhci, lower_32_bits(in_ctx_ptr),
1732 upper_32_bits(in_ctx_ptr), 0,
1615 TRB_TYPE(TRB_CONFIG_EP) | SLOT_ID_FOR_TRB(slot_id)); 1733 TRB_TYPE(TRB_CONFIG_EP) | SLOT_ID_FOR_TRB(slot_id));
1616} 1734}
1617 1735
@@ -1639,10 +1757,23 @@ static int queue_set_tr_deq(struct xhci_hcd *xhci, int slot_id,
1639 u32 type = TRB_TYPE(TRB_SET_DEQ); 1757 u32 type = TRB_TYPE(TRB_SET_DEQ);
1640 1758
1641 addr = xhci_trb_virt_to_dma(deq_seg, deq_ptr); 1759 addr = xhci_trb_virt_to_dma(deq_seg, deq_ptr);
1642 if (addr == 0) 1760 if (addr == 0) {
1643 xhci_warn(xhci, "WARN Cannot submit Set TR Deq Ptr\n"); 1761 xhci_warn(xhci, "WARN Cannot submit Set TR Deq Ptr\n");
1644 xhci_warn(xhci, "WARN deq seg = %p, deq pt = %p\n", 1762 xhci_warn(xhci, "WARN deq seg = %p, deq pt = %p\n",
1645 deq_seg, deq_ptr); 1763 deq_seg, deq_ptr);
1646 return queue_command(xhci, (u32) addr | cycle_state, 0, 0, 1764 return 0;
1765 }
1766 return queue_command(xhci, lower_32_bits(addr) | cycle_state,
1767 upper_32_bits(addr), 0,
1647 trb_slot_id | trb_ep_index | type); 1768 trb_slot_id | trb_ep_index | type);
1648} 1769}
1770
1771int xhci_queue_reset_ep(struct xhci_hcd *xhci, int slot_id,
1772 unsigned int ep_index)
1773{
1774 u32 trb_slot_id = SLOT_ID_FOR_TRB(slot_id);
1775 u32 trb_ep_index = EP_ID_FOR_TRB(ep_index);
1776 u32 type = TRB_TYPE(TRB_RESET_EP);
1777
1778 return queue_command(xhci, 0, 0, 0, trb_slot_id | trb_ep_index | type);
1779}
diff --git a/drivers/usb/host/xhci.h b/drivers/usb/host/xhci.h
index 8936eeb5588b..d31d32206ba3 100644
--- a/drivers/usb/host/xhci.h
+++ b/drivers/usb/host/xhci.h
@@ -25,6 +25,7 @@
25 25
26#include <linux/usb.h> 26#include <linux/usb.h>
27#include <linux/timer.h> 27#include <linux/timer.h>
28#include <linux/kernel.h>
28 29
29#include "../core/hcd.h" 30#include "../core/hcd.h"
30/* Code sharing between pci-quirks and xhci hcd */ 31/* Code sharing between pci-quirks and xhci hcd */
@@ -42,14 +43,6 @@
42 * xHCI register interface. 43 * xHCI register interface.
43 * This corresponds to the eXtensible Host Controller Interface (xHCI) 44 * This corresponds to the eXtensible Host Controller Interface (xHCI)
44 * Revision 0.95 specification 45 * Revision 0.95 specification
45 *
46 * Registers should always be accessed with double word or quad word accesses.
47 *
48 * Some xHCI implementations may support 64-bit address pointers. Registers
49 * with 64-bit address pointers should be written to with dword accesses by
50 * writing the low dword first (ptr[0]), then the high dword (ptr[1]) second.
51 * xHCI implementations that do not support 64-bit address pointers will ignore
52 * the high dword, and write order is irrelevant.
53 */ 46 */
54 47
55/** 48/**
@@ -96,6 +89,7 @@ struct xhci_cap_regs {
96#define HCS_ERST_MAX(p) (((p) >> 4) & 0xf) 89#define HCS_ERST_MAX(p) (((p) >> 4) & 0xf)
97/* bit 26 Scratchpad restore - for save/restore HW state - not used yet */ 90/* bit 26 Scratchpad restore - for save/restore HW state - not used yet */
98/* bits 27:31 number of Scratchpad buffers SW must allocate for the HW */ 91/* bits 27:31 number of Scratchpad buffers SW must allocate for the HW */
92#define HCS_MAX_SCRATCHPAD(p) (((p) >> 27) & 0x1f)
99 93
100/* HCSPARAMS3 - hcs_params3 - bitmasks */ 94/* HCSPARAMS3 - hcs_params3 - bitmasks */
101/* bits 0:7, Max U1 to U0 latency for the roothub ports */ 95/* bits 0:7, Max U1 to U0 latency for the roothub ports */
@@ -166,10 +160,10 @@ struct xhci_op_regs {
166 u32 reserved1; 160 u32 reserved1;
167 u32 reserved2; 161 u32 reserved2;
168 u32 dev_notification; 162 u32 dev_notification;
169 u32 cmd_ring[2]; 163 u64 cmd_ring;
170 /* rsvd: offset 0x20-2F */ 164 /* rsvd: offset 0x20-2F */
171 u32 reserved3[4]; 165 u32 reserved3[4];
172 u32 dcbaa_ptr[2]; 166 u64 dcbaa_ptr;
173 u32 config_reg; 167 u32 config_reg;
174 /* rsvd: offset 0x3C-3FF */ 168 /* rsvd: offset 0x3C-3FF */
175 u32 reserved4[241]; 169 u32 reserved4[241];
@@ -254,7 +248,7 @@ struct xhci_op_regs {
254#define CMD_RING_RUNNING (1 << 3) 248#define CMD_RING_RUNNING (1 << 3)
255/* bits 4:5 reserved and should be preserved */ 249/* bits 4:5 reserved and should be preserved */
256/* Command Ring pointer - bit mask for the lower 32 bits. */ 250/* Command Ring pointer - bit mask for the lower 32 bits. */
257#define CMD_RING_ADDR_MASK (0xffffffc0) 251#define CMD_RING_RSVD_BITS (0x3f)
258 252
259/* CONFIG - Configure Register - config_reg bitmasks */ 253/* CONFIG - Configure Register - config_reg bitmasks */
260/* bits 0:7 - maximum number of device slots enabled (NumSlotsEn) */ 254/* bits 0:7 - maximum number of device slots enabled (NumSlotsEn) */
@@ -382,8 +376,8 @@ struct xhci_intr_reg {
382 u32 irq_control; 376 u32 irq_control;
383 u32 erst_size; 377 u32 erst_size;
384 u32 rsvd; 378 u32 rsvd;
385 u32 erst_base[2]; 379 u64 erst_base;
386 u32 erst_dequeue[2]; 380 u64 erst_dequeue;
387}; 381};
388 382
389/* irq_pending bitmasks */ 383/* irq_pending bitmasks */
@@ -453,6 +447,27 @@ struct xhci_doorbell_array {
453 447
454 448
455/** 449/**
450 * struct xhci_container_ctx
451 * @type: Type of context. Used to calculated offsets to contained contexts.
452 * @size: Size of the context data
453 * @bytes: The raw context data given to HW
454 * @dma: dma address of the bytes
455 *
456 * Represents either a Device or Input context. Holds a pointer to the raw
457 * memory used for the context (bytes) and dma address of it (dma).
458 */
459struct xhci_container_ctx {
460 unsigned type;
461#define XHCI_CTX_TYPE_DEVICE 0x1
462#define XHCI_CTX_TYPE_INPUT 0x2
463
464 int size;
465
466 u8 *bytes;
467 dma_addr_t dma;
468};
469
470/**
456 * struct xhci_slot_ctx 471 * struct xhci_slot_ctx
457 * @dev_info: Route string, device speed, hub info, and last valid endpoint 472 * @dev_info: Route string, device speed, hub info, and last valid endpoint
458 * @dev_info2: Max exit latency for device number, root hub port number 473 * @dev_info2: Max exit latency for device number, root hub port number
@@ -538,7 +553,7 @@ struct xhci_slot_ctx {
538struct xhci_ep_ctx { 553struct xhci_ep_ctx {
539 u32 ep_info; 554 u32 ep_info;
540 u32 ep_info2; 555 u32 ep_info2;
541 u32 deq[2]; 556 u64 deq;
542 u32 tx_info; 557 u32 tx_info;
543 /* offset 0x14 - 0x1f reserved for HC internal use */ 558 /* offset 0x14 - 0x1f reserved for HC internal use */
544 u32 reserved[3]; 559 u32 reserved[3];
@@ -589,18 +604,16 @@ struct xhci_ep_ctx {
589 604
590 605
591/** 606/**
592 * struct xhci_device_control 607 * struct xhci_input_control_context
593 * Input/Output context; see section 6.2.5. 608 * Input control context; see section 6.2.5.
594 * 609 *
595 * @drop_context: set the bit of the endpoint context you want to disable 610 * @drop_context: set the bit of the endpoint context you want to disable
596 * @add_context: set the bit of the endpoint context you want to enable 611 * @add_context: set the bit of the endpoint context you want to enable
597 */ 612 */
598struct xhci_device_control { 613struct xhci_input_control_ctx {
599 u32 drop_flags; 614 u32 drop_flags;
600 u32 add_flags; 615 u32 add_flags;
601 u32 rsvd[6]; 616 u32 rsvd2[6];
602 struct xhci_slot_ctx slot;
603 struct xhci_ep_ctx ep[31];
604}; 617};
605 618
606/* drop context bitmasks */ 619/* drop context bitmasks */
@@ -608,7 +621,6 @@ struct xhci_device_control {
608/* add context bitmasks */ 621/* add context bitmasks */
609#define ADD_EP(x) (0x1 << x) 622#define ADD_EP(x) (0x1 << x)
610 623
611
612struct xhci_virt_device { 624struct xhci_virt_device {
613 /* 625 /*
614 * Commands to the hardware are passed an "input context" that 626 * Commands to the hardware are passed an "input context" that
@@ -618,11 +630,10 @@ struct xhci_virt_device {
618 * track of input and output contexts separately because 630 * track of input and output contexts separately because
619 * these commands might fail and we don't trust the hardware. 631 * these commands might fail and we don't trust the hardware.
620 */ 632 */
621 struct xhci_device_control *out_ctx; 633 struct xhci_container_ctx *out_ctx;
622 dma_addr_t out_ctx_dma;
623 /* Used for addressing devices and configuration changes */ 634 /* Used for addressing devices and configuration changes */
624 struct xhci_device_control *in_ctx; 635 struct xhci_container_ctx *in_ctx;
625 dma_addr_t in_ctx_dma; 636
626 /* FIXME when stream support is added */ 637 /* FIXME when stream support is added */
627 struct xhci_ring *ep_rings[31]; 638 struct xhci_ring *ep_rings[31];
628 /* Temporary storage in case the configure endpoint command fails and we 639 /* Temporary storage in case the configure endpoint command fails and we
@@ -641,7 +652,7 @@ struct xhci_virt_device {
641 */ 652 */
642struct xhci_device_context_array { 653struct xhci_device_context_array {
643 /* 64-bit device addresses; we only write 32-bit addresses */ 654 /* 64-bit device addresses; we only write 32-bit addresses */
644 u32 dev_context_ptrs[2*MAX_HC_SLOTS]; 655 u64 dev_context_ptrs[MAX_HC_SLOTS];
645 /* private xHCD pointers */ 656 /* private xHCD pointers */
646 dma_addr_t dma; 657 dma_addr_t dma;
647}; 658};
@@ -654,7 +665,7 @@ struct xhci_device_context_array {
654 665
655struct xhci_stream_ctx { 666struct xhci_stream_ctx {
656 /* 64-bit stream ring address, cycle state, and stream type */ 667 /* 64-bit stream ring address, cycle state, and stream type */
657 u32 stream_ring[2]; 668 u64 stream_ring;
658 /* offset 0x14 - 0x1f reserved for HC internal use */ 669 /* offset 0x14 - 0x1f reserved for HC internal use */
659 u32 reserved[2]; 670 u32 reserved[2];
660}; 671};
@@ -662,7 +673,7 @@ struct xhci_stream_ctx {
662 673
663struct xhci_transfer_event { 674struct xhci_transfer_event {
664 /* 64-bit buffer address, or immediate data */ 675 /* 64-bit buffer address, or immediate data */
665 u32 buffer[2]; 676 u64 buffer;
666 u32 transfer_len; 677 u32 transfer_len;
667 /* This field is interpreted differently based on the type of TRB */ 678 /* This field is interpreted differently based on the type of TRB */
668 u32 flags; 679 u32 flags;
@@ -744,7 +755,7 @@ struct xhci_transfer_event {
744 755
745struct xhci_link_trb { 756struct xhci_link_trb {
746 /* 64-bit segment pointer*/ 757 /* 64-bit segment pointer*/
747 u32 segment_ptr[2]; 758 u64 segment_ptr;
748 u32 intr_target; 759 u32 intr_target;
749 u32 control; 760 u32 control;
750}; 761};
@@ -755,7 +766,7 @@ struct xhci_link_trb {
755/* Command completion event TRB */ 766/* Command completion event TRB */
756struct xhci_event_cmd { 767struct xhci_event_cmd {
757 /* Pointer to command TRB, or the value passed by the event data trb */ 768 /* Pointer to command TRB, or the value passed by the event data trb */
758 u32 cmd_trb[2]; 769 u64 cmd_trb;
759 u32 status; 770 u32 status;
760 u32 flags; 771 u32 flags;
761}; 772};
@@ -848,8 +859,8 @@ union xhci_trb {
848#define TRB_CONFIG_EP 12 859#define TRB_CONFIG_EP 12
849/* Evaluate Context Command */ 860/* Evaluate Context Command */
850#define TRB_EVAL_CONTEXT 13 861#define TRB_EVAL_CONTEXT 13
851/* Reset Transfer Ring Command */ 862/* Reset Endpoint Command */
852#define TRB_RESET_RING 14 863#define TRB_RESET_EP 14
853/* Stop Transfer Ring Command */ 864/* Stop Transfer Ring Command */
854#define TRB_STOP_RING 15 865#define TRB_STOP_RING 15
855/* Set Transfer Ring Dequeue Pointer Command */ 866/* Set Transfer Ring Dequeue Pointer Command */
@@ -929,6 +940,7 @@ struct xhci_ring {
929 unsigned int cancels_pending; 940 unsigned int cancels_pending;
930 unsigned int state; 941 unsigned int state;
931#define SET_DEQ_PENDING (1 << 0) 942#define SET_DEQ_PENDING (1 << 0)
943#define EP_HALTED (1 << 1)
932 /* The TRB that was last reported in a stopped endpoint ring */ 944 /* The TRB that was last reported in a stopped endpoint ring */
933 union xhci_trb *stopped_trb; 945 union xhci_trb *stopped_trb;
934 struct xhci_td *stopped_td; 946 struct xhci_td *stopped_td;
@@ -940,9 +952,15 @@ struct xhci_ring {
940 u32 cycle_state; 952 u32 cycle_state;
941}; 953};
942 954
955struct xhci_dequeue_state {
956 struct xhci_segment *new_deq_seg;
957 union xhci_trb *new_deq_ptr;
958 int new_cycle_state;
959};
960
943struct xhci_erst_entry { 961struct xhci_erst_entry {
944 /* 64-bit event ring segment address */ 962 /* 64-bit event ring segment address */
945 u32 seg_addr[2]; 963 u64 seg_addr;
946 u32 seg_size; 964 u32 seg_size;
947 /* Set to zero */ 965 /* Set to zero */
948 u32 rsvd; 966 u32 rsvd;
@@ -957,6 +975,13 @@ struct xhci_erst {
957 unsigned int erst_size; 975 unsigned int erst_size;
958}; 976};
959 977
978struct xhci_scratchpad {
979 u64 *sp_array;
980 dma_addr_t sp_dma;
981 void **sp_buffers;
982 dma_addr_t *sp_dma_buffers;
983};
984
960/* 985/*
961 * Each segment table entry is 4*32bits long. 1K seems like an ok size: 986 * Each segment table entry is 4*32bits long. 1K seems like an ok size:
962 * (1K bytes * 8bytes/bit) / (4*32 bits) = 64 segment entries in the table, 987 * (1K bytes * 8bytes/bit) / (4*32 bits) = 64 segment entries in the table,
@@ -1011,6 +1036,9 @@ struct xhci_hcd {
1011 struct xhci_ring *cmd_ring; 1036 struct xhci_ring *cmd_ring;
1012 struct xhci_ring *event_ring; 1037 struct xhci_ring *event_ring;
1013 struct xhci_erst erst; 1038 struct xhci_erst erst;
1039 /* Scratchpad */
1040 struct xhci_scratchpad *scratchpad;
1041
1014 /* slot enabling and address device helpers */ 1042 /* slot enabling and address device helpers */
1015 struct completion addr_dev; 1043 struct completion addr_dev;
1016 int slot_id; 1044 int slot_id;
@@ -1071,13 +1099,43 @@ static inline unsigned int xhci_readl(const struct xhci_hcd *xhci,
1071static inline void xhci_writel(struct xhci_hcd *xhci, 1099static inline void xhci_writel(struct xhci_hcd *xhci,
1072 const unsigned int val, __u32 __iomem *regs) 1100 const unsigned int val, __u32 __iomem *regs)
1073{ 1101{
1074 if (!in_interrupt()) 1102 xhci_dbg(xhci,
1075 xhci_dbg(xhci, 1103 "`MEM_WRITE_DWORD(3'b000, 32'h%p, 32'h%0x, 4'hf);\n",
1076 "`MEM_WRITE_DWORD(3'b000, 32'h%p, 32'h%0x, 4'hf);\n", 1104 regs, val);
1077 regs, val);
1078 writel(val, regs); 1105 writel(val, regs);
1079} 1106}
1080 1107
1108/*
1109 * Registers should always be accessed with double word or quad word accesses.
1110 *
1111 * Some xHCI implementations may support 64-bit address pointers. Registers
1112 * with 64-bit address pointers should be written to with dword accesses by
1113 * writing the low dword first (ptr[0]), then the high dword (ptr[1]) second.
1114 * xHCI implementations that do not support 64-bit address pointers will ignore
1115 * the high dword, and write order is irrelevant.
1116 */
1117static inline u64 xhci_read_64(const struct xhci_hcd *xhci,
1118 __u64 __iomem *regs)
1119{
1120 __u32 __iomem *ptr = (__u32 __iomem *) regs;
1121 u64 val_lo = readl(ptr);
1122 u64 val_hi = readl(ptr + 1);
1123 return val_lo + (val_hi << 32);
1124}
1125static inline void xhci_write_64(struct xhci_hcd *xhci,
1126 const u64 val, __u64 __iomem *regs)
1127{
1128 __u32 __iomem *ptr = (__u32 __iomem *) regs;
1129 u32 val_lo = lower_32_bits(val);
1130 u32 val_hi = upper_32_bits(val);
1131
1132 xhci_dbg(xhci,
1133 "`MEM_WRITE_DWORD(3'b000, 64'h%p, 64'h%0lx, 4'hf);\n",
1134 regs, (long unsigned int) val);
1135 writel(val_lo, ptr);
1136 writel(val_hi, ptr + 1);
1137}
1138
1081/* xHCI debugging */ 1139/* xHCI debugging */
1082void xhci_print_ir_set(struct xhci_hcd *xhci, struct xhci_intr_reg *ir_set, int set_num); 1140void xhci_print_ir_set(struct xhci_hcd *xhci, struct xhci_intr_reg *ir_set, int set_num);
1083void xhci_print_registers(struct xhci_hcd *xhci); 1141void xhci_print_registers(struct xhci_hcd *xhci);
@@ -1090,7 +1148,7 @@ void xhci_debug_ring(struct xhci_hcd *xhci, struct xhci_ring *ring);
1090void xhci_dbg_erst(struct xhci_hcd *xhci, struct xhci_erst *erst); 1148void xhci_dbg_erst(struct xhci_hcd *xhci, struct xhci_erst *erst);
1091void xhci_dbg_cmd_ptrs(struct xhci_hcd *xhci); 1149void xhci_dbg_cmd_ptrs(struct xhci_hcd *xhci);
1092void xhci_dbg_ring_ptrs(struct xhci_hcd *xhci, struct xhci_ring *ring); 1150void xhci_dbg_ring_ptrs(struct xhci_hcd *xhci, struct xhci_ring *ring);
1093void xhci_dbg_ctx(struct xhci_hcd *xhci, struct xhci_device_control *ctx, dma_addr_t dma, unsigned int last_ep); 1151void xhci_dbg_ctx(struct xhci_hcd *xhci, struct xhci_container_ctx *ctx, unsigned int last_ep);
1094 1152
1095/* xHCI memory managment */ 1153/* xHCI memory managment */
1096void xhci_mem_cleanup(struct xhci_hcd *xhci); 1154void xhci_mem_cleanup(struct xhci_hcd *xhci);
@@ -1128,6 +1186,7 @@ int xhci_urb_enqueue(struct usb_hcd *hcd, struct urb *urb, gfp_t mem_flags);
1128int xhci_urb_dequeue(struct usb_hcd *hcd, struct urb *urb, int status); 1186int xhci_urb_dequeue(struct usb_hcd *hcd, struct urb *urb, int status);
1129int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev, struct usb_host_endpoint *ep); 1187int xhci_add_endpoint(struct usb_hcd *hcd, struct usb_device *udev, struct usb_host_endpoint *ep);
1130int xhci_drop_endpoint(struct usb_hcd *hcd, struct usb_device *udev, struct usb_host_endpoint *ep); 1188int xhci_drop_endpoint(struct usb_hcd *hcd, struct usb_device *udev, struct usb_host_endpoint *ep);
1189void xhci_endpoint_reset(struct usb_hcd *hcd, struct usb_host_endpoint *ep);
1131int xhci_check_bandwidth(struct usb_hcd *hcd, struct usb_device *udev); 1190int xhci_check_bandwidth(struct usb_hcd *hcd, struct usb_device *udev);
1132void xhci_reset_bandwidth(struct usb_hcd *hcd, struct usb_device *udev); 1191void xhci_reset_bandwidth(struct usb_hcd *hcd, struct usb_device *udev);
1133 1192
@@ -1148,10 +1207,23 @@ int xhci_queue_bulk_tx(struct xhci_hcd *xhci, gfp_t mem_flags, struct urb *urb,
1148 int slot_id, unsigned int ep_index); 1207 int slot_id, unsigned int ep_index);
1149int xhci_queue_configure_endpoint(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr, 1208int xhci_queue_configure_endpoint(struct xhci_hcd *xhci, dma_addr_t in_ctx_ptr,
1150 u32 slot_id); 1209 u32 slot_id);
1210int xhci_queue_reset_ep(struct xhci_hcd *xhci, int slot_id,
1211 unsigned int ep_index);
1212void xhci_find_new_dequeue_state(struct xhci_hcd *xhci,
1213 unsigned int slot_id, unsigned int ep_index,
1214 struct xhci_td *cur_td, struct xhci_dequeue_state *state);
1215void xhci_queue_new_dequeue_state(struct xhci_hcd *xhci,
1216 struct xhci_ring *ep_ring, unsigned int slot_id,
1217 unsigned int ep_index, struct xhci_dequeue_state *deq_state);
1151 1218
1152/* xHCI roothub code */ 1219/* xHCI roothub code */
1153int xhci_hub_control(struct usb_hcd *hcd, u16 typeReq, u16 wValue, u16 wIndex, 1220int xhci_hub_control(struct usb_hcd *hcd, u16 typeReq, u16 wValue, u16 wIndex,
1154 char *buf, u16 wLength); 1221 char *buf, u16 wLength);
1155int xhci_hub_status_data(struct usb_hcd *hcd, char *buf); 1222int xhci_hub_status_data(struct usb_hcd *hcd, char *buf);
1156 1223
1224/* xHCI contexts */
1225struct xhci_input_control_ctx *xhci_get_input_control_ctx(struct xhci_hcd *xhci, struct xhci_container_ctx *ctx);
1226struct xhci_slot_ctx *xhci_get_slot_ctx(struct xhci_hcd *xhci, struct xhci_container_ctx *ctx);
1227struct xhci_ep_ctx *xhci_get_ep_ctx(struct xhci_hcd *xhci, struct xhci_container_ctx *ctx, unsigned int ep_index);
1228
1157#endif /* __LINUX_XHCI_HCD_H */ 1229#endif /* __LINUX_XHCI_HCD_H */
diff --git a/drivers/usb/misc/Kconfig b/drivers/usb/misc/Kconfig
index a68d91a11bee..abe3aa67ed00 100644
--- a/drivers/usb/misc/Kconfig
+++ b/drivers/usb/misc/Kconfig
@@ -220,7 +220,7 @@ config USB_IOWARRIOR
220 220
221config USB_TEST 221config USB_TEST
222 tristate "USB testing driver" 222 tristate "USB testing driver"
223 depends on USB && USB_DEVICEFS 223 depends on USB
224 help 224 help
225 This driver is for testing host controller software. It is used 225 This driver is for testing host controller software. It is used
226 with specialized device firmware for regression and stress testing, 226 with specialized device firmware for regression and stress testing,
diff --git a/drivers/usb/musb/musb_core.c b/drivers/usb/musb/musb_core.c
index 1191928902f4..1d26beddf2ca 100644
--- a/drivers/usb/musb/musb_core.c
+++ b/drivers/usb/musb/musb_core.c
@@ -1326,7 +1326,6 @@ static int __init musb_core_init(u16 musb_type, struct musb *musb)
1326 int i; 1326 int i;
1327 1327
1328 /* log core options (read using indexed model) */ 1328 /* log core options (read using indexed model) */
1329 musb_ep_select(mbase, 0);
1330 reg = musb_read_configdata(mbase); 1329 reg = musb_read_configdata(mbase);
1331 1330
1332 strcpy(aInfo, (reg & MUSB_CONFIGDATA_UTMIDW) ? "UTMI-16" : "UTMI-8"); 1331 strcpy(aInfo, (reg & MUSB_CONFIGDATA_UTMIDW) ? "UTMI-16" : "UTMI-8");
@@ -1990,7 +1989,7 @@ bad_config:
1990 if (status < 0) 1989 if (status < 0)
1991 goto fail2; 1990 goto fail2;
1992 1991
1993#ifdef CONFIG_USB_OTG 1992#ifdef CONFIG_USB_MUSB_OTG
1994 setup_timer(&musb->otg_timer, musb_otg_timer_func, (unsigned long) musb); 1993 setup_timer(&musb->otg_timer, musb_otg_timer_func, (unsigned long) musb);
1995#endif 1994#endif
1996 1995
diff --git a/drivers/usb/musb/musb_gadget_ep0.c b/drivers/usb/musb/musb_gadget_ep0.c
index 40ed50ecedff..7a6778675ad3 100644
--- a/drivers/usb/musb/musb_gadget_ep0.c
+++ b/drivers/usb/musb/musb_gadget_ep0.c
@@ -407,7 +407,7 @@ stall:
407 csr |= MUSB_RXCSR_P_SENDSTALL 407 csr |= MUSB_RXCSR_P_SENDSTALL
408 | MUSB_RXCSR_FLUSHFIFO 408 | MUSB_RXCSR_FLUSHFIFO
409 | MUSB_RXCSR_CLRDATATOG 409 | MUSB_RXCSR_CLRDATATOG
410 | MUSB_TXCSR_P_WZC_BITS; 410 | MUSB_RXCSR_P_WZC_BITS;
411 musb_writew(regs, MUSB_RXCSR, 411 musb_writew(regs, MUSB_RXCSR,
412 csr); 412 csr);
413 } 413 }
diff --git a/drivers/usb/musb/musb_regs.h b/drivers/usb/musb/musb_regs.h
index de3b2f18db44..fbfd3fd9ce1f 100644
--- a/drivers/usb/musb/musb_regs.h
+++ b/drivers/usb/musb/musb_regs.h
@@ -323,6 +323,7 @@ static inline void musb_write_rxfifoadd(void __iomem *mbase, u16 c_off)
323 323
324static inline u8 musb_read_configdata(void __iomem *mbase) 324static inline u8 musb_read_configdata(void __iomem *mbase)
325{ 325{
326 musb_writeb(mbase, MUSB_INDEX, 0);
326 return musb_readb(mbase, 0x10 + MUSB_CONFIGDATA); 327 return musb_readb(mbase, 0x10 + MUSB_CONFIGDATA);
327} 328}
328 329
diff --git a/drivers/usb/serial/cp210x.c b/drivers/usb/serial/cp210x.c
index e9a40b820fd4..985cbcf48bda 100644
--- a/drivers/usb/serial/cp210x.c
+++ b/drivers/usb/serial/cp210x.c
@@ -80,6 +80,7 @@ static struct usb_device_id id_table [] = {
80 { USB_DEVICE(0x10C4, 0x80F6) }, /* Suunto sports instrument */ 80 { USB_DEVICE(0x10C4, 0x80F6) }, /* Suunto sports instrument */
81 { USB_DEVICE(0x10C4, 0x8115) }, /* Arygon NFC/Mifare Reader */ 81 { USB_DEVICE(0x10C4, 0x8115) }, /* Arygon NFC/Mifare Reader */
82 { USB_DEVICE(0x10C4, 0x813D) }, /* Burnside Telecom Deskmobile */ 82 { USB_DEVICE(0x10C4, 0x813D) }, /* Burnside Telecom Deskmobile */
83 { USB_DEVICE(0x10C4, 0x813F) }, /* Tams Master Easy Control */
83 { USB_DEVICE(0x10C4, 0x814A) }, /* West Mountain Radio RIGblaster P&P */ 84 { USB_DEVICE(0x10C4, 0x814A) }, /* West Mountain Radio RIGblaster P&P */
84 { USB_DEVICE(0x10C4, 0x814B) }, /* West Mountain Radio RIGtalk */ 85 { USB_DEVICE(0x10C4, 0x814B) }, /* West Mountain Radio RIGtalk */
85 { USB_DEVICE(0x10C4, 0x815E) }, /* Helicomm IP-Link 1220-DVM */ 86 { USB_DEVICE(0x10C4, 0x815E) }, /* Helicomm IP-Link 1220-DVM */
@@ -96,7 +97,9 @@ static struct usb_device_id id_table [] = {
96 { USB_DEVICE(0x10c4, 0x8293) }, /* Telegesys ETRX2USB */ 97 { USB_DEVICE(0x10c4, 0x8293) }, /* Telegesys ETRX2USB */
97 { USB_DEVICE(0x10C4, 0x82F9) }, /* Procyon AVS */ 98 { USB_DEVICE(0x10C4, 0x82F9) }, /* Procyon AVS */
98 { USB_DEVICE(0x10C4, 0x8341) }, /* Siemens MC35PU GPRS Modem */ 99 { USB_DEVICE(0x10C4, 0x8341) }, /* Siemens MC35PU GPRS Modem */
100 { USB_DEVICE(0x10C4, 0x8382) }, /* Cygnal Integrated Products, Inc. */
99 { USB_DEVICE(0x10C4, 0x83A8) }, /* Amber Wireless AMB2560 */ 101 { USB_DEVICE(0x10C4, 0x83A8) }, /* Amber Wireless AMB2560 */
102 { USB_DEVICE(0x10C4, 0x8411) }, /* Kyocera GPS Module */
100 { USB_DEVICE(0x10C4, 0x846E) }, /* BEI USB Sensor Interface (VCP) */ 103 { USB_DEVICE(0x10C4, 0x846E) }, /* BEI USB Sensor Interface (VCP) */
101 { USB_DEVICE(0x10C4, 0xEA60) }, /* Silicon Labs factory default */ 104 { USB_DEVICE(0x10C4, 0xEA60) }, /* Silicon Labs factory default */
102 { USB_DEVICE(0x10C4, 0xEA61) }, /* Silicon Labs factory default */ 105 { USB_DEVICE(0x10C4, 0xEA61) }, /* Silicon Labs factory default */
diff --git a/drivers/usb/serial/ftdi_sio.c b/drivers/usb/serial/ftdi_sio.c
index 60c64cc5be2a..b574878c78b2 100644
--- a/drivers/usb/serial/ftdi_sio.c
+++ b/drivers/usb/serial/ftdi_sio.c
@@ -698,6 +698,7 @@ static struct usb_device_id id_table_combined [] = {
698 { USB_DEVICE(MARVELL_VID, MARVELL_SHEEVAPLUG_PID), 698 { USB_DEVICE(MARVELL_VID, MARVELL_SHEEVAPLUG_PID),
699 .driver_info = (kernel_ulong_t)&ftdi_jtag_quirk }, 699 .driver_info = (kernel_ulong_t)&ftdi_jtag_quirk },
700 { USB_DEVICE(LARSENBRUSGAARD_VID, LB_ALTITRACK_PID) }, 700 { USB_DEVICE(LARSENBRUSGAARD_VID, LB_ALTITRACK_PID) },
701 { USB_DEVICE(GN_OTOMETRICS_VID, AURICAL_USB_PID) },
701 { }, /* Optional parameter entry */ 702 { }, /* Optional parameter entry */
702 { } /* Terminating entry */ 703 { } /* Terminating entry */
703}; 704};
diff --git a/drivers/usb/serial/ftdi_sio.h b/drivers/usb/serial/ftdi_sio.h
index c9fbd7415092..24dbd99e87d7 100644
--- a/drivers/usb/serial/ftdi_sio.h
+++ b/drivers/usb/serial/ftdi_sio.h
@@ -947,6 +947,13 @@
947#define FTDI_TURTELIZER_PID 0xBDC8 /* JTAG/RS-232 adapter by egnite GmBH */ 947#define FTDI_TURTELIZER_PID 0xBDC8 /* JTAG/RS-232 adapter by egnite GmBH */
948 948
949/* 949/*
950 * GN Otometrics (http://www.otometrics.com)
951 * Submitted by Ville Sundberg.
952 */
953#define GN_OTOMETRICS_VID 0x0c33 /* Vendor ID */
954#define AURICAL_USB_PID 0x0010 /* Aurical USB Audiometer */
955
956/*
950 * BmRequestType: 1100 0000b 957 * BmRequestType: 1100 0000b
951 * bRequest: FTDI_E2_READ 958 * bRequest: FTDI_E2_READ
952 * wValue: 0 959 * wValue: 0
diff --git a/drivers/usb/serial/mos7840.c b/drivers/usb/serial/mos7840.c
index c31940a307f8..270009afdf77 100644
--- a/drivers/usb/serial/mos7840.c
+++ b/drivers/usb/serial/mos7840.c
@@ -124,10 +124,13 @@
124#define BANDB_DEVICE_ID_USOPTL4_4 0xAC44 124#define BANDB_DEVICE_ID_USOPTL4_4 0xAC44
125#define BANDB_DEVICE_ID_USOPTL4_2 0xAC42 125#define BANDB_DEVICE_ID_USOPTL4_2 0xAC42
126 126
127/* This driver also supports the ATEN UC2324 device since it is mos7840 based 127/* This driver also supports
128 * - if I knew the device id it would also support the ATEN UC2322 */ 128 * ATEN UC2324 device using Moschip MCS7840
129 * ATEN UC2322 device using Moschip MCS7820
130 */
129#define USB_VENDOR_ID_ATENINTL 0x0557 131#define USB_VENDOR_ID_ATENINTL 0x0557
130#define ATENINTL_DEVICE_ID_UC2324 0x2011 132#define ATENINTL_DEVICE_ID_UC2324 0x2011
133#define ATENINTL_DEVICE_ID_UC2322 0x7820
131 134
132/* Interrupt Routine Defines */ 135/* Interrupt Routine Defines */
133 136
@@ -177,6 +180,7 @@ static struct usb_device_id moschip_port_id_table[] = {
177 {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_4)}, 180 {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_4)},
178 {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_2)}, 181 {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_2)},
179 {USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_UC2324)}, 182 {USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_UC2324)},
183 {USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_UC2322)},
180 {} /* terminating entry */ 184 {} /* terminating entry */
181}; 185};
182 186
@@ -186,6 +190,7 @@ static __devinitdata struct usb_device_id moschip_id_table_combined[] = {
186 {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_4)}, 190 {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_4)},
187 {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_2)}, 191 {USB_DEVICE(USB_VENDOR_ID_BANDB, BANDB_DEVICE_ID_USOPTL4_2)},
188 {USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_UC2324)}, 192 {USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_UC2324)},
193 {USB_DEVICE(USB_VENDOR_ID_ATENINTL, ATENINTL_DEVICE_ID_UC2322)},
189 {} /* terminating entry */ 194 {} /* terminating entry */
190}; 195};
191 196
diff --git a/drivers/usb/serial/option.c b/drivers/usb/serial/option.c
index 98262dd552bb..c784ddbe7b61 100644
--- a/drivers/usb/serial/option.c
+++ b/drivers/usb/serial/option.c
@@ -66,8 +66,10 @@ static int option_tiocmget(struct tty_struct *tty, struct file *file);
66static int option_tiocmset(struct tty_struct *tty, struct file *file, 66static int option_tiocmset(struct tty_struct *tty, struct file *file,
67 unsigned int set, unsigned int clear); 67 unsigned int set, unsigned int clear);
68static int option_send_setup(struct usb_serial_port *port); 68static int option_send_setup(struct usb_serial_port *port);
69#ifdef CONFIG_PM
69static int option_suspend(struct usb_serial *serial, pm_message_t message); 70static int option_suspend(struct usb_serial *serial, pm_message_t message);
70static int option_resume(struct usb_serial *serial); 71static int option_resume(struct usb_serial *serial);
72#endif
71 73
72/* Vendor and product IDs */ 74/* Vendor and product IDs */
73#define OPTION_VENDOR_ID 0x0AF0 75#define OPTION_VENDOR_ID 0x0AF0
@@ -205,6 +207,7 @@ static int option_resume(struct usb_serial *serial);
205#define NOVATELWIRELESS_PRODUCT_MC727 0x4100 207#define NOVATELWIRELESS_PRODUCT_MC727 0x4100
206#define NOVATELWIRELESS_PRODUCT_MC950D 0x4400 208#define NOVATELWIRELESS_PRODUCT_MC950D 0x4400
207#define NOVATELWIRELESS_PRODUCT_U727 0x5010 209#define NOVATELWIRELESS_PRODUCT_U727 0x5010
210#define NOVATELWIRELESS_PRODUCT_MC727_NEW 0x5100
208#define NOVATELWIRELESS_PRODUCT_MC760 0x6000 211#define NOVATELWIRELESS_PRODUCT_MC760 0x6000
209#define NOVATELWIRELESS_PRODUCT_OVMC760 0x6002 212#define NOVATELWIRELESS_PRODUCT_OVMC760 0x6002
210 213
@@ -259,11 +262,6 @@ static int option_resume(struct usb_serial *serial);
259#define AXESSTEL_VENDOR_ID 0x1726 262#define AXESSTEL_VENDOR_ID 0x1726
260#define AXESSTEL_PRODUCT_MV110H 0x1000 263#define AXESSTEL_PRODUCT_MV110H 0x1000
261 264
262#define ONDA_VENDOR_ID 0x19d2
263#define ONDA_PRODUCT_MSA501HS 0x0001
264#define ONDA_PRODUCT_ET502HS 0x0002
265#define ONDA_PRODUCT_MT503HS 0x2000
266
267#define BANDRICH_VENDOR_ID 0x1A8D 265#define BANDRICH_VENDOR_ID 0x1A8D
268#define BANDRICH_PRODUCT_C100_1 0x1002 266#define BANDRICH_PRODUCT_C100_1 0x1002
269#define BANDRICH_PRODUCT_C100_2 0x1003 267#define BANDRICH_PRODUCT_C100_2 0x1003
@@ -301,6 +299,7 @@ static int option_resume(struct usb_serial *serial);
301#define ZTE_PRODUCT_MF628 0x0015 299#define ZTE_PRODUCT_MF628 0x0015
302#define ZTE_PRODUCT_MF626 0x0031 300#define ZTE_PRODUCT_MF626 0x0031
303#define ZTE_PRODUCT_CDMA_TECH 0xfffe 301#define ZTE_PRODUCT_CDMA_TECH 0xfffe
302#define ZTE_PRODUCT_AC8710 0xfff1
304 303
305#define BENQ_VENDOR_ID 0x04a5 304#define BENQ_VENDOR_ID 0x04a5
306#define BENQ_PRODUCT_H10 0x4068 305#define BENQ_PRODUCT_H10 0x4068
@@ -322,6 +321,11 @@ static int option_resume(struct usb_serial *serial);
322#define ALINK_VENDOR_ID 0x1e0e 321#define ALINK_VENDOR_ID 0x1e0e
323#define ALINK_PRODUCT_3GU 0x9200 322#define ALINK_PRODUCT_3GU 0x9200
324 323
324/* ALCATEL PRODUCTS */
325#define ALCATEL_VENDOR_ID 0x1bbb
326#define ALCATEL_PRODUCT_X060S 0x0000
327
328
325static struct usb_device_id option_ids[] = { 329static struct usb_device_id option_ids[] = {
326 { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_COLT) }, 330 { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_COLT) },
327 { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA) }, 331 { USB_DEVICE(OPTION_VENDOR_ID, OPTION_PRODUCT_RICOLA) },
@@ -438,6 +442,7 @@ static struct usb_device_id option_ids[] = {
438 { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EU870D) }, /* Novatel EU850D/EU860D/EU870D */ 442 { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_EU870D) }, /* Novatel EU850D/EU860D/EU870D */
439 { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC950D) }, /* Novatel MC930D/MC950D */ 443 { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC950D) }, /* Novatel MC930D/MC950D */
440 { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC727) }, /* Novatel MC727/U727/USB727 */ 444 { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC727) }, /* Novatel MC727/U727/USB727 */
445 { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC727_NEW) }, /* Novatel MC727/U727/USB727 refresh */
441 { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_U727) }, /* Novatel MC727/U727/USB727 */ 446 { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_U727) }, /* Novatel MC727/U727/USB727 */
442 { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC760) }, /* Novatel MC760/U760/USB760 */ 447 { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_MC760) }, /* Novatel MC760/U760/USB760 */
443 { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_OVMC760) }, /* Novatel Ovation MC760 */ 448 { USB_DEVICE(NOVATELWIRELESS_VENDOR_ID, NOVATELWIRELESS_PRODUCT_OVMC760) }, /* Novatel Ovation MC760 */
@@ -474,42 +479,6 @@ static struct usb_device_id option_ids[] = {
474 { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_500A) }, 479 { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_500A) },
475 { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_620UW) }, 480 { USB_DEVICE(ANYDATA_VENDOR_ID, ANYDATA_PRODUCT_ADU_620UW) },
476 { USB_DEVICE(AXESSTEL_VENDOR_ID, AXESSTEL_PRODUCT_MV110H) }, 481 { USB_DEVICE(AXESSTEL_VENDOR_ID, AXESSTEL_PRODUCT_MV110H) },
477 { USB_DEVICE(ONDA_VENDOR_ID, ONDA_PRODUCT_MSA501HS) },
478 { USB_DEVICE(ONDA_VENDOR_ID, ONDA_PRODUCT_ET502HS) },
479 { USB_DEVICE(ONDA_VENDOR_ID, 0x0003) },
480 { USB_DEVICE(ONDA_VENDOR_ID, 0x0004) },
481 { USB_DEVICE(ONDA_VENDOR_ID, 0x0005) },
482 { USB_DEVICE(ONDA_VENDOR_ID, 0x0006) },
483 { USB_DEVICE(ONDA_VENDOR_ID, 0x0007) },
484 { USB_DEVICE(ONDA_VENDOR_ID, 0x0008) },
485 { USB_DEVICE(ONDA_VENDOR_ID, 0x0009) },
486 { USB_DEVICE(ONDA_VENDOR_ID, 0x000a) },
487 { USB_DEVICE(ONDA_VENDOR_ID, 0x000b) },
488 { USB_DEVICE(ONDA_VENDOR_ID, 0x000c) },
489 { USB_DEVICE(ONDA_VENDOR_ID, 0x000d) },
490 { USB_DEVICE(ONDA_VENDOR_ID, 0x000e) },
491 { USB_DEVICE(ONDA_VENDOR_ID, 0x000f) },
492 { USB_DEVICE(ONDA_VENDOR_ID, 0x0010) },
493 { USB_DEVICE(ONDA_VENDOR_ID, 0x0011) },
494 { USB_DEVICE(ONDA_VENDOR_ID, 0x0012) },
495 { USB_DEVICE(ONDA_VENDOR_ID, 0x0013) },
496 { USB_DEVICE(ONDA_VENDOR_ID, 0x0014) },
497 { USB_DEVICE(ONDA_VENDOR_ID, 0x0015) },
498 { USB_DEVICE(ONDA_VENDOR_ID, 0x0016) },
499 { USB_DEVICE(ONDA_VENDOR_ID, 0x0017) },
500 { USB_DEVICE(ONDA_VENDOR_ID, 0x0018) },
501 { USB_DEVICE(ONDA_VENDOR_ID, 0x0019) },
502 { USB_DEVICE(ONDA_VENDOR_ID, 0x0020) },
503 { USB_DEVICE(ONDA_VENDOR_ID, 0x0021) },
504 { USB_DEVICE(ONDA_VENDOR_ID, 0x0022) },
505 { USB_DEVICE(ONDA_VENDOR_ID, 0x0023) },
506 { USB_DEVICE(ONDA_VENDOR_ID, 0x0024) },
507 { USB_DEVICE(ONDA_VENDOR_ID, 0x0025) },
508 { USB_DEVICE(ONDA_VENDOR_ID, 0x0026) },
509 { USB_DEVICE(ONDA_VENDOR_ID, 0x0027) },
510 { USB_DEVICE(ONDA_VENDOR_ID, 0x0028) },
511 { USB_DEVICE(ONDA_VENDOR_ID, 0x0029) },
512 { USB_DEVICE(ONDA_VENDOR_ID, ONDA_PRODUCT_MT503HS) },
513 { USB_DEVICE(YISO_VENDOR_ID, YISO_PRODUCT_U893) }, 482 { USB_DEVICE(YISO_VENDOR_ID, YISO_PRODUCT_U893) },
514 { USB_DEVICE(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_C100_1) }, 483 { USB_DEVICE(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_C100_1) },
515 { USB_DEVICE(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_C100_2) }, 484 { USB_DEVICE(BANDRICH_VENDOR_ID, BANDRICH_PRODUCT_C100_2) },
@@ -534,10 +503,75 @@ static struct usb_device_id option_ids[] = {
534 { USB_DEVICE(QUALCOMM_VENDOR_ID, 0x6613)}, /* Onda H600/ZTE MF330 */ 503 { USB_DEVICE(QUALCOMM_VENDOR_ID, 0x6613)}, /* Onda H600/ZTE MF330 */
535 { USB_DEVICE(MAXON_VENDOR_ID, 0x6280) }, /* BP3-USB & BP3-EXT HSDPA */ 504 { USB_DEVICE(MAXON_VENDOR_ID, 0x6280) }, /* BP3-USB & BP3-EXT HSDPA */
536 { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_UC864E) }, 505 { USB_DEVICE(TELIT_VENDOR_ID, TELIT_PRODUCT_UC864E) },
537 { USB_DEVICE(ZTE_VENDOR_ID, ZTE_PRODUCT_MF622) }, 506 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_MF622, 0xff, 0xff, 0xff) }, /* ZTE WCDMA products */
538 { USB_DEVICE(ZTE_VENDOR_ID, ZTE_PRODUCT_MF626) }, 507 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0002, 0xff, 0xff, 0xff) },
539 { USB_DEVICE(ZTE_VENDOR_ID, ZTE_PRODUCT_MF628) }, 508 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0003, 0xff, 0xff, 0xff) },
540 { USB_DEVICE(ZTE_VENDOR_ID, ZTE_PRODUCT_CDMA_TECH) }, 509 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0004, 0xff, 0xff, 0xff) },
510 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0005, 0xff, 0xff, 0xff) },
511 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0006, 0xff, 0xff, 0xff) },
512 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0007, 0xff, 0xff, 0xff) },
513 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0008, 0xff, 0xff, 0xff) },
514 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0009, 0xff, 0xff, 0xff) },
515 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000a, 0xff, 0xff, 0xff) },
516 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000b, 0xff, 0xff, 0xff) },
517 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000c, 0xff, 0xff, 0xff) },
518 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000d, 0xff, 0xff, 0xff) },
519 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000e, 0xff, 0xff, 0xff) },
520 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x000f, 0xff, 0xff, 0xff) },
521 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0010, 0xff, 0xff, 0xff) },
522 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0011, 0xff, 0xff, 0xff) },
523 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0012, 0xff, 0xff, 0xff) },
524 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0013, 0xff, 0xff, 0xff) },
525 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_MF628, 0xff, 0xff, 0xff) },
526 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0016, 0xff, 0xff, 0xff) },
527 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0017, 0xff, 0xff, 0xff) },
528 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0018, 0xff, 0xff, 0xff) },
529 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0019, 0xff, 0xff, 0xff) },
530 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0020, 0xff, 0xff, 0xff) },
531 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0021, 0xff, 0xff, 0xff) },
532 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0022, 0xff, 0xff, 0xff) },
533 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0023, 0xff, 0xff, 0xff) },
534 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0024, 0xff, 0xff, 0xff) },
535 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0025, 0xff, 0xff, 0xff) },
536 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0026, 0xff, 0xff, 0xff) },
537 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0028, 0xff, 0xff, 0xff) },
538 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0029, 0xff, 0xff, 0xff) },
539 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0030, 0xff, 0xff, 0xff) },
540 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_MF626, 0xff, 0xff, 0xff) },
541 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0032, 0xff, 0xff, 0xff) },
542 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0033, 0xff, 0xff, 0xff) },
543 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0037, 0xff, 0xff, 0xff) },
544 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0039, 0xff, 0xff, 0xff) },
545 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0042, 0xff, 0xff, 0xff) },
546 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0043, 0xff, 0xff, 0xff) },
547 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0048, 0xff, 0xff, 0xff) },
548 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0049, 0xff, 0xff, 0xff) },
549 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0051, 0xff, 0xff, 0xff) },
550 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0052, 0xff, 0xff, 0xff) },
551 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0054, 0xff, 0xff, 0xff) },
552 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0055, 0xff, 0xff, 0xff) },
553 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0057, 0xff, 0xff, 0xff) },
554 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0058, 0xff, 0xff, 0xff) },
555 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0061, 0xff, 0xff, 0xff) },
556 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0062, 0xff, 0xff, 0xff) },
557 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0063, 0xff, 0xff, 0xff) },
558 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0064, 0xff, 0xff, 0xff) },
559 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0066, 0xff, 0xff, 0xff) },
560 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0069, 0xff, 0xff, 0xff) },
561 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0076, 0xff, 0xff, 0xff) },
562 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0078, 0xff, 0xff, 0xff) },
563 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0082, 0xff, 0xff, 0xff) },
564 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0086, 0xff, 0xff, 0xff) },
565 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x2002, 0xff, 0xff, 0xff) },
566 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x2003, 0xff, 0xff, 0xff) },
567 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0014, 0xff, 0xff, 0xff) }, /* ZTE CDMA products */
568 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0027, 0xff, 0xff, 0xff) },
569 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0059, 0xff, 0xff, 0xff) },
570 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0060, 0xff, 0xff, 0xff) },
571 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0070, 0xff, 0xff, 0xff) },
572 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, 0x0073, 0xff, 0xff, 0xff) },
573 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_CDMA_TECH, 0xff, 0xff, 0xff) },
574 { USB_DEVICE_AND_INTERFACE_INFO(ZTE_VENDOR_ID, ZTE_PRODUCT_AC8710, 0xff, 0xff, 0xff) },
541 { USB_DEVICE(BENQ_VENDOR_ID, BENQ_PRODUCT_H10) }, 575 { USB_DEVICE(BENQ_VENDOR_ID, BENQ_PRODUCT_H10) },
542 { USB_DEVICE(DLINK_VENDOR_ID, DLINK_PRODUCT_DWM_652) }, 576 { USB_DEVICE(DLINK_VENDOR_ID, DLINK_PRODUCT_DWM_652) },
543 { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H21_4512) }, 577 { USB_DEVICE(QISDA_VENDOR_ID, QISDA_PRODUCT_H21_4512) },
@@ -547,6 +581,7 @@ static struct usb_device_id option_ids[] = {
547 { USB_DEVICE(TOSHIBA_VENDOR_ID, TOSHIBA_PRODUCT_HSDPA_MINICARD ) }, /* Toshiba 3G HSDPA == Novatel Expedite EU870D MiniCard */ 581 { USB_DEVICE(TOSHIBA_VENDOR_ID, TOSHIBA_PRODUCT_HSDPA_MINICARD ) }, /* Toshiba 3G HSDPA == Novatel Expedite EU870D MiniCard */
548 { USB_DEVICE(ALINK_VENDOR_ID, 0x9000) }, 582 { USB_DEVICE(ALINK_VENDOR_ID, 0x9000) },
549 { USB_DEVICE_AND_INTERFACE_INFO(ALINK_VENDOR_ID, ALINK_PRODUCT_3GU, 0xff, 0xff, 0xff) }, 583 { USB_DEVICE_AND_INTERFACE_INFO(ALINK_VENDOR_ID, ALINK_PRODUCT_3GU, 0xff, 0xff, 0xff) },
584 { USB_DEVICE(ALCATEL_VENDOR_ID, ALCATEL_PRODUCT_X060S) },
550 { } /* Terminating entry */ 585 { } /* Terminating entry */
551}; 586};
552MODULE_DEVICE_TABLE(usb, option_ids); 587MODULE_DEVICE_TABLE(usb, option_ids);
@@ -555,8 +590,10 @@ static struct usb_driver option_driver = {
555 .name = "option", 590 .name = "option",
556 .probe = usb_serial_probe, 591 .probe = usb_serial_probe,
557 .disconnect = usb_serial_disconnect, 592 .disconnect = usb_serial_disconnect,
593#ifdef CONFIG_PM
558 .suspend = usb_serial_suspend, 594 .suspend = usb_serial_suspend,
559 .resume = usb_serial_resume, 595 .resume = usb_serial_resume,
596#endif
560 .id_table = option_ids, 597 .id_table = option_ids,
561 .no_dynamic_id = 1, 598 .no_dynamic_id = 1,
562}; 599};
@@ -588,8 +625,10 @@ static struct usb_serial_driver option_1port_device = {
588 .disconnect = option_disconnect, 625 .disconnect = option_disconnect,
589 .release = option_release, 626 .release = option_release,
590 .read_int_callback = option_instat_callback, 627 .read_int_callback = option_instat_callback,
628#ifdef CONFIG_PM
591 .suspend = option_suspend, 629 .suspend = option_suspend,
592 .resume = option_resume, 630 .resume = option_resume,
631#endif
593}; 632};
594 633
595static int debug; 634static int debug;
@@ -831,7 +870,6 @@ static void option_instat_callback(struct urb *urb)
831 int status = urb->status; 870 int status = urb->status;
832 struct usb_serial_port *port = urb->context; 871 struct usb_serial_port *port = urb->context;
833 struct option_port_private *portdata = usb_get_serial_port_data(port); 872 struct option_port_private *portdata = usb_get_serial_port_data(port);
834 struct usb_serial *serial = port->serial;
835 873
836 dbg("%s", __func__); 874 dbg("%s", __func__);
837 dbg("%s: urb %p port %p has data %p", __func__, urb, port, portdata); 875 dbg("%s: urb %p port %p has data %p", __func__, urb, port, portdata);
@@ -927,7 +965,6 @@ static int option_open(struct tty_struct *tty,
927 struct usb_serial_port *port, struct file *filp) 965 struct usb_serial_port *port, struct file *filp)
928{ 966{
929 struct option_port_private *portdata; 967 struct option_port_private *portdata;
930 struct usb_serial *serial = port->serial;
931 int i, err; 968 int i, err;
932 struct urb *urb; 969 struct urb *urb;
933 970
@@ -1187,6 +1224,7 @@ static void option_release(struct usb_serial *serial)
1187 } 1224 }
1188} 1225}
1189 1226
1227#ifdef CONFIG_PM
1190static int option_suspend(struct usb_serial *serial, pm_message_t message) 1228static int option_suspend(struct usb_serial *serial, pm_message_t message)
1191{ 1229{
1192 dbg("%s entered", __func__); 1230 dbg("%s entered", __func__);
@@ -1245,6 +1283,7 @@ static int option_resume(struct usb_serial *serial)
1245 } 1283 }
1246 return 0; 1284 return 0;
1247} 1285}
1286#endif
1248 1287
1249MODULE_AUTHOR(DRIVER_AUTHOR); 1288MODULE_AUTHOR(DRIVER_AUTHOR);
1250MODULE_DESCRIPTION(DRIVER_DESC); 1289MODULE_DESCRIPTION(DRIVER_DESC);
diff --git a/drivers/usb/storage/transport.c b/drivers/usb/storage/transport.c
index fcb320217218..e20dc525d177 100644
--- a/drivers/usb/storage/transport.c
+++ b/drivers/usb/storage/transport.c
@@ -961,7 +961,7 @@ int usb_stor_Bulk_max_lun(struct us_data *us)
961 US_BULK_GET_MAX_LUN, 961 US_BULK_GET_MAX_LUN,
962 USB_DIR_IN | USB_TYPE_CLASS | 962 USB_DIR_IN | USB_TYPE_CLASS |
963 USB_RECIP_INTERFACE, 963 USB_RECIP_INTERFACE,
964 0, us->ifnum, us->iobuf, 1, HZ); 964 0, us->ifnum, us->iobuf, 1, 10*HZ);
965 965
966 US_DEBUGP("GetMaxLUN command result is %d, data is %d\n", 966 US_DEBUGP("GetMaxLUN command result is %d, data is %d\n",
967 result, us->iobuf[0]); 967 result, us->iobuf[0]);
diff --git a/drivers/video/backlight/jornada720_bl.c b/drivers/video/backlight/jornada720_bl.c
index c3ebb6b41ce1..7aed2565c1bd 100644
--- a/drivers/video/backlight/jornada720_bl.c
+++ b/drivers/video/backlight/jornada720_bl.c
@@ -72,7 +72,7 @@ static int jornada_bl_update_status(struct backlight_device *bd)
72 if (jornada_ssp_byte(SETBRIGHTNESS) != TXDUMMY) { 72 if (jornada_ssp_byte(SETBRIGHTNESS) != TXDUMMY) {
73 printk(KERN_INFO "bl : failed to set brightness\n"); 73 printk(KERN_INFO "bl : failed to set brightness\n");
74 ret = -ETIMEDOUT; 74 ret = -ETIMEDOUT;
75 goto out 75 goto out;
76 } 76 }
77 77
78 /* at this point we expect that the mcu has accepted 78 /* at this point we expect that the mcu has accepted
diff --git a/drivers/video/s3c-fb.c b/drivers/video/s3c-fb.c
index bb63c07e13de..5a72083dc67c 100644
--- a/drivers/video/s3c-fb.c
+++ b/drivers/video/s3c-fb.c
@@ -964,7 +964,7 @@ static int __devexit s3c_fb_remove(struct platform_device *pdev)
964 struct s3c_fb *sfb = platform_get_drvdata(pdev); 964 struct s3c_fb *sfb = platform_get_drvdata(pdev);
965 int win; 965 int win;
966 966
967 for (win = 0; win <= S3C_FB_MAX_WIN; win++) 967 for (win = 0; win < S3C_FB_MAX_WIN; win++)
968 if (sfb->windows[win]) 968 if (sfb->windows[win])
969 s3c_fb_release_win(sfb, sfb->windows[win]); 969 s3c_fb_release_win(sfb, sfb->windows[win]);
970 970
@@ -988,7 +988,7 @@ static int s3c_fb_suspend(struct platform_device *pdev, pm_message_t state)
988 struct s3c_fb_win *win; 988 struct s3c_fb_win *win;
989 int win_no; 989 int win_no;
990 990
991 for (win_no = S3C_FB_MAX_WIN; win_no >= 0; win_no--) { 991 for (win_no = S3C_FB_MAX_WIN - 1; win_no >= 0; win_no--) {
992 win = sfb->windows[win_no]; 992 win = sfb->windows[win_no];
993 if (!win) 993 if (!win)
994 continue; 994 continue;
diff --git a/fs/block_dev.c b/fs/block_dev.c
index 3a6d4fb2a329..94dfda24c06e 100644
--- a/fs/block_dev.c
+++ b/fs/block_dev.c
@@ -564,6 +564,16 @@ struct block_device *bdget(dev_t dev)
564 564
565EXPORT_SYMBOL(bdget); 565EXPORT_SYMBOL(bdget);
566 566
567/**
568 * bdgrab -- Grab a reference to an already referenced block device
569 * @bdev: Block device to grab a reference to.
570 */
571struct block_device *bdgrab(struct block_device *bdev)
572{
573 atomic_inc(&bdev->bd_inode->i_count);
574 return bdev;
575}
576
567long nr_blockdev_pages(void) 577long nr_blockdev_pages(void)
568{ 578{
569 struct block_device *bdev; 579 struct block_device *bdev;
diff --git a/fs/ramfs/file-nommu.c b/fs/ramfs/file-nommu.c
index ebb2c417912c..11f0c06316de 100644
--- a/fs/ramfs/file-nommu.c
+++ b/fs/ramfs/file-nommu.c
@@ -20,6 +20,7 @@
20#include <linux/ramfs.h> 20#include <linux/ramfs.h>
21#include <linux/pagevec.h> 21#include <linux/pagevec.h>
22#include <linux/mman.h> 22#include <linux/mman.h>
23#include <linux/sched.h>
23 24
24#include <asm/uaccess.h> 25#include <asm/uaccess.h>
25#include "internal.h" 26#include "internal.h"
diff --git a/fs/sysfs/dir.c b/fs/sysfs/dir.c
index d88d0fac9fa5..14f2d71ea3ce 100644
--- a/fs/sysfs/dir.c
+++ b/fs/sysfs/dir.c
@@ -939,8 +939,10 @@ again:
939 /* Remove from old parent's list and insert into new parent's list. */ 939 /* Remove from old parent's list and insert into new parent's list. */
940 sysfs_unlink_sibling(sd); 940 sysfs_unlink_sibling(sd);
941 sysfs_get(new_parent_sd); 941 sysfs_get(new_parent_sd);
942 drop_nlink(old_parent->d_inode);
942 sysfs_put(sd->s_parent); 943 sysfs_put(sd->s_parent);
943 sd->s_parent = new_parent_sd; 944 sd->s_parent = new_parent_sd;
945 inc_nlink(new_parent->d_inode);
944 sysfs_link_sibling(sd); 946 sysfs_link_sibling(sd);
945 947
946 out_unlock: 948 out_unlock:
diff --git a/include/drm/radeon_drm.h b/include/drm/radeon_drm.h
index 41862e9a4c20..af4b4826997e 100644
--- a/include/drm/radeon_drm.h
+++ b/include/drm/radeon_drm.h
@@ -506,6 +506,8 @@ typedef struct {
506#define DRM_RADEON_GEM_WAIT_IDLE 0x24 506#define DRM_RADEON_GEM_WAIT_IDLE 0x24
507#define DRM_RADEON_CS 0x26 507#define DRM_RADEON_CS 0x26
508#define DRM_RADEON_INFO 0x27 508#define DRM_RADEON_INFO 0x27
509#define DRM_RADEON_GEM_SET_TILING 0x28
510#define DRM_RADEON_GEM_GET_TILING 0x29
509 511
510#define DRM_IOCTL_RADEON_CP_INIT DRM_IOW( DRM_COMMAND_BASE + DRM_RADEON_CP_INIT, drm_radeon_init_t) 512#define DRM_IOCTL_RADEON_CP_INIT DRM_IOW( DRM_COMMAND_BASE + DRM_RADEON_CP_INIT, drm_radeon_init_t)
511#define DRM_IOCTL_RADEON_CP_START DRM_IO( DRM_COMMAND_BASE + DRM_RADEON_CP_START) 513#define DRM_IOCTL_RADEON_CP_START DRM_IO( DRM_COMMAND_BASE + DRM_RADEON_CP_START)
@@ -544,7 +546,8 @@ typedef struct {
544#define DRM_IOCTL_RADEON_GEM_WAIT_IDLE DRM_IOW(DRM_COMMAND_BASE + DRM_RADEON_GEM_WAIT_IDLE, struct drm_radeon_gem_wait_idle) 546#define DRM_IOCTL_RADEON_GEM_WAIT_IDLE DRM_IOW(DRM_COMMAND_BASE + DRM_RADEON_GEM_WAIT_IDLE, struct drm_radeon_gem_wait_idle)
545#define DRM_IOCTL_RADEON_CS DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_CS, struct drm_radeon_cs) 547#define DRM_IOCTL_RADEON_CS DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_CS, struct drm_radeon_cs)
546#define DRM_IOCTL_RADEON_INFO DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_INFO, struct drm_radeon_info) 548#define DRM_IOCTL_RADEON_INFO DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_INFO, struct drm_radeon_info)
547 549#define DRM_IOCTL_RADEON_SET_TILING DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_GEM_SET_TILING, struct drm_radeon_gem_set_tiling)
550#define DRM_IOCTL_RADEON_GET_TILING DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_GEM_GET_TILING, struct drm_radeon_gem_get_tiling)
548 551
549typedef struct drm_radeon_init { 552typedef struct drm_radeon_init {
550 enum { 553 enum {
@@ -796,6 +799,24 @@ struct drm_radeon_gem_create {
796 uint32_t flags; 799 uint32_t flags;
797}; 800};
798 801
802#define RADEON_TILING_MACRO 0x1
803#define RADEON_TILING_MICRO 0x2
804#define RADEON_TILING_SWAP 0x4
805#define RADEON_TILING_SURFACE 0x8 /* this object requires a surface
806 * when mapped - i.e. front buffer */
807
808struct drm_radeon_gem_set_tiling {
809 uint32_t handle;
810 uint32_t tiling_flags;
811 uint32_t pitch;
812};
813
814struct drm_radeon_gem_get_tiling {
815 uint32_t handle;
816 uint32_t tiling_flags;
817 uint32_t pitch;
818};
819
799struct drm_radeon_gem_mmap { 820struct drm_radeon_gem_mmap {
800 uint32_t handle; 821 uint32_t handle;
801 uint32_t pad; 822 uint32_t pad;
diff --git a/include/drm/ttm/ttm_bo_driver.h b/include/drm/ttm/ttm_bo_driver.h
index 62ed733c52a2..a68829db381a 100644
--- a/include/drm/ttm/ttm_bo_driver.h
+++ b/include/drm/ttm/ttm_bo_driver.h
@@ -121,6 +121,7 @@ struct ttm_backend {
121#define TTM_PAGE_FLAG_SWAPPED (1 << 4) 121#define TTM_PAGE_FLAG_SWAPPED (1 << 4)
122#define TTM_PAGE_FLAG_PERSISTANT_SWAP (1 << 5) 122#define TTM_PAGE_FLAG_PERSISTANT_SWAP (1 << 5)
123#define TTM_PAGE_FLAG_ZERO_ALLOC (1 << 6) 123#define TTM_PAGE_FLAG_ZERO_ALLOC (1 << 6)
124#define TTM_PAGE_FLAG_DMA32 (1 << 7)
124 125
125enum ttm_caching_state { 126enum ttm_caching_state {
126 tt_uncached, 127 tt_uncached,
@@ -353,6 +354,14 @@ struct ttm_bo_driver {
353 int (*sync_obj_flush) (void *sync_obj, void *sync_arg); 354 int (*sync_obj_flush) (void *sync_obj, void *sync_arg);
354 void (*sync_obj_unref) (void **sync_obj); 355 void (*sync_obj_unref) (void **sync_obj);
355 void *(*sync_obj_ref) (void *sync_obj); 356 void *(*sync_obj_ref) (void *sync_obj);
357
358 /* hook to notify driver about a driver move so it
359 * can do tiling things */
360 void (*move_notify)(struct ttm_buffer_object *bo,
361 struct ttm_mem_reg *new_mem);
362 /* notify the driver we are taking a fault on this BO
363 * and have reserved it */
364 void (*fault_reserve_notify)(struct ttm_buffer_object *bo);
356}; 365};
357 366
358#define TTM_NUM_MEM_TYPES 8 367#define TTM_NUM_MEM_TYPES 8
@@ -429,6 +438,8 @@ struct ttm_bo_device {
429 */ 438 */
430 439
431 struct delayed_work wq; 440 struct delayed_work wq;
441
442 bool need_dma32;
432}; 443};
433 444
434/** 445/**
@@ -648,7 +659,14 @@ extern int ttm_bo_device_release(struct ttm_bo_device *bdev);
648extern int ttm_bo_device_init(struct ttm_bo_device *bdev, 659extern int ttm_bo_device_init(struct ttm_bo_device *bdev,
649 struct ttm_mem_global *mem_glob, 660 struct ttm_mem_global *mem_glob,
650 struct ttm_bo_driver *driver, 661 struct ttm_bo_driver *driver,
651 uint64_t file_page_offset); 662 uint64_t file_page_offset, bool need_dma32);
663
664/**
665 * ttm_bo_unmap_virtual
666 *
667 * @bo: tear down the virtual mappings for this BO
668 */
669extern void ttm_bo_unmap_virtual(struct ttm_buffer_object *bo);
652 670
653/** 671/**
654 * ttm_bo_reserve: 672 * ttm_bo_reserve:
diff --git a/include/drm/ttm/ttm_module.h b/include/drm/ttm/ttm_module.h
index 889a4c7958ae..d1d433834e4f 100644
--- a/include/drm/ttm/ttm_module.h
+++ b/include/drm/ttm/ttm_module.h
@@ -33,7 +33,7 @@
33 33
34#include <linux/kernel.h> 34#include <linux/kernel.h>
35 35
36#define TTM_PFX "[TTM]" 36#define TTM_PFX "[TTM] "
37 37
38enum ttm_global_types { 38enum ttm_global_types {
39 TTM_GLOBAL_TTM_MEM = 0, 39 TTM_GLOBAL_TTM_MEM = 0,
diff --git a/include/linux/cgroup.h b/include/linux/cgroup.h
index 665fa70e4094..90bba9e62286 100644
--- a/include/linux/cgroup.h
+++ b/include/linux/cgroup.h
@@ -179,14 +179,11 @@ struct cgroup {
179 */ 179 */
180 struct list_head release_list; 180 struct list_head release_list;
181 181
182 /* pids_mutex protects the fields below */ 182 /* pids_mutex protects pids_list and cached pid arrays. */
183 struct rw_semaphore pids_mutex; 183 struct rw_semaphore pids_mutex;
184 /* Array of process ids in the cgroup */ 184
185 pid_t *tasks_pids; 185 /* Linked list of struct cgroup_pids */
186 /* How many files are using the current tasks_pids array */ 186 struct list_head pids_list;
187 int pids_use_count;
188 /* Length of the current tasks_pids array */
189 int pids_length;
190 187
191 /* For RCU-protected deletion */ 188 /* For RCU-protected deletion */
192 struct rcu_head rcu_head; 189 struct rcu_head rcu_head;
@@ -366,6 +363,23 @@ int cgroup_task_count(const struct cgroup *cgrp);
366int cgroup_is_descendant(const struct cgroup *cgrp, struct task_struct *task); 363int cgroup_is_descendant(const struct cgroup *cgrp, struct task_struct *task);
367 364
368/* 365/*
366 * When the subsys has to access css and may add permanent refcnt to css,
367 * it should take care of racy conditions with rmdir(). Following set of
368 * functions, is for stop/restart rmdir if necessary.
369 * Because these will call css_get/put, "css" should be alive css.
370 *
371 * cgroup_exclude_rmdir();
372 * ...do some jobs which may access arbitrary empty cgroup
373 * cgroup_release_and_wakeup_rmdir();
374 *
375 * When someone removes a cgroup while cgroup_exclude_rmdir() holds it,
376 * it sleeps and cgroup_release_and_wakeup_rmdir() will wake him up.
377 */
378
379void cgroup_exclude_rmdir(struct cgroup_subsys_state *css);
380void cgroup_release_and_wakeup_rmdir(struct cgroup_subsys_state *css);
381
382/*
369 * Control Group subsystem type. 383 * Control Group subsystem type.
370 * See Documentation/cgroups/cgroups.txt for details 384 * See Documentation/cgroups/cgroups.txt for details
371 */ 385 */
diff --git a/include/linux/flex_array.h b/include/linux/flex_array.h
new file mode 100644
index 000000000000..23c1ec79a31b
--- /dev/null
+++ b/include/linux/flex_array.h
@@ -0,0 +1,47 @@
1#ifndef _FLEX_ARRAY_H
2#define _FLEX_ARRAY_H
3
4#include <linux/types.h>
5#include <asm/page.h>
6
7#define FLEX_ARRAY_PART_SIZE PAGE_SIZE
8#define FLEX_ARRAY_BASE_SIZE PAGE_SIZE
9
10struct flex_array_part;
11
12/*
13 * This is meant to replace cases where an array-like
14 * structure has gotten too big to fit into kmalloc()
15 * and the developer is getting tempted to use
16 * vmalloc().
17 */
18
19struct flex_array {
20 union {
21 struct {
22 int element_size;
23 int total_nr_elements;
24 struct flex_array_part *parts[0];
25 };
26 /*
27 * This little trick makes sure that
28 * sizeof(flex_array) == PAGE_SIZE
29 */
30 char padding[FLEX_ARRAY_BASE_SIZE];
31 };
32};
33
34#define FLEX_ARRAY_INIT(size, total) { { {\
35 .element_size = (size), \
36 .total_nr_elements = (total), \
37} } }
38
39struct flex_array *flex_array_alloc(int element_size, int total, gfp_t flags);
40int flex_array_prealloc(struct flex_array *fa, int start, int end, gfp_t flags);
41void flex_array_free(struct flex_array *fa);
42void flex_array_free_parts(struct flex_array *fa);
43int flex_array_put(struct flex_array *fa, int element_nr, void *src,
44 gfp_t flags);
45void *flex_array_get(struct flex_array *fa, int element_nr);
46
47#endif /* _FLEX_ARRAY_H */
diff --git a/include/linux/fs.h b/include/linux/fs.h
index 0872372184fe..a36ffa5a77a4 100644
--- a/include/linux/fs.h
+++ b/include/linux/fs.h
@@ -1946,6 +1946,7 @@ extern void putname(const char *name);
1946extern int register_blkdev(unsigned int, const char *); 1946extern int register_blkdev(unsigned int, const char *);
1947extern void unregister_blkdev(unsigned int, const char *); 1947extern void unregister_blkdev(unsigned int, const char *);
1948extern struct block_device *bdget(dev_t); 1948extern struct block_device *bdget(dev_t);
1949extern struct block_device *bdgrab(struct block_device *bdev);
1949extern void bd_set_size(struct block_device *, loff_t size); 1950extern void bd_set_size(struct block_device *, loff_t size);
1950extern void bd_forget(struct inode *inode); 1951extern void bd_forget(struct inode *inode);
1951extern void bdput(struct block_device *); 1952extern void bdput(struct block_device *);
diff --git a/include/linux/libata.h b/include/linux/libata.h
index 79b6d7fd4ac2..e5b6e33c6571 100644
--- a/include/linux/libata.h
+++ b/include/linux/libata.h
@@ -589,6 +589,7 @@ struct ata_device {
589#endif 589#endif
590 /* n_sector is CLEAR_BEGIN, read comment above CLEAR_BEGIN */ 590 /* n_sector is CLEAR_BEGIN, read comment above CLEAR_BEGIN */
591 u64 n_sectors; /* size of device, if ATA */ 591 u64 n_sectors; /* size of device, if ATA */
592 u64 n_native_sectors; /* native size, if ATA */
592 unsigned int class; /* ATA_DEV_xxx */ 593 unsigned int class; /* ATA_DEV_xxx */
593 unsigned long unpark_deadline; 594 unsigned long unpark_deadline;
594 595
diff --git a/include/linux/pps.h b/include/linux/pps.h
index cfe5c7214ec6..0194ab06177b 100644
--- a/include/linux/pps.h
+++ b/include/linux/pps.h
@@ -22,6 +22,8 @@
22#ifndef _PPS_H_ 22#ifndef _PPS_H_
23#define _PPS_H_ 23#define _PPS_H_
24 24
25#include <linux/types.h>
26
25#define PPS_VERSION "5.3.6" 27#define PPS_VERSION "5.3.6"
26#define PPS_MAX_SOURCES 16 /* should be enough... */ 28#define PPS_MAX_SOURCES 16 /* should be enough... */
27 29
diff --git a/include/linux/tty.h b/include/linux/tty.h
index 1488d8c81aac..e8c6c9136c97 100644
--- a/include/linux/tty.h
+++ b/include/linux/tty.h
@@ -394,6 +394,7 @@ extern void __do_SAK(struct tty_struct *tty);
394extern void disassociate_ctty(int priv); 394extern void disassociate_ctty(int priv);
395extern void no_tty(void); 395extern void no_tty(void);
396extern void tty_flip_buffer_push(struct tty_struct *tty); 396extern void tty_flip_buffer_push(struct tty_struct *tty);
397extern void tty_flush_to_ldisc(struct tty_struct *tty);
397extern void tty_buffer_free_all(struct tty_struct *tty); 398extern void tty_buffer_free_all(struct tty_struct *tty);
398extern void tty_buffer_flush(struct tty_struct *tty); 399extern void tty_buffer_flush(struct tty_struct *tty);
399extern void tty_buffer_init(struct tty_struct *tty); 400extern void tty_buffer_init(struct tty_struct *tty);
diff --git a/include/linux/uio.h b/include/linux/uio.h
index b7fe13883bdb..98c114323a8b 100644
--- a/include/linux/uio.h
+++ b/include/linux/uio.h
@@ -19,15 +19,6 @@ struct iovec
19 __kernel_size_t iov_len; /* Must be size_t (1003.1g) */ 19 __kernel_size_t iov_len; /* Must be size_t (1003.1g) */
20}; 20};
21 21
22#ifdef __KERNEL__
23
24struct kvec {
25 void *iov_base; /* and that should *never* hold a userland pointer */
26 size_t iov_len;
27};
28
29#endif
30
31/* 22/*
32 * UIO_MAXIOV shall be at least 16 1003.1g (5.4.1.1) 23 * UIO_MAXIOV shall be at least 16 1003.1g (5.4.1.1)
33 */ 24 */
@@ -35,6 +26,13 @@ struct kvec {
35#define UIO_FASTIOV 8 26#define UIO_FASTIOV 8
36#define UIO_MAXIOV 1024 27#define UIO_MAXIOV 1024
37 28
29#ifdef __KERNEL__
30
31struct kvec {
32 void *iov_base; /* and that should *never* hold a userland pointer */
33 size_t iov_len;
34};
35
38/* 36/*
39 * Total number of bytes covered by an iovec. 37 * Total number of bytes covered by an iovec.
40 * 38 *
@@ -53,5 +51,6 @@ static inline size_t iov_length(const struct iovec *iov, unsigned long nr_segs)
53} 51}
54 52
55unsigned long iov_shorten(struct iovec *iov, unsigned long nr_segs, size_t to); 53unsigned long iov_shorten(struct iovec *iov, unsigned long nr_segs, size_t to);
54#endif
56 55
57#endif 56#endif
diff --git a/kernel/cgroup.c b/kernel/cgroup.c
index 3737a682cdf5..b6eadfe30e7b 100644
--- a/kernel/cgroup.c
+++ b/kernel/cgroup.c
@@ -47,6 +47,7 @@
47#include <linux/hash.h> 47#include <linux/hash.h>
48#include <linux/namei.h> 48#include <linux/namei.h>
49#include <linux/smp_lock.h> 49#include <linux/smp_lock.h>
50#include <linux/pid_namespace.h>
50 51
51#include <asm/atomic.h> 52#include <asm/atomic.h>
52 53
@@ -734,16 +735,28 @@ static void cgroup_d_remove_dir(struct dentry *dentry)
734 * reference to css->refcnt. In general, this refcnt is expected to goes down 735 * reference to css->refcnt. In general, this refcnt is expected to goes down
735 * to zero, soon. 736 * to zero, soon.
736 * 737 *
737 * CGRP_WAIT_ON_RMDIR flag is modified under cgroup's inode->i_mutex; 738 * CGRP_WAIT_ON_RMDIR flag is set under cgroup's inode->i_mutex;
738 */ 739 */
739DECLARE_WAIT_QUEUE_HEAD(cgroup_rmdir_waitq); 740DECLARE_WAIT_QUEUE_HEAD(cgroup_rmdir_waitq);
740 741
741static void cgroup_wakeup_rmdir_waiters(const struct cgroup *cgrp) 742static void cgroup_wakeup_rmdir_waiter(struct cgroup *cgrp)
742{ 743{
743 if (unlikely(test_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags))) 744 if (unlikely(test_and_clear_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags)))
744 wake_up_all(&cgroup_rmdir_waitq); 745 wake_up_all(&cgroup_rmdir_waitq);
745} 746}
746 747
748void cgroup_exclude_rmdir(struct cgroup_subsys_state *css)
749{
750 css_get(css);
751}
752
753void cgroup_release_and_wakeup_rmdir(struct cgroup_subsys_state *css)
754{
755 cgroup_wakeup_rmdir_waiter(css->cgroup);
756 css_put(css);
757}
758
759
747static int rebind_subsystems(struct cgroupfs_root *root, 760static int rebind_subsystems(struct cgroupfs_root *root,
748 unsigned long final_bits) 761 unsigned long final_bits)
749{ 762{
@@ -960,6 +973,7 @@ static void init_cgroup_housekeeping(struct cgroup *cgrp)
960 INIT_LIST_HEAD(&cgrp->children); 973 INIT_LIST_HEAD(&cgrp->children);
961 INIT_LIST_HEAD(&cgrp->css_sets); 974 INIT_LIST_HEAD(&cgrp->css_sets);
962 INIT_LIST_HEAD(&cgrp->release_list); 975 INIT_LIST_HEAD(&cgrp->release_list);
976 INIT_LIST_HEAD(&cgrp->pids_list);
963 init_rwsem(&cgrp->pids_mutex); 977 init_rwsem(&cgrp->pids_mutex);
964} 978}
965static void init_cgroup_root(struct cgroupfs_root *root) 979static void init_cgroup_root(struct cgroupfs_root *root)
@@ -1357,7 +1371,7 @@ int cgroup_attach_task(struct cgroup *cgrp, struct task_struct *tsk)
1357 * wake up rmdir() waiter. the rmdir should fail since the cgroup 1371 * wake up rmdir() waiter. the rmdir should fail since the cgroup
1358 * is no longer empty. 1372 * is no longer empty.
1359 */ 1373 */
1360 cgroup_wakeup_rmdir_waiters(cgrp); 1374 cgroup_wakeup_rmdir_waiter(cgrp);
1361 return 0; 1375 return 0;
1362} 1376}
1363 1377
@@ -2201,12 +2215,30 @@ err:
2201 return ret; 2215 return ret;
2202} 2216}
2203 2217
2218/*
2219 * Cache pids for all threads in the same pid namespace that are
2220 * opening the same "tasks" file.
2221 */
2222struct cgroup_pids {
2223 /* The node in cgrp->pids_list */
2224 struct list_head list;
2225 /* The cgroup those pids belong to */
2226 struct cgroup *cgrp;
2227 /* The namepsace those pids belong to */
2228 struct pid_namespace *ns;
2229 /* Array of process ids in the cgroup */
2230 pid_t *tasks_pids;
2231 /* How many files are using the this tasks_pids array */
2232 int use_count;
2233 /* Length of the current tasks_pids array */
2234 int length;
2235};
2236
2204static int cmppid(const void *a, const void *b) 2237static int cmppid(const void *a, const void *b)
2205{ 2238{
2206 return *(pid_t *)a - *(pid_t *)b; 2239 return *(pid_t *)a - *(pid_t *)b;
2207} 2240}
2208 2241
2209
2210/* 2242/*
2211 * seq_file methods for the "tasks" file. The seq_file position is the 2243 * seq_file methods for the "tasks" file. The seq_file position is the
2212 * next pid to display; the seq_file iterator is a pointer to the pid 2244 * next pid to display; the seq_file iterator is a pointer to the pid
@@ -2221,45 +2253,47 @@ static void *cgroup_tasks_start(struct seq_file *s, loff_t *pos)
2221 * after a seek to the start). Use a binary-search to find the 2253 * after a seek to the start). Use a binary-search to find the
2222 * next pid to display, if any 2254 * next pid to display, if any
2223 */ 2255 */
2224 struct cgroup *cgrp = s->private; 2256 struct cgroup_pids *cp = s->private;
2257 struct cgroup *cgrp = cp->cgrp;
2225 int index = 0, pid = *pos; 2258 int index = 0, pid = *pos;
2226 int *iter; 2259 int *iter;
2227 2260
2228 down_read(&cgrp->pids_mutex); 2261 down_read(&cgrp->pids_mutex);
2229 if (pid) { 2262 if (pid) {
2230 int end = cgrp->pids_length; 2263 int end = cp->length;
2231 2264
2232 while (index < end) { 2265 while (index < end) {
2233 int mid = (index + end) / 2; 2266 int mid = (index + end) / 2;
2234 if (cgrp->tasks_pids[mid] == pid) { 2267 if (cp->tasks_pids[mid] == pid) {
2235 index = mid; 2268 index = mid;
2236 break; 2269 break;
2237 } else if (cgrp->tasks_pids[mid] <= pid) 2270 } else if (cp->tasks_pids[mid] <= pid)
2238 index = mid + 1; 2271 index = mid + 1;
2239 else 2272 else
2240 end = mid; 2273 end = mid;
2241 } 2274 }
2242 } 2275 }
2243 /* If we're off the end of the array, we're done */ 2276 /* If we're off the end of the array, we're done */
2244 if (index >= cgrp->pids_length) 2277 if (index >= cp->length)
2245 return NULL; 2278 return NULL;
2246 /* Update the abstract position to be the actual pid that we found */ 2279 /* Update the abstract position to be the actual pid that we found */
2247 iter = cgrp->tasks_pids + index; 2280 iter = cp->tasks_pids + index;
2248 *pos = *iter; 2281 *pos = *iter;
2249 return iter; 2282 return iter;
2250} 2283}
2251 2284
2252static void cgroup_tasks_stop(struct seq_file *s, void *v) 2285static void cgroup_tasks_stop(struct seq_file *s, void *v)
2253{ 2286{
2254 struct cgroup *cgrp = s->private; 2287 struct cgroup_pids *cp = s->private;
2288 struct cgroup *cgrp = cp->cgrp;
2255 up_read(&cgrp->pids_mutex); 2289 up_read(&cgrp->pids_mutex);
2256} 2290}
2257 2291
2258static void *cgroup_tasks_next(struct seq_file *s, void *v, loff_t *pos) 2292static void *cgroup_tasks_next(struct seq_file *s, void *v, loff_t *pos)
2259{ 2293{
2260 struct cgroup *cgrp = s->private; 2294 struct cgroup_pids *cp = s->private;
2261 int *p = v; 2295 int *p = v;
2262 int *end = cgrp->tasks_pids + cgrp->pids_length; 2296 int *end = cp->tasks_pids + cp->length;
2263 2297
2264 /* 2298 /*
2265 * Advance to the next pid in the array. If this goes off the 2299 * Advance to the next pid in the array. If this goes off the
@@ -2286,26 +2320,33 @@ static struct seq_operations cgroup_tasks_seq_operations = {
2286 .show = cgroup_tasks_show, 2320 .show = cgroup_tasks_show,
2287}; 2321};
2288 2322
2289static void release_cgroup_pid_array(struct cgroup *cgrp) 2323static void release_cgroup_pid_array(struct cgroup_pids *cp)
2290{ 2324{
2325 struct cgroup *cgrp = cp->cgrp;
2326
2291 down_write(&cgrp->pids_mutex); 2327 down_write(&cgrp->pids_mutex);
2292 BUG_ON(!cgrp->pids_use_count); 2328 BUG_ON(!cp->use_count);
2293 if (!--cgrp->pids_use_count) { 2329 if (!--cp->use_count) {
2294 kfree(cgrp->tasks_pids); 2330 list_del(&cp->list);
2295 cgrp->tasks_pids = NULL; 2331 put_pid_ns(cp->ns);
2296 cgrp->pids_length = 0; 2332 kfree(cp->tasks_pids);
2333 kfree(cp);
2297 } 2334 }
2298 up_write(&cgrp->pids_mutex); 2335 up_write(&cgrp->pids_mutex);
2299} 2336}
2300 2337
2301static int cgroup_tasks_release(struct inode *inode, struct file *file) 2338static int cgroup_tasks_release(struct inode *inode, struct file *file)
2302{ 2339{
2303 struct cgroup *cgrp = __d_cgrp(file->f_dentry->d_parent); 2340 struct seq_file *seq;
2341 struct cgroup_pids *cp;
2304 2342
2305 if (!(file->f_mode & FMODE_READ)) 2343 if (!(file->f_mode & FMODE_READ))
2306 return 0; 2344 return 0;
2307 2345
2308 release_cgroup_pid_array(cgrp); 2346 seq = file->private_data;
2347 cp = seq->private;
2348
2349 release_cgroup_pid_array(cp);
2309 return seq_release(inode, file); 2350 return seq_release(inode, file);
2310} 2351}
2311 2352
@@ -2324,6 +2365,8 @@ static struct file_operations cgroup_tasks_operations = {
2324static int cgroup_tasks_open(struct inode *unused, struct file *file) 2365static int cgroup_tasks_open(struct inode *unused, struct file *file)
2325{ 2366{
2326 struct cgroup *cgrp = __d_cgrp(file->f_dentry->d_parent); 2367 struct cgroup *cgrp = __d_cgrp(file->f_dentry->d_parent);
2368 struct pid_namespace *ns = current->nsproxy->pid_ns;
2369 struct cgroup_pids *cp;
2327 pid_t *pidarray; 2370 pid_t *pidarray;
2328 int npids; 2371 int npids;
2329 int retval; 2372 int retval;
@@ -2350,20 +2393,37 @@ static int cgroup_tasks_open(struct inode *unused, struct file *file)
2350 * array if necessary 2393 * array if necessary
2351 */ 2394 */
2352 down_write(&cgrp->pids_mutex); 2395 down_write(&cgrp->pids_mutex);
2353 kfree(cgrp->tasks_pids); 2396
2354 cgrp->tasks_pids = pidarray; 2397 list_for_each_entry(cp, &cgrp->pids_list, list) {
2355 cgrp->pids_length = npids; 2398 if (ns == cp->ns)
2356 cgrp->pids_use_count++; 2399 goto found;
2400 }
2401
2402 cp = kzalloc(sizeof(*cp), GFP_KERNEL);
2403 if (!cp) {
2404 up_write(&cgrp->pids_mutex);
2405 kfree(pidarray);
2406 return -ENOMEM;
2407 }
2408 cp->cgrp = cgrp;
2409 cp->ns = ns;
2410 get_pid_ns(ns);
2411 list_add(&cp->list, &cgrp->pids_list);
2412found:
2413 kfree(cp->tasks_pids);
2414 cp->tasks_pids = pidarray;
2415 cp->length = npids;
2416 cp->use_count++;
2357 up_write(&cgrp->pids_mutex); 2417 up_write(&cgrp->pids_mutex);
2358 2418
2359 file->f_op = &cgroup_tasks_operations; 2419 file->f_op = &cgroup_tasks_operations;
2360 2420
2361 retval = seq_open(file, &cgroup_tasks_seq_operations); 2421 retval = seq_open(file, &cgroup_tasks_seq_operations);
2362 if (retval) { 2422 if (retval) {
2363 release_cgroup_pid_array(cgrp); 2423 release_cgroup_pid_array(cp);
2364 return retval; 2424 return retval;
2365 } 2425 }
2366 ((struct seq_file *)file->private_data)->private = cgrp; 2426 ((struct seq_file *)file->private_data)->private = cp;
2367 return 0; 2427 return 0;
2368} 2428}
2369 2429
@@ -2696,33 +2756,42 @@ again:
2696 mutex_unlock(&cgroup_mutex); 2756 mutex_unlock(&cgroup_mutex);
2697 2757
2698 /* 2758 /*
2759 * In general, subsystem has no css->refcnt after pre_destroy(). But
2760 * in racy cases, subsystem may have to get css->refcnt after
2761 * pre_destroy() and it makes rmdir return with -EBUSY. This sometimes
2762 * make rmdir return -EBUSY too often. To avoid that, we use waitqueue
2763 * for cgroup's rmdir. CGRP_WAIT_ON_RMDIR is for synchronizing rmdir
2764 * and subsystem's reference count handling. Please see css_get/put
2765 * and css_tryget() and cgroup_wakeup_rmdir_waiter() implementation.
2766 */
2767 set_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags);
2768
2769 /*
2699 * Call pre_destroy handlers of subsys. Notify subsystems 2770 * Call pre_destroy handlers of subsys. Notify subsystems
2700 * that rmdir() request comes. 2771 * that rmdir() request comes.
2701 */ 2772 */
2702 ret = cgroup_call_pre_destroy(cgrp); 2773 ret = cgroup_call_pre_destroy(cgrp);
2703 if (ret) 2774 if (ret) {
2775 clear_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags);
2704 return ret; 2776 return ret;
2777 }
2705 2778
2706 mutex_lock(&cgroup_mutex); 2779 mutex_lock(&cgroup_mutex);
2707 parent = cgrp->parent; 2780 parent = cgrp->parent;
2708 if (atomic_read(&cgrp->count) || !list_empty(&cgrp->children)) { 2781 if (atomic_read(&cgrp->count) || !list_empty(&cgrp->children)) {
2782 clear_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags);
2709 mutex_unlock(&cgroup_mutex); 2783 mutex_unlock(&cgroup_mutex);
2710 return -EBUSY; 2784 return -EBUSY;
2711 } 2785 }
2712 /*
2713 * css_put/get is provided for subsys to grab refcnt to css. In typical
2714 * case, subsystem has no reference after pre_destroy(). But, under
2715 * hierarchy management, some *temporal* refcnt can be hold.
2716 * To avoid returning -EBUSY to a user, waitqueue is used. If subsys
2717 * is really busy, it should return -EBUSY at pre_destroy(). wake_up
2718 * is called when css_put() is called and refcnt goes down to 0.
2719 */
2720 set_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags);
2721 prepare_to_wait(&cgroup_rmdir_waitq, &wait, TASK_INTERRUPTIBLE); 2786 prepare_to_wait(&cgroup_rmdir_waitq, &wait, TASK_INTERRUPTIBLE);
2722
2723 if (!cgroup_clear_css_refs(cgrp)) { 2787 if (!cgroup_clear_css_refs(cgrp)) {
2724 mutex_unlock(&cgroup_mutex); 2788 mutex_unlock(&cgroup_mutex);
2725 schedule(); 2789 /*
2790 * Because someone may call cgroup_wakeup_rmdir_waiter() before
2791 * prepare_to_wait(), we need to check this flag.
2792 */
2793 if (test_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags))
2794 schedule();
2726 finish_wait(&cgroup_rmdir_waitq, &wait); 2795 finish_wait(&cgroup_rmdir_waitq, &wait);
2727 clear_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags); 2796 clear_bit(CGRP_WAIT_ON_RMDIR, &cgrp->flags);
2728 if (signal_pending(current)) 2797 if (signal_pending(current))
@@ -3294,7 +3363,7 @@ void __css_put(struct cgroup_subsys_state *css)
3294 set_bit(CGRP_RELEASABLE, &cgrp->flags); 3363 set_bit(CGRP_RELEASABLE, &cgrp->flags);
3295 check_for_release(cgrp); 3364 check_for_release(cgrp);
3296 } 3365 }
3297 cgroup_wakeup_rmdir_waiters(cgrp); 3366 cgroup_wakeup_rmdir_waiter(cgrp);
3298 } 3367 }
3299 rcu_read_unlock(); 3368 rcu_read_unlock();
3300} 3369}
diff --git a/kernel/fork.c b/kernel/fork.c
index 9b42695f0d14..29b532e718f7 100644
--- a/kernel/fork.c
+++ b/kernel/fork.c
@@ -426,6 +426,7 @@ static struct mm_struct * mm_init(struct mm_struct * mm, struct task_struct *p)
426 init_rwsem(&mm->mmap_sem); 426 init_rwsem(&mm->mmap_sem);
427 INIT_LIST_HEAD(&mm->mmlist); 427 INIT_LIST_HEAD(&mm->mmlist);
428 mm->flags = (current->mm) ? current->mm->flags : default_dump_filter; 428 mm->flags = (current->mm) ? current->mm->flags : default_dump_filter;
429 mm->oom_adj = (current->mm) ? current->mm->oom_adj : 0;
429 mm->core_state = NULL; 430 mm->core_state = NULL;
430 mm->nr_ptes = 0; 431 mm->nr_ptes = 0;
431 set_mm_counter(mm, file_rss, 0); 432 set_mm_counter(mm, file_rss, 0);
diff --git a/kernel/kexec.c b/kernel/kexec.c
index ae1c35201cc8..f336e2107f98 100644
--- a/kernel/kexec.c
+++ b/kernel/kexec.c
@@ -1228,7 +1228,7 @@ static int __init parse_crashkernel_mem(char *cmdline,
1228 } while (*cur++ == ','); 1228 } while (*cur++ == ',');
1229 1229
1230 if (*crash_size > 0) { 1230 if (*crash_size > 0) {
1231 while (*cur != ' ' && *cur != '@') 1231 while (*cur && *cur != ' ' && *cur != '@')
1232 cur++; 1232 cur++;
1233 if (*cur == '@') { 1233 if (*cur == '@') {
1234 cur++; 1234 cur++;
diff --git a/kernel/profile.c b/kernel/profile.c
index 69911b5745eb..419250ebec4d 100644
--- a/kernel/profile.c
+++ b/kernel/profile.c
@@ -117,11 +117,12 @@ int __ref profile_init(void)
117 117
118 cpumask_copy(prof_cpu_mask, cpu_possible_mask); 118 cpumask_copy(prof_cpu_mask, cpu_possible_mask);
119 119
120 prof_buffer = kzalloc(buffer_bytes, GFP_KERNEL); 120 prof_buffer = kzalloc(buffer_bytes, GFP_KERNEL|__GFP_NOWARN);
121 if (prof_buffer) 121 if (prof_buffer)
122 return 0; 122 return 0;
123 123
124 prof_buffer = alloc_pages_exact(buffer_bytes, GFP_KERNEL|__GFP_ZERO); 124 prof_buffer = alloc_pages_exact(buffer_bytes,
125 GFP_KERNEL|__GFP_ZERO|__GFP_NOWARN);
125 if (prof_buffer) 126 if (prof_buffer)
126 return 0; 127 return 0;
127 128
diff --git a/lib/Makefile b/lib/Makefile
index b6d1857bbf08..2e78277eff9d 100644
--- a/lib/Makefile
+++ b/lib/Makefile
@@ -12,7 +12,7 @@ lib-y := ctype.o string.o vsprintf.o cmdline.o \
12 idr.o int_sqrt.o extable.o prio_tree.o \ 12 idr.o int_sqrt.o extable.o prio_tree.o \
13 sha1.o irq_regs.o reciprocal_div.o argv_split.o \ 13 sha1.o irq_regs.o reciprocal_div.o argv_split.o \
14 proportions.o prio_heap.o ratelimit.o show_mem.o \ 14 proportions.o prio_heap.o ratelimit.o show_mem.o \
15 is_single_threaded.o plist.o decompress.o 15 is_single_threaded.o plist.o decompress.o flex_array.o
16 16
17lib-$(CONFIG_MMU) += ioremap.o 17lib-$(CONFIG_MMU) += ioremap.o
18lib-$(CONFIG_SMP) += cpumask.o 18lib-$(CONFIG_SMP) += cpumask.o
diff --git a/lib/atomic64.c b/lib/atomic64.c
index c5e725562416..8bee16ec7524 100644
--- a/lib/atomic64.c
+++ b/lib/atomic64.c
@@ -13,6 +13,7 @@
13#include <linux/cache.h> 13#include <linux/cache.h>
14#include <linux/spinlock.h> 14#include <linux/spinlock.h>
15#include <linux/init.h> 15#include <linux/init.h>
16#include <linux/module.h>
16#include <asm/atomic.h> 17#include <asm/atomic.h>
17 18
18/* 19/*
@@ -52,6 +53,7 @@ long long atomic64_read(const atomic64_t *v)
52 spin_unlock_irqrestore(lock, flags); 53 spin_unlock_irqrestore(lock, flags);
53 return val; 54 return val;
54} 55}
56EXPORT_SYMBOL(atomic64_read);
55 57
56void atomic64_set(atomic64_t *v, long long i) 58void atomic64_set(atomic64_t *v, long long i)
57{ 59{
@@ -62,6 +64,7 @@ void atomic64_set(atomic64_t *v, long long i)
62 v->counter = i; 64 v->counter = i;
63 spin_unlock_irqrestore(lock, flags); 65 spin_unlock_irqrestore(lock, flags);
64} 66}
67EXPORT_SYMBOL(atomic64_set);
65 68
66void atomic64_add(long long a, atomic64_t *v) 69void atomic64_add(long long a, atomic64_t *v)
67{ 70{
@@ -72,6 +75,7 @@ void atomic64_add(long long a, atomic64_t *v)
72 v->counter += a; 75 v->counter += a;
73 spin_unlock_irqrestore(lock, flags); 76 spin_unlock_irqrestore(lock, flags);
74} 77}
78EXPORT_SYMBOL(atomic64_add);
75 79
76long long atomic64_add_return(long long a, atomic64_t *v) 80long long atomic64_add_return(long long a, atomic64_t *v)
77{ 81{
@@ -84,6 +88,7 @@ long long atomic64_add_return(long long a, atomic64_t *v)
84 spin_unlock_irqrestore(lock, flags); 88 spin_unlock_irqrestore(lock, flags);
85 return val; 89 return val;
86} 90}
91EXPORT_SYMBOL(atomic64_add_return);
87 92
88void atomic64_sub(long long a, atomic64_t *v) 93void atomic64_sub(long long a, atomic64_t *v)
89{ 94{
@@ -94,6 +99,7 @@ void atomic64_sub(long long a, atomic64_t *v)
94 v->counter -= a; 99 v->counter -= a;
95 spin_unlock_irqrestore(lock, flags); 100 spin_unlock_irqrestore(lock, flags);
96} 101}
102EXPORT_SYMBOL(atomic64_sub);
97 103
98long long atomic64_sub_return(long long a, atomic64_t *v) 104long long atomic64_sub_return(long long a, atomic64_t *v)
99{ 105{
@@ -106,6 +112,7 @@ long long atomic64_sub_return(long long a, atomic64_t *v)
106 spin_unlock_irqrestore(lock, flags); 112 spin_unlock_irqrestore(lock, flags);
107 return val; 113 return val;
108} 114}
115EXPORT_SYMBOL(atomic64_sub_return);
109 116
110long long atomic64_dec_if_positive(atomic64_t *v) 117long long atomic64_dec_if_positive(atomic64_t *v)
111{ 118{
@@ -120,6 +127,7 @@ long long atomic64_dec_if_positive(atomic64_t *v)
120 spin_unlock_irqrestore(lock, flags); 127 spin_unlock_irqrestore(lock, flags);
121 return val; 128 return val;
122} 129}
130EXPORT_SYMBOL(atomic64_dec_if_positive);
123 131
124long long atomic64_cmpxchg(atomic64_t *v, long long o, long long n) 132long long atomic64_cmpxchg(atomic64_t *v, long long o, long long n)
125{ 133{
@@ -134,6 +142,7 @@ long long atomic64_cmpxchg(atomic64_t *v, long long o, long long n)
134 spin_unlock_irqrestore(lock, flags); 142 spin_unlock_irqrestore(lock, flags);
135 return val; 143 return val;
136} 144}
145EXPORT_SYMBOL(atomic64_cmpxchg);
137 146
138long long atomic64_xchg(atomic64_t *v, long long new) 147long long atomic64_xchg(atomic64_t *v, long long new)
139{ 148{
@@ -147,6 +156,7 @@ long long atomic64_xchg(atomic64_t *v, long long new)
147 spin_unlock_irqrestore(lock, flags); 156 spin_unlock_irqrestore(lock, flags);
148 return val; 157 return val;
149} 158}
159EXPORT_SYMBOL(atomic64_xchg);
150 160
151int atomic64_add_unless(atomic64_t *v, long long a, long long u) 161int atomic64_add_unless(atomic64_t *v, long long a, long long u)
152{ 162{
@@ -162,6 +172,7 @@ int atomic64_add_unless(atomic64_t *v, long long a, long long u)
162 spin_unlock_irqrestore(lock, flags); 172 spin_unlock_irqrestore(lock, flags);
163 return ret; 173 return ret;
164} 174}
175EXPORT_SYMBOL(atomic64_add_unless);
165 176
166static int init_atomic64_lock(void) 177static int init_atomic64_lock(void)
167{ 178{
diff --git a/lib/dynamic_debug.c b/lib/dynamic_debug.c
index 833139ce1e22..e22c148e4b7f 100644
--- a/lib/dynamic_debug.c
+++ b/lib/dynamic_debug.c
@@ -164,7 +164,7 @@ static void ddebug_change(const struct ddebug_query *query,
164 164
165 if (!newflags) 165 if (!newflags)
166 dt->num_enabled--; 166 dt->num_enabled--;
167 else if (!dp-flags) 167 else if (!dp->flags)
168 dt->num_enabled++; 168 dt->num_enabled++;
169 dp->flags = newflags; 169 dp->flags = newflags;
170 if (newflags) { 170 if (newflags) {
diff --git a/lib/flex_array.c b/lib/flex_array.c
new file mode 100644
index 000000000000..0e7894ce8882
--- /dev/null
+++ b/lib/flex_array.c
@@ -0,0 +1,269 @@
1/*
2 * Flexible array managed in PAGE_SIZE parts
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
17 *
18 * Copyright IBM Corporation, 2009
19 *
20 * Author: Dave Hansen <dave@linux.vnet.ibm.com>
21 */
22
23#include <linux/flex_array.h>
24#include <linux/slab.h>
25#include <linux/stddef.h>
26
27struct flex_array_part {
28 char elements[FLEX_ARRAY_PART_SIZE];
29};
30
31static inline int __elements_per_part(int element_size)
32{
33 return FLEX_ARRAY_PART_SIZE / element_size;
34}
35
36static inline int bytes_left_in_base(void)
37{
38 int element_offset = offsetof(struct flex_array, parts);
39 int bytes_left = FLEX_ARRAY_BASE_SIZE - element_offset;
40 return bytes_left;
41}
42
43static inline int nr_base_part_ptrs(void)
44{
45 return bytes_left_in_base() / sizeof(struct flex_array_part *);
46}
47
48/*
49 * If a user requests an allocation which is small
50 * enough, we may simply use the space in the
51 * flex_array->parts[] array to store the user
52 * data.
53 */
54static inline int elements_fit_in_base(struct flex_array *fa)
55{
56 int data_size = fa->element_size * fa->total_nr_elements;
57 if (data_size <= bytes_left_in_base())
58 return 1;
59 return 0;
60}
61
62/**
63 * flex_array_alloc - allocate a new flexible array
64 * @element_size: the size of individual elements in the array
65 * @total: total number of elements that this should hold
66 *
67 * Note: all locking must be provided by the caller.
68 *
69 * @total is used to size internal structures. If the user ever
70 * accesses any array indexes >=@total, it will produce errors.
71 *
72 * The maximum number of elements is defined as: the number of
73 * elements that can be stored in a page times the number of
74 * page pointers that we can fit in the base structure or (using
75 * integer math):
76 *
77 * (PAGE_SIZE/element_size) * (PAGE_SIZE-8)/sizeof(void *)
78 *
79 * Here's a table showing example capacities. Note that the maximum
80 * index that the get/put() functions is just nr_objects-1. This
81 * basically means that you get 4MB of storage on 32-bit and 2MB on
82 * 64-bit.
83 *
84 *
85 * Element size | Objects | Objects |
86 * PAGE_SIZE=4k | 32-bit | 64-bit |
87 * ---------------------------------|
88 * 1 bytes | 4186112 | 2093056 |
89 * 2 bytes | 2093056 | 1046528 |
90 * 3 bytes | 1395030 | 697515 |
91 * 4 bytes | 1046528 | 523264 |
92 * 32 bytes | 130816 | 65408 |
93 * 33 bytes | 126728 | 63364 |
94 * 2048 bytes | 2044 | 1022 |
95 * 2049 bytes | 1022 | 511 |
96 * void * | 1046528 | 261632 |
97 *
98 * Since 64-bit pointers are twice the size, we lose half the
99 * capacity in the base structure. Also note that no effort is made
100 * to efficiently pack objects across page boundaries.
101 */
102struct flex_array *flex_array_alloc(int element_size, int total, gfp_t flags)
103{
104 struct flex_array *ret;
105 int max_size = nr_base_part_ptrs() * __elements_per_part(element_size);
106
107 /* max_size will end up 0 if element_size > PAGE_SIZE */
108 if (total > max_size)
109 return NULL;
110 ret = kzalloc(sizeof(struct flex_array), flags);
111 if (!ret)
112 return NULL;
113 ret->element_size = element_size;
114 ret->total_nr_elements = total;
115 return ret;
116}
117
118static int fa_element_to_part_nr(struct flex_array *fa, int element_nr)
119{
120 return element_nr / __elements_per_part(fa->element_size);
121}
122
123/**
124 * flex_array_free_parts - just free the second-level pages
125 * @src: address of data to copy into the array
126 * @element_nr: index of the position in which to insert
127 * the new element.
128 *
129 * This is to be used in cases where the base 'struct flex_array'
130 * has been statically allocated and should not be free.
131 */
132void flex_array_free_parts(struct flex_array *fa)
133{
134 int part_nr;
135 int max_part = nr_base_part_ptrs();
136
137 if (elements_fit_in_base(fa))
138 return;
139 for (part_nr = 0; part_nr < max_part; part_nr++)
140 kfree(fa->parts[part_nr]);
141}
142
143void flex_array_free(struct flex_array *fa)
144{
145 flex_array_free_parts(fa);
146 kfree(fa);
147}
148
149static int fa_index_inside_part(struct flex_array *fa, int element_nr)
150{
151 return element_nr % __elements_per_part(fa->element_size);
152}
153
154static int index_inside_part(struct flex_array *fa, int element_nr)
155{
156 int part_offset = fa_index_inside_part(fa, element_nr);
157 return part_offset * fa->element_size;
158}
159
160static struct flex_array_part *
161__fa_get_part(struct flex_array *fa, int part_nr, gfp_t flags)
162{
163 struct flex_array_part *part = fa->parts[part_nr];
164 if (!part) {
165 /*
166 * This leaves the part pages uninitialized
167 * and with potentially random data, just
168 * as if the user had kmalloc()'d the whole.
169 * __GFP_ZERO can be used to zero it.
170 */
171 part = kmalloc(FLEX_ARRAY_PART_SIZE, flags);
172 if (!part)
173 return NULL;
174 fa->parts[part_nr] = part;
175 }
176 return part;
177}
178
179/**
180 * flex_array_put - copy data into the array at @element_nr
181 * @src: address of data to copy into the array
182 * @element_nr: index of the position in which to insert
183 * the new element.
184 *
185 * Note that this *copies* the contents of @src into
186 * the array. If you are trying to store an array of
187 * pointers, make sure to pass in &ptr instead of ptr.
188 *
189 * Locking must be provided by the caller.
190 */
191int flex_array_put(struct flex_array *fa, int element_nr, void *src, gfp_t flags)
192{
193 int part_nr = fa_element_to_part_nr(fa, element_nr);
194 struct flex_array_part *part;
195 void *dst;
196
197 if (element_nr >= fa->total_nr_elements)
198 return -ENOSPC;
199 if (elements_fit_in_base(fa))
200 part = (struct flex_array_part *)&fa->parts[0];
201 else
202 part = __fa_get_part(fa, part_nr, flags);
203 if (!part)
204 return -ENOMEM;
205 dst = &part->elements[index_inside_part(fa, element_nr)];
206 memcpy(dst, src, fa->element_size);
207 return 0;
208}
209
210/**
211 * flex_array_prealloc - guarantee that array space exists
212 * @start: index of first array element for which space is allocated
213 * @end: index of last (inclusive) element for which space is allocated
214 *
215 * This will guarantee that no future calls to flex_array_put()
216 * will allocate memory. It can be used if you are expecting to
217 * be holding a lock or in some atomic context while writing
218 * data into the array.
219 *
220 * Locking must be provided by the caller.
221 */
222int flex_array_prealloc(struct flex_array *fa, int start, int end, gfp_t flags)
223{
224 int start_part;
225 int end_part;
226 int part_nr;
227 struct flex_array_part *part;
228
229 if (start >= fa->total_nr_elements || end >= fa->total_nr_elements)
230 return -ENOSPC;
231 if (elements_fit_in_base(fa))
232 return 0;
233 start_part = fa_element_to_part_nr(fa, start);
234 end_part = fa_element_to_part_nr(fa, end);
235 for (part_nr = start_part; part_nr <= end_part; part_nr++) {
236 part = __fa_get_part(fa, part_nr, flags);
237 if (!part)
238 return -ENOMEM;
239 }
240 return 0;
241}
242
243/**
244 * flex_array_get - pull data back out of the array
245 * @element_nr: index of the element to fetch from the array
246 *
247 * Returns a pointer to the data at index @element_nr. Note
248 * that this is a copy of the data that was passed in. If you
249 * are using this to store pointers, you'll get back &ptr.
250 *
251 * Locking must be provided by the caller.
252 */
253void *flex_array_get(struct flex_array *fa, int element_nr)
254{
255 int part_nr = fa_element_to_part_nr(fa, element_nr);
256 struct flex_array_part *part;
257 int index;
258
259 if (element_nr >= fa->total_nr_elements)
260 return NULL;
261 if (!fa->parts[part_nr])
262 return NULL;
263 if (elements_fit_in_base(fa))
264 part = (struct flex_array_part *)&fa->parts[0];
265 else
266 part = fa->parts[part_nr];
267 index = index_inside_part(fa, element_nr);
268 return &part->elements[index_inside_part(fa, element_nr)];
269}
diff --git a/mm/hugetlb.c b/mm/hugetlb.c
index d0351e31f474..cafdcee154e8 100644
--- a/mm/hugetlb.c
+++ b/mm/hugetlb.c
@@ -2370,7 +2370,7 @@ void hugetlb_unreserve_pages(struct inode *inode, long offset, long freed)
2370 long chg = region_truncate(&inode->i_mapping->private_list, offset); 2370 long chg = region_truncate(&inode->i_mapping->private_list, offset);
2371 2371
2372 spin_lock(&inode->i_lock); 2372 spin_lock(&inode->i_lock);
2373 inode->i_blocks -= blocks_per_huge_page(h); 2373 inode->i_blocks -= (blocks_per_huge_page(h) * freed);
2374 spin_unlock(&inode->i_lock); 2374 spin_unlock(&inode->i_lock);
2375 2375
2376 hugetlb_put_quota(inode->i_mapping, (chg - freed)); 2376 hugetlb_put_quota(inode->i_mapping, (chg - freed));
diff --git a/mm/kmemleak.c b/mm/kmemleak.c
index 5aabd41ffb8f..487267310a84 100644
--- a/mm/kmemleak.c
+++ b/mm/kmemleak.c
@@ -1217,7 +1217,6 @@ static void *kmemleak_seq_start(struct seq_file *seq, loff_t *pos)
1217 } 1217 }
1218 object = NULL; 1218 object = NULL;
1219out: 1219out:
1220 rcu_read_unlock();
1221 return object; 1220 return object;
1222} 1221}
1223 1222
@@ -1233,13 +1232,11 @@ static void *kmemleak_seq_next(struct seq_file *seq, void *v, loff_t *pos)
1233 1232
1234 ++(*pos); 1233 ++(*pos);
1235 1234
1236 rcu_read_lock();
1237 list_for_each_continue_rcu(n, &object_list) { 1235 list_for_each_continue_rcu(n, &object_list) {
1238 next_obj = list_entry(n, struct kmemleak_object, object_list); 1236 next_obj = list_entry(n, struct kmemleak_object, object_list);
1239 if (get_object(next_obj)) 1237 if (get_object(next_obj))
1240 break; 1238 break;
1241 } 1239 }
1242 rcu_read_unlock();
1243 1240
1244 put_object(prev_obj); 1241 put_object(prev_obj);
1245 return next_obj; 1242 return next_obj;
@@ -1255,6 +1252,7 @@ static void kmemleak_seq_stop(struct seq_file *seq, void *v)
1255 * kmemleak_seq_start may return ERR_PTR if the scan_mutex 1252 * kmemleak_seq_start may return ERR_PTR if the scan_mutex
1256 * waiting was interrupted, so only release it if !IS_ERR. 1253 * waiting was interrupted, so only release it if !IS_ERR.
1257 */ 1254 */
1255 rcu_read_unlock();
1258 mutex_unlock(&scan_mutex); 1256 mutex_unlock(&scan_mutex);
1259 if (v) 1257 if (v)
1260 put_object(v); 1258 put_object(v);
diff --git a/mm/memcontrol.c b/mm/memcontrol.c
index e717964cb5a0..fd4529d86de5 100644
--- a/mm/memcontrol.c
+++ b/mm/memcontrol.c
@@ -1207,6 +1207,12 @@ static int mem_cgroup_move_account(struct page_cgroup *pc,
1207 ret = 0; 1207 ret = 0;
1208out: 1208out:
1209 unlock_page_cgroup(pc); 1209 unlock_page_cgroup(pc);
1210 /*
1211 * We charges against "to" which may not have any tasks. Then, "to"
1212 * can be under rmdir(). But in current implementation, caller of
1213 * this function is just force_empty() and it's garanteed that
1214 * "to" is never removed. So, we don't check rmdir status here.
1215 */
1210 return ret; 1216 return ret;
1211} 1217}
1212 1218
@@ -1428,6 +1434,7 @@ __mem_cgroup_commit_charge_swapin(struct page *page, struct mem_cgroup *ptr,
1428 return; 1434 return;
1429 if (!ptr) 1435 if (!ptr)
1430 return; 1436 return;
1437 cgroup_exclude_rmdir(&ptr->css);
1431 pc = lookup_page_cgroup(page); 1438 pc = lookup_page_cgroup(page);
1432 mem_cgroup_lru_del_before_commit_swapcache(page); 1439 mem_cgroup_lru_del_before_commit_swapcache(page);
1433 __mem_cgroup_commit_charge(ptr, pc, ctype); 1440 __mem_cgroup_commit_charge(ptr, pc, ctype);
@@ -1457,8 +1464,12 @@ __mem_cgroup_commit_charge_swapin(struct page *page, struct mem_cgroup *ptr,
1457 } 1464 }
1458 rcu_read_unlock(); 1465 rcu_read_unlock();
1459 } 1466 }
1460 /* add this page(page_cgroup) to the LRU we want. */ 1467 /*
1461 1468 * At swapin, we may charge account against cgroup which has no tasks.
1469 * So, rmdir()->pre_destroy() can be called while we do this charge.
1470 * In that case, we need to call pre_destroy() again. check it here.
1471 */
1472 cgroup_release_and_wakeup_rmdir(&ptr->css);
1462} 1473}
1463 1474
1464void mem_cgroup_commit_charge_swapin(struct page *page, struct mem_cgroup *ptr) 1475void mem_cgroup_commit_charge_swapin(struct page *page, struct mem_cgroup *ptr)
@@ -1664,7 +1675,7 @@ void mem_cgroup_end_migration(struct mem_cgroup *mem,
1664 1675
1665 if (!mem) 1676 if (!mem)
1666 return; 1677 return;
1667 1678 cgroup_exclude_rmdir(&mem->css);
1668 /* at migration success, oldpage->mapping is NULL. */ 1679 /* at migration success, oldpage->mapping is NULL. */
1669 if (oldpage->mapping) { 1680 if (oldpage->mapping) {
1670 target = oldpage; 1681 target = oldpage;
@@ -1704,6 +1715,12 @@ void mem_cgroup_end_migration(struct mem_cgroup *mem,
1704 */ 1715 */
1705 if (ctype == MEM_CGROUP_CHARGE_TYPE_MAPPED) 1716 if (ctype == MEM_CGROUP_CHARGE_TYPE_MAPPED)
1706 mem_cgroup_uncharge_page(target); 1717 mem_cgroup_uncharge_page(target);
1718 /*
1719 * At migration, we may charge account against cgroup which has no tasks
1720 * So, rmdir()->pre_destroy() can be called while we do this charge.
1721 * In that case, we need to call pre_destroy() again. check it here.
1722 */
1723 cgroup_release_and_wakeup_rmdir(&mem->css);
1707} 1724}
1708 1725
1709/* 1726/*
diff --git a/mm/page_alloc.c b/mm/page_alloc.c
index caa92689aac9..d052abbe3063 100644
--- a/mm/page_alloc.c
+++ b/mm/page_alloc.c
@@ -882,7 +882,7 @@ retry_reserve:
882 */ 882 */
883static int rmqueue_bulk(struct zone *zone, unsigned int order, 883static int rmqueue_bulk(struct zone *zone, unsigned int order,
884 unsigned long count, struct list_head *list, 884 unsigned long count, struct list_head *list,
885 int migratetype) 885 int migratetype, int cold)
886{ 886{
887 int i; 887 int i;
888 888
@@ -901,7 +901,10 @@ static int rmqueue_bulk(struct zone *zone, unsigned int order,
901 * merge IO requests if the physical pages are ordered 901 * merge IO requests if the physical pages are ordered
902 * properly. 902 * properly.
903 */ 903 */
904 list_add(&page->lru, list); 904 if (likely(cold == 0))
905 list_add(&page->lru, list);
906 else
907 list_add_tail(&page->lru, list);
905 set_page_private(page, migratetype); 908 set_page_private(page, migratetype);
906 list = &page->lru; 909 list = &page->lru;
907 } 910 }
@@ -1119,7 +1122,8 @@ again:
1119 local_irq_save(flags); 1122 local_irq_save(flags);
1120 if (!pcp->count) { 1123 if (!pcp->count) {
1121 pcp->count = rmqueue_bulk(zone, 0, 1124 pcp->count = rmqueue_bulk(zone, 0,
1122 pcp->batch, &pcp->list, migratetype); 1125 pcp->batch, &pcp->list,
1126 migratetype, cold);
1123 if (unlikely(!pcp->count)) 1127 if (unlikely(!pcp->count))
1124 goto failed; 1128 goto failed;
1125 } 1129 }
@@ -1138,7 +1142,8 @@ again:
1138 /* Allocate more to the pcp list if necessary */ 1142 /* Allocate more to the pcp list if necessary */
1139 if (unlikely(&page->lru == &pcp->list)) { 1143 if (unlikely(&page->lru == &pcp->list)) {
1140 pcp->count += rmqueue_bulk(zone, 0, 1144 pcp->count += rmqueue_bulk(zone, 0,
1141 pcp->batch, &pcp->list, migratetype); 1145 pcp->batch, &pcp->list,
1146 migratetype, cold);
1142 page = list_entry(pcp->list.next, struct page, lru); 1147 page = list_entry(pcp->list.next, struct page, lru);
1143 } 1148 }
1144 1149
@@ -1740,8 +1745,10 @@ __alloc_pages_slowpath(gfp_t gfp_mask, unsigned int order,
1740 * be using allocators in order of preference for an area that is 1745 * be using allocators in order of preference for an area that is
1741 * too large. 1746 * too large.
1742 */ 1747 */
1743 if (WARN_ON_ONCE(order >= MAX_ORDER)) 1748 if (order >= MAX_ORDER) {
1749 WARN_ON_ONCE(!(gfp_mask & __GFP_NOWARN));
1744 return NULL; 1750 return NULL;
1751 }
1745 1752
1746 /* 1753 /*
1747 * GFP_THISNODE (meaning __GFP_THISNODE, __GFP_NORETRY and 1754 * GFP_THISNODE (meaning __GFP_THISNODE, __GFP_NORETRY and
@@ -1789,6 +1796,10 @@ rebalance:
1789 if (p->flags & PF_MEMALLOC) 1796 if (p->flags & PF_MEMALLOC)
1790 goto nopage; 1797 goto nopage;
1791 1798
1799 /* Avoid allocations with no watermarks from looping endlessly */
1800 if (test_thread_flag(TIF_MEMDIE) && !(gfp_mask & __GFP_NOFAIL))
1801 goto nopage;
1802
1792 /* Try direct reclaim and then allocating */ 1803 /* Try direct reclaim and then allocating */
1793 page = __alloc_pages_direct_reclaim(gfp_mask, order, 1804 page = __alloc_pages_direct_reclaim(gfp_mask, order,
1794 zonelist, high_zoneidx, 1805 zonelist, high_zoneidx,
diff --git a/mm/swapfile.c b/mm/swapfile.c
index d1ade1a48ee7..8ffdc0d23c53 100644
--- a/mm/swapfile.c
+++ b/mm/swapfile.c
@@ -753,7 +753,7 @@ int swap_type_of(dev_t device, sector_t offset, struct block_device **bdev_p)
753 753
754 if (!bdev) { 754 if (!bdev) {
755 if (bdev_p) 755 if (bdev_p)
756 *bdev_p = bdget(sis->bdev->bd_dev); 756 *bdev_p = bdgrab(sis->bdev);
757 757
758 spin_unlock(&swap_lock); 758 spin_unlock(&swap_lock);
759 return i; 759 return i;
@@ -765,7 +765,7 @@ int swap_type_of(dev_t device, sector_t offset, struct block_device **bdev_p)
765 struct swap_extent, list); 765 struct swap_extent, list);
766 if (se->start_block == offset) { 766 if (se->start_block == offset) {
767 if (bdev_p) 767 if (bdev_p)
768 *bdev_p = bdget(sis->bdev->bd_dev); 768 *bdev_p = bdgrab(sis->bdev);
769 769
770 spin_unlock(&swap_lock); 770 spin_unlock(&swap_lock);
771 bdput(bdev); 771 bdput(bdev);
diff --git a/net/dccp/proto.c b/net/dccp/proto.c
index 94ca8eaace7d..3281013ce038 100644
--- a/net/dccp/proto.c
+++ b/net/dccp/proto.c
@@ -1066,7 +1066,7 @@ static int __init dccp_init(void)
1066 (dccp_hashinfo.ehash_size - 1)) 1066 (dccp_hashinfo.ehash_size - 1))
1067 dccp_hashinfo.ehash_size--; 1067 dccp_hashinfo.ehash_size--;
1068 dccp_hashinfo.ehash = (struct inet_ehash_bucket *) 1068 dccp_hashinfo.ehash = (struct inet_ehash_bucket *)
1069 __get_free_pages(GFP_ATOMIC, ehash_order); 1069 __get_free_pages(GFP_ATOMIC|__GFP_NOWARN, ehash_order);
1070 } while (!dccp_hashinfo.ehash && --ehash_order > 0); 1070 } while (!dccp_hashinfo.ehash && --ehash_order > 0);
1071 1071
1072 if (!dccp_hashinfo.ehash) { 1072 if (!dccp_hashinfo.ehash) {
@@ -1091,7 +1091,7 @@ static int __init dccp_init(void)
1091 bhash_order > 0) 1091 bhash_order > 0)
1092 continue; 1092 continue;
1093 dccp_hashinfo.bhash = (struct inet_bind_hashbucket *) 1093 dccp_hashinfo.bhash = (struct inet_bind_hashbucket *)
1094 __get_free_pages(GFP_ATOMIC, bhash_order); 1094 __get_free_pages(GFP_ATOMIC|__GFP_NOWARN, bhash_order);
1095 } while (!dccp_hashinfo.bhash && --bhash_order >= 0); 1095 } while (!dccp_hashinfo.bhash && --bhash_order >= 0);
1096 1096
1097 if (!dccp_hashinfo.bhash) { 1097 if (!dccp_hashinfo.bhash) {
diff --git a/scripts/get_maintainer.pl b/scripts/get_maintainer.pl
index 3e733146cd51..278a45bd45a5 100755
--- a/scripts/get_maintainer.pl
+++ b/scripts/get_maintainer.pl
@@ -13,7 +13,7 @@
13use strict; 13use strict;
14 14
15my $P = $0; 15my $P = $0;
16my $V = '0.16'; 16my $V = '0.17';
17 17
18use Getopt::Long qw(:config no_auto_abbrev); 18use Getopt::Long qw(:config no_auto_abbrev);
19 19
@@ -27,6 +27,7 @@ my $email_git = 1;
27my $email_git_penguin_chiefs = 0; 27my $email_git_penguin_chiefs = 0;
28my $email_git_min_signatures = 1; 28my $email_git_min_signatures = 1;
29my $email_git_max_maintainers = 5; 29my $email_git_max_maintainers = 5;
30my $email_git_min_percent = 5;
30my $email_git_since = "1-year-ago"; 31my $email_git_since = "1-year-ago";
31my $output_multiline = 1; 32my $output_multiline = 1;
32my $output_separator = ", "; 33my $output_separator = ", ";
@@ -65,6 +66,7 @@ if (!GetOptions(
65 'git-chief-penguins!' => \$email_git_penguin_chiefs, 66 'git-chief-penguins!' => \$email_git_penguin_chiefs,
66 'git-min-signatures=i' => \$email_git_min_signatures, 67 'git-min-signatures=i' => \$email_git_min_signatures,
67 'git-max-maintainers=i' => \$email_git_max_maintainers, 68 'git-max-maintainers=i' => \$email_git_max_maintainers,
69 'git-min-percent=i' => \$email_git_min_percent,
68 'git-since=s' => \$email_git_since, 70 'git-since=s' => \$email_git_since,
69 'm!' => \$email_maintainer, 71 'm!' => \$email_maintainer,
70 'n!' => \$email_usename, 72 'n!' => \$email_usename,
@@ -132,6 +134,10 @@ while (<MAINT>) {
132 $value =~ s@\.@\\\.@g; ##Convert . to \. 134 $value =~ s@\.@\\\.@g; ##Convert . to \.
133 $value =~ s/\*/\.\*/g; ##Convert * to .* 135 $value =~ s/\*/\.\*/g; ##Convert * to .*
134 $value =~ s/\?/\./g; ##Convert ? to . 136 $value =~ s/\?/\./g; ##Convert ? to .
137 ##if pattern is a directory and it lacks a trailing slash, add one
138 if ((-d $value)) {
139 $value =~ s@([^/])$@$1/@;
140 }
135 } 141 }
136 push(@typevalue, "$type:$value"); 142 push(@typevalue, "$type:$value");
137 } elsif (!/^(\s)*$/) { 143 } elsif (!/^(\s)*$/) {
@@ -146,8 +152,10 @@ close(MAINT);
146my @files = (); 152my @files = ();
147 153
148foreach my $file (@ARGV) { 154foreach my $file (@ARGV) {
149 next if ((-d $file)); 155 ##if $file is a directory and it lacks a trailing slash, add one
150 if (!(-f $file)) { 156 if ((-d $file)) {
157 $file =~ s@([^/])$@$1/@;
158 } elsif (!(-f $file)) {
151 die "$P: file '${file}' not found\n"; 159 die "$P: file '${file}' not found\n";
152 } 160 }
153 if ($from_filename) { 161 if ($from_filename) {
@@ -292,7 +300,7 @@ sub file_match_pattern {
292sub usage { 300sub usage {
293 print <<EOT; 301 print <<EOT;
294usage: $P [options] patchfile 302usage: $P [options] patchfile
295 $P [options] -f file 303 $P [options] -f file|directory
296version: $V 304version: $V
297 305
298MAINTAINER field selection options: 306MAINTAINER field selection options:
@@ -301,6 +309,7 @@ MAINTAINER field selection options:
301 --git-chief-penguins => include ${penguin_chiefs} 309 --git-chief-penguins => include ${penguin_chiefs}
302 --git-min-signatures => number of signatures required (default: 1) 310 --git-min-signatures => number of signatures required (default: 1)
303 --git-max-maintainers => maximum maintainers to add (default: 5) 311 --git-max-maintainers => maximum maintainers to add (default: 5)
312 --git-min-percent => minimum percentage of commits required (default: 5)
304 --git-since => git history to use (default: 1-year-ago) 313 --git-since => git history to use (default: 1-year-ago)
305 --m => include maintainer(s) if any 314 --m => include maintainer(s) if any
306 --n => include name 'Full Name <addr\@domain.tld>' 315 --n => include name 'Full Name <addr\@domain.tld>'
@@ -322,6 +331,15 @@ Other options:
322 --version => show version 331 --version => show version
323 --help => show this help information 332 --help => show this help information
324 333
334Notes:
335 Using "-f directory" may give unexpected results:
336
337 Used with "--git", git signators for _all_ files in and below
338 directory are examined as git recurses directories.
339 Any specified X: (exclude) pattern matches are _not_ ignored.
340 Used with "--nogit", directory is used as a pattern match,
341 no individual file within the directory or subdirectory
342 is matched.
325EOT 343EOT
326} 344}
327 345
@@ -482,6 +500,7 @@ sub recent_git_signoffs {
482 my $output = ""; 500 my $output = "";
483 my $count = 0; 501 my $count = 0;
484 my @lines = (); 502 my @lines = ();
503 my $total_sign_offs;
485 504
486 if (which("git") eq "") { 505 if (which("git") eq "") {
487 warn("$P: git not found. Add --nogit to options?\n"); 506 warn("$P: git not found. Add --nogit to options?\n");
@@ -505,17 +524,26 @@ sub recent_git_signoffs {
505 $output =~ s/^\s*//gm; 524 $output =~ s/^\s*//gm;
506 525
507 @lines = split("\n", $output); 526 @lines = split("\n", $output);
527
528 $total_sign_offs = 0;
529 foreach my $line (@lines) {
530 if ($line =~ m/([0-9]+)\s+(.*)/) {
531 $total_sign_offs += $1;
532 } else {
533 die("$P: Unexpected git output: ${line}\n");
534 }
535 }
536
508 foreach my $line (@lines) { 537 foreach my $line (@lines) {
509 if ($line =~ m/([0-9]+)\s+(.*)/) { 538 if ($line =~ m/([0-9]+)\s+(.*)/) {
510 my $sign_offs = $1; 539 my $sign_offs = $1;
511 $line = $2; 540 $line = $2;
512 $count++; 541 $count++;
513 if ($sign_offs < $email_git_min_signatures || 542 if ($sign_offs < $email_git_min_signatures ||
514 $count > $email_git_max_maintainers) { 543 $count > $email_git_max_maintainers ||
544 $sign_offs * 100 / $total_sign_offs < $email_git_min_percent) {
515 last; 545 last;
516 } 546 }
517 } else {
518 die("$P: Unexpected git output: ${line}\n");
519 } 547 }
520 if ($line =~ m/(.+)<(.+)>/) { 548 if ($line =~ m/(.+)<(.+)>/) {
521 my $git_name = $1; 549 my $git_name = $1;
diff --git a/scripts/markup_oops.pl b/scripts/markup_oops.pl
index 528492bcba5b..89774011965d 100644
--- a/scripts/markup_oops.pl
+++ b/scripts/markup_oops.pl
@@ -1,6 +1,7 @@
1#!/usr/bin/perl 1#!/usr/bin/perl
2 2
3use File::Basename; 3use File::Basename;
4use Math::BigInt;
4 5
5# Copyright 2008, Intel Corporation 6# Copyright 2008, Intel Corporation
6# 7#
@@ -172,8 +173,8 @@ while (<STDIN>) {
172 parse_x86_regs($line); 173 parse_x86_regs($line);
173} 174}
174 175
175my $decodestart = hex($target) - hex($func_offset); 176my $decodestart = Math::BigInt->from_hex("0x$target") - Math::BigInt->from_hex("0x$func_offset");
176my $decodestop = hex($target) + 8192; 177my $decodestop = Math::BigInt->from_hex("0x$target") + 8192;
177if ($target eq "0") { 178if ($target eq "0") {
178 print "No oops found!\n"; 179 print "No oops found!\n";
179 print "Usage: \n"; 180 print "Usage: \n";