diff options
| author | Greg KH <greg@press.(none)> | 2005-10-28 13:13:16 -0400 |
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@suse.de> | 2005-10-28 13:13:16 -0400 |
| commit | 6fbfddcb52d8d9fa2cd209f5ac2a1c87497d55b5 (patch) | |
| tree | c0414e89678fcef7ce3493e048d855bde781ae8d /include | |
| parent | 1a222bca26ca691e83be1b08f5e96ae96d0d8cae (diff) | |
| parent | 27d1097d39509494706eaa2620ef3b1e780a3224 (diff) | |
Merge ../bleed-2.6
Diffstat (limited to 'include')
118 files changed, 1697 insertions, 518 deletions
diff --git a/include/asm-alpha/dma-mapping.h b/include/asm-alpha/dma-mapping.h index c675f282d6ad..680f7ecbb28f 100644 --- a/include/asm-alpha/dma-mapping.h +++ b/include/asm-alpha/dma-mapping.h | |||
| @@ -31,7 +31,7 @@ | |||
| 31 | #else /* no PCI - no IOMMU. */ | 31 | #else /* no PCI - no IOMMU. */ |
| 32 | 32 | ||
| 33 | void *dma_alloc_coherent(struct device *dev, size_t size, | 33 | void *dma_alloc_coherent(struct device *dev, size_t size, |
| 34 | dma_addr_t *dma_handle, int gfp); | 34 | dma_addr_t *dma_handle, gfp_t gfp); |
| 35 | int dma_map_sg(struct device *dev, struct scatterlist *sg, int nents, | 35 | int dma_map_sg(struct device *dev, struct scatterlist *sg, int nents, |
| 36 | enum dma_data_direction direction); | 36 | enum dma_data_direction direction); |
| 37 | 37 | ||
diff --git a/include/asm-arm/arch-aaec2000/aaec2000.h b/include/asm-arm/arch-aaec2000/aaec2000.h index 0e9b7e18af05..002227924b9f 100644 --- a/include/asm-arm/arch-aaec2000/aaec2000.h +++ b/include/asm-arm/arch-aaec2000/aaec2000.h | |||
| @@ -17,6 +17,16 @@ | |||
| 17 | #error You must include hardware.h not this file | 17 | #error You must include hardware.h not this file |
| 18 | #endif /* __ASM_ARCH_HARDWARE_H */ | 18 | #endif /* __ASM_ARCH_HARDWARE_H */ |
| 19 | 19 | ||
| 20 | /* Chip selects */ | ||
| 21 | #define AAEC_CS0 0x00000000 | ||
| 22 | #define AAEC_CS1 0x10000000 | ||
| 23 | #define AAEC_CS2 0x20000000 | ||
| 24 | #define AAEC_CS3 0x30000000 | ||
| 25 | |||
| 26 | /* Flash */ | ||
| 27 | #define AAEC_FLASH_BASE AAEC_CS0 | ||
| 28 | #define AAEC_FLASH_SIZE SZ_64M | ||
| 29 | |||
| 20 | /* Interrupt controller */ | 30 | /* Interrupt controller */ |
| 21 | #define IRQ_BASE __REG(0x80000500) | 31 | #define IRQ_BASE __REG(0x80000500) |
| 22 | #define IRQ_INTSR __REG(0x80000500) /* Int Status Register */ | 32 | #define IRQ_INTSR __REG(0x80000500) /* Int Status Register */ |
| @@ -148,4 +158,50 @@ | |||
| 148 | #define POWER_STFCLR __REG(0x8000041c) /* NbFlg, RSTFlg, PFFlg, CLDFlg Clear */ | 158 | #define POWER_STFCLR __REG(0x8000041c) /* NbFlg, RSTFlg, PFFlg, CLDFlg Clear */ |
| 149 | #define POWER_CLKSET __REG(0x80000420) /* Clock Speed Control */ | 159 | #define POWER_CLKSET __REG(0x80000420) /* Clock Speed Control */ |
| 150 | 160 | ||
| 161 | /* GPIO Registers */ | ||
| 162 | #define AAEC_GPIO_PHYS 0x80000e00 | ||
| 163 | |||
| 164 | #define AAEC_GPIO_PADR __REG(AAEC_GPIO_PHYS + 0x00) | ||
| 165 | #define AAEC_GPIO_PBDR __REG(AAEC_GPIO_PHYS + 0x04) | ||
| 166 | #define AAEC_GPIO_PCDR __REG(AAEC_GPIO_PHYS + 0x08) | ||
| 167 | #define AAEC_GPIO_PDDR __REG(AAEC_GPIO_PHYS + 0x0c) | ||
| 168 | #define AAEC_GPIO_PADDR __REG(AAEC_GPIO_PHYS + 0x10) | ||
| 169 | #define AAEC_GPIO_PBDDR __REG(AAEC_GPIO_PHYS + 0x14) | ||
| 170 | #define AAEC_GPIO_PCDDR __REG(AAEC_GPIO_PHYS + 0x18) | ||
| 171 | #define AAEC_GPIO_PDDDR __REG(AAEC_GPIO_PHYS + 0x1c) | ||
| 172 | #define AAEC_GPIO_PEDR __REG(AAEC_GPIO_PHYS + 0x20) | ||
| 173 | #define AAEC_GPIO_PEDDR __REG(AAEC_GPIO_PHYS + 0x24) | ||
| 174 | #define AAEC_GPIO_KSCAN __REG(AAEC_GPIO_PHYS + 0x28) | ||
| 175 | #define AAEC_GPIO_PINMUX __REG(AAEC_GPIO_PHYS + 0x2c) | ||
| 176 | #define AAEC_GPIO_PFDR __REG(AAEC_GPIO_PHYS + 0x30) | ||
| 177 | #define AAEC_GPIO_PFDDR __REG(AAEC_GPIO_PHYS + 0x34) | ||
| 178 | #define AAEC_GPIO_PGDR __REG(AAEC_GPIO_PHYS + 0x38) | ||
| 179 | #define AAEC_GPIO_PGDDR __REG(AAEC_GPIO_PHYS + 0x3c) | ||
| 180 | #define AAEC_GPIO_PHDR __REG(AAEC_GPIO_PHYS + 0x40) | ||
| 181 | #define AAEC_GPIO_PHDDR __REG(AAEC_GPIO_PHYS + 0x44) | ||
| 182 | #define AAEC_GPIO_RAZ __REG(AAEC_GPIO_PHYS + 0x48) | ||
| 183 | #define AAEC_GPIO_INTTYPE1 __REG(AAEC_GPIO_PHYS + 0x4c) | ||
| 184 | #define AAEC_GPIO_INTTYPE2 __REG(AAEC_GPIO_PHYS + 0x50) | ||
| 185 | #define AAEC_GPIO_FEOI __REG(AAEC_GPIO_PHYS + 0x54) | ||
| 186 | #define AAEC_GPIO_INTEN __REG(AAEC_GPIO_PHYS + 0x58) | ||
| 187 | #define AAEC_GPIO_INTSTATUS __REG(AAEC_GPIO_PHYS + 0x5c) | ||
| 188 | #define AAEC_GPIO_RAWINTSTATUS __REG(AAEC_GPIO_PHYS + 0x60) | ||
| 189 | #define AAEC_GPIO_DB __REG(AAEC_GPIO_PHYS + 0x64) | ||
| 190 | #define AAEC_GPIO_PAPINDR __REG(AAEC_GPIO_PHYS + 0x68) | ||
| 191 | #define AAEC_GPIO_PBPINDR __REG(AAEC_GPIO_PHYS + 0x6c) | ||
| 192 | #define AAEC_GPIO_PCPINDR __REG(AAEC_GPIO_PHYS + 0x70) | ||
| 193 | #define AAEC_GPIO_PDPINDR __REG(AAEC_GPIO_PHYS + 0x74) | ||
| 194 | #define AAEC_GPIO_PEPINDR __REG(AAEC_GPIO_PHYS + 0x78) | ||
| 195 | #define AAEC_GPIO_PFPINDR __REG(AAEC_GPIO_PHYS + 0x7c) | ||
| 196 | #define AAEC_GPIO_PGPINDR __REG(AAEC_GPIO_PHYS + 0x80) | ||
| 197 | #define AAEC_GPIO_PHPINDR __REG(AAEC_GPIO_PHYS + 0x84) | ||
| 198 | |||
| 199 | #define AAEC_GPIO_PINMUX_PE0CON (1 << 0) | ||
| 200 | #define AAEC_GPIO_PINMUX_PD0CON (1 << 1) | ||
| 201 | #define AAEC_GPIO_PINMUX_CODECON (1 << 2) | ||
| 202 | #define AAEC_GPIO_PINMUX_UART3CON (1 << 3) | ||
| 203 | |||
| 204 | /* LCD Controller */ | ||
| 205 | #define AAEC_CLCD_PHYS 0x80003000 | ||
| 206 | |||
| 151 | #endif /* __ARM_ARCH_AAEC2000_H */ | 207 | #endif /* __ARM_ARCH_AAEC2000_H */ |
diff --git a/include/asm-arm/arch-aaec2000/aaed2000.h b/include/asm-arm/arch-aaec2000/aaed2000.h new file mode 100644 index 000000000000..bc76d2badb91 --- /dev/null +++ b/include/asm-arm/arch-aaec2000/aaed2000.h | |||
| @@ -0,0 +1,40 @@ | |||
| 1 | /* | ||
| 2 | * linux/include/asm-arm/arch-aaec2000/aaed2000.h | ||
| 3 | * | ||
| 4 | * AAED-2000 specific bits definition | ||
| 5 | * | ||
| 6 | * Copyright (c) 2005 Nicolas Bellido Y Ortega | ||
| 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 version 2 as | ||
| 10 | * published by the Free Software Foundation. | ||
| 11 | */ | ||
| 12 | |||
| 13 | #ifndef __ASM_ARCH_AAED2000_H | ||
| 14 | #define __ASM_ARCH_AAED2000_H | ||
| 15 | |||
| 16 | /* External GPIOs. */ | ||
| 17 | |||
| 18 | #define EXT_GPIO_PBASE AAEC_CS3 | ||
| 19 | #define EXT_GPIO_VBASE 0xf8100000 | ||
| 20 | #define EXT_GPIO_LENGTH 0x00001000 | ||
| 21 | |||
| 22 | #define __ext_gpio_p2v(x) ((x) - EXT_GPIO_PBASE + EXT_GPIO_VBASE) | ||
| 23 | #define __ext_gpio_v2p(x) ((x) + EXT_GPIO_PBASE - EXT_GPIO_VBASE) | ||
| 24 | |||
| 25 | #define __EXT_GPIO_REG(x) (*((volatile u32 *)__ext_gpio_p2v(x))) | ||
| 26 | #define __EXT_GPIO_PREG(x) (__ext_gpio_v2p((u32)&(x))) | ||
| 27 | |||
| 28 | #define AAED_EXT_GPIO __EXT_GPIO_REG(EXT_GPIO_PBASE) | ||
| 29 | |||
| 30 | #define AAED_EGPIO_KBD_SCAN 0x00003fff /* Keyboard scan data */ | ||
| 31 | #define AAED_EGPIO_PWR_INT 0x00008fff /* Smart battery charger interrupt */ | ||
| 32 | #define AAED_EGPIO_SWITCHED 0x000f0000 /* DIP Switches */ | ||
| 33 | #define AAED_EGPIO_USB_VBUS 0x00400000 /* USB Vbus sense */ | ||
| 34 | #define AAED_EGPIO_LCD_PWR_EN 0x02000000 /* LCD and backlight PWR enable */ | ||
| 35 | #define AAED_EGPIO_nLED0 0x20000000 /* LED 0 */ | ||
| 36 | #define AAED_EGPIO_nLED1 0x20000000 /* LED 1 */ | ||
| 37 | #define AAED_EGPIO_nLED2 0x20000000 /* LED 2 */ | ||
| 38 | |||
| 39 | |||
| 40 | #endif /* __ARM_ARCH_AAED2000_H */ | ||
diff --git a/include/asm-arm/arch-aaec2000/hardware.h b/include/asm-arm/arch-aaec2000/hardware.h index 4c37219e030e..153506fd06ed 100644 --- a/include/asm-arm/arch-aaec2000/hardware.h +++ b/include/asm-arm/arch-aaec2000/hardware.h | |||
| @@ -11,7 +11,8 @@ | |||
| 11 | #ifndef __ASM_ARCH_HARDWARE_H | 11 | #ifndef __ASM_ARCH_HARDWARE_H |
| 12 | #define __ASM_ARCH_HARDWARE_H | 12 | #define __ASM_ARCH_HARDWARE_H |
| 13 | 13 | ||
| 14 | #include <linux/config.h> | 14 | #include <asm/sizes.h> |
| 15 | #include <asm/arch/aaec2000.h> | ||
| 15 | 16 | ||
| 16 | /* The kernel is loaded at physical address 0xf8000000. | 17 | /* The kernel is loaded at physical address 0xf8000000. |
| 17 | * We map the IO space a bit after | 18 | * We map the IO space a bit after |
diff --git a/include/asm-arm/arch-aaec2000/io.h b/include/asm-arm/arch-aaec2000/io.h index c58a8d10425a..8d67907fd4f0 100644 --- a/include/asm-arm/arch-aaec2000/io.h +++ b/include/asm-arm/arch-aaec2000/io.h | |||
| @@ -6,6 +6,8 @@ | |||
| 6 | #ifndef __ASM_ARM_ARCH_IO_H | 6 | #ifndef __ASM_ARM_ARCH_IO_H |
| 7 | #define __ASM_ARM_ARCH_IO_H | 7 | #define __ASM_ARM_ARCH_IO_H |
| 8 | 8 | ||
| 9 | #include <asm/hardware.h> | ||
| 10 | |||
| 9 | #define IO_SPACE_LIMIT 0xffffffff | 11 | #define IO_SPACE_LIMIT 0xffffffff |
| 10 | 12 | ||
| 11 | /* | 13 | /* |
diff --git a/include/asm-arm/arch-cl7500/io.h b/include/asm-arm/arch-cl7500/io.h index f0113bc75630..89a33287f4fe 100644 --- a/include/asm-arm/arch-cl7500/io.h +++ b/include/asm-arm/arch-cl7500/io.h | |||
| @@ -10,6 +10,8 @@ | |||
| 10 | #ifndef __ASM_ARM_ARCH_IO_H | 10 | #ifndef __ASM_ARM_ARCH_IO_H |
| 11 | #define __ASM_ARM_ARCH_IO_H | 11 | #define __ASM_ARM_ARCH_IO_H |
| 12 | 12 | ||
| 13 | #include <asm/hardware.h> | ||
| 14 | |||
| 13 | #define IO_SPACE_LIMIT 0xffffffff | 15 | #define IO_SPACE_LIMIT 0xffffffff |
| 14 | 16 | ||
| 15 | /* | 17 | /* |
diff --git a/include/asm-arm/arch-clps711x/hardware.h b/include/asm-arm/arch-clps711x/hardware.h index 1386871e1a5a..f864c367c934 100644 --- a/include/asm-arm/arch-clps711x/hardware.h +++ b/include/asm-arm/arch-clps711x/hardware.h | |||
| @@ -235,4 +235,121 @@ | |||
| 235 | #define CEIVA_PB0_BLK_BTN (1<<0) | 235 | #define CEIVA_PB0_BLK_BTN (1<<0) |
| 236 | #endif // #if defined (CONFIG_ARCH_CEIVA) | 236 | #endif // #if defined (CONFIG_ARCH_CEIVA) |
| 237 | 237 | ||
| 238 | #if defined (CONFIG_MACH_MP1000) | ||
| 239 | /* NOR FLASH */ | ||
| 240 | #define MP1000_NIO_BASE 0xf9000000 /* virtual */ | ||
| 241 | #define MP1000_NIO_START CS0_PHYS_BASE /* physical */ | ||
| 242 | #define MP1000_NIO_SIZE 0x00400000 | ||
| 243 | |||
| 244 | /* DSP Interface */ | ||
| 245 | #define MP1000_DSP_BASE 0xfa000000 /* virtual */ | ||
| 246 | #define MP1000_DSP_START CS1_PHYS_BASE /* physical */ | ||
| 247 | #define MP1000_DSP_SIZE 0x00100000 | ||
| 248 | |||
| 249 | /* LCD, DAA/DSP, RTC, DAA RW Reg all in CS2 */ | ||
| 250 | #define MP1000_LIO_BASE 0xfb000000 /* virtual */ | ||
| 251 | #define MP1000_LIO_START CS2_PHYS_BASE /* physical */ | ||
| 252 | #define MP1000_LIO_SIZE 0x00100000 | ||
| 253 | |||
| 254 | /* NAND FLASH */ | ||
| 255 | #define MP1000_FIO_BASE 0xfc000000 /* virtual */ | ||
| 256 | #define MP1000_FIO_START CS3_PHYS_BASE /* physical */ | ||
| 257 | #define MP1000_FIO_SIZE 0x00800000 | ||
| 258 | |||
| 259 | /* Ethernet */ | ||
| 260 | #define MP1000_EIO_BASE 0xfd000000 /* virtual */ | ||
| 261 | #define MP1000_EIO_START CS4_PHYS_BASE /* physical */ | ||
| 262 | #define MP1000_EIO_SIZE 0x00100000 | ||
| 263 | |||
| 264 | #define MP1000_LCD_OFFSET 0x00000000 /* LCD offset in CS2 */ | ||
| 265 | #define MP1000_DDD_OFFSET 0x00001000 /* DAA/DAI/DSP sft reset offst*/ | ||
| 266 | #define MP1000_RTC_OFFSET 0x00002000 /* RTC offset in CS2 */ | ||
| 267 | #define MP1000_DAA_OFFSET 0x00003000 /* DAA RW reg offset in CS2 */ | ||
| 268 | |||
| 269 | /* IDE */ | ||
| 270 | #define MP1000_IDE_BASE 0xfe000000 /* virtual */ | ||
| 271 | #define MP1000_IDE_START CS5_PHYS_BASE /* physical */ | ||
| 272 | #define MP1000_IDE_SIZE 0x00100000 /* actually it's only 0x1000 */ | ||
| 273 | |||
| 274 | #define IRQ_HARDDISK IRQ_EINT2 | ||
| 275 | |||
| 276 | /* | ||
| 277 | * IDE registers definition | ||
| 278 | */ | ||
| 279 | |||
| 280 | #define IDE_CONTROL_BASE (MP1000_IDE_BASE + 0x1000) | ||
| 281 | #define IDE_BASE_OFF (MP1000_IDE_BASE) | ||
| 282 | |||
| 283 | #define IDE_WRITE_DEVICE_DATA (IDE_BASE_OFF + 0x0) | ||
| 284 | #define IDE_FEATURES_REGISTER (IDE_BASE_OFF + 0x2) | ||
| 285 | #define IDE_SECTOR_COUNT_REGISTER (IDE_BASE_OFF + 0x4) | ||
| 286 | #define IDE_SECTOR_NUMBER_REGISTER (IDE_BASE_OFF + 0x6) | ||
| 287 | #define IDE_CYLINDER_LOW_REGISTER (IDE_BASE_OFF + 0x8) | ||
| 288 | #define IDE_CYLINDER_HIGH_REGISTER (IDE_BASE_OFF + 0xa) | ||
| 289 | #define IDE_DEVICE_HEAD_REGISTER (IDE_BASE_OFF + 0xc) | ||
| 290 | #define IDE_COMMAND_DATA_REGISTER (IDE_BASE_OFF + 0xe) | ||
| 291 | #define IDE_DEVICE_CONTROL_REGISTER (IDE_CONTROL_BASE + 0xc) | ||
| 292 | |||
| 293 | #define IDE_IRQ IRQ_EINT2 | ||
| 294 | |||
| 295 | |||
| 296 | #define RTC_PORT(x) (MP1000_LIO_BASE+0x2000 + (x*2)) | ||
| 297 | #define RTC_ALWAYS_BCD 0 | ||
| 298 | |||
| 299 | /* | ||
| 300 | // Definitions of the bit fields in the HwPortA register for the | ||
| 301 | // MP1000 board. | ||
| 302 | */ | ||
| 303 | #define HwPortAKeyboardRow1 0x00000001 | ||
| 304 | #define HwPortAKeyboardRow2 0x00000002 | ||
| 305 | #define HwPortAKeyboardRow3 0x00000004 | ||
| 306 | #define HwPortAKeyboardRow4 0x00000008 | ||
| 307 | #define HwPortAKeyboardRow5 0x00000010 | ||
| 308 | #define HwPortAKeyboardRow6 0x00000020 | ||
| 309 | #define HwPortALCDEnable 0x00000040 | ||
| 310 | #define HwPortAOffhook 0x00000080 | ||
| 311 | |||
| 312 | /* | ||
| 313 | // Definitions of the bit fields in the HwPortB register for the | ||
| 314 | // MP1000 board. | ||
| 315 | */ | ||
| 316 | #define HwPortBL3Mode 0x00000001 | ||
| 317 | #define HwPortBL3Clk 0x00000002 | ||
| 318 | #define HwPortBSClk 0x00000001 | ||
| 319 | #define HwPortBSData 0x00000002 | ||
| 320 | #define HwPortBL3Data 0x00000004 | ||
| 321 | #define HwPortBMute 0x00000008 | ||
| 322 | #define HwPortBQD0 0x00000010 | ||
| 323 | #define HwPortBQD1 0x00000020 | ||
| 324 | #define HwPortBQD2 0x00000040 | ||
| 325 | #define HwPortBQD3 0x00000080 | ||
| 326 | |||
| 327 | /* | ||
| 328 | // Definitions of the bit fields in the HwPortD register for the | ||
| 329 | // MP1000 board. | ||
| 330 | */ | ||
| 331 | #define HwPortDLED1 0x00000001 | ||
| 332 | #define HwPortDLED2 0x00000002 | ||
| 333 | #define HwPortDLED3 0x00000004 | ||
| 334 | #define HwPortDLED4 0x00000008 | ||
| 335 | #define HwPortDLED5 0x00000010 | ||
| 336 | #define HwPortDEECS 0x00000020 | ||
| 337 | #define HwPortBRTS 0x00000040 | ||
| 338 | #define HwPortBRI 0x00000080 | ||
| 339 | |||
| 340 | |||
| 341 | /* | ||
| 342 | // Definitions of the bit fields in the HwPortE register for the | ||
| 343 | // MP1000 board. | ||
| 344 | */ | ||
| 345 | |||
| 346 | #define HwPortECLE 0x00000001 | ||
| 347 | #define HwPortESepromDOut 0x00000001 | ||
| 348 | #define HwPortEALE 0x00000002 | ||
| 349 | #define HwPortESepromDIn 0x00000002 | ||
| 350 | #define HwPortENANDCS 0x00000004 | ||
| 351 | #define HwPortESepromCLK 0x00000004 | ||
| 352 | |||
| 353 | #endif // #if defined (CONFIG_MACH_MP1000) | ||
| 354 | |||
| 238 | #endif | 355 | #endif |
diff --git a/include/asm-arm/arch-clps711x/io.h b/include/asm-arm/arch-clps711x/io.h index 14d7e8da5453..62613b0e2d96 100644 --- a/include/asm-arm/arch-clps711x/io.h +++ b/include/asm-arm/arch-clps711x/io.h | |||
| @@ -20,6 +20,8 @@ | |||
| 20 | #ifndef __ASM_ARM_ARCH_IO_H | 20 | #ifndef __ASM_ARM_ARCH_IO_H |
| 21 | #define __ASM_ARM_ARCH_IO_H | 21 | #define __ASM_ARM_ARCH_IO_H |
| 22 | 22 | ||
| 23 | #include <asm/hardware.h> | ||
| 24 | |||
| 23 | #define IO_SPACE_LIMIT 0xffffffff | 25 | #define IO_SPACE_LIMIT 0xffffffff |
| 24 | 26 | ||
| 25 | #define __io(a) ((void __iomem *)(a)) | 27 | #define __io(a) ((void __iomem *)(a)) |
diff --git a/include/asm-arm/arch-clps711x/mp1000-seprom.h b/include/asm-arm/arch-clps711x/mp1000-seprom.h new file mode 100644 index 000000000000..3e5566cf9666 --- /dev/null +++ b/include/asm-arm/arch-clps711x/mp1000-seprom.h | |||
| @@ -0,0 +1,77 @@ | |||
| 1 | #ifndef MP1000_SEPROM_H | ||
| 2 | #define MP1000_SEPROM_H | ||
| 3 | |||
| 4 | /* | ||
| 5 | * mp1000-seprom.h | ||
| 6 | * | ||
| 7 | * | ||
| 8 | * This file contains the Serial EEPROM definitions for the MP1000 board | ||
| 9 | * | ||
| 10 | * Copyright (C) 2005 Comdial Corporation | ||
| 11 | * | ||
| 12 | * This program is free software; you can redistribute it and/or modify | ||
| 13 | * it under the terms of the GNU General Public License as published by | ||
| 14 | * the Free Software Foundation; either version 2 of the License, or | ||
| 15 | * (at your option) any later version. | ||
| 16 | * | ||
| 17 | * This program is distributed in the hope that it will be useful, | ||
| 18 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 19 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 20 | * GNU General Public License for more details. | ||
| 21 | * | ||
| 22 | * You should have received a copy of the GNU General Public License | ||
| 23 | * along with this program; if not, write to the Free Software | ||
| 24 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
| 25 | * | ||
| 26 | */ | ||
| 27 | |||
| 28 | #define COMMAND_ERASE (0x1C0) | ||
| 29 | #define COMMAND_ERASE_ALL (0x120) | ||
| 30 | #define COMMAND_WRITE_DISABLE (0x100) | ||
| 31 | #define COMMAND_WRITE_ENABLE (0x130) | ||
| 32 | #define COMMAND_READ (0x180) | ||
| 33 | #define COMMAND_WRITE (0x140) | ||
| 34 | #define COMMAND_WRITE_ALL (0x110) | ||
| 35 | |||
| 36 | // | ||
| 37 | // Serial EEPROM data format | ||
| 38 | // | ||
| 39 | |||
| 40 | #define PACKED __attribute__ ((packed)) | ||
| 41 | |||
| 42 | typedef struct _EEPROM { | ||
| 43 | union { | ||
| 44 | unsigned char eprom_byte_data[128]; | ||
| 45 | unsigned short eprom_short_data[64]; | ||
| 46 | struct { | ||
| 47 | unsigned char version PACKED; // EEPROM Version "1" for now | ||
| 48 | unsigned char box_id PACKED; // Box ID (Standalone, SOHO, embedded, etc) | ||
| 49 | unsigned char major_hw_version PACKED; // Major Hardware version (Hex) | ||
| 50 | unsigned char minor_hw_version PACKED; // Minor Hardware Version (Hex) | ||
| 51 | unsigned char mfg_id[3] PACKED; // Manufacturer ID (3 character Alphabetic) | ||
| 52 | unsigned char mfg_serial_number[10] PACKED; // Manufacturer Serial number | ||
| 53 | unsigned char mfg_date[3] PACKED; // Date of Mfg (Formatted YY:MM:DD) | ||
| 54 | unsigned char country PACKED; // Country of deployment | ||
| 55 | unsigned char mac_Address[6] PACKED; // MAC Address | ||
| 56 | unsigned char oem_string[20] PACKED; // OEM ID string | ||
| 57 | unsigned short feature_bits1 PACKED; // Feature Bits 1 | ||
| 58 | unsigned short feature_bits2 PACKED; // Feature Bits 2 | ||
| 59 | unsigned char filler[75] PACKED; // Unused/Undefined “0” initialized | ||
| 60 | unsigned short checksum PACKED; // byte accumulated short checksum | ||
| 61 | } eprom_struct; | ||
| 62 | } variant; | ||
| 63 | } eeprom_struct; | ||
| 64 | |||
| 65 | /* These settings must be mutually exclusive */ | ||
| 66 | #define FEATURE_BITS1_DRAMSIZE_16MEG 0x0001 /* 0 signifies 4 MEG system */ | ||
| 67 | #define FEATURE_BITS1_DRAMSIZE_8MEG 0x0002 /* 1 in bit 1 = 8MEG system */ | ||
| 68 | #define FEATURE_BITS1_DRAMSIZE_64MEG 0x0004 /* 1 in bit 2 = 64MEG system */ | ||
| 69 | |||
| 70 | #define FEATURE_BITS1_CPUIS90MEG 0x0010 | ||
| 71 | |||
| 72 | extern void seprom_init(void); | ||
| 73 | extern eeprom_struct* get_seprom_ptr(void); | ||
| 74 | extern unsigned char* get_eeprom_mac_address(void); | ||
| 75 | |||
| 76 | #endif /* MP1000_SEPROM_H */ | ||
| 77 | |||
diff --git a/include/asm-arm/arch-ebsa285/io.h b/include/asm-arm/arch-ebsa285/io.h index 70576b17f922..776f9d377057 100644 --- a/include/asm-arm/arch-ebsa285/io.h +++ b/include/asm-arm/arch-ebsa285/io.h | |||
| @@ -14,6 +14,8 @@ | |||
| 14 | #ifndef __ASM_ARM_ARCH_IO_H | 14 | #ifndef __ASM_ARM_ARCH_IO_H |
| 15 | #define __ASM_ARM_ARCH_IO_H | 15 | #define __ASM_ARM_ARCH_IO_H |
| 16 | 16 | ||
| 17 | #include <asm/hardware.h> | ||
| 18 | |||
| 17 | #define IO_SPACE_LIMIT 0xffff | 19 | #define IO_SPACE_LIMIT 0xffff |
| 18 | 20 | ||
| 19 | /* | 21 | /* |
diff --git a/include/asm-arm/arch-epxa10db/io.h b/include/asm-arm/arch-epxa10db/io.h index 1f0afa257621..9fe100c9d6be 100644 --- a/include/asm-arm/arch-epxa10db/io.h +++ b/include/asm-arm/arch-epxa10db/io.h | |||
| @@ -20,6 +20,8 @@ | |||
| 20 | #ifndef __ASM_ARM_ARCH_IO_H | 20 | #ifndef __ASM_ARM_ARCH_IO_H |
| 21 | #define __ASM_ARM_ARCH_IO_H | 21 | #define __ASM_ARM_ARCH_IO_H |
| 22 | 22 | ||
| 23 | #include <asm/hardware.h> | ||
| 24 | |||
| 23 | #define IO_SPACE_LIMIT 0xffff | 25 | #define IO_SPACE_LIMIT 0xffff |
| 24 | 26 | ||
| 25 | 27 | ||
diff --git a/include/asm-arm/arch-h720x/io.h b/include/asm-arm/arch-h720x/io.h index 68814828c9a7..d3ccfd8172b7 100644 --- a/include/asm-arm/arch-h720x/io.h +++ b/include/asm-arm/arch-h720x/io.h | |||
| @@ -14,7 +14,7 @@ | |||
| 14 | #ifndef __ASM_ARM_ARCH_IO_H | 14 | #ifndef __ASM_ARM_ARCH_IO_H |
| 15 | #define __ASM_ARM_ARCH_IO_H | 15 | #define __ASM_ARM_ARCH_IO_H |
| 16 | 16 | ||
| 17 | #include <asm/arch/hardware.h> | 17 | #include <asm/hardware.h> |
| 18 | 18 | ||
| 19 | #define IO_SPACE_LIMIT 0xffffffff | 19 | #define IO_SPACE_LIMIT 0xffffffff |
| 20 | 20 | ||
diff --git a/include/asm-arm/arch-imx/io.h b/include/asm-arm/arch-imx/io.h index 28a4cca6a4cb..b191cdd05576 100644 --- a/include/asm-arm/arch-imx/io.h +++ b/include/asm-arm/arch-imx/io.h | |||
| @@ -20,6 +20,8 @@ | |||
| 20 | #ifndef __ASM_ARM_ARCH_IO_H | 20 | #ifndef __ASM_ARM_ARCH_IO_H |
| 21 | #define __ASM_ARM_ARCH_IO_H | 21 | #define __ASM_ARM_ARCH_IO_H |
| 22 | 22 | ||
| 23 | #include <asm/hardware.h> | ||
| 24 | |||
| 23 | #define IO_SPACE_LIMIT 0xffffffff | 25 | #define IO_SPACE_LIMIT 0xffffffff |
| 24 | 26 | ||
| 25 | #define __io(a) ((void __iomem *)(a)) | 27 | #define __io(a) ((void __iomem *)(a)) |
diff --git a/include/asm-arm/arch-integrator/hardware.h b/include/asm-arm/arch-integrator/hardware.h index be2716eeaa02..6f0947bc500d 100644 --- a/include/asm-arm/arch-integrator/hardware.h +++ b/include/asm-arm/arch-integrator/hardware.h | |||
| @@ -33,15 +33,6 @@ | |||
| 33 | #define IO_SIZE 0x0B000000 // How much? | 33 | #define IO_SIZE 0x0B000000 // How much? |
| 34 | #define IO_START INTEGRATOR_HDR_BASE // PA of IO | 34 | #define IO_START INTEGRATOR_HDR_BASE // PA of IO |
| 35 | 35 | ||
| 36 | /* | ||
| 37 | * Similar to above, but for PCI addresses (memory, IO, Config and the | ||
| 38 | * V3 chip itself). WARNING: this has to mirror definitions in platform.h | ||
| 39 | */ | ||
| 40 | #define PCI_MEMORY_VADDR 0xe8000000 | ||
| 41 | #define PCI_CONFIG_VADDR 0xec000000 | ||
| 42 | #define PCI_V3_VADDR 0xed000000 | ||
| 43 | #define PCI_IO_VADDR 0xee000000 | ||
| 44 | |||
| 45 | #define PCIO_BASE PCI_IO_VADDR | 36 | #define PCIO_BASE PCI_IO_VADDR |
| 46 | #define PCIMEM_BASE PCI_MEMORY_VADDR | 37 | #define PCIMEM_BASE PCI_MEMORY_VADDR |
| 47 | 38 | ||
diff --git a/include/asm-arm/arch-integrator/io.h b/include/asm-arm/arch-integrator/io.h index fbea8be67d26..31f2deab51b0 100644 --- a/include/asm-arm/arch-integrator/io.h +++ b/include/asm-arm/arch-integrator/io.h | |||
| @@ -22,6 +22,14 @@ | |||
| 22 | 22 | ||
| 23 | #define IO_SPACE_LIMIT 0xffff | 23 | #define IO_SPACE_LIMIT 0xffff |
| 24 | 24 | ||
| 25 | /* | ||
| 26 | * WARNING: this has to mirror definitions in platform.h | ||
| 27 | */ | ||
| 28 | #define PCI_MEMORY_VADDR 0xe8000000 | ||
| 29 | #define PCI_CONFIG_VADDR 0xec000000 | ||
| 30 | #define PCI_V3_VADDR 0xed000000 | ||
| 31 | #define PCI_IO_VADDR 0xee000000 | ||
| 32 | |||
| 25 | #define __io(a) ((void __iomem *)(PCI_IO_VADDR + (a))) | 33 | #define __io(a) ((void __iomem *)(PCI_IO_VADDR + (a))) |
| 26 | #define __mem_pci(a) (a) | 34 | #define __mem_pci(a) (a) |
| 27 | #define __mem_isa(a) ((a) + PCI_MEMORY_VADDR) | 35 | #define __mem_isa(a) ((a) + PCI_MEMORY_VADDR) |
diff --git a/include/asm-arm/arch-iop3xx/io.h b/include/asm-arm/arch-iop3xx/io.h index 2761dfd8694d..f39046a6ab14 100644 --- a/include/asm-arm/arch-iop3xx/io.h +++ b/include/asm-arm/arch-iop3xx/io.h | |||
| @@ -11,6 +11,8 @@ | |||
| 11 | #ifndef __ASM_ARM_ARCH_IO_H | 11 | #ifndef __ASM_ARM_ARCH_IO_H |
| 12 | #define __ASM_ARM_ARCH_IO_H | 12 | #define __ASM_ARM_ARCH_IO_H |
| 13 | 13 | ||
| 14 | #include <asm/hardware.h> | ||
| 15 | |||
| 14 | #define IO_SPACE_LIMIT 0xffffffff | 16 | #define IO_SPACE_LIMIT 0xffffffff |
| 15 | 17 | ||
| 16 | #define __io(p) ((void __iomem *)(p)) | 18 | #define __io(p) ((void __iomem *)(p)) |
diff --git a/include/asm-arm/arch-ixp2000/io.h b/include/asm-arm/arch-ixp2000/io.h index 3241cd6f0778..7fbcdf9931ee 100644 --- a/include/asm-arm/arch-ixp2000/io.h +++ b/include/asm-arm/arch-ixp2000/io.h | |||
| @@ -15,6 +15,8 @@ | |||
| 15 | #ifndef __ASM_ARM_ARCH_IO_H | 15 | #ifndef __ASM_ARM_ARCH_IO_H |
| 16 | #define __ASM_ARM_ARCH_IO_H | 16 | #define __ASM_ARM_ARCH_IO_H |
| 17 | 17 | ||
| 18 | #include <asm/hardware.h> | ||
| 19 | |||
| 18 | #define IO_SPACE_LIMIT 0xffffffff | 20 | #define IO_SPACE_LIMIT 0xffffffff |
| 19 | #define __mem_pci(a) (a) | 21 | #define __mem_pci(a) (a) |
| 20 | 22 | ||
diff --git a/include/asm-arm/arch-ixp2000/ixp2000-regs.h b/include/asm-arm/arch-ixp2000/ixp2000-regs.h index 32aece069869..def089d693d2 100644 --- a/include/asm-arm/arch-ixp2000/ixp2000-regs.h +++ b/include/asm-arm/arch-ixp2000/ixp2000-regs.h | |||
| @@ -392,4 +392,47 @@ | |||
| 392 | #define WDT_RESET_ENABLE 0x01000000 | 392 | #define WDT_RESET_ENABLE 0x01000000 |
| 393 | 393 | ||
| 394 | 394 | ||
| 395 | /* | ||
| 396 | * MSF registers. The IXP2400 and IXP2800 have somewhat different MSF | ||
| 397 | * units, but the registers that differ between the two don't overlap, | ||
| 398 | * so we can have one register list for both. | ||
| 399 | */ | ||
| 400 | #define IXP2000_MSF_REG(x) ((volatile unsigned long*)(IXP2000_MSF_VIRT_BASE + (x))) | ||
| 401 | #define IXP2000_MSF_RX_CONTROL IXP2000_MSF_REG(0x0000) | ||
| 402 | #define IXP2000_MSF_TX_CONTROL IXP2000_MSF_REG(0x0004) | ||
| 403 | #define IXP2000_MSF_INTERRUPT_STATUS IXP2000_MSF_REG(0x0008) | ||
| 404 | #define IXP2000_MSF_INTERRUPT_ENABLE IXP2000_MSF_REG(0x000c) | ||
| 405 | #define IXP2000_MSF_CSIX_TYPE_MAP IXP2000_MSF_REG(0x0010) | ||
| 406 | #define IXP2000_MSF_FC_EGRESS_STATUS IXP2000_MSF_REG(0x0014) | ||
| 407 | #define IXP2000_MSF_FC_INGRESS_STATUS IXP2000_MSF_REG(0x0018) | ||
| 408 | #define IXP2000_MSF_HWM_CONTROL IXP2000_MSF_REG(0x0024) | ||
| 409 | #define IXP2000_MSF_FC_STATUS_OVERRIDE IXP2000_MSF_REG(0x0028) | ||
| 410 | #define IXP2000_MSF_CLOCK_CONTROL IXP2000_MSF_REG(0x002c) | ||
| 411 | #define IXP2000_MSF_RX_PORT_MAP IXP2000_MSF_REG(0x0040) | ||
| 412 | #define IXP2000_MSF_RBUF_ELEMENT_DONE IXP2000_MSF_REG(0x0044) | ||
| 413 | #define IXP2000_MSF_RX_MPHY_POLL_LIMIT IXP2000_MSF_REG(0x0048) | ||
| 414 | #define IXP2000_MSF_RX_CALENDAR_LENGTH IXP2000_MSF_REG(0x0048) | ||
| 415 | #define IXP2000_MSF_RX_THREAD_FREELIST_TIMEOUT_0 IXP2000_MSF_REG(0x0050) | ||
| 416 | #define IXP2000_MSF_RX_THREAD_FREELIST_TIMEOUT_1 IXP2000_MSF_REG(0x0054) | ||
| 417 | #define IXP2000_MSF_RX_THREAD_FREELIST_TIMEOUT_2 IXP2000_MSF_REG(0x0058) | ||
| 418 | #define IXP2000_MSF_TX_SEQUENCE_0 IXP2000_MSF_REG(0x0060) | ||
| 419 | #define IXP2000_MSF_TX_SEQUENCE_1 IXP2000_MSF_REG(0x0064) | ||
| 420 | #define IXP2000_MSF_TX_SEQUENCE_2 IXP2000_MSF_REG(0x0068) | ||
| 421 | #define IXP2000_MSF_TX_MPHY_POLL_LIMIT IXP2000_MSF_REG(0x0070) | ||
| 422 | #define IXP2000_MSF_TX_CALENDAR_LENGTH IXP2000_MSF_REG(0x0070) | ||
| 423 | #define IXP2000_MSF_RX_UP_CONTROL_0 IXP2000_MSF_REG(0x0080) | ||
| 424 | #define IXP2000_MSF_RX_UP_CONTROL_1 IXP2000_MSF_REG(0x0084) | ||
| 425 | #define IXP2000_MSF_RX_UP_CONTROL_2 IXP2000_MSF_REG(0x0088) | ||
| 426 | #define IXP2000_MSF_RX_UP_CONTROL_3 IXP2000_MSF_REG(0x008c) | ||
| 427 | #define IXP2000_MSF_TX_UP_CONTROL_0 IXP2000_MSF_REG(0x0090) | ||
| 428 | #define IXP2000_MSF_TX_UP_CONTROL_1 IXP2000_MSF_REG(0x0094) | ||
| 429 | #define IXP2000_MSF_TX_UP_CONTROL_2 IXP2000_MSF_REG(0x0098) | ||
| 430 | #define IXP2000_MSF_TX_UP_CONTROL_3 IXP2000_MSF_REG(0x009c) | ||
| 431 | #define IXP2000_MSF_TRAIN_DATA IXP2000_MSF_REG(0x00a0) | ||
| 432 | #define IXP2000_MSF_TRAIN_CALENDAR IXP2000_MSF_REG(0x00a4) | ||
| 433 | #define IXP2000_MSF_TRAIN_FLOW_CONTROL IXP2000_MSF_REG(0x00a8) | ||
| 434 | #define IXP2000_MSF_TX_CALENDAR_0 IXP2000_MSF_REG(0x1000) | ||
| 435 | #define IXP2000_MSF_RX_PORT_CALENDAR_STATUS IXP2000_MSF_REG(0x1400) | ||
| 436 | |||
| 437 | |||
| 395 | #endif /* _IXP2000_H_ */ | 438 | #endif /* _IXP2000_H_ */ |
diff --git a/include/asm-arm/arch-l7200/io.h b/include/asm-arm/arch-l7200/io.h index fc012a39e2cb..cab8ad0adf09 100644 --- a/include/asm-arm/arch-l7200/io.h +++ b/include/asm-arm/arch-l7200/io.h | |||
| @@ -10,7 +10,7 @@ | |||
| 10 | #ifndef __ASM_ARM_ARCH_IO_H | 10 | #ifndef __ASM_ARM_ARCH_IO_H |
| 11 | #define __ASM_ARM_ARCH_IO_H | 11 | #define __ASM_ARM_ARCH_IO_H |
| 12 | 12 | ||
| 13 | #include <asm/arch/hardware.h> | 13 | #include <asm/hardware.h> |
| 14 | 14 | ||
| 15 | #define IO_SPACE_LIMIT 0xffffffff | 15 | #define IO_SPACE_LIMIT 0xffffffff |
| 16 | 16 | ||
diff --git a/include/asm-arm/arch-lh7a40x/io.h b/include/asm-arm/arch-lh7a40x/io.h index c13bdd9add92..bbcd4335f441 100644 --- a/include/asm-arm/arch-lh7a40x/io.h +++ b/include/asm-arm/arch-lh7a40x/io.h | |||
| @@ -11,6 +11,8 @@ | |||
| 11 | #ifndef __ASM_ARCH_IO_H | 11 | #ifndef __ASM_ARCH_IO_H |
| 12 | #define __ASM_ARCH_IO_H | 12 | #define __ASM_ARCH_IO_H |
| 13 | 13 | ||
| 14 | #include <asm/hardware.h> | ||
| 15 | |||
| 14 | #define IO_SPACE_LIMIT 0xffffffff | 16 | #define IO_SPACE_LIMIT 0xffffffff |
| 15 | 17 | ||
| 16 | /* No ISA or PCI bus on this machine. */ | 18 | /* No ISA or PCI bus on this machine. */ |
diff --git a/include/asm-arm/arch-omap/io.h b/include/asm-arm/arch-omap/io.h index 11fbf629bf75..3d5bcd545082 100644 --- a/include/asm-arm/arch-omap/io.h +++ b/include/asm-arm/arch-omap/io.h | |||
| @@ -34,6 +34,8 @@ | |||
| 34 | #ifndef __ASM_ARM_ARCH_IO_H | 34 | #ifndef __ASM_ARM_ARCH_IO_H |
| 35 | #define __ASM_ARM_ARCH_IO_H | 35 | #define __ASM_ARM_ARCH_IO_H |
| 36 | 36 | ||
| 37 | #include <asm/hardware.h> | ||
| 38 | |||
| 37 | #define IO_SPACE_LIMIT 0xffffffff | 39 | #define IO_SPACE_LIMIT 0xffffffff |
| 38 | 40 | ||
| 39 | /* | 41 | /* |
diff --git a/include/asm-arm/arch-pxa/hardware.h b/include/asm-arm/arch-pxa/hardware.h index cf35721cfa45..3e70bd95472c 100644 --- a/include/asm-arm/arch-pxa/hardware.h +++ b/include/asm-arm/arch-pxa/hardware.h | |||
| @@ -44,12 +44,12 @@ | |||
| 44 | 44 | ||
| 45 | #ifndef __ASSEMBLY__ | 45 | #ifndef __ASSEMBLY__ |
| 46 | 46 | ||
| 47 | # define __REG(x) (*((volatile unsigned long *)io_p2v(x))) | 47 | # define __REG(x) (*((volatile u32 *)io_p2v(x))) |
| 48 | 48 | ||
| 49 | /* With indexed regs we don't want to feed the index through io_p2v() | 49 | /* With indexed regs we don't want to feed the index through io_p2v() |
| 50 | especially if it is a variable, otherwise horrible code will result. */ | 50 | especially if it is a variable, otherwise horrible code will result. */ |
| 51 | # define __REG2(x,y) \ | 51 | # define __REG2(x,y) \ |
| 52 | (*(volatile unsigned long *)((unsigned long)&__REG(x) + (y))) | 52 | (*(volatile u32 *)((u32)&__REG(x) + (y))) |
| 53 | 53 | ||
| 54 | # define __PREG(x) (io_v2p((u32)&(x))) | 54 | # define __PREG(x) (io_v2p((u32)&(x))) |
| 55 | 55 | ||
diff --git a/include/asm-arm/arch-pxa/io.h b/include/asm-arm/arch-pxa/io.h index c3bdbe44e21f..eb2dd58d397f 100644 --- a/include/asm-arm/arch-pxa/io.h +++ b/include/asm-arm/arch-pxa/io.h | |||
| @@ -6,6 +6,8 @@ | |||
| 6 | #ifndef __ASM_ARM_ARCH_IO_H | 6 | #ifndef __ASM_ARM_ARCH_IO_H |
| 7 | #define __ASM_ARM_ARCH_IO_H | 7 | #define __ASM_ARM_ARCH_IO_H |
| 8 | 8 | ||
| 9 | #include <asm/hardware.h> | ||
| 10 | |||
| 9 | #define IO_SPACE_LIMIT 0xffffffff | 11 | #define IO_SPACE_LIMIT 0xffffffff |
| 10 | 12 | ||
| 11 | /* | 13 | /* |
diff --git a/include/asm-arm/arch-pxa/irda.h b/include/asm-arm/arch-pxa/irda.h new file mode 100644 index 000000000000..748406f384c2 --- /dev/null +++ b/include/asm-arm/arch-pxa/irda.h | |||
| @@ -0,0 +1,17 @@ | |||
| 1 | #ifndef ASMARM_ARCH_IRDA_H | ||
| 2 | #define ASMARM_ARCH_IRDA_H | ||
| 3 | |||
| 4 | /* board specific transceiver capabilities */ | ||
| 5 | |||
| 6 | #define IR_OFF 1 | ||
| 7 | #define IR_SIRMODE 2 | ||
| 8 | #define IR_FIRMODE 4 | ||
| 9 | |||
| 10 | struct pxaficp_platform_data { | ||
| 11 | int transceiver_cap; | ||
| 12 | void (*transceiver_mode)(struct device *dev, int mode); | ||
| 13 | }; | ||
| 14 | |||
| 15 | extern void pxa_set_ficp_info(struct pxaficp_platform_data *info); | ||
| 16 | |||
| 17 | #endif | ||
diff --git a/include/asm-arm/arch-pxa/pxa-regs.h b/include/asm-arm/arch-pxa/pxa-regs.h index 3af7165ab0d7..a75a2470f4f5 100644 --- a/include/asm-arm/arch-pxa/pxa-regs.h +++ b/include/asm-arm/arch-pxa/pxa-regs.h | |||
| @@ -326,6 +326,25 @@ | |||
| 326 | #define STDLL __REG(0x40700000) /* Divisor Latch Low Register (DLAB = 1) (read/write) */ | 326 | #define STDLL __REG(0x40700000) /* Divisor Latch Low Register (DLAB = 1) (read/write) */ |
| 327 | #define STDLH __REG(0x40700004) /* Divisor Latch High Register (DLAB = 1) (read/write) */ | 327 | #define STDLH __REG(0x40700004) /* Divisor Latch High Register (DLAB = 1) (read/write) */ |
| 328 | 328 | ||
| 329 | /* Hardware UART (HWUART) */ | ||
| 330 | #define HWUART HWRBR | ||
| 331 | #define HWRBR __REG(0x41600000) /* Receive Buffer Register (read only) */ | ||
| 332 | #define HWTHR __REG(0x41600000) /* Transmit Holding Register (write only) */ | ||
| 333 | #define HWIER __REG(0x41600004) /* Interrupt Enable Register (read/write) */ | ||
| 334 | #define HWIIR __REG(0x41600008) /* Interrupt ID Register (read only) */ | ||
| 335 | #define HWFCR __REG(0x41600008) /* FIFO Control Register (write only) */ | ||
| 336 | #define HWLCR __REG(0x4160000C) /* Line Control Register (read/write) */ | ||
| 337 | #define HWMCR __REG(0x41600010) /* Modem Control Register (read/write) */ | ||
| 338 | #define HWLSR __REG(0x41600014) /* Line Status Register (read only) */ | ||
| 339 | #define HWMSR __REG(0x41600018) /* Modem Status Register (read only) */ | ||
| 340 | #define HWSPR __REG(0x4160001C) /* Scratch Pad Register (read/write) */ | ||
| 341 | #define HWISR __REG(0x41600020) /* Infrared Selection Register (read/write) */ | ||
| 342 | #define HWFOR __REG(0x41600024) /* Receive FIFO Occupancy Register (read only) */ | ||
| 343 | #define HWABR __REG(0x41600028) /* Auto-Baud Control Register (read/write) */ | ||
| 344 | #define HWACR __REG(0x4160002C) /* Auto-Baud Count Register (read only) */ | ||
| 345 | #define HWDLL __REG(0x41600000) /* Divisor Latch Low Register (DLAB = 1) (read/write) */ | ||
| 346 | #define HWDLH __REG(0x41600004) /* Divisor Latch High Register (DLAB = 1) (read/write) */ | ||
| 347 | |||
| 329 | #define IER_DMAE (1 << 7) /* DMA Requests Enable */ | 348 | #define IER_DMAE (1 << 7) /* DMA Requests Enable */ |
| 330 | #define IER_UUE (1 << 6) /* UART Unit Enable */ | 349 | #define IER_UUE (1 << 6) /* UART Unit Enable */ |
| 331 | #define IER_NRZE (1 << 5) /* NRZ coding Enable */ | 350 | #define IER_NRZE (1 << 5) /* NRZ coding Enable */ |
| @@ -1013,14 +1032,12 @@ | |||
| 1013 | #define ICCR0_LBM (1 << 1) /* Loopback mode */ | 1032 | #define ICCR0_LBM (1 << 1) /* Loopback mode */ |
| 1014 | #define ICCR0_ITR (1 << 0) /* IrDA transmission */ | 1033 | #define ICCR0_ITR (1 << 0) /* IrDA transmission */ |
| 1015 | 1034 | ||
| 1016 | #ifdef CONFIG_PXA27x | ||
| 1017 | #define ICCR2_RXP (1 << 3) /* Receive Pin Polarity select */ | 1035 | #define ICCR2_RXP (1 << 3) /* Receive Pin Polarity select */ |
| 1018 | #define ICCR2_TXP (1 << 2) /* Transmit Pin Polarity select */ | 1036 | #define ICCR2_TXP (1 << 2) /* Transmit Pin Polarity select */ |
| 1019 | #define ICCR2_TRIG (3 << 0) /* Receive FIFO Trigger threshold */ | 1037 | #define ICCR2_TRIG (3 << 0) /* Receive FIFO Trigger threshold */ |
| 1020 | #define ICCR2_TRIG_8 (0 << 0) /* >= 8 bytes */ | 1038 | #define ICCR2_TRIG_8 (0 << 0) /* >= 8 bytes */ |
| 1021 | #define ICCR2_TRIG_16 (1 << 0) /* >= 16 bytes */ | 1039 | #define ICCR2_TRIG_16 (1 << 0) /* >= 16 bytes */ |
| 1022 | #define ICCR2_TRIG_32 (2 << 0) /* >= 32 bytes */ | 1040 | #define ICCR2_TRIG_32 (2 << 0) /* >= 32 bytes */ |
| 1023 | #endif | ||
| 1024 | 1041 | ||
| 1025 | #ifdef CONFIG_PXA27x | 1042 | #ifdef CONFIG_PXA27x |
| 1026 | #define ICSR0_EOC (1 << 6) /* DMA End of Descriptor Chain */ | 1043 | #define ICSR0_EOC (1 << 6) /* DMA End of Descriptor Chain */ |
| @@ -1250,9 +1267,13 @@ | |||
| 1250 | #define GPIO40_FFDTR 40 /* FFUART data terminal Ready */ | 1267 | #define GPIO40_FFDTR 40 /* FFUART data terminal Ready */ |
| 1251 | #define GPIO41_FFRTS 41 /* FFUART request to send */ | 1268 | #define GPIO41_FFRTS 41 /* FFUART request to send */ |
| 1252 | #define GPIO42_BTRXD 42 /* BTUART receive data */ | 1269 | #define GPIO42_BTRXD 42 /* BTUART receive data */ |
| 1270 | #define GPIO42_HWRXD 42 /* HWUART receive data */ | ||
| 1253 | #define GPIO43_BTTXD 43 /* BTUART transmit data */ | 1271 | #define GPIO43_BTTXD 43 /* BTUART transmit data */ |
| 1272 | #define GPIO43_HWTXD 43 /* HWUART transmit data */ | ||
| 1254 | #define GPIO44_BTCTS 44 /* BTUART clear to send */ | 1273 | #define GPIO44_BTCTS 44 /* BTUART clear to send */ |
| 1274 | #define GPIO44_HWCTS 44 /* HWUART clear to send */ | ||
| 1255 | #define GPIO45_BTRTS 45 /* BTUART request to send */ | 1275 | #define GPIO45_BTRTS 45 /* BTUART request to send */ |
| 1276 | #define GPIO45_HWRTS 45 /* HWUART request to send */ | ||
| 1256 | #define GPIO45_AC97_SYSCLK 45 /* AC97 System Clock */ | 1277 | #define GPIO45_AC97_SYSCLK 45 /* AC97 System Clock */ |
| 1257 | #define GPIO46_ICPRXD 46 /* ICP receive data */ | 1278 | #define GPIO46_ICPRXD 46 /* ICP receive data */ |
| 1258 | #define GPIO46_STRXD 46 /* STD_UART receive data */ | 1279 | #define GPIO46_STRXD 46 /* STD_UART receive data */ |
| @@ -1378,17 +1399,26 @@ | |||
| 1378 | #define GPIO40_FFDTR_MD (40 | GPIO_ALT_FN_2_OUT) | 1399 | #define GPIO40_FFDTR_MD (40 | GPIO_ALT_FN_2_OUT) |
| 1379 | #define GPIO41_FFRTS_MD (41 | GPIO_ALT_FN_2_OUT) | 1400 | #define GPIO41_FFRTS_MD (41 | GPIO_ALT_FN_2_OUT) |
| 1380 | #define GPIO42_BTRXD_MD (42 | GPIO_ALT_FN_1_IN) | 1401 | #define GPIO42_BTRXD_MD (42 | GPIO_ALT_FN_1_IN) |
| 1402 | #define GPIO42_HWRXD_MD (42 | GPIO_ALT_FN_3_IN) | ||
| 1381 | #define GPIO43_BTTXD_MD (43 | GPIO_ALT_FN_2_OUT) | 1403 | #define GPIO43_BTTXD_MD (43 | GPIO_ALT_FN_2_OUT) |
| 1404 | #define GPIO43_HWTXD_MD (43 | GPIO_ALT_FN_3_OUT) | ||
| 1382 | #define GPIO44_BTCTS_MD (44 | GPIO_ALT_FN_1_IN) | 1405 | #define GPIO44_BTCTS_MD (44 | GPIO_ALT_FN_1_IN) |
| 1406 | #define GPIO44_HWCTS_MD (44 | GPIO_ALT_FN_3_IN) | ||
| 1383 | #define GPIO45_BTRTS_MD (45 | GPIO_ALT_FN_2_OUT) | 1407 | #define GPIO45_BTRTS_MD (45 | GPIO_ALT_FN_2_OUT) |
| 1408 | #define GPIO45_HWRTS_MD (45 | GPIO_ALT_FN_3_OUT) | ||
| 1384 | #define GPIO45_SYSCLK_AC97_MD (45 | GPIO_ALT_FN_1_OUT) | 1409 | #define GPIO45_SYSCLK_AC97_MD (45 | GPIO_ALT_FN_1_OUT) |
| 1385 | #define GPIO46_ICPRXD_MD (46 | GPIO_ALT_FN_1_IN) | 1410 | #define GPIO46_ICPRXD_MD (46 | GPIO_ALT_FN_1_IN) |
| 1386 | #define GPIO46_STRXD_MD (46 | GPIO_ALT_FN_2_IN) | 1411 | #define GPIO46_STRXD_MD (46 | GPIO_ALT_FN_2_IN) |
| 1387 | #define GPIO47_ICPTXD_MD (47 | GPIO_ALT_FN_2_OUT) | 1412 | #define GPIO47_ICPTXD_MD (47 | GPIO_ALT_FN_2_OUT) |
| 1388 | #define GPIO47_STTXD_MD (47 | GPIO_ALT_FN_1_OUT) | 1413 | #define GPIO47_STTXD_MD (47 | GPIO_ALT_FN_1_OUT) |
| 1389 | #define GPIO48_nPOE_MD (48 | GPIO_ALT_FN_2_OUT) | 1414 | #define GPIO48_nPOE_MD (48 | GPIO_ALT_FN_2_OUT) |
| 1415 | #define GPIO48_HWTXD_MD (48 | GPIO_ALT_FN_1_OUT) | ||
| 1416 | #define GPIO48_nPOE_MD (48 | GPIO_ALT_FN_2_OUT) | ||
| 1417 | #define GPIO49_HWRXD_MD (49 | GPIO_ALT_FN_1_IN) | ||
| 1390 | #define GPIO49_nPWE_MD (49 | GPIO_ALT_FN_2_OUT) | 1418 | #define GPIO49_nPWE_MD (49 | GPIO_ALT_FN_2_OUT) |
| 1391 | #define GPIO50_nPIOR_MD (50 | GPIO_ALT_FN_2_OUT) | 1419 | #define GPIO50_nPIOR_MD (50 | GPIO_ALT_FN_2_OUT) |
| 1420 | #define GPIO50_HWCTS_MD (50 | GPIO_ALT_FN_1_IN) | ||
| 1421 | #define GPIO51_HWRTS_MD (51 | GPIO_ALT_FN_1_OUT) | ||
| 1392 | #define GPIO51_nPIOW_MD (51 | GPIO_ALT_FN_2_OUT) | 1422 | #define GPIO51_nPIOW_MD (51 | GPIO_ALT_FN_2_OUT) |
| 1393 | #define GPIO52_nPCE_1_MD (52 | GPIO_ALT_FN_2_OUT) | 1423 | #define GPIO52_nPCE_1_MD (52 | GPIO_ALT_FN_2_OUT) |
| 1394 | #define GPIO53_nPCE_2_MD (53 | GPIO_ALT_FN_2_OUT) | 1424 | #define GPIO53_nPCE_2_MD (53 | GPIO_ALT_FN_2_OUT) |
| @@ -1763,6 +1793,7 @@ | |||
| 1763 | #define CKEN7_BTUART (1 << 7) /* BTUART Unit Clock Enable */ | 1793 | #define CKEN7_BTUART (1 << 7) /* BTUART Unit Clock Enable */ |
| 1764 | #define CKEN6_FFUART (1 << 6) /* FFUART Unit Clock Enable */ | 1794 | #define CKEN6_FFUART (1 << 6) /* FFUART Unit Clock Enable */ |
| 1765 | #define CKEN5_STUART (1 << 5) /* STUART Unit Clock Enable */ | 1795 | #define CKEN5_STUART (1 << 5) /* STUART Unit Clock Enable */ |
| 1796 | #define CKEN4_HWUART (1 << 4) /* HWUART Unit Clock Enable */ | ||
| 1766 | #define CKEN4_SSP3 (1 << 4) /* SSP3 Unit Clock Enable */ | 1797 | #define CKEN4_SSP3 (1 << 4) /* SSP3 Unit Clock Enable */ |
| 1767 | #define CKEN3_SSP (1 << 3) /* SSP Unit Clock Enable */ | 1798 | #define CKEN3_SSP (1 << 3) /* SSP Unit Clock Enable */ |
| 1768 | #define CKEN3_SSP2 (1 << 3) /* SSP2 Unit Clock Enable */ | 1799 | #define CKEN3_SSP2 (1 << 3) /* SSP2 Unit Clock Enable */ |
| @@ -2282,4 +2313,11 @@ | |||
| 2282 | 2313 | ||
| 2283 | #endif | 2314 | #endif |
| 2284 | 2315 | ||
| 2316 | /* PWRMODE register M field values */ | ||
| 2317 | |||
| 2318 | #define PWRMODE_IDLE 0x1 | ||
| 2319 | #define PWRMODE_STANDBY 0x2 | ||
| 2320 | #define PWRMODE_SLEEP 0x3 | ||
| 2321 | #define PWRMODE_DEEPSLEEP 0x7 | ||
| 2322 | |||
| 2285 | #endif | 2323 | #endif |
diff --git a/include/asm-arm/arch-pxa/uncompress.h b/include/asm-arm/arch-pxa/uncompress.h index 4428d3eb7432..fe38090444e0 100644 --- a/include/asm-arm/arch-pxa/uncompress.h +++ b/include/asm-arm/arch-pxa/uncompress.h | |||
| @@ -12,6 +12,7 @@ | |||
| 12 | #define FFUART ((volatile unsigned long *)0x40100000) | 12 | #define FFUART ((volatile unsigned long *)0x40100000) |
| 13 | #define BTUART ((volatile unsigned long *)0x40200000) | 13 | #define BTUART ((volatile unsigned long *)0x40200000) |
| 14 | #define STUART ((volatile unsigned long *)0x40700000) | 14 | #define STUART ((volatile unsigned long *)0x40700000) |
| 15 | #define HWUART ((volatile unsigned long *)0x41600000) | ||
| 15 | 16 | ||
| 16 | #define UART FFUART | 17 | #define UART FFUART |
| 17 | 18 | ||
diff --git a/include/asm-arm/arch-rpc/io.h b/include/asm-arm/arch-rpc/io.h index 24453c405a87..b4da08d7a336 100644 --- a/include/asm-arm/arch-rpc/io.h +++ b/include/asm-arm/arch-rpc/io.h | |||
| @@ -13,6 +13,8 @@ | |||
| 13 | #ifndef __ASM_ARM_ARCH_IO_H | 13 | #ifndef __ASM_ARM_ARCH_IO_H |
| 14 | #define __ASM_ARM_ARCH_IO_H | 14 | #define __ASM_ARM_ARCH_IO_H |
| 15 | 15 | ||
| 16 | #include <asm/hardware.h> | ||
| 17 | |||
| 16 | #define IO_SPACE_LIMIT 0xffffffff | 18 | #define IO_SPACE_LIMIT 0xffffffff |
| 17 | 19 | ||
| 18 | /* | 20 | /* |
diff --git a/include/asm-arm/arch-s3c2410/fb.h b/include/asm-arm/arch-s3c2410/fb.h index ac57bc887d82..4790491ba9d0 100644 --- a/include/asm-arm/arch-s3c2410/fb.h +++ b/include/asm-arm/arch-s3c2410/fb.h | |||
| @@ -13,6 +13,7 @@ | |||
| 13 | * 07-Sep-2004 RTP Created file | 13 | * 07-Sep-2004 RTP Created file |
| 14 | * 03-Nov-2004 BJD Updated and minor cleanups | 14 | * 03-Nov-2004 BJD Updated and minor cleanups |
| 15 | * 03-Aug-2005 RTP Renamed to fb.h | 15 | * 03-Aug-2005 RTP Renamed to fb.h |
| 16 | * 26-Oct-2005 BJD Changed name of platdata init | ||
| 16 | */ | 17 | */ |
| 17 | 18 | ||
| 18 | #ifndef __ASM_ARM_FB_H | 19 | #ifndef __ASM_ARM_FB_H |
| @@ -64,6 +65,6 @@ struct s3c2410fb_mach_info { | |||
| 64 | unsigned long lpcsel; | 65 | unsigned long lpcsel; |
| 65 | }; | 66 | }; |
| 66 | 67 | ||
| 67 | void __init set_s3c2410fb_info(struct s3c2410fb_mach_info *hard_s3c2410fb_info); | 68 | extern void __init s3c24xx_fb_set_platdata(struct s3c2410fb_mach_info *); |
| 68 | 69 | ||
| 69 | #endif /* __ASM_ARM_FB_H */ | 70 | #endif /* __ASM_ARM_FB_H */ |
diff --git a/include/asm-arm/arch-s3c2410/io.h b/include/asm-arm/arch-s3c2410/io.h index 4bf272ed9add..16fbc8afffd9 100644 --- a/include/asm-arm/arch-s3c2410/io.h +++ b/include/asm-arm/arch-s3c2410/io.h | |||
| @@ -15,6 +15,8 @@ | |||
| 15 | #ifndef __ASM_ARM_ARCH_IO_H | 15 | #ifndef __ASM_ARM_ARCH_IO_H |
| 16 | #define __ASM_ARM_ARCH_IO_H | 16 | #define __ASM_ARM_ARCH_IO_H |
| 17 | 17 | ||
| 18 | #include <asm/hardware.h> | ||
| 19 | |||
| 18 | #define IO_SPACE_LIMIT 0xffffffff | 20 | #define IO_SPACE_LIMIT 0xffffffff |
| 19 | 21 | ||
| 20 | /* | 22 | /* |
diff --git a/include/asm-arm/arch-s3c2410/regs-gpio.h b/include/asm-arm/arch-s3c2410/regs-gpio.h index 2053cbacffc3..cb33d57c146c 100644 --- a/include/asm-arm/arch-s3c2410/regs-gpio.h +++ b/include/asm-arm/arch-s3c2410/regs-gpio.h | |||
| @@ -20,6 +20,7 @@ | |||
| 20 | * 18-11-2004 BJD Added S3C2440 AC97 controls | 20 | * 18-11-2004 BJD Added S3C2440 AC97 controls |
| 21 | * 10-Mar-2005 LCVR Changed S3C2410_VA to S3C24XX_VA | 21 | * 10-Mar-2005 LCVR Changed S3C2410_VA to S3C24XX_VA |
| 22 | * 28-Mar-2005 LCVR Fixed definition of GPB10 | 22 | * 28-Mar-2005 LCVR Fixed definition of GPB10 |
| 23 | * 26-Oct-2005 BJD Added generic configuration types | ||
| 23 | */ | 24 | */ |
| 24 | 25 | ||
| 25 | 26 | ||
| @@ -43,6 +44,11 @@ | |||
| 43 | /* general configuration options */ | 44 | /* general configuration options */ |
| 44 | 45 | ||
| 45 | #define S3C2410_GPIO_LEAVE (0xFFFFFFFF) | 46 | #define S3C2410_GPIO_LEAVE (0xFFFFFFFF) |
| 47 | #define S3C2410_GPIO_INPUT (0xFFFFFFF0) | ||
| 48 | #define S3C2410_GPIO_OUTPUT (0xFFFFFFF1) | ||
| 49 | #define S3C2410_GPIO_IRQ (0xFFFFFFF2) /* not available for all */ | ||
| 50 | #define S3C2410_GPIO_SFN2 (0xFFFFFFF2) /* not available on A */ | ||
| 51 | #define S3C2410_GPIO_SFN3 (0xFFFFFFF3) /* not available on A */ | ||
| 46 | 52 | ||
| 47 | /* configure GPIO ports A..G */ | 53 | /* configure GPIO ports A..G */ |
| 48 | 54 | ||
diff --git a/include/asm-arm/arch-sa1100/hardware.h b/include/asm-arm/arch-sa1100/hardware.h index 19c3b1e186bb..28711aaa4968 100644 --- a/include/asm-arm/arch-sa1100/hardware.h +++ b/include/asm-arm/arch-sa1100/hardware.h | |||
| @@ -22,13 +22,6 @@ | |||
| 22 | 22 | ||
| 23 | 23 | ||
| 24 | /* | 24 | /* |
| 25 | * We requires absolute addresses i.e. (PCMCIA_IO_0_BASE + 0x3f8) for | ||
| 26 | * in*()/out*() macros to be usable for all cases. | ||
| 27 | */ | ||
| 28 | #define PCIO_BASE 0 | ||
| 29 | |||
| 30 | |||
| 31 | /* | ||
| 32 | * SA1100 internal I/O mappings | 25 | * SA1100 internal I/O mappings |
| 33 | * | 26 | * |
| 34 | * We have the following mapping: | 27 | * We have the following mapping: |
diff --git a/include/asm-arm/arch-sa1100/io.h b/include/asm-arm/arch-sa1100/io.h index 7d969ffbd3bb..9d4fe6cf205b 100644 --- a/include/asm-arm/arch-sa1100/io.h +++ b/include/asm-arm/arch-sa1100/io.h | |||
| @@ -10,13 +10,19 @@ | |||
| 10 | #ifndef __ASM_ARM_ARCH_IO_H | 10 | #ifndef __ASM_ARM_ARCH_IO_H |
| 11 | #define __ASM_ARM_ARCH_IO_H | 11 | #define __ASM_ARM_ARCH_IO_H |
| 12 | 12 | ||
| 13 | #include <asm/hardware.h> | ||
| 14 | |||
| 13 | #define IO_SPACE_LIMIT 0xffffffff | 15 | #define IO_SPACE_LIMIT 0xffffffff |
| 14 | 16 | ||
| 15 | /* | 17 | /* |
| 16 | * We don't actually have real ISA nor PCI buses, but there is so many | 18 | * We don't actually have real ISA nor PCI buses, but there is so many |
| 17 | * drivers out there that might just work if we fake them... | 19 | * drivers out there that might just work if we fake them... |
| 18 | */ | 20 | */ |
| 19 | #define __io(a) ((void __iomem *)(PCIO_BASE + (a))) | 21 | static inline void __iomem *__io(unsigned long addr) |
| 22 | { | ||
| 23 | return (void __iomem *)addr; | ||
| 24 | } | ||
| 25 | #define __io(a) __io(a) | ||
| 20 | #define __mem_pci(a) (a) | 26 | #define __mem_pci(a) (a) |
| 21 | #define __mem_isa(a) (a) | 27 | #define __mem_isa(a) (a) |
| 22 | 28 | ||
diff --git a/include/asm-arm/arch-sa1100/system.h b/include/asm-arm/arch-sa1100/system.h index 6f52118ba1a4..0f0612f79b2b 100644 --- a/include/asm-arm/arch-sa1100/system.h +++ b/include/asm-arm/arch-sa1100/system.h | |||
| @@ -4,6 +4,7 @@ | |||
| 4 | * Copyright (c) 1999 Nicolas Pitre <nico@cam.org> | 4 | * Copyright (c) 1999 Nicolas Pitre <nico@cam.org> |
| 5 | */ | 5 | */ |
| 6 | #include <linux/config.h> | 6 | #include <linux/config.h> |
| 7 | #include <asm/hardware.h> | ||
| 7 | 8 | ||
| 8 | static inline void arch_idle(void) | 9 | static inline void arch_idle(void) |
| 9 | { | 10 | { |
diff --git a/include/asm-arm/arch-shark/io.h b/include/asm-arm/arch-shark/io.h index 5e6ed0038b2b..87ffa27f2962 100644 --- a/include/asm-arm/arch-shark/io.h +++ b/include/asm-arm/arch-shark/io.h | |||
| @@ -11,6 +11,8 @@ | |||
| 11 | #ifndef __ASM_ARM_ARCH_IO_H | 11 | #ifndef __ASM_ARM_ARCH_IO_H |
| 12 | #define __ASM_ARM_ARCH_IO_H | 12 | #define __ASM_ARM_ARCH_IO_H |
| 13 | 13 | ||
| 14 | #include <asm/hardware.h> | ||
| 15 | |||
| 14 | #define IO_SPACE_LIMIT 0xffffffff | 16 | #define IO_SPACE_LIMIT 0xffffffff |
| 15 | 17 | ||
| 16 | /* | 18 | /* |
diff --git a/include/asm-arm/dma-mapping.h b/include/asm-arm/dma-mapping.h index d62ade4e4cbb..e3e8541ee63b 100644 --- a/include/asm-arm/dma-mapping.h +++ b/include/asm-arm/dma-mapping.h | |||
| @@ -70,7 +70,7 @@ static inline int dma_mapping_error(dma_addr_t dma_addr) | |||
| 70 | * device-viewed address. | 70 | * device-viewed address. |
| 71 | */ | 71 | */ |
| 72 | extern void * | 72 | extern void * |
| 73 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *handle, int gfp); | 73 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *handle, gfp_t gfp); |
| 74 | 74 | ||
| 75 | /** | 75 | /** |
| 76 | * dma_free_coherent - free memory allocated by dma_alloc_coherent | 76 | * dma_free_coherent - free memory allocated by dma_alloc_coherent |
| @@ -117,7 +117,7 @@ int dma_mmap_coherent(struct device *dev, struct vm_area_struct *vma, | |||
| 117 | * device-viewed address. | 117 | * device-viewed address. |
| 118 | */ | 118 | */ |
| 119 | extern void * | 119 | extern void * |
| 120 | dma_alloc_writecombine(struct device *dev, size_t size, dma_addr_t *handle, int gfp); | 120 | dma_alloc_writecombine(struct device *dev, size_t size, dma_addr_t *handle, gfp_t gfp); |
| 121 | 121 | ||
| 122 | #define dma_free_writecombine(dev,size,cpu_addr,handle) \ | 122 | #define dma_free_writecombine(dev,size,cpu_addr,handle) \ |
| 123 | dma_free_coherent(dev,size,cpu_addr,handle) | 123 | dma_free_coherent(dev,size,cpu_addr,handle) |
diff --git a/include/asm-arm/io.h b/include/asm-arm/io.h index 5c4ae8f5dbb0..2e6799632f12 100644 --- a/include/asm-arm/io.h +++ b/include/asm-arm/io.h | |||
| @@ -26,7 +26,6 @@ | |||
| 26 | #include <linux/types.h> | 26 | #include <linux/types.h> |
| 27 | #include <asm/byteorder.h> | 27 | #include <asm/byteorder.h> |
| 28 | #include <asm/memory.h> | 28 | #include <asm/memory.h> |
| 29 | #include <asm/arch/hardware.h> | ||
| 30 | 29 | ||
| 31 | /* | 30 | /* |
| 32 | * ISA I/O bus memory addresses are 1:1 with the physical address. | 31 | * ISA I/O bus memory addresses are 1:1 with the physical address. |
diff --git a/include/asm-arm/mach/arch.h b/include/asm-arm/mach/arch.h index 4fa95084a8c0..7273c6fd95b5 100644 --- a/include/asm-arm/mach/arch.h +++ b/include/asm-arm/mach/arch.h | |||
| @@ -48,10 +48,10 @@ struct machine_desc { | |||
| 48 | * Set of macros to define architecture features. This is built into | 48 | * Set of macros to define architecture features. This is built into |
| 49 | * a table by the linker. | 49 | * a table by the linker. |
| 50 | */ | 50 | */ |
| 51 | #define MACHINE_START(_type,_name) \ | 51 | #define MACHINE_START(_type,_name) \ |
| 52 | const struct machine_desc __mach_desc_##_type \ | 52 | static const struct machine_desc __mach_desc_##_type \ |
| 53 | __attribute__((__section__(".arch.info.init"))) = { \ | 53 | __attribute__((__section__(".arch.info.init"))) = { \ |
| 54 | .nr = MACH_TYPE_##_type, \ | 54 | .nr = MACH_TYPE_##_type, \ |
| 55 | .name = _name, | 55 | .name = _name, |
| 56 | 56 | ||
| 57 | #define MACHINE_END \ | 57 | #define MACHINE_END \ |
diff --git a/include/asm-arm/mach/map.h b/include/asm-arm/mach/map.h index 9ac47cf8d2e4..0619522bd926 100644 --- a/include/asm-arm/mach/map.h +++ b/include/asm-arm/mach/map.h | |||
| @@ -11,7 +11,7 @@ | |||
| 11 | */ | 11 | */ |
| 12 | struct map_desc { | 12 | struct map_desc { |
| 13 | unsigned long virtual; | 13 | unsigned long virtual; |
| 14 | unsigned long physical; | 14 | unsigned long pfn; |
| 15 | unsigned long length; | 15 | unsigned long length; |
| 16 | unsigned int type; | 16 | unsigned int type; |
| 17 | }; | 17 | }; |
| @@ -27,6 +27,9 @@ struct meminfo; | |||
| 27 | #define MT_ROM 6 | 27 | #define MT_ROM 6 |
| 28 | #define MT_IXP2000_DEVICE 7 | 28 | #define MT_IXP2000_DEVICE 7 |
| 29 | 29 | ||
| 30 | #define __phys_to_pfn(paddr) (paddr >> PAGE_SHIFT) | ||
| 31 | #define __pfn_to_phys(pfn) (pfn << PAGE_SHIFT) | ||
| 32 | |||
| 30 | extern void create_memmap_holes(struct meminfo *); | 33 | extern void create_memmap_holes(struct meminfo *); |
| 31 | extern void memtable_init(struct meminfo *); | 34 | extern void memtable_init(struct meminfo *); |
| 32 | extern void iotable_init(struct map_desc *, int); | 35 | extern void iotable_init(struct map_desc *, int); |
diff --git a/include/asm-cris/dma-mapping.h b/include/asm-cris/dma-mapping.h index 0b5c3fdaefe1..8eff51349ae7 100644 --- a/include/asm-cris/dma-mapping.h +++ b/include/asm-cris/dma-mapping.h | |||
| @@ -15,14 +15,14 @@ | |||
| 15 | 15 | ||
| 16 | #ifdef CONFIG_PCI | 16 | #ifdef CONFIG_PCI |
| 17 | void *dma_alloc_coherent(struct device *dev, size_t size, | 17 | void *dma_alloc_coherent(struct device *dev, size_t size, |
| 18 | dma_addr_t *dma_handle, int flag); | 18 | dma_addr_t *dma_handle, gfp_t flag); |
| 19 | 19 | ||
| 20 | void dma_free_coherent(struct device *dev, size_t size, | 20 | void dma_free_coherent(struct device *dev, size_t size, |
| 21 | void *vaddr, dma_addr_t dma_handle); | 21 | void *vaddr, dma_addr_t dma_handle); |
| 22 | #else | 22 | #else |
| 23 | static inline void * | 23 | static inline void * |
| 24 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, | 24 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, |
| 25 | int flag) | 25 | gfp_t flag) |
| 26 | { | 26 | { |
| 27 | BUG(); | 27 | BUG(); |
| 28 | return NULL; | 28 | return NULL; |
diff --git a/include/asm-frv/dma-mapping.h b/include/asm-frv/dma-mapping.h index 0206ab35eae0..5003e017fd1e 100644 --- a/include/asm-frv/dma-mapping.h +++ b/include/asm-frv/dma-mapping.h | |||
| @@ -13,7 +13,7 @@ | |||
| 13 | extern unsigned long __nongprelbss dma_coherent_mem_start; | 13 | extern unsigned long __nongprelbss dma_coherent_mem_start; |
| 14 | extern unsigned long __nongprelbss dma_coherent_mem_end; | 14 | extern unsigned long __nongprelbss dma_coherent_mem_end; |
| 15 | 15 | ||
| 16 | void *dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, int gfp); | 16 | void *dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, gfp_t gfp); |
| 17 | void dma_free_coherent(struct device *dev, size_t size, void *vaddr, dma_addr_t dma_handle); | 17 | void dma_free_coherent(struct device *dev, size_t size, void *vaddr, dma_addr_t dma_handle); |
| 18 | 18 | ||
| 19 | /* | 19 | /* |
diff --git a/include/asm-frv/pci.h b/include/asm-frv/pci.h index b4efe5e3591a..1168451c275f 100644 --- a/include/asm-frv/pci.h +++ b/include/asm-frv/pci.h | |||
| @@ -32,7 +32,7 @@ extern void pcibios_set_master(struct pci_dev *dev); | |||
| 32 | extern void pcibios_penalize_isa_irq(int irq); | 32 | extern void pcibios_penalize_isa_irq(int irq); |
| 33 | 33 | ||
| 34 | #ifdef CONFIG_MMU | 34 | #ifdef CONFIG_MMU |
| 35 | extern void *consistent_alloc(int gfp, size_t size, dma_addr_t *dma_handle); | 35 | extern void *consistent_alloc(gfp_t gfp, size_t size, dma_addr_t *dma_handle); |
| 36 | extern void consistent_free(void *vaddr); | 36 | extern void consistent_free(void *vaddr); |
| 37 | extern void consistent_sync(void *vaddr, size_t size, int direction); | 37 | extern void consistent_sync(void *vaddr, size_t size, int direction); |
| 38 | extern void consistent_sync_page(struct page *page, unsigned long offset, | 38 | extern void consistent_sync_page(struct page *page, unsigned long offset, |
diff --git a/include/asm-generic/dma-mapping-broken.h b/include/asm-generic/dma-mapping-broken.h index fd9de9502dff..a7f1a55ce6b0 100644 --- a/include/asm-generic/dma-mapping-broken.h +++ b/include/asm-generic/dma-mapping-broken.h | |||
| @@ -6,7 +6,7 @@ | |||
| 6 | 6 | ||
| 7 | static inline void * | 7 | static inline void * |
| 8 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, | 8 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, |
| 9 | int flag) | 9 | gfp_t flag) |
| 10 | { | 10 | { |
| 11 | BUG(); | 11 | BUG(); |
| 12 | return NULL; | 12 | return NULL; |
diff --git a/include/asm-ia64/machvec.h b/include/asm-ia64/machvec.h index 79e89a7db566..a2f6ac5aef7d 100644 --- a/include/asm-ia64/machvec.h +++ b/include/asm-ia64/machvec.h | |||
| @@ -37,7 +37,7 @@ typedef int ia64_mv_pci_legacy_write_t (struct pci_bus *, u16 port, u32 val, | |||
| 37 | 37 | ||
| 38 | /* DMA-mapping interface: */ | 38 | /* DMA-mapping interface: */ |
| 39 | typedef void ia64_mv_dma_init (void); | 39 | typedef void ia64_mv_dma_init (void); |
| 40 | typedef void *ia64_mv_dma_alloc_coherent (struct device *, size_t, dma_addr_t *, int); | 40 | typedef void *ia64_mv_dma_alloc_coherent (struct device *, size_t, dma_addr_t *, gfp_t); |
| 41 | typedef void ia64_mv_dma_free_coherent (struct device *, size_t, void *, dma_addr_t); | 41 | typedef void ia64_mv_dma_free_coherent (struct device *, size_t, void *, dma_addr_t); |
| 42 | typedef dma_addr_t ia64_mv_dma_map_single (struct device *, void *, size_t, int); | 42 | typedef dma_addr_t ia64_mv_dma_map_single (struct device *, void *, size_t, int); |
| 43 | typedef void ia64_mv_dma_unmap_single (struct device *, dma_addr_t, size_t, int); | 43 | typedef void ia64_mv_dma_unmap_single (struct device *, dma_addr_t, size_t, int); |
diff --git a/include/asm-m32r/dma-mapping.h b/include/asm-m32r/dma-mapping.h index 3a2db28834b6..a7fa0302bda7 100644 --- a/include/asm-m32r/dma-mapping.h +++ b/include/asm-m32r/dma-mapping.h | |||
| @@ -8,7 +8,7 @@ | |||
| 8 | 8 | ||
| 9 | static inline void * | 9 | static inline void * |
| 10 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, | 10 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, |
| 11 | int flag) | 11 | gfp_t flag) |
| 12 | { | 12 | { |
| 13 | return (void *)NULL; | 13 | return (void *)NULL; |
| 14 | } | 14 | } |
diff --git a/include/asm-mips/dma-mapping.h b/include/asm-mips/dma-mapping.h index af28dc88930b..43288634c38a 100644 --- a/include/asm-mips/dma-mapping.h +++ b/include/asm-mips/dma-mapping.h | |||
| @@ -5,13 +5,13 @@ | |||
| 5 | #include <asm/cache.h> | 5 | #include <asm/cache.h> |
| 6 | 6 | ||
| 7 | void *dma_alloc_noncoherent(struct device *dev, size_t size, | 7 | void *dma_alloc_noncoherent(struct device *dev, size_t size, |
| 8 | dma_addr_t *dma_handle, int flag); | 8 | dma_addr_t *dma_handle, gfp_t flag); |
| 9 | 9 | ||
| 10 | void dma_free_noncoherent(struct device *dev, size_t size, | 10 | void dma_free_noncoherent(struct device *dev, size_t size, |
| 11 | void *vaddr, dma_addr_t dma_handle); | 11 | void *vaddr, dma_addr_t dma_handle); |
| 12 | 12 | ||
| 13 | void *dma_alloc_coherent(struct device *dev, size_t size, | 13 | void *dma_alloc_coherent(struct device *dev, size_t size, |
| 14 | dma_addr_t *dma_handle, int flag); | 14 | dma_addr_t *dma_handle, gfp_t flag); |
| 15 | 15 | ||
| 16 | void dma_free_coherent(struct device *dev, size_t size, | 16 | void dma_free_coherent(struct device *dev, size_t size, |
| 17 | void *vaddr, dma_addr_t dma_handle); | 17 | void *vaddr, dma_addr_t dma_handle); |
diff --git a/include/asm-mips/sgi/hpc3.h b/include/asm-mips/sgi/hpc3.h index ac3dfc7af5b0..fcec52bafb25 100644 --- a/include/asm-mips/sgi/hpc3.h +++ b/include/asm-mips/sgi/hpc3.h | |||
| @@ -128,26 +128,26 @@ struct hpc3_ethregs { | |||
| 128 | volatile u32 rx_gfptr; /* current GIO fifo ptr */ | 128 | volatile u32 rx_gfptr; /* current GIO fifo ptr */ |
| 129 | volatile u32 rx_dfptr; /* current device fifo ptr */ | 129 | volatile u32 rx_dfptr; /* current device fifo ptr */ |
| 130 | u32 _unused1; /* padding */ | 130 | u32 _unused1; /* padding */ |
| 131 | volatile u32 rx_reset; /* reset register */ | 131 | volatile u32 reset; /* reset register */ |
| 132 | #define HPC3_ERXRST_CRESET 0x1 /* Reset dma channel and external controller */ | 132 | #define HPC3_ERST_CRESET 0x1 /* Reset dma channel and external controller */ |
| 133 | #define HPC3_ERXRST_CLRIRQ 0x2 /* Clear channel interrupt */ | 133 | #define HPC3_ERST_CLRIRQ 0x2 /* Clear channel interrupt */ |
| 134 | #define HPC3_ERXRST_LBACK 0x4 /* Enable diagnostic loopback mode of Seeq8003 */ | 134 | #define HPC3_ERST_LBACK 0x4 /* Enable diagnostic loopback mode of Seeq8003 */ |
| 135 | 135 | ||
| 136 | volatile u32 rx_dconfig; /* DMA configuration register */ | 136 | volatile u32 dconfig; /* DMA configuration register */ |
| 137 | #define HPC3_ERXDCFG_D1 0x0000f /* Cycles to spend in D1 state for PIO */ | 137 | #define HPC3_EDCFG_D1 0x0000f /* Cycles to spend in D1 state for PIO */ |
| 138 | #define HPC3_ERXDCFG_D2 0x000f0 /* Cycles to spend in D2 state for PIO */ | 138 | #define HPC3_EDCFG_D2 0x000f0 /* Cycles to spend in D2 state for PIO */ |
| 139 | #define HPC3_ERXDCFG_D3 0x00f00 /* Cycles to spend in D3 state for PIO */ | 139 | #define HPC3_EDCFG_D3 0x00f00 /* Cycles to spend in D3 state for PIO */ |
| 140 | #define HPC3_ERXDCFG_WCTRL 0x01000 /* Enable writes of desc into ex ctrl port */ | 140 | #define HPC3_EDCFG_WCTRL 0x01000 /* Enable writes of desc into ex ctrl port */ |
| 141 | #define HPC3_ERXDCFG_FRXDC 0x02000 /* Clear eop stat bits upon rxdc, hw seeq fix */ | 141 | #define HPC3_EDCFG_FRXDC 0x02000 /* Clear eop stat bits upon rxdc, hw seeq fix */ |
| 142 | #define HPC3_ERXDCFG_FEOP 0x04000 /* Bad packet marker timeout enable */ | 142 | #define HPC3_EDCFG_FEOP 0x04000 /* Bad packet marker timeout enable */ |
| 143 | #define HPC3_ERXDCFG_FIRQ 0x08000 /* Another bad packet timeout enable */ | 143 | #define HPC3_EDCFG_FIRQ 0x08000 /* Another bad packet timeout enable */ |
| 144 | #define HPC3_ERXDCFG_PTO 0x30000 /* Programmed timeout value for above two */ | 144 | #define HPC3_EDCFG_PTO 0x30000 /* Programmed timeout value for above two */ |
| 145 | 145 | ||
| 146 | volatile u32 rx_pconfig; /* PIO configuration register */ | 146 | volatile u32 pconfig; /* PIO configuration register */ |
| 147 | #define HPC3_ERXPCFG_P1 0x000f /* Cycles to spend in P1 state for PIO */ | 147 | #define HPC3_EPCFG_P1 0x000f /* Cycles to spend in P1 state for PIO */ |
| 148 | #define HPC3_ERXPCFG_P2 0x00f0 /* Cycles to spend in P2 state for PIO */ | 148 | #define HPC3_EPCFG_P2 0x00f0 /* Cycles to spend in P2 state for PIO */ |
| 149 | #define HPC3_ERXPCFG_P3 0x0f00 /* Cycles to spend in P3 state for PIO */ | 149 | #define HPC3_EPCFG_P3 0x0f00 /* Cycles to spend in P3 state for PIO */ |
| 150 | #define HPC3_ERXPCFG_TST 0x1000 /* Diagnistic ram test feature bit */ | 150 | #define HPC3_EPCFG_TST 0x1000 /* Diagnistic ram test feature bit */ |
| 151 | 151 | ||
| 152 | u32 _unused2[0x1000/4 - 8]; /* padding */ | 152 | u32 _unused2[0x1000/4 - 8]; /* padding */ |
| 153 | 153 | ||
diff --git a/include/asm-parisc/dma-mapping.h b/include/asm-parisc/dma-mapping.h index 4db84f969e9e..74d4ac6f2151 100644 --- a/include/asm-parisc/dma-mapping.h +++ b/include/asm-parisc/dma-mapping.h | |||
| @@ -9,8 +9,8 @@ | |||
| 9 | /* See Documentation/DMA-mapping.txt */ | 9 | /* See Documentation/DMA-mapping.txt */ |
| 10 | struct hppa_dma_ops { | 10 | struct hppa_dma_ops { |
| 11 | int (*dma_supported)(struct device *dev, u64 mask); | 11 | int (*dma_supported)(struct device *dev, u64 mask); |
| 12 | void *(*alloc_consistent)(struct device *dev, size_t size, dma_addr_t *iova, int flag); | 12 | void *(*alloc_consistent)(struct device *dev, size_t size, dma_addr_t *iova, gfp_t flag); |
| 13 | void *(*alloc_noncoherent)(struct device *dev, size_t size, dma_addr_t *iova, int flag); | 13 | void *(*alloc_noncoherent)(struct device *dev, size_t size, dma_addr_t *iova, gfp_t flag); |
| 14 | void (*free_consistent)(struct device *dev, size_t size, void *vaddr, dma_addr_t iova); | 14 | void (*free_consistent)(struct device *dev, size_t size, void *vaddr, dma_addr_t iova); |
| 15 | dma_addr_t (*map_single)(struct device *dev, void *addr, size_t size, enum dma_data_direction direction); | 15 | dma_addr_t (*map_single)(struct device *dev, void *addr, size_t size, enum dma_data_direction direction); |
| 16 | void (*unmap_single)(struct device *dev, dma_addr_t iova, size_t size, enum dma_data_direction direction); | 16 | void (*unmap_single)(struct device *dev, dma_addr_t iova, size_t size, enum dma_data_direction direction); |
| @@ -49,14 +49,14 @@ extern struct hppa_dma_ops *hppa_dma_ops; | |||
| 49 | 49 | ||
| 50 | static inline void * | 50 | static inline void * |
| 51 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, | 51 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, |
| 52 | int flag) | 52 | gfp_t flag) |
| 53 | { | 53 | { |
| 54 | return hppa_dma_ops->alloc_consistent(dev, size, dma_handle, flag); | 54 | return hppa_dma_ops->alloc_consistent(dev, size, dma_handle, flag); |
| 55 | } | 55 | } |
| 56 | 56 | ||
| 57 | static inline void * | 57 | static inline void * |
| 58 | dma_alloc_noncoherent(struct device *dev, size_t size, dma_addr_t *dma_handle, | 58 | dma_alloc_noncoherent(struct device *dev, size_t size, dma_addr_t *dma_handle, |
| 59 | int flag) | 59 | gfp_t flag) |
| 60 | { | 60 | { |
| 61 | return hppa_dma_ops->alloc_noncoherent(dev, size, dma_handle, flag); | 61 | return hppa_dma_ops->alloc_noncoherent(dev, size, dma_handle, flag); |
| 62 | } | 62 | } |
diff --git a/include/asm-ppc/dma-mapping.h b/include/asm-ppc/dma-mapping.h index 061bfcac1bf1..6e9635114433 100644 --- a/include/asm-ppc/dma-mapping.h +++ b/include/asm-ppc/dma-mapping.h | |||
| @@ -19,7 +19,7 @@ | |||
| 19 | * allocate the space "normally" and use the cache management functions | 19 | * allocate the space "normally" and use the cache management functions |
| 20 | * to ensure it is consistent. | 20 | * to ensure it is consistent. |
| 21 | */ | 21 | */ |
| 22 | extern void *__dma_alloc_coherent(size_t size, dma_addr_t *handle, int gfp); | 22 | extern void *__dma_alloc_coherent(size_t size, dma_addr_t *handle, gfp_t gfp); |
| 23 | extern void __dma_free_coherent(size_t size, void *vaddr); | 23 | extern void __dma_free_coherent(size_t size, void *vaddr); |
| 24 | extern void __dma_sync(void *vaddr, size_t size, int direction); | 24 | extern void __dma_sync(void *vaddr, size_t size, int direction); |
| 25 | extern void __dma_sync_page(struct page *page, unsigned long offset, | 25 | extern void __dma_sync_page(struct page *page, unsigned long offset, |
diff --git a/include/asm-sh/dma-mapping.h b/include/asm-sh/dma-mapping.h index 80d164c1529e..d3fa5c2b889d 100644 --- a/include/asm-sh/dma-mapping.h +++ b/include/asm-sh/dma-mapping.h | |||
| @@ -9,7 +9,7 @@ | |||
| 9 | extern struct bus_type pci_bus_type; | 9 | extern struct bus_type pci_bus_type; |
| 10 | 10 | ||
| 11 | /* arch/sh/mm/consistent.c */ | 11 | /* arch/sh/mm/consistent.c */ |
| 12 | extern void *consistent_alloc(int gfp, size_t size, dma_addr_t *handle); | 12 | extern void *consistent_alloc(gfp_t gfp, size_t size, dma_addr_t *handle); |
| 13 | extern void consistent_free(void *vaddr, size_t size); | 13 | extern void consistent_free(void *vaddr, size_t size); |
| 14 | extern void consistent_sync(void *vaddr, size_t size, int direction); | 14 | extern void consistent_sync(void *vaddr, size_t size, int direction); |
| 15 | 15 | ||
| @@ -26,7 +26,7 @@ static inline int dma_set_mask(struct device *dev, u64 mask) | |||
| 26 | } | 26 | } |
| 27 | 27 | ||
| 28 | static inline void *dma_alloc_coherent(struct device *dev, size_t size, | 28 | static inline void *dma_alloc_coherent(struct device *dev, size_t size, |
| 29 | dma_addr_t *dma_handle, int flag) | 29 | dma_addr_t *dma_handle, gfp_t flag) |
| 30 | { | 30 | { |
| 31 | if (sh_mv.mv_consistent_alloc) { | 31 | if (sh_mv.mv_consistent_alloc) { |
| 32 | void *ret; | 32 | void *ret; |
diff --git a/include/asm-sh/machvec.h b/include/asm-sh/machvec.h index 5771f4baa478..3f18aa180516 100644 --- a/include/asm-sh/machvec.h +++ b/include/asm-sh/machvec.h | |||
| @@ -64,7 +64,7 @@ struct sh_machine_vector | |||
| 64 | 64 | ||
| 65 | void (*mv_heartbeat)(void); | 65 | void (*mv_heartbeat)(void); |
| 66 | 66 | ||
| 67 | void *(*mv_consistent_alloc)(struct device *, size_t, dma_addr_t *, int); | 67 | void *(*mv_consistent_alloc)(struct device *, size_t, dma_addr_t *, gfp_t); |
| 68 | int (*mv_consistent_free)(struct device *, size_t, void *, dma_addr_t); | 68 | int (*mv_consistent_free)(struct device *, size_t, void *, dma_addr_t); |
| 69 | }; | 69 | }; |
| 70 | 70 | ||
diff --git a/include/asm-sh64/dma-mapping.h b/include/asm-sh64/dma-mapping.h index b8d26fe677f4..cc9a2e86f5b4 100644 --- a/include/asm-sh64/dma-mapping.h +++ b/include/asm-sh64/dma-mapping.h | |||
| @@ -25,7 +25,7 @@ static inline int dma_set_mask(struct device *dev, u64 mask) | |||
| 25 | } | 25 | } |
| 26 | 26 | ||
| 27 | static inline void *dma_alloc_coherent(struct device *dev, size_t size, | 27 | static inline void *dma_alloc_coherent(struct device *dev, size_t size, |
| 28 | dma_addr_t *dma_handle, int flag) | 28 | dma_addr_t *dma_handle, gfp_t flag) |
| 29 | { | 29 | { |
| 30 | return consistent_alloc(NULL, size, dma_handle); | 30 | return consistent_alloc(NULL, size, dma_handle); |
| 31 | } | 31 | } |
diff --git a/include/asm-sparc/dma-mapping.h b/include/asm-sparc/dma-mapping.h index 2dc5bb8effa6..d7c3b0f0a901 100644 --- a/include/asm-sparc/dma-mapping.h +++ b/include/asm-sparc/dma-mapping.h | |||
| @@ -8,7 +8,7 @@ | |||
| 8 | #else | 8 | #else |
| 9 | 9 | ||
| 10 | static inline void *dma_alloc_coherent(struct device *dev, size_t size, | 10 | static inline void *dma_alloc_coherent(struct device *dev, size_t size, |
| 11 | dma_addr_t *dma_handle, int flag) | 11 | dma_addr_t *dma_handle, gfp_t flag) |
| 12 | { | 12 | { |
| 13 | BUG(); | 13 | BUG(); |
| 14 | return NULL; | 14 | return NULL; |
diff --git a/include/asm-sparc64/dma-mapping.h b/include/asm-sparc64/dma-mapping.h index 1c5da41653a4..c7d5804ba76d 100644 --- a/include/asm-sparc64/dma-mapping.h +++ b/include/asm-sparc64/dma-mapping.h | |||
| @@ -10,7 +10,7 @@ | |||
| 10 | struct device; | 10 | struct device; |
| 11 | 11 | ||
| 12 | static inline void *dma_alloc_coherent(struct device *dev, size_t size, | 12 | static inline void *dma_alloc_coherent(struct device *dev, size_t size, |
| 13 | dma_addr_t *dma_handle, int flag) | 13 | dma_addr_t *dma_handle, gfp_t flag) |
| 14 | { | 14 | { |
| 15 | BUG(); | 15 | BUG(); |
| 16 | return NULL; | 16 | return NULL; |
diff --git a/include/asm-um/dma-mapping.h b/include/asm-um/dma-mapping.h index 13e6291f7151..babd29895114 100644 --- a/include/asm-um/dma-mapping.h +++ b/include/asm-um/dma-mapping.h | |||
| @@ -19,7 +19,7 @@ dma_set_mask(struct device *dev, u64 dma_mask) | |||
| 19 | 19 | ||
| 20 | static inline void * | 20 | static inline void * |
| 21 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, | 21 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, |
| 22 | int flag) | 22 | gfp_t flag) |
| 23 | { | 23 | { |
| 24 | BUG(); | 24 | BUG(); |
| 25 | return((void *) 0); | 25 | return((void *) 0); |
diff --git a/include/asm-um/page.h b/include/asm-um/page.h index 2c192abe9aeb..0229814af31e 100644 --- a/include/asm-um/page.h +++ b/include/asm-um/page.h | |||
| @@ -115,7 +115,7 @@ extern unsigned long uml_physmem; | |||
| 115 | #define pfn_valid(pfn) ((pfn) < max_mapnr) | 115 | #define pfn_valid(pfn) ((pfn) < max_mapnr) |
| 116 | #define virt_addr_valid(v) pfn_valid(phys_to_pfn(__pa(v))) | 116 | #define virt_addr_valid(v) pfn_valid(phys_to_pfn(__pa(v))) |
| 117 | 117 | ||
| 118 | extern struct page *arch_validate(struct page *page, int mask, int order); | 118 | extern struct page *arch_validate(struct page *page, gfp_t mask, int order); |
| 119 | #define HAVE_ARCH_VALIDATE | 119 | #define HAVE_ARCH_VALIDATE |
| 120 | 120 | ||
| 121 | extern void arch_free_page(struct page *page, int order); | 121 | extern void arch_free_page(struct page *page, int order); |
diff --git a/include/asm-x86_64/dma-mapping.h b/include/asm-x86_64/dma-mapping.h index e784fdc524f1..54a380efed41 100644 --- a/include/asm-x86_64/dma-mapping.h +++ b/include/asm-x86_64/dma-mapping.h | |||
| @@ -17,7 +17,7 @@ extern dma_addr_t bad_dma_address; | |||
| 17 | (swiotlb ? swiotlb_dma_mapping_error(x) : ((x) == bad_dma_address)) | 17 | (swiotlb ? swiotlb_dma_mapping_error(x) : ((x) == bad_dma_address)) |
| 18 | 18 | ||
| 19 | void *dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, | 19 | void *dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *dma_handle, |
| 20 | unsigned gfp); | 20 | gfp_t gfp); |
| 21 | void dma_free_coherent(struct device *dev, size_t size, void *vaddr, | 21 | void dma_free_coherent(struct device *dev, size_t size, void *vaddr, |
| 22 | dma_addr_t dma_handle); | 22 | dma_addr_t dma_handle); |
| 23 | 23 | ||
diff --git a/include/asm-x86_64/swiotlb.h b/include/asm-x86_64/swiotlb.h index 36293061f4ed..7cbfd10ecc3c 100644 --- a/include/asm-x86_64/swiotlb.h +++ b/include/asm-x86_64/swiotlb.h | |||
| @@ -27,7 +27,7 @@ extern void swiotlb_unmap_sg(struct device *hwdev, struct scatterlist *sg, | |||
| 27 | int nents, int direction); | 27 | int nents, int direction); |
| 28 | extern int swiotlb_dma_mapping_error(dma_addr_t dma_addr); | 28 | extern int swiotlb_dma_mapping_error(dma_addr_t dma_addr); |
| 29 | extern void *swiotlb_alloc_coherent (struct device *hwdev, size_t size, | 29 | extern void *swiotlb_alloc_coherent (struct device *hwdev, size_t size, |
| 30 | dma_addr_t *dma_handle, int flags); | 30 | dma_addr_t *dma_handle, gfp_t flags); |
| 31 | extern void swiotlb_free_coherent (struct device *hwdev, size_t size, | 31 | extern void swiotlb_free_coherent (struct device *hwdev, size_t size, |
| 32 | void *vaddr, dma_addr_t dma_handle); | 32 | void *vaddr, dma_addr_t dma_handle); |
| 33 | 33 | ||
diff --git a/include/asm-xtensa/dma-mapping.h b/include/asm-xtensa/dma-mapping.h index e86a206f1209..c425f10d086a 100644 --- a/include/asm-xtensa/dma-mapping.h +++ b/include/asm-xtensa/dma-mapping.h | |||
| @@ -28,7 +28,7 @@ extern void consistent_sync(void*, size_t, int); | |||
| 28 | #define dma_free_noncoherent(d, s, v, h) dma_free_coherent(d, s, v, h) | 28 | #define dma_free_noncoherent(d, s, v, h) dma_free_coherent(d, s, v, h) |
| 29 | 29 | ||
| 30 | void *dma_alloc_coherent(struct device *dev, size_t size, | 30 | void *dma_alloc_coherent(struct device *dev, size_t size, |
| 31 | dma_addr_t *dma_handle, int flag); | 31 | dma_addr_t *dma_handle, gfp_t flag); |
| 32 | 32 | ||
| 33 | void dma_free_coherent(struct device *dev, size_t size, | 33 | void dma_free_coherent(struct device *dev, size_t size, |
| 34 | void *vaddr, dma_addr_t dma_handle); | 34 | void *vaddr, dma_addr_t dma_handle); |
diff --git a/include/linux/ata.h b/include/linux/ata.h index a5b74efab067..d2873b732bb1 100644 --- a/include/linux/ata.h +++ b/include/linux/ata.h | |||
| @@ -42,13 +42,18 @@ enum { | |||
| 42 | ATA_SECT_SIZE = 512, | 42 | ATA_SECT_SIZE = 512, |
| 43 | 43 | ||
| 44 | ATA_ID_WORDS = 256, | 44 | ATA_ID_WORDS = 256, |
| 45 | ATA_ID_PROD_OFS = 27, | ||
| 46 | ATA_ID_FW_REV_OFS = 23, | ||
| 47 | ATA_ID_SERNO_OFS = 10, | 45 | ATA_ID_SERNO_OFS = 10, |
| 48 | ATA_ID_MAJOR_VER = 80, | 46 | ATA_ID_FW_REV_OFS = 23, |
| 49 | ATA_ID_PIO_MODES = 64, | 47 | ATA_ID_PROD_OFS = 27, |
| 48 | ATA_ID_OLD_PIO_MODES = 51, | ||
| 49 | ATA_ID_FIELD_VALID = 53, | ||
| 50 | ATA_ID_MWDMA_MODES = 63, | 50 | ATA_ID_MWDMA_MODES = 63, |
| 51 | ATA_ID_PIO_MODES = 64, | ||
| 52 | ATA_ID_EIDE_DMA_MIN = 65, | ||
| 53 | ATA_ID_EIDE_PIO = 67, | ||
| 54 | ATA_ID_EIDE_PIO_IORDY = 68, | ||
| 51 | ATA_ID_UDMA_MODES = 88, | 55 | ATA_ID_UDMA_MODES = 88, |
| 56 | ATA_ID_MAJOR_VER = 80, | ||
| 52 | ATA_ID_PIO4 = (1 << 1), | 57 | ATA_ID_PIO4 = (1 << 1), |
| 53 | 58 | ||
| 54 | ATA_PCI_CTL_OFS = 2, | 59 | ATA_PCI_CTL_OFS = 2, |
| @@ -128,10 +133,15 @@ enum { | |||
| 128 | ATA_CMD_PIO_READ_EXT = 0x24, | 133 | ATA_CMD_PIO_READ_EXT = 0x24, |
| 129 | ATA_CMD_PIO_WRITE = 0x30, | 134 | ATA_CMD_PIO_WRITE = 0x30, |
| 130 | ATA_CMD_PIO_WRITE_EXT = 0x34, | 135 | ATA_CMD_PIO_WRITE_EXT = 0x34, |
| 136 | ATA_CMD_READ_MULTI = 0xC4, | ||
| 137 | ATA_CMD_READ_MULTI_EXT = 0x29, | ||
| 138 | ATA_CMD_WRITE_MULTI = 0xC5, | ||
| 139 | ATA_CMD_WRITE_MULTI_EXT = 0x39, | ||
| 131 | ATA_CMD_SET_FEATURES = 0xEF, | 140 | ATA_CMD_SET_FEATURES = 0xEF, |
| 132 | ATA_CMD_PACKET = 0xA0, | 141 | ATA_CMD_PACKET = 0xA0, |
| 133 | ATA_CMD_VERIFY = 0x40, | 142 | ATA_CMD_VERIFY = 0x40, |
| 134 | ATA_CMD_VERIFY_EXT = 0x42, | 143 | ATA_CMD_VERIFY_EXT = 0x42, |
| 144 | ATA_CMD_INIT_DEV_PARAMS = 0x91, | ||
| 135 | 145 | ||
| 136 | /* SETFEATURES stuff */ | 146 | /* SETFEATURES stuff */ |
| 137 | SETFEATURES_XFER = 0x03, | 147 | SETFEATURES_XFER = 0x03, |
| @@ -146,14 +156,14 @@ enum { | |||
| 146 | XFER_MW_DMA_2 = 0x22, | 156 | XFER_MW_DMA_2 = 0x22, |
| 147 | XFER_MW_DMA_1 = 0x21, | 157 | XFER_MW_DMA_1 = 0x21, |
| 148 | XFER_MW_DMA_0 = 0x20, | 158 | XFER_MW_DMA_0 = 0x20, |
| 159 | XFER_SW_DMA_2 = 0x12, | ||
| 160 | XFER_SW_DMA_1 = 0x11, | ||
| 161 | XFER_SW_DMA_0 = 0x10, | ||
| 149 | XFER_PIO_4 = 0x0C, | 162 | XFER_PIO_4 = 0x0C, |
| 150 | XFER_PIO_3 = 0x0B, | 163 | XFER_PIO_3 = 0x0B, |
| 151 | XFER_PIO_2 = 0x0A, | 164 | XFER_PIO_2 = 0x0A, |
| 152 | XFER_PIO_1 = 0x09, | 165 | XFER_PIO_1 = 0x09, |
| 153 | XFER_PIO_0 = 0x08, | 166 | XFER_PIO_0 = 0x08, |
| 154 | XFER_SW_DMA_2 = 0x12, | ||
| 155 | XFER_SW_DMA_1 = 0x11, | ||
| 156 | XFER_SW_DMA_0 = 0x10, | ||
| 157 | XFER_PIO_SLOW = 0x00, | 167 | XFER_PIO_SLOW = 0x00, |
| 158 | 168 | ||
| 159 | /* ATAPI stuff */ | 169 | /* ATAPI stuff */ |
| @@ -181,6 +191,7 @@ enum { | |||
| 181 | ATA_TFLAG_ISADDR = (1 << 1), /* enable r/w to nsect/lba regs */ | 191 | ATA_TFLAG_ISADDR = (1 << 1), /* enable r/w to nsect/lba regs */ |
| 182 | ATA_TFLAG_DEVICE = (1 << 2), /* enable r/w to device reg */ | 192 | ATA_TFLAG_DEVICE = (1 << 2), /* enable r/w to device reg */ |
| 183 | ATA_TFLAG_WRITE = (1 << 3), /* data dir: host->dev==1 (write) */ | 193 | ATA_TFLAG_WRITE = (1 << 3), /* data dir: host->dev==1 (write) */ |
| 194 | ATA_TFLAG_LBA = (1 << 4), /* enable LBA */ | ||
| 184 | }; | 195 | }; |
| 185 | 196 | ||
| 186 | enum ata_tf_protocols { | 197 | enum ata_tf_protocols { |
| @@ -250,7 +261,19 @@ struct ata_taskfile { | |||
| 250 | ((u64) (id)[(n) + 1] << 16) | \ | 261 | ((u64) (id)[(n) + 1] << 16) | \ |
| 251 | ((u64) (id)[(n) + 0]) ) | 262 | ((u64) (id)[(n) + 0]) ) |
| 252 | 263 | ||
| 253 | static inline int atapi_cdb_len(u16 *dev_id) | 264 | static inline int ata_id_current_chs_valid(const u16 *id) |
| 265 | { | ||
| 266 | /* For ATA-1 devices, if the INITIALIZE DEVICE PARAMETERS command | ||
| 267 | has not been issued to the device then the values of | ||
| 268 | id[54] to id[56] are vendor specific. */ | ||
| 269 | return (id[53] & 0x01) && /* Current translation valid */ | ||
| 270 | id[54] && /* cylinders in current translation */ | ||
| 271 | id[55] && /* heads in current translation */ | ||
| 272 | id[55] <= 16 && | ||
| 273 | id[56]; /* sectors in current translation */ | ||
| 274 | } | ||
| 275 | |||
| 276 | static inline int atapi_cdb_len(const u16 *dev_id) | ||
| 254 | { | 277 | { |
| 255 | u16 tmp = dev_id[0] & 0x3; | 278 | u16 tmp = dev_id[0] & 0x3; |
| 256 | switch (tmp) { | 279 | switch (tmp) { |
| @@ -260,7 +283,7 @@ static inline int atapi_cdb_len(u16 *dev_id) | |||
| 260 | } | 283 | } |
| 261 | } | 284 | } |
| 262 | 285 | ||
| 263 | static inline int is_atapi_taskfile(struct ata_taskfile *tf) | 286 | static inline int is_atapi_taskfile(const struct ata_taskfile *tf) |
| 264 | { | 287 | { |
| 265 | return (tf->protocol == ATA_PROT_ATAPI) || | 288 | return (tf->protocol == ATA_PROT_ATAPI) || |
| 266 | (tf->protocol == ATA_PROT_ATAPI_NODATA) || | 289 | (tf->protocol == ATA_PROT_ATAPI_NODATA) || |
diff --git a/include/linux/audit.h b/include/linux/audit.h index b2a2509bd7ea..da3c01955f3d 100644 --- a/include/linux/audit.h +++ b/include/linux/audit.h | |||
| @@ -260,11 +260,11 @@ extern int audit_filter_user(struct netlink_skb_parms *cb, int type); | |||
| 260 | #ifdef CONFIG_AUDIT | 260 | #ifdef CONFIG_AUDIT |
| 261 | /* These are defined in audit.c */ | 261 | /* These are defined in audit.c */ |
| 262 | /* Public API */ | 262 | /* Public API */ |
| 263 | extern void audit_log(struct audit_context *ctx, int gfp_mask, | 263 | extern void audit_log(struct audit_context *ctx, gfp_t gfp_mask, |
| 264 | int type, const char *fmt, ...) | 264 | int type, const char *fmt, ...) |
| 265 | __attribute__((format(printf,4,5))); | 265 | __attribute__((format(printf,4,5))); |
| 266 | 266 | ||
| 267 | extern struct audit_buffer *audit_log_start(struct audit_context *ctx, int gfp_mask, int type); | 267 | extern struct audit_buffer *audit_log_start(struct audit_context *ctx, gfp_t gfp_mask, int type); |
| 268 | extern void audit_log_format(struct audit_buffer *ab, | 268 | extern void audit_log_format(struct audit_buffer *ab, |
| 269 | const char *fmt, ...) | 269 | const char *fmt, ...) |
| 270 | __attribute__((format(printf,2,3))); | 270 | __attribute__((format(printf,2,3))); |
diff --git a/include/linux/bio.h b/include/linux/bio.h index 3344b4e8e43a..685fd3720df5 100644 --- a/include/linux/bio.h +++ b/include/linux/bio.h | |||
| @@ -301,7 +301,7 @@ extern struct bio *bio_map_user_iov(struct request_queue *, | |||
| 301 | struct sg_iovec *, int, int); | 301 | struct sg_iovec *, int, int); |
| 302 | extern void bio_unmap_user(struct bio *); | 302 | extern void bio_unmap_user(struct bio *); |
| 303 | extern struct bio *bio_map_kern(struct request_queue *, void *, unsigned int, | 303 | extern struct bio *bio_map_kern(struct request_queue *, void *, unsigned int, |
| 304 | unsigned int); | 304 | gfp_t); |
| 305 | extern void bio_set_pages_dirty(struct bio *bio); | 305 | extern void bio_set_pages_dirty(struct bio *bio); |
| 306 | extern void bio_check_pages_dirty(struct bio *bio); | 306 | extern void bio_check_pages_dirty(struct bio *bio); |
| 307 | extern struct bio *bio_copy_user(struct request_queue *, unsigned long, unsigned int, int); | 307 | extern struct bio *bio_copy_user(struct request_queue *, unsigned long, unsigned int, int); |
diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h index efdc9b5bc05c..025a7f084dbd 100644 --- a/include/linux/blkdev.h +++ b/include/linux/blkdev.h | |||
| @@ -96,8 +96,8 @@ struct io_context { | |||
| 96 | 96 | ||
| 97 | void put_io_context(struct io_context *ioc); | 97 | void put_io_context(struct io_context *ioc); |
| 98 | void exit_io_context(void); | 98 | void exit_io_context(void); |
| 99 | struct io_context *current_io_context(int gfp_flags); | 99 | struct io_context *current_io_context(gfp_t gfp_flags); |
| 100 | struct io_context *get_io_context(int gfp_flags); | 100 | struct io_context *get_io_context(gfp_t gfp_flags); |
| 101 | void copy_io_context(struct io_context **pdst, struct io_context **psrc); | 101 | void copy_io_context(struct io_context **pdst, struct io_context **psrc); |
| 102 | void swap_io_context(struct io_context **ioc1, struct io_context **ioc2); | 102 | void swap_io_context(struct io_context **ioc1, struct io_context **ioc2); |
| 103 | 103 | ||
| @@ -107,9 +107,9 @@ typedef void (rq_end_io_fn)(struct request *); | |||
| 107 | struct request_list { | 107 | struct request_list { |
| 108 | int count[2]; | 108 | int count[2]; |
| 109 | int starved[2]; | 109 | int starved[2]; |
| 110 | int elvpriv; | ||
| 110 | mempool_t *rq_pool; | 111 | mempool_t *rq_pool; |
| 111 | wait_queue_head_t wait[2]; | 112 | wait_queue_head_t wait[2]; |
| 112 | wait_queue_head_t drain; | ||
| 113 | }; | 113 | }; |
| 114 | 114 | ||
| 115 | #define BLK_MAX_CDB 16 | 115 | #define BLK_MAX_CDB 16 |
| @@ -203,6 +203,7 @@ struct request { | |||
| 203 | enum rq_flag_bits { | 203 | enum rq_flag_bits { |
| 204 | __REQ_RW, /* not set, read. set, write */ | 204 | __REQ_RW, /* not set, read. set, write */ |
| 205 | __REQ_FAILFAST, /* no low level driver retries */ | 205 | __REQ_FAILFAST, /* no low level driver retries */ |
| 206 | __REQ_SORTED, /* elevator knows about this request */ | ||
| 206 | __REQ_SOFTBARRIER, /* may not be passed by ioscheduler */ | 207 | __REQ_SOFTBARRIER, /* may not be passed by ioscheduler */ |
| 207 | __REQ_HARDBARRIER, /* may not be passed by drive either */ | 208 | __REQ_HARDBARRIER, /* may not be passed by drive either */ |
| 208 | __REQ_CMD, /* is a regular fs rw request */ | 209 | __REQ_CMD, /* is a regular fs rw request */ |
| @@ -210,6 +211,7 @@ enum rq_flag_bits { | |||
| 210 | __REQ_STARTED, /* drive already may have started this one */ | 211 | __REQ_STARTED, /* drive already may have started this one */ |
| 211 | __REQ_DONTPREP, /* don't call prep for this one */ | 212 | __REQ_DONTPREP, /* don't call prep for this one */ |
| 212 | __REQ_QUEUED, /* uses queueing */ | 213 | __REQ_QUEUED, /* uses queueing */ |
| 214 | __REQ_ELVPRIV, /* elevator private data attached */ | ||
| 213 | /* | 215 | /* |
| 214 | * for ATA/ATAPI devices | 216 | * for ATA/ATAPI devices |
| 215 | */ | 217 | */ |
| @@ -235,6 +237,7 @@ enum rq_flag_bits { | |||
| 235 | 237 | ||
| 236 | #define REQ_RW (1 << __REQ_RW) | 238 | #define REQ_RW (1 << __REQ_RW) |
| 237 | #define REQ_FAILFAST (1 << __REQ_FAILFAST) | 239 | #define REQ_FAILFAST (1 << __REQ_FAILFAST) |
| 240 | #define REQ_SORTED (1 << __REQ_SORTED) | ||
| 238 | #define REQ_SOFTBARRIER (1 << __REQ_SOFTBARRIER) | 241 | #define REQ_SOFTBARRIER (1 << __REQ_SOFTBARRIER) |
| 239 | #define REQ_HARDBARRIER (1 << __REQ_HARDBARRIER) | 242 | #define REQ_HARDBARRIER (1 << __REQ_HARDBARRIER) |
| 240 | #define REQ_CMD (1 << __REQ_CMD) | 243 | #define REQ_CMD (1 << __REQ_CMD) |
| @@ -242,6 +245,7 @@ enum rq_flag_bits { | |||
| 242 | #define REQ_STARTED (1 << __REQ_STARTED) | 245 | #define REQ_STARTED (1 << __REQ_STARTED) |
| 243 | #define REQ_DONTPREP (1 << __REQ_DONTPREP) | 246 | #define REQ_DONTPREP (1 << __REQ_DONTPREP) |
| 244 | #define REQ_QUEUED (1 << __REQ_QUEUED) | 247 | #define REQ_QUEUED (1 << __REQ_QUEUED) |
| 248 | #define REQ_ELVPRIV (1 << __REQ_ELVPRIV) | ||
| 245 | #define REQ_PC (1 << __REQ_PC) | 249 | #define REQ_PC (1 << __REQ_PC) |
| 246 | #define REQ_BLOCK_PC (1 << __REQ_BLOCK_PC) | 250 | #define REQ_BLOCK_PC (1 << __REQ_BLOCK_PC) |
| 247 | #define REQ_SENSE (1 << __REQ_SENSE) | 251 | #define REQ_SENSE (1 << __REQ_SENSE) |
| @@ -333,6 +337,12 @@ struct request_queue | |||
| 333 | end_flush_fn *end_flush_fn; | 337 | end_flush_fn *end_flush_fn; |
| 334 | 338 | ||
| 335 | /* | 339 | /* |
| 340 | * Dispatch queue sorting | ||
| 341 | */ | ||
| 342 | sector_t end_sector; | ||
| 343 | struct request *boundary_rq; | ||
| 344 | |||
| 345 | /* | ||
| 336 | * Auto-unplugging state | 346 | * Auto-unplugging state |
| 337 | */ | 347 | */ |
| 338 | struct timer_list unplug_timer; | 348 | struct timer_list unplug_timer; |
| @@ -354,7 +364,7 @@ struct request_queue | |||
| 354 | * queue needs bounce pages for pages above this limit | 364 | * queue needs bounce pages for pages above this limit |
| 355 | */ | 365 | */ |
| 356 | unsigned long bounce_pfn; | 366 | unsigned long bounce_pfn; |
| 357 | unsigned int bounce_gfp; | 367 | gfp_t bounce_gfp; |
| 358 | 368 | ||
| 359 | /* | 369 | /* |
| 360 | * various queue flags, see QUEUE_* below | 370 | * various queue flags, see QUEUE_* below |
| @@ -405,8 +415,6 @@ struct request_queue | |||
| 405 | unsigned int sg_reserved_size; | 415 | unsigned int sg_reserved_size; |
| 406 | int node; | 416 | int node; |
| 407 | 417 | ||
| 408 | struct list_head drain_list; | ||
| 409 | |||
| 410 | /* | 418 | /* |
| 411 | * reserved for flush operations | 419 | * reserved for flush operations |
| 412 | */ | 420 | */ |
| @@ -434,7 +442,7 @@ enum { | |||
| 434 | #define QUEUE_FLAG_DEAD 5 /* queue being torn down */ | 442 | #define QUEUE_FLAG_DEAD 5 /* queue being torn down */ |
| 435 | #define QUEUE_FLAG_REENTER 6 /* Re-entrancy avoidance */ | 443 | #define QUEUE_FLAG_REENTER 6 /* Re-entrancy avoidance */ |
| 436 | #define QUEUE_FLAG_PLUGGED 7 /* queue is plugged */ | 444 | #define QUEUE_FLAG_PLUGGED 7 /* queue is plugged */ |
| 437 | #define QUEUE_FLAG_DRAIN 8 /* draining queue for sched switch */ | 445 | #define QUEUE_FLAG_ELVSWITCH 8 /* don't use elevator, just do FIFO */ |
| 438 | #define QUEUE_FLAG_FLUSH 9 /* doing barrier flush sequence */ | 446 | #define QUEUE_FLAG_FLUSH 9 /* doing barrier flush sequence */ |
| 439 | 447 | ||
| 440 | #define blk_queue_plugged(q) test_bit(QUEUE_FLAG_PLUGGED, &(q)->queue_flags) | 448 | #define blk_queue_plugged(q) test_bit(QUEUE_FLAG_PLUGGED, &(q)->queue_flags) |
| @@ -454,6 +462,7 @@ enum { | |||
| 454 | #define blk_pm_request(rq) \ | 462 | #define blk_pm_request(rq) \ |
| 455 | ((rq)->flags & (REQ_PM_SUSPEND | REQ_PM_RESUME)) | 463 | ((rq)->flags & (REQ_PM_SUSPEND | REQ_PM_RESUME)) |
| 456 | 464 | ||
| 465 | #define blk_sorted_rq(rq) ((rq)->flags & REQ_SORTED) | ||
| 457 | #define blk_barrier_rq(rq) ((rq)->flags & REQ_HARDBARRIER) | 466 | #define blk_barrier_rq(rq) ((rq)->flags & REQ_HARDBARRIER) |
| 458 | #define blk_barrier_preflush(rq) ((rq)->flags & REQ_BAR_PREFLUSH) | 467 | #define blk_barrier_preflush(rq) ((rq)->flags & REQ_BAR_PREFLUSH) |
| 459 | #define blk_barrier_postflush(rq) ((rq)->flags & REQ_BAR_POSTFLUSH) | 468 | #define blk_barrier_postflush(rq) ((rq)->flags & REQ_BAR_POSTFLUSH) |
| @@ -550,7 +559,7 @@ extern void generic_make_request(struct bio *bio); | |||
| 550 | extern void blk_put_request(struct request *); | 559 | extern void blk_put_request(struct request *); |
| 551 | extern void blk_end_sync_rq(struct request *rq); | 560 | extern void blk_end_sync_rq(struct request *rq); |
| 552 | extern void blk_attempt_remerge(request_queue_t *, struct request *); | 561 | extern void blk_attempt_remerge(request_queue_t *, struct request *); |
| 553 | extern struct request *blk_get_request(request_queue_t *, int, int); | 562 | extern struct request *blk_get_request(request_queue_t *, int, gfp_t); |
| 554 | extern void blk_insert_request(request_queue_t *, struct request *, int, void *); | 563 | extern void blk_insert_request(request_queue_t *, struct request *, int, void *); |
| 555 | extern void blk_requeue_request(request_queue_t *, struct request *); | 564 | extern void blk_requeue_request(request_queue_t *, struct request *); |
| 556 | extern void blk_plug_device(request_queue_t *); | 565 | extern void blk_plug_device(request_queue_t *); |
| @@ -565,7 +574,7 @@ extern void blk_run_queue(request_queue_t *); | |||
| 565 | extern void blk_queue_activity_fn(request_queue_t *, activity_fn *, void *); | 574 | extern void blk_queue_activity_fn(request_queue_t *, activity_fn *, void *); |
| 566 | extern int blk_rq_map_user(request_queue_t *, struct request *, void __user *, unsigned int); | 575 | extern int blk_rq_map_user(request_queue_t *, struct request *, void __user *, unsigned int); |
| 567 | extern int blk_rq_unmap_user(struct bio *, unsigned int); | 576 | extern int blk_rq_unmap_user(struct bio *, unsigned int); |
| 568 | extern int blk_rq_map_kern(request_queue_t *, struct request *, void *, unsigned int, unsigned int); | 577 | extern int blk_rq_map_kern(request_queue_t *, struct request *, void *, unsigned int, gfp_t); |
| 569 | extern int blk_rq_map_user_iov(request_queue_t *, struct request *, struct sg_iovec *, int); | 578 | extern int blk_rq_map_user_iov(request_queue_t *, struct request *, struct sg_iovec *, int); |
| 570 | extern int blk_execute_rq(request_queue_t *, struct gendisk *, | 579 | extern int blk_execute_rq(request_queue_t *, struct gendisk *, |
| 571 | struct request *, int); | 580 | struct request *, int); |
| @@ -611,12 +620,21 @@ extern void end_request(struct request *req, int uptodate); | |||
| 611 | 620 | ||
| 612 | static inline void blkdev_dequeue_request(struct request *req) | 621 | static inline void blkdev_dequeue_request(struct request *req) |
| 613 | { | 622 | { |
| 614 | BUG_ON(list_empty(&req->queuelist)); | 623 | elv_dequeue_request(req->q, req); |
| 624 | } | ||
| 615 | 625 | ||
| 616 | list_del_init(&req->queuelist); | 626 | /* |
| 627 | * This should be in elevator.h, but that requires pulling in rq and q | ||
| 628 | */ | ||
| 629 | static inline void elv_dispatch_add_tail(struct request_queue *q, | ||
| 630 | struct request *rq) | ||
| 631 | { | ||
| 632 | if (q->last_merge == rq) | ||
| 633 | q->last_merge = NULL; | ||
| 617 | 634 | ||
| 618 | if (req->rl) | 635 | q->end_sector = rq_end_sector(rq); |
| 619 | elv_remove_request(req->q, req); | 636 | q->boundary_rq = rq; |
| 637 | list_add_tail(&rq->queuelist, &q->queue_head); | ||
| 620 | } | 638 | } |
| 621 | 639 | ||
| 622 | /* | 640 | /* |
| @@ -650,12 +668,10 @@ extern void blk_dump_rq_flags(struct request *, char *); | |||
| 650 | extern void generic_unplug_device(request_queue_t *); | 668 | extern void generic_unplug_device(request_queue_t *); |
| 651 | extern void __generic_unplug_device(request_queue_t *); | 669 | extern void __generic_unplug_device(request_queue_t *); |
| 652 | extern long nr_blockdev_pages(void); | 670 | extern long nr_blockdev_pages(void); |
| 653 | extern void blk_wait_queue_drained(request_queue_t *, int); | ||
| 654 | extern void blk_finish_queue_drain(request_queue_t *); | ||
| 655 | 671 | ||
| 656 | int blk_get_queue(request_queue_t *); | 672 | int blk_get_queue(request_queue_t *); |
| 657 | request_queue_t *blk_alloc_queue(int gfp_mask); | 673 | request_queue_t *blk_alloc_queue(gfp_t); |
| 658 | request_queue_t *blk_alloc_queue_node(int,int); | 674 | request_queue_t *blk_alloc_queue_node(gfp_t, int); |
| 659 | #define blk_put_queue(q) blk_cleanup_queue((q)) | 675 | #define blk_put_queue(q) blk_cleanup_queue((q)) |
| 660 | 676 | ||
| 661 | /* | 677 | /* |
diff --git a/include/linux/buffer_head.h b/include/linux/buffer_head.h index 6a1d154c0825..88af42f5e04a 100644 --- a/include/linux/buffer_head.h +++ b/include/linux/buffer_head.h | |||
| @@ -188,7 +188,7 @@ extern int buffer_heads_over_limit; | |||
| 188 | * Generic address_space_operations implementations for buffer_head-backed | 188 | * Generic address_space_operations implementations for buffer_head-backed |
| 189 | * address_spaces. | 189 | * address_spaces. |
| 190 | */ | 190 | */ |
| 191 | int try_to_release_page(struct page * page, int gfp_mask); | 191 | int try_to_release_page(struct page * page, gfp_t gfp_mask); |
| 192 | int block_invalidatepage(struct page *page, unsigned long offset); | 192 | int block_invalidatepage(struct page *page, unsigned long offset); |
| 193 | int block_write_full_page(struct page *page, get_block_t *get_block, | 193 | int block_write_full_page(struct page *page, get_block_t *get_block, |
| 194 | struct writeback_control *wbc); | 194 | struct writeback_control *wbc); |
diff --git a/include/linux/cyclomx.h b/include/linux/cyclomx.h index 04fa7dff079c..300d704bdb9a 100644 --- a/include/linux/cyclomx.h +++ b/include/linux/cyclomx.h | |||
| @@ -37,8 +37,6 @@ | |||
| 37 | #include <linux/cycx_x25.h> | 37 | #include <linux/cycx_x25.h> |
| 38 | #endif | 38 | #endif |
| 39 | 39 | ||
| 40 | #define is_digit(ch) (((ch)>=(unsigned)'0'&&(ch)<=(unsigned)'9')?1:0) | ||
| 41 | |||
| 42 | /* Adapter Data Space. | 40 | /* Adapter Data Space. |
| 43 | * This structure is needed because we handle multiple cards, otherwise | 41 | * This structure is needed because we handle multiple cards, otherwise |
| 44 | * static data would do it. | 42 | * static data would do it. |
diff --git a/include/linux/cycx_drv.h b/include/linux/cycx_drv.h index 6621df86a748..12fe6b0bfcff 100644 --- a/include/linux/cycx_drv.h +++ b/include/linux/cycx_drv.h | |||
| @@ -60,6 +60,5 @@ extern int cycx_peek(struct cycx_hw *hw, u32 addr, void *buf, u32 len); | |||
| 60 | extern int cycx_poke(struct cycx_hw *hw, u32 addr, void *buf, u32 len); | 60 | extern int cycx_poke(struct cycx_hw *hw, u32 addr, void *buf, u32 len); |
| 61 | extern int cycx_exec(void __iomem *addr); | 61 | extern int cycx_exec(void __iomem *addr); |
| 62 | 62 | ||
| 63 | extern void cycx_inten(struct cycx_hw *hw); | ||
| 64 | extern void cycx_intr(struct cycx_hw *hw); | 63 | extern void cycx_intr(struct cycx_hw *hw); |
| 65 | #endif /* _CYCX_DRV_H */ | 64 | #endif /* _CYCX_DRV_H */ |
diff --git a/include/linux/elevator.h b/include/linux/elevator.h index ea6bbc2d7407..a74c27e460ba 100644 --- a/include/linux/elevator.h +++ b/include/linux/elevator.h | |||
| @@ -8,18 +8,17 @@ typedef void (elevator_merge_req_fn) (request_queue_t *, struct request *, struc | |||
| 8 | 8 | ||
| 9 | typedef void (elevator_merged_fn) (request_queue_t *, struct request *); | 9 | typedef void (elevator_merged_fn) (request_queue_t *, struct request *); |
| 10 | 10 | ||
| 11 | typedef struct request *(elevator_next_req_fn) (request_queue_t *); | 11 | typedef int (elevator_dispatch_fn) (request_queue_t *, int); |
| 12 | 12 | ||
| 13 | typedef void (elevator_add_req_fn) (request_queue_t *, struct request *, int); | 13 | typedef void (elevator_add_req_fn) (request_queue_t *, struct request *); |
| 14 | typedef int (elevator_queue_empty_fn) (request_queue_t *); | 14 | typedef int (elevator_queue_empty_fn) (request_queue_t *); |
| 15 | typedef void (elevator_remove_req_fn) (request_queue_t *, struct request *); | ||
| 16 | typedef void (elevator_requeue_req_fn) (request_queue_t *, struct request *); | ||
| 17 | typedef struct request *(elevator_request_list_fn) (request_queue_t *, struct request *); | 15 | typedef struct request *(elevator_request_list_fn) (request_queue_t *, struct request *); |
| 18 | typedef void (elevator_completed_req_fn) (request_queue_t *, struct request *); | 16 | typedef void (elevator_completed_req_fn) (request_queue_t *, struct request *); |
| 19 | typedef int (elevator_may_queue_fn) (request_queue_t *, int, struct bio *); | 17 | typedef int (elevator_may_queue_fn) (request_queue_t *, int, struct bio *); |
| 20 | 18 | ||
| 21 | typedef int (elevator_set_req_fn) (request_queue_t *, struct request *, struct bio *, int); | 19 | typedef int (elevator_set_req_fn) (request_queue_t *, struct request *, struct bio *, gfp_t); |
| 22 | typedef void (elevator_put_req_fn) (request_queue_t *, struct request *); | 20 | typedef void (elevator_put_req_fn) (request_queue_t *, struct request *); |
| 21 | typedef void (elevator_activate_req_fn) (request_queue_t *, struct request *); | ||
| 23 | typedef void (elevator_deactivate_req_fn) (request_queue_t *, struct request *); | 22 | typedef void (elevator_deactivate_req_fn) (request_queue_t *, struct request *); |
| 24 | 23 | ||
| 25 | typedef int (elevator_init_fn) (request_queue_t *, elevator_t *); | 24 | typedef int (elevator_init_fn) (request_queue_t *, elevator_t *); |
| @@ -31,10 +30,9 @@ struct elevator_ops | |||
| 31 | elevator_merged_fn *elevator_merged_fn; | 30 | elevator_merged_fn *elevator_merged_fn; |
| 32 | elevator_merge_req_fn *elevator_merge_req_fn; | 31 | elevator_merge_req_fn *elevator_merge_req_fn; |
| 33 | 32 | ||
| 34 | elevator_next_req_fn *elevator_next_req_fn; | 33 | elevator_dispatch_fn *elevator_dispatch_fn; |
| 35 | elevator_add_req_fn *elevator_add_req_fn; | 34 | elevator_add_req_fn *elevator_add_req_fn; |
| 36 | elevator_remove_req_fn *elevator_remove_req_fn; | 35 | elevator_activate_req_fn *elevator_activate_req_fn; |
| 37 | elevator_requeue_req_fn *elevator_requeue_req_fn; | ||
| 38 | elevator_deactivate_req_fn *elevator_deactivate_req_fn; | 36 | elevator_deactivate_req_fn *elevator_deactivate_req_fn; |
| 39 | 37 | ||
| 40 | elevator_queue_empty_fn *elevator_queue_empty_fn; | 38 | elevator_queue_empty_fn *elevator_queue_empty_fn; |
| @@ -81,15 +79,15 @@ struct elevator_queue | |||
| 81 | /* | 79 | /* |
| 82 | * block elevator interface | 80 | * block elevator interface |
| 83 | */ | 81 | */ |
| 82 | extern void elv_dispatch_sort(request_queue_t *, struct request *); | ||
| 84 | extern void elv_add_request(request_queue_t *, struct request *, int, int); | 83 | extern void elv_add_request(request_queue_t *, struct request *, int, int); |
| 85 | extern void __elv_add_request(request_queue_t *, struct request *, int, int); | 84 | extern void __elv_add_request(request_queue_t *, struct request *, int, int); |
| 86 | extern int elv_merge(request_queue_t *, struct request **, struct bio *); | 85 | extern int elv_merge(request_queue_t *, struct request **, struct bio *); |
| 87 | extern void elv_merge_requests(request_queue_t *, struct request *, | 86 | extern void elv_merge_requests(request_queue_t *, struct request *, |
| 88 | struct request *); | 87 | struct request *); |
| 89 | extern void elv_merged_request(request_queue_t *, struct request *); | 88 | extern void elv_merged_request(request_queue_t *, struct request *); |
| 90 | extern void elv_remove_request(request_queue_t *, struct request *); | 89 | extern void elv_dequeue_request(request_queue_t *, struct request *); |
| 91 | extern void elv_requeue_request(request_queue_t *, struct request *); | 90 | extern void elv_requeue_request(request_queue_t *, struct request *); |
| 92 | extern void elv_deactivate_request(request_queue_t *, struct request *); | ||
| 93 | extern int elv_queue_empty(request_queue_t *); | 91 | extern int elv_queue_empty(request_queue_t *); |
| 94 | extern struct request *elv_next_request(struct request_queue *q); | 92 | extern struct request *elv_next_request(struct request_queue *q); |
| 95 | extern struct request *elv_former_request(request_queue_t *, struct request *); | 93 | extern struct request *elv_former_request(request_queue_t *, struct request *); |
| @@ -98,7 +96,7 @@ extern int elv_register_queue(request_queue_t *q); | |||
| 98 | extern void elv_unregister_queue(request_queue_t *q); | 96 | extern void elv_unregister_queue(request_queue_t *q); |
| 99 | extern int elv_may_queue(request_queue_t *, int, struct bio *); | 97 | extern int elv_may_queue(request_queue_t *, int, struct bio *); |
| 100 | extern void elv_completed_request(request_queue_t *, struct request *); | 98 | extern void elv_completed_request(request_queue_t *, struct request *); |
| 101 | extern int elv_set_request(request_queue_t *, struct request *, struct bio *, int); | 99 | extern int elv_set_request(request_queue_t *, struct request *, struct bio *, gfp_t); |
| 102 | extern void elv_put_request(request_queue_t *, struct request *); | 100 | extern void elv_put_request(request_queue_t *, struct request *); |
| 103 | 101 | ||
| 104 | /* | 102 | /* |
| @@ -142,4 +140,6 @@ enum { | |||
| 142 | ELV_MQUEUE_MUST, | 140 | ELV_MQUEUE_MUST, |
| 143 | }; | 141 | }; |
| 144 | 142 | ||
| 143 | #define rq_end_sector(rq) ((rq)->sector + (rq)->nr_sectors) | ||
| 144 | |||
| 145 | #endif | 145 | #endif |
diff --git a/include/linux/fs.h b/include/linux/fs.h index e0b77c5af9a0..f83d997c5582 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h | |||
| @@ -320,7 +320,7 @@ struct address_space_operations { | |||
| 320 | /* Unfortunately this kludge is needed for FIBMAP. Don't use it */ | 320 | /* Unfortunately this kludge is needed for FIBMAP. Don't use it */ |
| 321 | sector_t (*bmap)(struct address_space *, sector_t); | 321 | sector_t (*bmap)(struct address_space *, sector_t); |
| 322 | int (*invalidatepage) (struct page *, unsigned long); | 322 | int (*invalidatepage) (struct page *, unsigned long); |
| 323 | int (*releasepage) (struct page *, int); | 323 | int (*releasepage) (struct page *, gfp_t); |
| 324 | ssize_t (*direct_IO)(int, struct kiocb *, const struct iovec *iov, | 324 | ssize_t (*direct_IO)(int, struct kiocb *, const struct iovec *iov, |
| 325 | loff_t offset, unsigned long nr_segs); | 325 | loff_t offset, unsigned long nr_segs); |
| 326 | struct page* (*get_xip_page)(struct address_space *, sector_t, | 326 | struct page* (*get_xip_page)(struct address_space *, sector_t, |
diff --git a/include/linux/genhd.h b/include/linux/genhd.h index 78af34840c69..eabdb5cce357 100644 --- a/include/linux/genhd.h +++ b/include/linux/genhd.h | |||
| @@ -119,7 +119,7 @@ struct gendisk { | |||
| 119 | int policy; | 119 | int policy; |
| 120 | 120 | ||
| 121 | atomic_t sync_io; /* RAID */ | 121 | atomic_t sync_io; /* RAID */ |
| 122 | unsigned long stamp, stamp_idle; | 122 | unsigned long stamp; |
| 123 | int in_flight; | 123 | int in_flight; |
| 124 | #ifdef CONFIG_SMP | 124 | #ifdef CONFIG_SMP |
| 125 | struct disk_stats *dkstats; | 125 | struct disk_stats *dkstats; |
diff --git a/include/linux/gfp.h b/include/linux/gfp.h index 3010e172394d..c3779432a723 100644 --- a/include/linux/gfp.h +++ b/include/linux/gfp.h | |||
| @@ -12,8 +12,8 @@ struct vm_area_struct; | |||
| 12 | * GFP bitmasks.. | 12 | * GFP bitmasks.. |
| 13 | */ | 13 | */ |
| 14 | /* Zone modifiers in GFP_ZONEMASK (see linux/mmzone.h - low two bits) */ | 14 | /* Zone modifiers in GFP_ZONEMASK (see linux/mmzone.h - low two bits) */ |
| 15 | #define __GFP_DMA 0x01u | 15 | #define __GFP_DMA ((__force gfp_t)0x01u) |
| 16 | #define __GFP_HIGHMEM 0x02u | 16 | #define __GFP_HIGHMEM ((__force gfp_t)0x02u) |
| 17 | 17 | ||
| 18 | /* | 18 | /* |
| 19 | * Action modifiers - doesn't change the zoning | 19 | * Action modifiers - doesn't change the zoning |
| @@ -26,24 +26,24 @@ struct vm_area_struct; | |||
| 26 | * | 26 | * |
| 27 | * __GFP_NORETRY: The VM implementation must not retry indefinitely. | 27 | * __GFP_NORETRY: The VM implementation must not retry indefinitely. |
| 28 | */ | 28 | */ |
| 29 | #define __GFP_WAIT 0x10u /* Can wait and reschedule? */ | 29 | #define __GFP_WAIT ((__force gfp_t)0x10u) /* Can wait and reschedule? */ |
| 30 | #define __GFP_HIGH 0x20u /* Should access emergency pools? */ | 30 | #define __GFP_HIGH ((__force gfp_t)0x20u) /* Should access emergency pools? */ |
| 31 | #define __GFP_IO 0x40u /* Can start physical IO? */ | 31 | #define __GFP_IO ((__force gfp_t)0x40u) /* Can start physical IO? */ |
| 32 | #define __GFP_FS 0x80u /* Can call down to low-level FS? */ | 32 | #define __GFP_FS ((__force gfp_t)0x80u) /* Can call down to low-level FS? */ |
| 33 | #define __GFP_COLD 0x100u /* Cache-cold page required */ | 33 | #define __GFP_COLD ((__force gfp_t)0x100u) /* Cache-cold page required */ |
| 34 | #define __GFP_NOWARN 0x200u /* Suppress page allocation failure warning */ | 34 | #define __GFP_NOWARN ((__force gfp_t)0x200u) /* Suppress page allocation failure warning */ |
| 35 | #define __GFP_REPEAT 0x400u /* Retry the allocation. Might fail */ | 35 | #define __GFP_REPEAT ((__force gfp_t)0x400u) /* Retry the allocation. Might fail */ |
| 36 | #define __GFP_NOFAIL 0x800u /* Retry for ever. Cannot fail */ | 36 | #define __GFP_NOFAIL ((__force gfp_t)0x800u) /* Retry for ever. Cannot fail */ |
| 37 | #define __GFP_NORETRY 0x1000u /* Do not retry. Might fail */ | 37 | #define __GFP_NORETRY ((__force gfp_t)0x1000u)/* Do not retry. Might fail */ |
| 38 | #define __GFP_NO_GROW 0x2000u /* Slab internal usage */ | 38 | #define __GFP_NO_GROW ((__force gfp_t)0x2000u)/* Slab internal usage */ |
| 39 | #define __GFP_COMP 0x4000u /* Add compound page metadata */ | 39 | #define __GFP_COMP ((__force gfp_t)0x4000u)/* Add compound page metadata */ |
| 40 | #define __GFP_ZERO 0x8000u /* Return zeroed page on success */ | 40 | #define __GFP_ZERO ((__force gfp_t)0x8000u)/* Return zeroed page on success */ |
| 41 | #define __GFP_NOMEMALLOC 0x10000u /* Don't use emergency reserves */ | 41 | #define __GFP_NOMEMALLOC ((__force gfp_t)0x10000u) /* Don't use emergency reserves */ |
| 42 | #define __GFP_NORECLAIM 0x20000u /* No realy zone reclaim during allocation */ | 42 | #define __GFP_NORECLAIM ((__force gfp_t)0x20000u) /* No realy zone reclaim during allocation */ |
| 43 | #define __GFP_HARDWALL 0x40000u /* Enforce hardwall cpuset memory allocs */ | 43 | #define __GFP_HARDWALL ((__force gfp_t)0x40000u) /* Enforce hardwall cpuset memory allocs */ |
| 44 | 44 | ||
| 45 | #define __GFP_BITS_SHIFT 20 /* Room for 20 __GFP_FOO bits */ | 45 | #define __GFP_BITS_SHIFT 20 /* Room for 20 __GFP_FOO bits */ |
| 46 | #define __GFP_BITS_MASK ((1 << __GFP_BITS_SHIFT) - 1) | 46 | #define __GFP_BITS_MASK ((__force gfp_t)((1 << __GFP_BITS_SHIFT) - 1)) |
| 47 | 47 | ||
| 48 | /* if you forget to add the bitmask here kernel will crash, period */ | 48 | /* if you forget to add the bitmask here kernel will crash, period */ |
| 49 | #define GFP_LEVEL_MASK (__GFP_WAIT|__GFP_HIGH|__GFP_IO|__GFP_FS| \ | 49 | #define GFP_LEVEL_MASK (__GFP_WAIT|__GFP_HIGH|__GFP_IO|__GFP_FS| \ |
| @@ -64,6 +64,7 @@ struct vm_area_struct; | |||
| 64 | 64 | ||
| 65 | #define GFP_DMA __GFP_DMA | 65 | #define GFP_DMA __GFP_DMA |
| 66 | 66 | ||
| 67 | #define gfp_zone(mask) ((__force int)((mask) & (__force gfp_t)GFP_ZONEMASK)) | ||
| 67 | 68 | ||
| 68 | /* | 69 | /* |
| 69 | * There is only one page-allocator function, and two main namespaces to | 70 | * There is only one page-allocator function, and two main namespaces to |
| @@ -94,7 +95,7 @@ static inline struct page *alloc_pages_node(int nid, gfp_t gfp_mask, | |||
| 94 | return NULL; | 95 | return NULL; |
| 95 | 96 | ||
| 96 | return __alloc_pages(gfp_mask, order, | 97 | return __alloc_pages(gfp_mask, order, |
| 97 | NODE_DATA(nid)->node_zonelists + (gfp_mask & GFP_ZONEMASK)); | 98 | NODE_DATA(nid)->node_zonelists + gfp_zone(gfp_mask)); |
| 98 | } | 99 | } |
| 99 | 100 | ||
| 100 | #ifdef CONFIG_NUMA | 101 | #ifdef CONFIG_NUMA |
diff --git a/include/linux/i2o.h b/include/linux/i2o.h index 84db8f6ae7e5..92300325dbcd 100644 --- a/include/linux/i2o.h +++ b/include/linux/i2o.h | |||
| @@ -490,7 +490,7 @@ static inline int i2o_dma_map_sg(struct i2o_controller *c, | |||
| 490 | * Returns 0 on success or -ENOMEM on failure. | 490 | * Returns 0 on success or -ENOMEM on failure. |
| 491 | */ | 491 | */ |
| 492 | static inline int i2o_dma_alloc(struct device *dev, struct i2o_dma *addr, | 492 | static inline int i2o_dma_alloc(struct device *dev, struct i2o_dma *addr, |
| 493 | size_t len, unsigned int gfp_mask) | 493 | size_t len, gfp_t gfp_mask) |
| 494 | { | 494 | { |
| 495 | struct pci_dev *pdev = to_pci_dev(dev); | 495 | struct pci_dev *pdev = to_pci_dev(dev); |
| 496 | int dma_64 = 0; | 496 | int dma_64 = 0; |
| @@ -549,7 +549,7 @@ static inline void i2o_dma_free(struct device *dev, struct i2o_dma *addr) | |||
| 549 | * Returns the 0 on success or negative error code on failure. | 549 | * Returns the 0 on success or negative error code on failure. |
| 550 | */ | 550 | */ |
| 551 | static inline int i2o_dma_realloc(struct device *dev, struct i2o_dma *addr, | 551 | static inline int i2o_dma_realloc(struct device *dev, struct i2o_dma *addr, |
| 552 | size_t len, unsigned int gfp_mask) | 552 | size_t len, gfp_t gfp_mask) |
| 553 | { | 553 | { |
| 554 | i2o_dma_free(dev, addr); | 554 | i2o_dma_free(dev, addr); |
| 555 | 555 | ||
diff --git a/include/linux/ibmtr.h b/include/linux/ibmtr.h index 2ef0b21517fb..1c7a0dd5536a 100644 --- a/include/linux/ibmtr.h +++ b/include/linux/ibmtr.h | |||
| @@ -7,8 +7,8 @@ | |||
| 7 | /* ported to the Alpha architecture 02/20/96 (just used the HZ macro) */ | 7 | /* ported to the Alpha architecture 02/20/96 (just used the HZ macro) */ |
| 8 | 8 | ||
| 9 | #define TR_RETRY_INTERVAL (30*HZ) /* 500 on PC = 5 s */ | 9 | #define TR_RETRY_INTERVAL (30*HZ) /* 500 on PC = 5 s */ |
| 10 | #define TR_RST_TIME (HZ/20) /* 5 on PC = 50 ms */ | 10 | #define TR_RST_TIME (msecs_to_jiffies(50)) /* 5 on PC = 50 ms */ |
| 11 | #define TR_BUSY_INTERVAL (HZ/5) /* 5 on PC = 200 ms */ | 11 | #define TR_BUSY_INTERVAL (msecs_to_jiffies(200)) /* 5 on PC = 200 ms */ |
| 12 | #define TR_SPIN_INTERVAL (3*HZ) /* 3 seconds before init timeout */ | 12 | #define TR_SPIN_INTERVAL (3*HZ) /* 3 seconds before init timeout */ |
| 13 | 13 | ||
| 14 | #define TR_ISA 1 | 14 | #define TR_ISA 1 |
diff --git a/include/linux/idr.h b/include/linux/idr.h index 3d5de45f961b..7fb3ff9c7b0e 100644 --- a/include/linux/idr.h +++ b/include/linux/idr.h | |||
| @@ -71,7 +71,7 @@ struct idr { | |||
| 71 | */ | 71 | */ |
| 72 | 72 | ||
| 73 | void *idr_find(struct idr *idp, int id); | 73 | void *idr_find(struct idr *idp, int id); |
| 74 | int idr_pre_get(struct idr *idp, unsigned gfp_mask); | 74 | int idr_pre_get(struct idr *idp, gfp_t gfp_mask); |
| 75 | int idr_get_new(struct idr *idp, void *ptr, int *id); | 75 | int idr_get_new(struct idr *idp, void *ptr, int *id); |
| 76 | int idr_get_new_above(struct idr *idp, void *ptr, int starting_id, int *id); | 76 | int idr_get_new_above(struct idr *idp, void *ptr, int starting_id, int *id); |
| 77 | void idr_remove(struct idr *idp, int id); | 77 | void idr_remove(struct idr *idp, int id); |
diff --git a/include/linux/if_arp.h b/include/linux/if_arp.h index 0856548a2a08..a8b1a2071838 100644 --- a/include/linux/if_arp.h +++ b/include/linux/if_arp.h | |||
| @@ -84,6 +84,7 @@ | |||
| 84 | #define ARPHRD_IEEE802_TR 800 /* Magic type ident for TR */ | 84 | #define ARPHRD_IEEE802_TR 800 /* Magic type ident for TR */ |
| 85 | #define ARPHRD_IEEE80211 801 /* IEEE 802.11 */ | 85 | #define ARPHRD_IEEE80211 801 /* IEEE 802.11 */ |
| 86 | #define ARPHRD_IEEE80211_PRISM 802 /* IEEE 802.11 + Prism2 header */ | 86 | #define ARPHRD_IEEE80211_PRISM 802 /* IEEE 802.11 + Prism2 header */ |
| 87 | #define ARPHRD_IEEE80211_RADIOTAP 803 /* IEEE 802.11 + radiotap header */ | ||
| 87 | 88 | ||
| 88 | #define ARPHRD_VOID 0xFFFF /* Void type, nothing is known */ | 89 | #define ARPHRD_VOID 0xFFFF /* Void type, nothing is known */ |
| 89 | #define ARPHRD_NONE 0xFFFE /* zero header length */ | 90 | #define ARPHRD_NONE 0xFFFE /* zero header length */ |
diff --git a/include/linux/jbd.h b/include/linux/jbd.h index ff853b3173c6..be197eb90077 100644 --- a/include/linux/jbd.h +++ b/include/linux/jbd.h | |||
| @@ -69,7 +69,7 @@ extern int journal_enable_debug; | |||
| 69 | #define jbd_debug(f, a...) /**/ | 69 | #define jbd_debug(f, a...) /**/ |
| 70 | #endif | 70 | #endif |
| 71 | 71 | ||
| 72 | extern void * __jbd_kmalloc (const char *where, size_t size, int flags, int retry); | 72 | extern void * __jbd_kmalloc (const char *where, size_t size, gfp_t flags, int retry); |
| 73 | #define jbd_kmalloc(size, flags) \ | 73 | #define jbd_kmalloc(size, flags) \ |
| 74 | __jbd_kmalloc(__FUNCTION__, (size), (flags), journal_oom_retry) | 74 | __jbd_kmalloc(__FUNCTION__, (size), (flags), journal_oom_retry) |
| 75 | #define jbd_rep_kmalloc(size, flags) \ | 75 | #define jbd_rep_kmalloc(size, flags) \ |
| @@ -890,7 +890,7 @@ extern int journal_forget (handle_t *, struct buffer_head *); | |||
| 890 | extern void journal_sync_buffer (struct buffer_head *); | 890 | extern void journal_sync_buffer (struct buffer_head *); |
| 891 | extern int journal_invalidatepage(journal_t *, | 891 | extern int journal_invalidatepage(journal_t *, |
| 892 | struct page *, unsigned long); | 892 | struct page *, unsigned long); |
| 893 | extern int journal_try_to_free_buffers(journal_t *, struct page *, int); | 893 | extern int journal_try_to_free_buffers(journal_t *, struct page *, gfp_t); |
| 894 | extern int journal_stop(handle_t *); | 894 | extern int journal_stop(handle_t *); |
| 895 | extern int journal_flush (journal_t *); | 895 | extern int journal_flush (journal_t *); |
| 896 | extern void journal_lock_updates (journal_t *); | 896 | extern void journal_lock_updates (journal_t *); |
diff --git a/include/linux/kobject.h b/include/linux/kobject.h index 3b22304f12fd..7f7403aa4a41 100644 --- a/include/linux/kobject.h +++ b/include/linux/kobject.h | |||
| @@ -65,7 +65,7 @@ extern void kobject_unregister(struct kobject *); | |||
| 65 | extern struct kobject * kobject_get(struct kobject *); | 65 | extern struct kobject * kobject_get(struct kobject *); |
| 66 | extern void kobject_put(struct kobject *); | 66 | extern void kobject_put(struct kobject *); |
| 67 | 67 | ||
| 68 | extern char * kobject_get_path(struct kobject *, int); | 68 | extern char * kobject_get_path(struct kobject *, gfp_t); |
| 69 | 69 | ||
| 70 | struct kobj_type { | 70 | struct kobj_type { |
| 71 | void (*release)(struct kobject *); | 71 | void (*release)(struct kobject *); |
diff --git a/include/linux/libata.h b/include/linux/libata.h index ceee1fc42c60..00a8a5738858 100644 --- a/include/linux/libata.h +++ b/include/linux/libata.h | |||
| @@ -91,12 +91,13 @@ enum { | |||
| 91 | ATA_SHT_EMULATED = 1, | 91 | ATA_SHT_EMULATED = 1, |
| 92 | ATA_SHT_CMD_PER_LUN = 1, | 92 | ATA_SHT_CMD_PER_LUN = 1, |
| 93 | ATA_SHT_THIS_ID = -1, | 93 | ATA_SHT_THIS_ID = -1, |
| 94 | ATA_SHT_USE_CLUSTERING = 0, | 94 | ATA_SHT_USE_CLUSTERING = 1, |
| 95 | 95 | ||
| 96 | /* struct ata_device stuff */ | 96 | /* struct ata_device stuff */ |
| 97 | ATA_DFLAG_LBA48 = (1 << 0), /* device supports LBA48 */ | 97 | ATA_DFLAG_LBA48 = (1 << 0), /* device supports LBA48 */ |
| 98 | ATA_DFLAG_PIO = (1 << 1), /* device currently in PIO mode */ | 98 | ATA_DFLAG_PIO = (1 << 1), /* device currently in PIO mode */ |
| 99 | ATA_DFLAG_LOCK_SECTORS = (1 << 2), /* don't adjust max_sectors */ | 99 | ATA_DFLAG_LOCK_SECTORS = (1 << 2), /* don't adjust max_sectors */ |
| 100 | ATA_DFLAG_LBA = (1 << 3), /* device supports LBA */ | ||
| 100 | 101 | ||
| 101 | ATA_DEV_UNKNOWN = 0, /* unknown device */ | 102 | ATA_DEV_UNKNOWN = 0, /* unknown device */ |
| 102 | ATA_DEV_ATA = 1, /* ATA device */ | 103 | ATA_DEV_ATA = 1, /* ATA device */ |
| @@ -154,17 +155,21 @@ enum { | |||
| 154 | ATA_SHIFT_UDMA = 0, | 155 | ATA_SHIFT_UDMA = 0, |
| 155 | ATA_SHIFT_MWDMA = 8, | 156 | ATA_SHIFT_MWDMA = 8, |
| 156 | ATA_SHIFT_PIO = 11, | 157 | ATA_SHIFT_PIO = 11, |
| 158 | |||
| 159 | /* Masks for port functions */ | ||
| 160 | ATA_PORT_PRIMARY = (1 << 0), | ||
| 161 | ATA_PORT_SECONDARY = (1 << 1), | ||
| 157 | }; | 162 | }; |
| 158 | 163 | ||
| 159 | enum pio_task_states { | 164 | enum hsm_task_states { |
| 160 | PIO_ST_UNKNOWN, | 165 | HSM_ST_UNKNOWN, |
| 161 | PIO_ST_IDLE, | 166 | HSM_ST_IDLE, |
| 162 | PIO_ST_POLL, | 167 | HSM_ST_POLL, |
| 163 | PIO_ST_TMOUT, | 168 | HSM_ST_TMOUT, |
| 164 | PIO_ST, | 169 | HSM_ST, |
| 165 | PIO_ST_LAST, | 170 | HSM_ST_LAST, |
| 166 | PIO_ST_LAST_POLL, | 171 | HSM_ST_LAST_POLL, |
| 167 | PIO_ST_ERR, | 172 | HSM_ST_ERR, |
| 168 | }; | 173 | }; |
| 169 | 174 | ||
| 170 | /* forward declarations */ | 175 | /* forward declarations */ |
| @@ -197,7 +202,7 @@ struct ata_ioports { | |||
| 197 | struct ata_probe_ent { | 202 | struct ata_probe_ent { |
| 198 | struct list_head node; | 203 | struct list_head node; |
| 199 | struct device *dev; | 204 | struct device *dev; |
| 200 | struct ata_port_operations *port_ops; | 205 | const struct ata_port_operations *port_ops; |
| 201 | Scsi_Host_Template *sht; | 206 | Scsi_Host_Template *sht; |
| 202 | struct ata_ioports port[ATA_MAX_PORTS]; | 207 | struct ata_ioports port[ATA_MAX_PORTS]; |
| 203 | unsigned int n_ports; | 208 | unsigned int n_ports; |
| @@ -220,7 +225,7 @@ struct ata_host_set { | |||
| 220 | void __iomem *mmio_base; | 225 | void __iomem *mmio_base; |
| 221 | unsigned int n_ports; | 226 | unsigned int n_ports; |
| 222 | void *private_data; | 227 | void *private_data; |
| 223 | struct ata_port_operations *ops; | 228 | const struct ata_port_operations *ops; |
| 224 | struct ata_port * ports[0]; | 229 | struct ata_port * ports[0]; |
| 225 | }; | 230 | }; |
| 226 | 231 | ||
| @@ -278,15 +283,18 @@ struct ata_device { | |||
| 278 | u8 xfer_mode; | 283 | u8 xfer_mode; |
| 279 | unsigned int xfer_shift; /* ATA_SHIFT_xxx */ | 284 | unsigned int xfer_shift; /* ATA_SHIFT_xxx */ |
| 280 | 285 | ||
| 281 | /* cache info about current transfer mode */ | 286 | unsigned int multi_count; /* sectors count for |
| 282 | u8 xfer_protocol; /* taskfile xfer protocol */ | 287 | READ/WRITE MULTIPLE */ |
| 283 | u8 read_cmd; /* opcode to use on read */ | 288 | |
| 284 | u8 write_cmd; /* opcode to use on write */ | 289 | /* for CHS addressing */ |
| 290 | u16 cylinders; /* Number of cylinders */ | ||
| 291 | u16 heads; /* Number of heads */ | ||
| 292 | u16 sectors; /* Number of sectors per track */ | ||
| 285 | }; | 293 | }; |
| 286 | 294 | ||
| 287 | struct ata_port { | 295 | struct ata_port { |
| 288 | struct Scsi_Host *host; /* our co-allocated scsi host */ | 296 | struct Scsi_Host *host; /* our co-allocated scsi host */ |
| 289 | struct ata_port_operations *ops; | 297 | const struct ata_port_operations *ops; |
| 290 | unsigned long flags; /* ATA_FLAG_xxx */ | 298 | unsigned long flags; /* ATA_FLAG_xxx */ |
| 291 | unsigned int id; /* unique id req'd by scsi midlyr */ | 299 | unsigned int id; /* unique id req'd by scsi midlyr */ |
| 292 | unsigned int port_no; /* unique port #; from zero */ | 300 | unsigned int port_no; /* unique port #; from zero */ |
| @@ -319,7 +327,7 @@ struct ata_port { | |||
| 319 | struct work_struct packet_task; | 327 | struct work_struct packet_task; |
| 320 | 328 | ||
| 321 | struct work_struct pio_task; | 329 | struct work_struct pio_task; |
| 322 | unsigned int pio_task_state; | 330 | unsigned int hsm_task_state; |
| 323 | unsigned long pio_task_timeout; | 331 | unsigned long pio_task_timeout; |
| 324 | 332 | ||
| 325 | void *private_data; | 333 | void *private_data; |
| @@ -333,10 +341,10 @@ struct ata_port_operations { | |||
| 333 | void (*set_piomode) (struct ata_port *, struct ata_device *); | 341 | void (*set_piomode) (struct ata_port *, struct ata_device *); |
| 334 | void (*set_dmamode) (struct ata_port *, struct ata_device *); | 342 | void (*set_dmamode) (struct ata_port *, struct ata_device *); |
| 335 | 343 | ||
| 336 | void (*tf_load) (struct ata_port *ap, struct ata_taskfile *tf); | 344 | void (*tf_load) (struct ata_port *ap, const struct ata_taskfile *tf); |
| 337 | void (*tf_read) (struct ata_port *ap, struct ata_taskfile *tf); | 345 | void (*tf_read) (struct ata_port *ap, struct ata_taskfile *tf); |
| 338 | 346 | ||
| 339 | void (*exec_command)(struct ata_port *ap, struct ata_taskfile *tf); | 347 | void (*exec_command)(struct ata_port *ap, const struct ata_taskfile *tf); |
| 340 | u8 (*check_status)(struct ata_port *ap); | 348 | u8 (*check_status)(struct ata_port *ap); |
| 341 | u8 (*check_altstatus)(struct ata_port *ap); | 349 | u8 (*check_altstatus)(struct ata_port *ap); |
| 342 | u8 (*check_err)(struct ata_port *ap); | 350 | u8 (*check_err)(struct ata_port *ap); |
| @@ -377,9 +385,22 @@ struct ata_port_info { | |||
| 377 | unsigned long pio_mask; | 385 | unsigned long pio_mask; |
| 378 | unsigned long mwdma_mask; | 386 | unsigned long mwdma_mask; |
| 379 | unsigned long udma_mask; | 387 | unsigned long udma_mask; |
| 380 | struct ata_port_operations *port_ops; | 388 | const struct ata_port_operations *port_ops; |
| 389 | }; | ||
| 390 | |||
| 391 | struct ata_timing { | ||
| 392 | unsigned short mode; /* ATA mode */ | ||
| 393 | unsigned short setup; /* t1 */ | ||
| 394 | unsigned short act8b; /* t2 for 8-bit I/O */ | ||
| 395 | unsigned short rec8b; /* t2i for 8-bit I/O */ | ||
| 396 | unsigned short cyc8b; /* t0 for 8-bit I/O */ | ||
| 397 | unsigned short active; /* t2 or tD */ | ||
| 398 | unsigned short recover; /* t2i or tK */ | ||
| 399 | unsigned short cycle; /* t0 */ | ||
| 400 | unsigned short udma; /* t2CYCTYP/2 */ | ||
| 381 | }; | 401 | }; |
| 382 | 402 | ||
| 403 | #define FIT(v,vmin,vmax) max_t(short,min_t(short,v,vmax),vmin) | ||
| 383 | 404 | ||
| 384 | extern void ata_port_probe(struct ata_port *); | 405 | extern void ata_port_probe(struct ata_port *); |
| 385 | extern void __sata_phy_reset(struct ata_port *ap); | 406 | extern void __sata_phy_reset(struct ata_port *ap); |
| @@ -392,7 +413,7 @@ extern int ata_pci_init_one (struct pci_dev *pdev, struct ata_port_info **port_i | |||
| 392 | unsigned int n_ports); | 413 | unsigned int n_ports); |
| 393 | extern void ata_pci_remove_one (struct pci_dev *pdev); | 414 | extern void ata_pci_remove_one (struct pci_dev *pdev); |
| 394 | #endif /* CONFIG_PCI */ | 415 | #endif /* CONFIG_PCI */ |
| 395 | extern int ata_device_add(struct ata_probe_ent *ent); | 416 | extern int ata_device_add(const struct ata_probe_ent *ent); |
| 396 | extern void ata_host_set_remove(struct ata_host_set *host_set); | 417 | extern void ata_host_set_remove(struct ata_host_set *host_set); |
| 397 | extern int ata_scsi_detect(Scsi_Host_Template *sht); | 418 | extern int ata_scsi_detect(Scsi_Host_Template *sht); |
| 398 | extern int ata_scsi_ioctl(struct scsi_device *dev, int cmd, void __user *arg); | 419 | extern int ata_scsi_ioctl(struct scsi_device *dev, int cmd, void __user *arg); |
| @@ -400,19 +421,21 @@ extern int ata_scsi_queuecmd(struct scsi_cmnd *cmd, void (*done)(struct scsi_cmn | |||
| 400 | extern int ata_scsi_error(struct Scsi_Host *host); | 421 | extern int ata_scsi_error(struct Scsi_Host *host); |
| 401 | extern int ata_scsi_release(struct Scsi_Host *host); | 422 | extern int ata_scsi_release(struct Scsi_Host *host); |
| 402 | extern unsigned int ata_host_intr(struct ata_port *ap, struct ata_queued_cmd *qc); | 423 | extern unsigned int ata_host_intr(struct ata_port *ap, struct ata_queued_cmd *qc); |
| 424 | extern int ata_ratelimit(void); | ||
| 425 | |||
| 403 | /* | 426 | /* |
| 404 | * Default driver ops implementations | 427 | * Default driver ops implementations |
| 405 | */ | 428 | */ |
| 406 | extern void ata_tf_load(struct ata_port *ap, struct ata_taskfile *tf); | 429 | extern void ata_tf_load(struct ata_port *ap, const struct ata_taskfile *tf); |
| 407 | extern void ata_tf_read(struct ata_port *ap, struct ata_taskfile *tf); | 430 | extern void ata_tf_read(struct ata_port *ap, struct ata_taskfile *tf); |
| 408 | extern void ata_tf_to_fis(struct ata_taskfile *tf, u8 *fis, u8 pmp); | 431 | extern void ata_tf_to_fis(const struct ata_taskfile *tf, u8 *fis, u8 pmp); |
| 409 | extern void ata_tf_from_fis(u8 *fis, struct ata_taskfile *tf); | 432 | extern void ata_tf_from_fis(const u8 *fis, struct ata_taskfile *tf); |
| 410 | extern void ata_noop_dev_select (struct ata_port *ap, unsigned int device); | 433 | extern void ata_noop_dev_select (struct ata_port *ap, unsigned int device); |
| 411 | extern void ata_std_dev_select (struct ata_port *ap, unsigned int device); | 434 | extern void ata_std_dev_select (struct ata_port *ap, unsigned int device); |
| 412 | extern u8 ata_check_status(struct ata_port *ap); | 435 | extern u8 ata_check_status(struct ata_port *ap); |
| 413 | extern u8 ata_altstatus(struct ata_port *ap); | 436 | extern u8 ata_altstatus(struct ata_port *ap); |
| 414 | extern u8 ata_chk_err(struct ata_port *ap); | 437 | extern u8 ata_chk_err(struct ata_port *ap); |
| 415 | extern void ata_exec_command(struct ata_port *ap, struct ata_taskfile *tf); | 438 | extern void ata_exec_command(struct ata_port *ap, const struct ata_taskfile *tf); |
| 416 | extern int ata_port_start (struct ata_port *ap); | 439 | extern int ata_port_start (struct ata_port *ap); |
| 417 | extern void ata_port_stop (struct ata_port *ap); | 440 | extern void ata_port_stop (struct ata_port *ap); |
| 418 | extern void ata_host_stop (struct ata_host_set *host_set); | 441 | extern void ata_host_stop (struct ata_host_set *host_set); |
| @@ -423,8 +446,8 @@ extern void ata_sg_init_one(struct ata_queued_cmd *qc, void *buf, | |||
| 423 | unsigned int buflen); | 446 | unsigned int buflen); |
| 424 | extern void ata_sg_init(struct ata_queued_cmd *qc, struct scatterlist *sg, | 447 | extern void ata_sg_init(struct ata_queued_cmd *qc, struct scatterlist *sg, |
| 425 | unsigned int n_elem); | 448 | unsigned int n_elem); |
| 426 | extern unsigned int ata_dev_classify(struct ata_taskfile *tf); | 449 | extern unsigned int ata_dev_classify(const struct ata_taskfile *tf); |
| 427 | extern void ata_dev_id_string(u16 *id, unsigned char *s, | 450 | extern void ata_dev_id_string(const u16 *id, unsigned char *s, |
| 428 | unsigned int ofs, unsigned int len); | 451 | unsigned int ofs, unsigned int len); |
| 429 | extern void ata_dev_config(struct ata_port *ap, unsigned int i); | 452 | extern void ata_dev_config(struct ata_port *ap, unsigned int i); |
| 430 | extern void ata_bmdma_setup (struct ata_queued_cmd *qc); | 453 | extern void ata_bmdma_setup (struct ata_queued_cmd *qc); |
| @@ -441,6 +464,32 @@ extern int ata_std_bios_param(struct scsi_device *sdev, | |||
| 441 | sector_t capacity, int geom[]); | 464 | sector_t capacity, int geom[]); |
| 442 | extern int ata_scsi_slave_config(struct scsi_device *sdev); | 465 | extern int ata_scsi_slave_config(struct scsi_device *sdev); |
| 443 | 466 | ||
| 467 | /* | ||
| 468 | * Timing helpers | ||
| 469 | */ | ||
| 470 | extern int ata_timing_compute(struct ata_device *, unsigned short, | ||
| 471 | struct ata_timing *, int, int); | ||
| 472 | extern void ata_timing_merge(const struct ata_timing *, | ||
| 473 | const struct ata_timing *, struct ata_timing *, | ||
| 474 | unsigned int); | ||
| 475 | |||
| 476 | enum { | ||
| 477 | ATA_TIMING_SETUP = (1 << 0), | ||
| 478 | ATA_TIMING_ACT8B = (1 << 1), | ||
| 479 | ATA_TIMING_REC8B = (1 << 2), | ||
| 480 | ATA_TIMING_CYC8B = (1 << 3), | ||
| 481 | ATA_TIMING_8BIT = ATA_TIMING_ACT8B | ATA_TIMING_REC8B | | ||
| 482 | ATA_TIMING_CYC8B, | ||
| 483 | ATA_TIMING_ACTIVE = (1 << 4), | ||
| 484 | ATA_TIMING_RECOVER = (1 << 5), | ||
| 485 | ATA_TIMING_CYCLE = (1 << 6), | ||
| 486 | ATA_TIMING_UDMA = (1 << 7), | ||
| 487 | ATA_TIMING_ALL = ATA_TIMING_SETUP | ATA_TIMING_ACT8B | | ||
| 488 | ATA_TIMING_REC8B | ATA_TIMING_CYC8B | | ||
| 489 | ATA_TIMING_ACTIVE | ATA_TIMING_RECOVER | | ||
| 490 | ATA_TIMING_CYCLE | ATA_TIMING_UDMA, | ||
| 491 | }; | ||
| 492 | |||
| 444 | 493 | ||
| 445 | #ifdef CONFIG_PCI | 494 | #ifdef CONFIG_PCI |
| 446 | struct pci_bits { | 495 | struct pci_bits { |
| @@ -452,8 +501,8 @@ struct pci_bits { | |||
| 452 | 501 | ||
| 453 | extern void ata_pci_host_stop (struct ata_host_set *host_set); | 502 | extern void ata_pci_host_stop (struct ata_host_set *host_set); |
| 454 | extern struct ata_probe_ent * | 503 | extern struct ata_probe_ent * |
| 455 | ata_pci_init_native_mode(struct pci_dev *pdev, struct ata_port_info **port); | 504 | ata_pci_init_native_mode(struct pci_dev *pdev, struct ata_port_info **port, int portmask); |
| 456 | extern int pci_test_config_bits(struct pci_dev *pdev, struct pci_bits *bits); | 505 | extern int pci_test_config_bits(struct pci_dev *pdev, const struct pci_bits *bits); |
| 457 | 506 | ||
| 458 | #endif /* CONFIG_PCI */ | 507 | #endif /* CONFIG_PCI */ |
| 459 | 508 | ||
| @@ -463,7 +512,7 @@ static inline unsigned int ata_tag_valid(unsigned int tag) | |||
| 463 | return (tag < ATA_MAX_QUEUE) ? 1 : 0; | 512 | return (tag < ATA_MAX_QUEUE) ? 1 : 0; |
| 464 | } | 513 | } |
| 465 | 514 | ||
| 466 | static inline unsigned int ata_dev_present(struct ata_device *dev) | 515 | static inline unsigned int ata_dev_present(const struct ata_device *dev) |
| 467 | { | 516 | { |
| 468 | return ((dev->class == ATA_DEV_ATA) || | 517 | return ((dev->class == ATA_DEV_ATA) || |
| 469 | (dev->class == ATA_DEV_ATAPI)); | 518 | (dev->class == ATA_DEV_ATAPI)); |
| @@ -662,7 +711,7 @@ static inline unsigned int sata_dev_present(struct ata_port *ap) | |||
| 662 | return ((scr_read(ap, SCR_STATUS) & 0xf) == 0x3) ? 1 : 0; | 711 | return ((scr_read(ap, SCR_STATUS) & 0xf) == 0x3) ? 1 : 0; |
| 663 | } | 712 | } |
| 664 | 713 | ||
| 665 | static inline int ata_try_flush_cache(struct ata_device *dev) | 714 | static inline int ata_try_flush_cache(const struct ata_device *dev) |
| 666 | { | 715 | { |
| 667 | return ata_id_wcache_enabled(dev->id) || | 716 | return ata_id_wcache_enabled(dev->id) || |
| 668 | ata_id_has_flush(dev->id) || | 717 | ata_id_has_flush(dev->id) || |
diff --git a/include/linux/loop.h b/include/linux/loop.h index 53fa51595443..40f63c9879d2 100644 --- a/include/linux/loop.h +++ b/include/linux/loop.h | |||
| @@ -52,7 +52,7 @@ struct loop_device { | |||
| 52 | unsigned lo_blocksize; | 52 | unsigned lo_blocksize; |
| 53 | void *key_data; | 53 | void *key_data; |
| 54 | 54 | ||
| 55 | int old_gfp_mask; | 55 | gfp_t old_gfp_mask; |
| 56 | 56 | ||
| 57 | spinlock_t lo_lock; | 57 | spinlock_t lo_lock; |
| 58 | struct bio *lo_bio; | 58 | struct bio *lo_bio; |
diff --git a/include/linux/mbcache.h b/include/linux/mbcache.h index 9263d2db2d67..99e044b4efc6 100644 --- a/include/linux/mbcache.h +++ b/include/linux/mbcache.h | |||
| @@ -22,7 +22,7 @@ struct mb_cache_entry { | |||
| 22 | }; | 22 | }; |
| 23 | 23 | ||
| 24 | struct mb_cache_op { | 24 | struct mb_cache_op { |
| 25 | int (*free)(struct mb_cache_entry *, int); | 25 | int (*free)(struct mb_cache_entry *, gfp_t); |
| 26 | }; | 26 | }; |
| 27 | 27 | ||
| 28 | /* Functions on caches */ | 28 | /* Functions on caches */ |
diff --git a/include/linux/mii.h b/include/linux/mii.h index 9b8d0476988a..68f5a0f392dd 100644 --- a/include/linux/mii.h +++ b/include/linux/mii.h | |||
| @@ -158,6 +158,7 @@ extern int mii_link_ok (struct mii_if_info *mii); | |||
| 158 | extern int mii_nway_restart (struct mii_if_info *mii); | 158 | extern int mii_nway_restart (struct mii_if_info *mii); |
| 159 | extern int mii_ethtool_gset(struct mii_if_info *mii, struct ethtool_cmd *ecmd); | 159 | extern int mii_ethtool_gset(struct mii_if_info *mii, struct ethtool_cmd *ecmd); |
| 160 | extern int mii_ethtool_sset(struct mii_if_info *mii, struct ethtool_cmd *ecmd); | 160 | extern int mii_ethtool_sset(struct mii_if_info *mii, struct ethtool_cmd *ecmd); |
| 161 | extern int mii_check_gmii_support(struct mii_if_info *mii); | ||
| 161 | extern void mii_check_link (struct mii_if_info *mii); | 162 | extern void mii_check_link (struct mii_if_info *mii); |
| 162 | extern unsigned int mii_check_media (struct mii_if_info *mii, | 163 | extern unsigned int mii_check_media (struct mii_if_info *mii, |
| 163 | unsigned int ok_to_print, | 164 | unsigned int ok_to_print, |
diff --git a/include/linux/mm.h b/include/linux/mm.h index 097b3a3c693d..e1649578fb0c 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h | |||
| @@ -747,7 +747,7 @@ extern unsigned long do_mremap(unsigned long addr, | |||
| 747 | * The callback will be passed nr_to_scan == 0 when the VM is querying the | 747 | * The callback will be passed nr_to_scan == 0 when the VM is querying the |
| 748 | * cache size, so a fastpath for that case is appropriate. | 748 | * cache size, so a fastpath for that case is appropriate. |
| 749 | */ | 749 | */ |
| 750 | typedef int (*shrinker_t)(int nr_to_scan, unsigned int gfp_mask); | 750 | typedef int (*shrinker_t)(int nr_to_scan, gfp_t gfp_mask); |
| 751 | 751 | ||
| 752 | /* | 752 | /* |
| 753 | * Add an aging callback. The int is the number of 'seeks' it takes | 753 | * Add an aging callback. The int is the number of 'seeks' it takes |
diff --git a/include/linux/mmc/mmc.h b/include/linux/mmc/mmc.h index 1ab78e8d6c53..aef6042f8f0b 100644 --- a/include/linux/mmc/mmc.h +++ b/include/linux/mmc/mmc.h | |||
| @@ -50,7 +50,7 @@ struct mmc_command { | |||
| 50 | #define MMC_ERR_INVALID 5 | 50 | #define MMC_ERR_INVALID 5 |
| 51 | 51 | ||
| 52 | struct mmc_data *data; /* data segment associated with cmd */ | 52 | struct mmc_data *data; /* data segment associated with cmd */ |
| 53 | struct mmc_request *mrq; /* assoicated request */ | 53 | struct mmc_request *mrq; /* associated request */ |
| 54 | }; | 54 | }; |
| 55 | 55 | ||
| 56 | struct mmc_data { | 56 | struct mmc_data { |
| @@ -68,7 +68,7 @@ struct mmc_data { | |||
| 68 | unsigned int bytes_xfered; | 68 | unsigned int bytes_xfered; |
| 69 | 69 | ||
| 70 | struct mmc_command *stop; /* stop command */ | 70 | struct mmc_command *stop; /* stop command */ |
| 71 | struct mmc_request *mrq; /* assoicated request */ | 71 | struct mmc_request *mrq; /* associated request */ |
| 72 | 72 | ||
| 73 | unsigned int sg_len; /* size of scatter list */ | 73 | unsigned int sg_len; /* size of scatter list */ |
| 74 | struct scatterlist *sg; /* I/O scatter list */ | 74 | struct scatterlist *sg; /* I/O scatter list */ |
diff --git a/include/linux/mmzone.h b/include/linux/mmzone.h index 5ed471b58f4f..7519eb4191e7 100644 --- a/include/linux/mmzone.h +++ b/include/linux/mmzone.h | |||
| @@ -302,7 +302,7 @@ void get_zone_counts(unsigned long *active, unsigned long *inactive, | |||
| 302 | void build_all_zonelists(void); | 302 | void build_all_zonelists(void); |
| 303 | void wakeup_kswapd(struct zone *zone, int order); | 303 | void wakeup_kswapd(struct zone *zone, int order); |
| 304 | int zone_watermark_ok(struct zone *z, int order, unsigned long mark, | 304 | int zone_watermark_ok(struct zone *z, int order, unsigned long mark, |
| 305 | int alloc_type, int can_try_harder, int gfp_high); | 305 | int alloc_type, int can_try_harder, gfp_t gfp_high); |
| 306 | 306 | ||
| 307 | #ifdef CONFIG_HAVE_MEMORY_PRESENT | 307 | #ifdef CONFIG_HAVE_MEMORY_PRESENT |
| 308 | void memory_present(int nid, unsigned long start, unsigned long end); | 308 | void memory_present(int nid, unsigned long start, unsigned long end); |
diff --git a/include/linux/namei.h b/include/linux/namei.h index 7db67b008cac..1c975d0d9e94 100644 --- a/include/linux/namei.h +++ b/include/linux/namei.h | |||
| @@ -8,6 +8,7 @@ struct vfsmount; | |||
| 8 | struct open_intent { | 8 | struct open_intent { |
| 9 | int flags; | 9 | int flags; |
| 10 | int create_mode; | 10 | int create_mode; |
| 11 | struct file *file; | ||
| 11 | }; | 12 | }; |
| 12 | 13 | ||
| 13 | enum { MAX_NESTED_LINKS = 5 }; | 14 | enum { MAX_NESTED_LINKS = 5 }; |
| @@ -65,6 +66,13 @@ extern int FASTCALL(link_path_walk(const char *, struct nameidata *)); | |||
| 65 | extern void path_release(struct nameidata *); | 66 | extern void path_release(struct nameidata *); |
| 66 | extern void path_release_on_umount(struct nameidata *); | 67 | extern void path_release_on_umount(struct nameidata *); |
| 67 | 68 | ||
| 69 | extern int __user_path_lookup_open(const char __user *, unsigned lookup_flags, struct nameidata *nd, int open_flags); | ||
| 70 | extern int path_lookup_open(const char *, unsigned lookup_flags, struct nameidata *, int open_flags); | ||
| 71 | extern struct file *lookup_instantiate_filp(struct nameidata *nd, struct dentry *dentry, | ||
| 72 | int (*open)(struct inode *, struct file *)); | ||
| 73 | extern struct file *nameidata_to_filp(struct nameidata *nd, int flags); | ||
| 74 | extern void release_open_intent(struct nameidata *); | ||
| 75 | |||
| 68 | extern struct dentry * lookup_one_len(const char *, struct dentry *, int); | 76 | extern struct dentry * lookup_one_len(const char *, struct dentry *, int); |
| 69 | extern struct dentry * lookup_hash(struct qstr *, struct dentry *); | 77 | extern struct dentry * lookup_hash(struct qstr *, struct dentry *); |
| 70 | 78 | ||
diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h index 368e4c825ff1..a9281b24c40b 100644 --- a/include/linux/netdevice.h +++ b/include/linux/netdevice.h | |||
| @@ -873,11 +873,9 @@ static inline void netif_rx_complete(struct net_device *dev) | |||
| 873 | 873 | ||
| 874 | static inline void netif_poll_disable(struct net_device *dev) | 874 | static inline void netif_poll_disable(struct net_device *dev) |
| 875 | { | 875 | { |
| 876 | while (test_and_set_bit(__LINK_STATE_RX_SCHED, &dev->state)) { | 876 | while (test_and_set_bit(__LINK_STATE_RX_SCHED, &dev->state)) |
| 877 | /* No hurry. */ | 877 | /* No hurry. */ |
| 878 | current->state = TASK_INTERRUPTIBLE; | 878 | schedule_timeout_interruptible(1); |
| 879 | schedule_timeout(1); | ||
| 880 | } | ||
| 881 | } | 879 | } |
| 882 | 880 | ||
| 883 | static inline void netif_poll_enable(struct net_device *dev) | 881 | static inline void netif_poll_enable(struct net_device *dev) |
diff --git a/include/linux/nfs_fs.h b/include/linux/nfs_fs.h index 9a6047ff1b25..325fe7ae49bb 100644 --- a/include/linux/nfs_fs.h +++ b/include/linux/nfs_fs.h | |||
| @@ -41,6 +41,10 @@ | |||
| 41 | #define NFS_MAX_FILE_IO_BUFFER_SIZE 32768 | 41 | #define NFS_MAX_FILE_IO_BUFFER_SIZE 32768 |
| 42 | #define NFS_DEF_FILE_IO_BUFFER_SIZE 4096 | 42 | #define NFS_DEF_FILE_IO_BUFFER_SIZE 4096 |
| 43 | 43 | ||
| 44 | /* Default timeout values */ | ||
| 45 | #define NFS_MAX_UDP_TIMEOUT (60*HZ) | ||
| 46 | #define NFS_MAX_TCP_TIMEOUT (600*HZ) | ||
| 47 | |||
| 44 | /* | 48 | /* |
| 45 | * superblock magic number for NFS | 49 | * superblock magic number for NFS |
| 46 | */ | 50 | */ |
| @@ -137,6 +141,7 @@ struct nfs_inode { | |||
| 137 | unsigned long attrtimeo_timestamp; | 141 | unsigned long attrtimeo_timestamp; |
| 138 | __u64 change_attr; /* v4 only */ | 142 | __u64 change_attr; /* v4 only */ |
| 139 | 143 | ||
| 144 | unsigned long last_updated; | ||
| 140 | /* "Generation counter" for the attribute cache. This is | 145 | /* "Generation counter" for the attribute cache. This is |
| 141 | * bumped whenever we update the metadata on the | 146 | * bumped whenever we update the metadata on the |
| 142 | * server. | 147 | * server. |
| @@ -236,13 +241,17 @@ static inline int nfs_caches_unstable(struct inode *inode) | |||
| 236 | return atomic_read(&NFS_I(inode)->data_updates) != 0; | 241 | return atomic_read(&NFS_I(inode)->data_updates) != 0; |
| 237 | } | 242 | } |
| 238 | 243 | ||
| 244 | static inline void nfs_mark_for_revalidate(struct inode *inode) | ||
| 245 | { | ||
| 246 | spin_lock(&inode->i_lock); | ||
| 247 | NFS_I(inode)->cache_validity |= NFS_INO_INVALID_ATTR | NFS_INO_INVALID_ACCESS; | ||
| 248 | spin_unlock(&inode->i_lock); | ||
| 249 | } | ||
| 250 | |||
| 239 | static inline void NFS_CACHEINV(struct inode *inode) | 251 | static inline void NFS_CACHEINV(struct inode *inode) |
| 240 | { | 252 | { |
| 241 | if (!nfs_caches_unstable(inode)) { | 253 | if (!nfs_caches_unstable(inode)) |
| 242 | spin_lock(&inode->i_lock); | 254 | nfs_mark_for_revalidate(inode); |
| 243 | NFS_I(inode)->cache_validity |= NFS_INO_INVALID_ATTR | NFS_INO_INVALID_ACCESS; | ||
| 244 | spin_unlock(&inode->i_lock); | ||
| 245 | } | ||
| 246 | } | 255 | } |
| 247 | 256 | ||
| 248 | static inline int nfs_server_capable(struct inode *inode, int cap) | 257 | static inline int nfs_server_capable(struct inode *inode, int cap) |
| @@ -276,7 +285,7 @@ static inline long nfs_save_change_attribute(struct inode *inode) | |||
| 276 | static inline int nfs_verify_change_attribute(struct inode *inode, unsigned long chattr) | 285 | static inline int nfs_verify_change_attribute(struct inode *inode, unsigned long chattr) |
| 277 | { | 286 | { |
| 278 | return !nfs_caches_unstable(inode) | 287 | return !nfs_caches_unstable(inode) |
| 279 | && chattr == NFS_I(inode)->cache_change_attribute; | 288 | && time_after_eq(chattr, NFS_I(inode)->cache_change_attribute); |
| 280 | } | 289 | } |
| 281 | 290 | ||
| 282 | /* | 291 | /* |
| @@ -286,6 +295,7 @@ extern void nfs_zap_caches(struct inode *); | |||
| 286 | extern struct inode *nfs_fhget(struct super_block *, struct nfs_fh *, | 295 | extern struct inode *nfs_fhget(struct super_block *, struct nfs_fh *, |
| 287 | struct nfs_fattr *); | 296 | struct nfs_fattr *); |
| 288 | extern int nfs_refresh_inode(struct inode *, struct nfs_fattr *); | 297 | extern int nfs_refresh_inode(struct inode *, struct nfs_fattr *); |
| 298 | extern int nfs_post_op_update_inode(struct inode *inode, struct nfs_fattr *fattr); | ||
| 289 | extern int nfs_getattr(struct vfsmount *, struct dentry *, struct kstat *); | 299 | extern int nfs_getattr(struct vfsmount *, struct dentry *, struct kstat *); |
| 290 | extern int nfs_permission(struct inode *, int, struct nameidata *); | 300 | extern int nfs_permission(struct inode *, int, struct nameidata *); |
| 291 | extern int nfs_access_get_cached(struct inode *, struct rpc_cred *, struct nfs_access_entry *); | 301 | extern int nfs_access_get_cached(struct inode *, struct rpc_cred *, struct nfs_access_entry *); |
| @@ -312,6 +322,12 @@ extern void nfs_file_clear_open_context(struct file *filp); | |||
| 312 | /* linux/net/ipv4/ipconfig.c: trims ip addr off front of name, too. */ | 322 | /* linux/net/ipv4/ipconfig.c: trims ip addr off front of name, too. */ |
| 313 | extern u32 root_nfs_parse_addr(char *name); /*__init*/ | 323 | extern u32 root_nfs_parse_addr(char *name); /*__init*/ |
| 314 | 324 | ||
| 325 | static inline void nfs_fattr_init(struct nfs_fattr *fattr) | ||
| 326 | { | ||
| 327 | fattr->valid = 0; | ||
| 328 | fattr->time_start = jiffies; | ||
| 329 | } | ||
| 330 | |||
| 315 | /* | 331 | /* |
| 316 | * linux/fs/nfs/file.c | 332 | * linux/fs/nfs/file.c |
| 317 | */ | 333 | */ |
diff --git a/include/linux/nfs_xdr.h b/include/linux/nfs_xdr.h index a2bf6914ff1b..40718669b9c8 100644 --- a/include/linux/nfs_xdr.h +++ b/include/linux/nfs_xdr.h | |||
| @@ -41,7 +41,7 @@ struct nfs_fattr { | |||
| 41 | __u32 bitmap[2]; /* NFSv4 returned attribute bitmap */ | 41 | __u32 bitmap[2]; /* NFSv4 returned attribute bitmap */ |
| 42 | __u64 change_attr; /* NFSv4 change attribute */ | 42 | __u64 change_attr; /* NFSv4 change attribute */ |
| 43 | __u64 pre_change_attr;/* pre-op NFSv4 change attribute */ | 43 | __u64 pre_change_attr;/* pre-op NFSv4 change attribute */ |
| 44 | unsigned long timestamp; | 44 | unsigned long time_start; |
| 45 | }; | 45 | }; |
| 46 | 46 | ||
| 47 | #define NFS_ATTR_WCC 0x0001 /* pre-op WCC data */ | 47 | #define NFS_ATTR_WCC 0x0001 /* pre-op WCC data */ |
| @@ -96,12 +96,13 @@ struct nfs4_change_info { | |||
| 96 | u64 after; | 96 | u64 after; |
| 97 | }; | 97 | }; |
| 98 | 98 | ||
| 99 | struct nfs_seqid; | ||
| 99 | /* | 100 | /* |
| 100 | * Arguments to the open call. | 101 | * Arguments to the open call. |
| 101 | */ | 102 | */ |
| 102 | struct nfs_openargs { | 103 | struct nfs_openargs { |
| 103 | const struct nfs_fh * fh; | 104 | const struct nfs_fh * fh; |
| 104 | __u32 seqid; | 105 | struct nfs_seqid * seqid; |
| 105 | int open_flags; | 106 | int open_flags; |
| 106 | __u64 clientid; | 107 | __u64 clientid; |
| 107 | __u32 id; | 108 | __u32 id; |
| @@ -123,6 +124,7 @@ struct nfs_openres { | |||
| 123 | struct nfs4_change_info cinfo; | 124 | struct nfs4_change_info cinfo; |
| 124 | __u32 rflags; | 125 | __u32 rflags; |
| 125 | struct nfs_fattr * f_attr; | 126 | struct nfs_fattr * f_attr; |
| 127 | struct nfs_fattr * dir_attr; | ||
| 126 | const struct nfs_server *server; | 128 | const struct nfs_server *server; |
| 127 | int delegation_type; | 129 | int delegation_type; |
| 128 | nfs4_stateid delegation; | 130 | nfs4_stateid delegation; |
| @@ -136,7 +138,7 @@ struct nfs_openres { | |||
| 136 | struct nfs_open_confirmargs { | 138 | struct nfs_open_confirmargs { |
| 137 | const struct nfs_fh * fh; | 139 | const struct nfs_fh * fh; |
| 138 | nfs4_stateid stateid; | 140 | nfs4_stateid stateid; |
| 139 | __u32 seqid; | 141 | struct nfs_seqid * seqid; |
| 140 | }; | 142 | }; |
| 141 | 143 | ||
| 142 | struct nfs_open_confirmres { | 144 | struct nfs_open_confirmres { |
| @@ -148,13 +150,16 @@ struct nfs_open_confirmres { | |||
| 148 | */ | 150 | */ |
| 149 | struct nfs_closeargs { | 151 | struct nfs_closeargs { |
| 150 | struct nfs_fh * fh; | 152 | struct nfs_fh * fh; |
| 151 | nfs4_stateid stateid; | 153 | nfs4_stateid * stateid; |
| 152 | __u32 seqid; | 154 | struct nfs_seqid * seqid; |
| 153 | int open_flags; | 155 | int open_flags; |
| 156 | const u32 * bitmask; | ||
| 154 | }; | 157 | }; |
| 155 | 158 | ||
| 156 | struct nfs_closeres { | 159 | struct nfs_closeres { |
| 157 | nfs4_stateid stateid; | 160 | nfs4_stateid stateid; |
| 161 | struct nfs_fattr * fattr; | ||
| 162 | const struct nfs_server *server; | ||
| 158 | }; | 163 | }; |
| 159 | /* | 164 | /* |
| 160 | * * Arguments to the lock,lockt, and locku call. | 165 | * * Arguments to the lock,lockt, and locku call. |
| @@ -164,30 +169,19 @@ struct nfs_lowner { | |||
| 164 | u32 id; | 169 | u32 id; |
| 165 | }; | 170 | }; |
| 166 | 171 | ||
| 167 | struct nfs_open_to_lock { | ||
| 168 | __u32 open_seqid; | ||
| 169 | nfs4_stateid open_stateid; | ||
| 170 | __u32 lock_seqid; | ||
| 171 | struct nfs_lowner lock_owner; | ||
| 172 | }; | ||
| 173 | |||
| 174 | struct nfs_exist_lock { | ||
| 175 | nfs4_stateid stateid; | ||
| 176 | __u32 seqid; | ||
| 177 | }; | ||
| 178 | |||
| 179 | struct nfs_lock_opargs { | 172 | struct nfs_lock_opargs { |
| 173 | struct nfs_seqid * lock_seqid; | ||
| 174 | nfs4_stateid * lock_stateid; | ||
| 175 | struct nfs_seqid * open_seqid; | ||
| 176 | nfs4_stateid * open_stateid; | ||
| 177 | struct nfs_lowner lock_owner; | ||
| 180 | __u32 reclaim; | 178 | __u32 reclaim; |
| 181 | __u32 new_lock_owner; | 179 | __u32 new_lock_owner; |
| 182 | union { | ||
| 183 | struct nfs_open_to_lock *open_lock; | ||
| 184 | struct nfs_exist_lock *exist_lock; | ||
| 185 | } u; | ||
| 186 | }; | 180 | }; |
| 187 | 181 | ||
| 188 | struct nfs_locku_opargs { | 182 | struct nfs_locku_opargs { |
| 189 | __u32 seqid; | 183 | struct nfs_seqid * seqid; |
| 190 | nfs4_stateid stateid; | 184 | nfs4_stateid * stateid; |
| 191 | }; | 185 | }; |
| 192 | 186 | ||
| 193 | struct nfs_lockargs { | 187 | struct nfs_lockargs { |
| @@ -262,6 +256,7 @@ struct nfs_writeargs { | |||
| 262 | enum nfs3_stable_how stable; | 256 | enum nfs3_stable_how stable; |
| 263 | unsigned int pgbase; | 257 | unsigned int pgbase; |
| 264 | struct page ** pages; | 258 | struct page ** pages; |
| 259 | const u32 * bitmask; | ||
| 265 | }; | 260 | }; |
| 266 | 261 | ||
| 267 | struct nfs_writeverf { | 262 | struct nfs_writeverf { |
| @@ -273,6 +268,7 @@ struct nfs_writeres { | |||
| 273 | struct nfs_fattr * fattr; | 268 | struct nfs_fattr * fattr; |
| 274 | struct nfs_writeverf * verf; | 269 | struct nfs_writeverf * verf; |
| 275 | __u32 count; | 270 | __u32 count; |
| 271 | const struct nfs_server *server; | ||
| 276 | }; | 272 | }; |
| 277 | 273 | ||
| 278 | /* | 274 | /* |
| @@ -550,6 +546,7 @@ struct nfs4_create_res { | |||
| 550 | struct nfs_fh * fh; | 546 | struct nfs_fh * fh; |
| 551 | struct nfs_fattr * fattr; | 547 | struct nfs_fattr * fattr; |
| 552 | struct nfs4_change_info dir_cinfo; | 548 | struct nfs4_change_info dir_cinfo; |
| 549 | struct nfs_fattr * dir_fattr; | ||
| 553 | }; | 550 | }; |
| 554 | 551 | ||
| 555 | struct nfs4_fsinfo_arg { | 552 | struct nfs4_fsinfo_arg { |
| @@ -571,8 +568,17 @@ struct nfs4_link_arg { | |||
| 571 | const struct nfs_fh * fh; | 568 | const struct nfs_fh * fh; |
| 572 | const struct nfs_fh * dir_fh; | 569 | const struct nfs_fh * dir_fh; |
| 573 | const struct qstr * name; | 570 | const struct qstr * name; |
| 571 | const u32 * bitmask; | ||
| 572 | }; | ||
| 573 | |||
| 574 | struct nfs4_link_res { | ||
| 575 | const struct nfs_server * server; | ||
| 576 | struct nfs_fattr * fattr; | ||
| 577 | struct nfs4_change_info cinfo; | ||
| 578 | struct nfs_fattr * dir_attr; | ||
| 574 | }; | 579 | }; |
| 575 | 580 | ||
| 581 | |||
| 576 | struct nfs4_lookup_arg { | 582 | struct nfs4_lookup_arg { |
| 577 | const struct nfs_fh * dir_fh; | 583 | const struct nfs_fh * dir_fh; |
| 578 | const struct qstr * name; | 584 | const struct qstr * name; |
| @@ -619,6 +625,13 @@ struct nfs4_readlink { | |||
| 619 | struct nfs4_remove_arg { | 625 | struct nfs4_remove_arg { |
| 620 | const struct nfs_fh * fh; | 626 | const struct nfs_fh * fh; |
| 621 | const struct qstr * name; | 627 | const struct qstr * name; |
| 628 | const u32 * bitmask; | ||
| 629 | }; | ||
| 630 | |||
| 631 | struct nfs4_remove_res { | ||
| 632 | const struct nfs_server * server; | ||
| 633 | struct nfs4_change_info cinfo; | ||
| 634 | struct nfs_fattr * dir_attr; | ||
| 622 | }; | 635 | }; |
| 623 | 636 | ||
| 624 | struct nfs4_rename_arg { | 637 | struct nfs4_rename_arg { |
| @@ -626,11 +639,15 @@ struct nfs4_rename_arg { | |||
| 626 | const struct nfs_fh * new_dir; | 639 | const struct nfs_fh * new_dir; |
| 627 | const struct qstr * old_name; | 640 | const struct qstr * old_name; |
| 628 | const struct qstr * new_name; | 641 | const struct qstr * new_name; |
| 642 | const u32 * bitmask; | ||
| 629 | }; | 643 | }; |
| 630 | 644 | ||
| 631 | struct nfs4_rename_res { | 645 | struct nfs4_rename_res { |
| 646 | const struct nfs_server * server; | ||
| 632 | struct nfs4_change_info old_cinfo; | 647 | struct nfs4_change_info old_cinfo; |
| 648 | struct nfs_fattr * old_fattr; | ||
| 633 | struct nfs4_change_info new_cinfo; | 649 | struct nfs4_change_info new_cinfo; |
| 650 | struct nfs_fattr * new_fattr; | ||
| 634 | }; | 651 | }; |
| 635 | 652 | ||
| 636 | struct nfs4_setclientid { | 653 | struct nfs4_setclientid { |
| @@ -722,7 +739,7 @@ struct nfs_rpc_ops { | |||
| 722 | int (*write) (struct nfs_write_data *); | 739 | int (*write) (struct nfs_write_data *); |
| 723 | int (*commit) (struct nfs_write_data *); | 740 | int (*commit) (struct nfs_write_data *); |
| 724 | int (*create) (struct inode *, struct dentry *, | 741 | int (*create) (struct inode *, struct dentry *, |
| 725 | struct iattr *, int); | 742 | struct iattr *, int, struct nameidata *); |
| 726 | int (*remove) (struct inode *, struct qstr *); | 743 | int (*remove) (struct inode *, struct qstr *); |
| 727 | int (*unlink_setup) (struct rpc_message *, | 744 | int (*unlink_setup) (struct rpc_message *, |
| 728 | struct dentry *, struct qstr *); | 745 | struct dentry *, struct qstr *); |
diff --git a/include/linux/pagemap.h b/include/linux/pagemap.h index acbf31c154f8..ba6c310a055f 100644 --- a/include/linux/pagemap.h +++ b/include/linux/pagemap.h | |||
| @@ -21,16 +21,17 @@ | |||
| 21 | 21 | ||
| 22 | static inline gfp_t mapping_gfp_mask(struct address_space * mapping) | 22 | static inline gfp_t mapping_gfp_mask(struct address_space * mapping) |
| 23 | { | 23 | { |
| 24 | return mapping->flags & __GFP_BITS_MASK; | 24 | return (__force gfp_t)mapping->flags & __GFP_BITS_MASK; |
| 25 | } | 25 | } |
| 26 | 26 | ||
| 27 | /* | 27 | /* |
| 28 | * This is non-atomic. Only to be used before the mapping is activated. | 28 | * This is non-atomic. Only to be used before the mapping is activated. |
| 29 | * Probably needs a barrier... | 29 | * Probably needs a barrier... |
| 30 | */ | 30 | */ |
| 31 | static inline void mapping_set_gfp_mask(struct address_space *m, int mask) | 31 | static inline void mapping_set_gfp_mask(struct address_space *m, gfp_t mask) |
| 32 | { | 32 | { |
| 33 | m->flags = (m->flags & ~__GFP_BITS_MASK) | mask; | 33 | m->flags = (m->flags & ~(__force unsigned long)__GFP_BITS_MASK) | |
| 34 | (__force unsigned long)mask; | ||
| 34 | } | 35 | } |
| 35 | 36 | ||
| 36 | /* | 37 | /* |
| @@ -69,7 +70,7 @@ extern struct page * find_lock_page(struct address_space *mapping, | |||
| 69 | extern struct page * find_trylock_page(struct address_space *mapping, | 70 | extern struct page * find_trylock_page(struct address_space *mapping, |
| 70 | unsigned long index); | 71 | unsigned long index); |
| 71 | extern struct page * find_or_create_page(struct address_space *mapping, | 72 | extern struct page * find_or_create_page(struct address_space *mapping, |
| 72 | unsigned long index, unsigned int gfp_mask); | 73 | unsigned long index, gfp_t gfp_mask); |
| 73 | unsigned find_get_pages(struct address_space *mapping, pgoff_t start, | 74 | unsigned find_get_pages(struct address_space *mapping, pgoff_t start, |
| 74 | unsigned int nr_pages, struct page **pages); | 75 | unsigned int nr_pages, struct page **pages); |
| 75 | unsigned find_get_pages_tag(struct address_space *mapping, pgoff_t *index, | 76 | unsigned find_get_pages_tag(struct address_space *mapping, pgoff_t *index, |
| @@ -92,9 +93,9 @@ extern int read_cache_pages(struct address_space *mapping, | |||
| 92 | struct list_head *pages, filler_t *filler, void *data); | 93 | struct list_head *pages, filler_t *filler, void *data); |
| 93 | 94 | ||
| 94 | int add_to_page_cache(struct page *page, struct address_space *mapping, | 95 | int add_to_page_cache(struct page *page, struct address_space *mapping, |
| 95 | unsigned long index, int gfp_mask); | 96 | unsigned long index, gfp_t gfp_mask); |
| 96 | int add_to_page_cache_lru(struct page *page, struct address_space *mapping, | 97 | int add_to_page_cache_lru(struct page *page, struct address_space *mapping, |
| 97 | unsigned long index, int gfp_mask); | 98 | unsigned long index, gfp_t gfp_mask); |
| 98 | extern void remove_from_page_cache(struct page *page); | 99 | extern void remove_from_page_cache(struct page *page); |
| 99 | extern void __remove_from_page_cache(struct page *page); | 100 | extern void __remove_from_page_cache(struct page *page); |
| 100 | 101 | ||
diff --git a/include/linux/radix-tree.h b/include/linux/radix-tree.h index 045d4761febc..9f0f9281f42a 100644 --- a/include/linux/radix-tree.h +++ b/include/linux/radix-tree.h | |||
| @@ -24,7 +24,7 @@ | |||
| 24 | 24 | ||
| 25 | struct radix_tree_root { | 25 | struct radix_tree_root { |
| 26 | unsigned int height; | 26 | unsigned int height; |
| 27 | unsigned int gfp_mask; | 27 | gfp_t gfp_mask; |
| 28 | struct radix_tree_node *rnode; | 28 | struct radix_tree_node *rnode; |
| 29 | }; | 29 | }; |
| 30 | 30 | ||
diff --git a/include/linux/reiserfs_fs.h b/include/linux/reiserfs_fs.h index af00b10294cd..001ab82df051 100644 --- a/include/linux/reiserfs_fs.h +++ b/include/linux/reiserfs_fs.h | |||
| @@ -1972,7 +1972,7 @@ extern struct address_space_operations reiserfs_address_space_operations; | |||
| 1972 | 1972 | ||
| 1973 | /* fix_nodes.c */ | 1973 | /* fix_nodes.c */ |
| 1974 | #ifdef CONFIG_REISERFS_CHECK | 1974 | #ifdef CONFIG_REISERFS_CHECK |
| 1975 | void *reiserfs_kmalloc(size_t size, int flags, struct super_block *s); | 1975 | void *reiserfs_kmalloc(size_t size, gfp_t flags, struct super_block *s); |
| 1976 | void reiserfs_kfree(const void *vp, size_t size, struct super_block *s); | 1976 | void reiserfs_kfree(const void *vp, size_t size, struct super_block *s); |
| 1977 | #else | 1977 | #else |
| 1978 | static inline void *reiserfs_kmalloc(size_t size, int flags, | 1978 | static inline void *reiserfs_kmalloc(size_t size, int flags, |
diff --git a/include/linux/sdladrv.h b/include/linux/sdladrv.h index 78f634007fc6..c85e103d5e7b 100644 --- a/include/linux/sdladrv.h +++ b/include/linux/sdladrv.h | |||
| @@ -52,12 +52,8 @@ typedef struct sdlahw | |||
| 52 | 52 | ||
| 53 | extern int sdla_setup (sdlahw_t* hw, void* sfm, unsigned len); | 53 | extern int sdla_setup (sdlahw_t* hw, void* sfm, unsigned len); |
| 54 | extern int sdla_down (sdlahw_t* hw); | 54 | extern int sdla_down (sdlahw_t* hw); |
| 55 | extern int sdla_inten (sdlahw_t* hw); | ||
| 56 | extern int sdla_intde (sdlahw_t* hw); | ||
| 57 | extern int sdla_intack (sdlahw_t* hw); | ||
| 58 | extern void S514_intack (sdlahw_t* hw, u32 int_status); | 55 | extern void S514_intack (sdlahw_t* hw, u32 int_status); |
| 59 | extern void read_S514_int_stat (sdlahw_t* hw, u32* int_status); | 56 | extern void read_S514_int_stat (sdlahw_t* hw, u32* int_status); |
| 60 | extern int sdla_intr (sdlahw_t* hw); | ||
| 61 | extern int sdla_mapmem (sdlahw_t* hw, unsigned long addr); | 57 | extern int sdla_mapmem (sdlahw_t* hw, unsigned long addr); |
| 62 | extern int sdla_peek (sdlahw_t* hw, unsigned long addr, void* buf, | 58 | extern int sdla_peek (sdlahw_t* hw, unsigned long addr, void* buf, |
| 63 | unsigned len); | 59 | unsigned len); |
diff --git a/include/linux/security.h b/include/linux/security.h index 627382e74057..dac956ed98f0 100644 --- a/include/linux/security.h +++ b/include/linux/security.h | |||
| @@ -1210,7 +1210,7 @@ struct security_operations { | |||
| 1210 | int (*socket_shutdown) (struct socket * sock, int how); | 1210 | int (*socket_shutdown) (struct socket * sock, int how); |
| 1211 | int (*socket_sock_rcv_skb) (struct sock * sk, struct sk_buff * skb); | 1211 | int (*socket_sock_rcv_skb) (struct sock * sk, struct sk_buff * skb); |
| 1212 | int (*socket_getpeersec) (struct socket *sock, char __user *optval, int __user *optlen, unsigned len); | 1212 | int (*socket_getpeersec) (struct socket *sock, char __user *optval, int __user *optlen, unsigned len); |
| 1213 | int (*sk_alloc_security) (struct sock *sk, int family, int priority); | 1213 | int (*sk_alloc_security) (struct sock *sk, int family, gfp_t priority); |
| 1214 | void (*sk_free_security) (struct sock *sk); | 1214 | void (*sk_free_security) (struct sock *sk); |
| 1215 | #endif /* CONFIG_SECURITY_NETWORK */ | 1215 | #endif /* CONFIG_SECURITY_NETWORK */ |
| 1216 | }; | 1216 | }; |
diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h index 8f5d9e7f8734..b756935da9c8 100644 --- a/include/linux/skbuff.h +++ b/include/linux/skbuff.h | |||
| @@ -171,7 +171,6 @@ enum { | |||
| 171 | * struct sk_buff - socket buffer | 171 | * struct sk_buff - socket buffer |
| 172 | * @next: Next buffer in list | 172 | * @next: Next buffer in list |
| 173 | * @prev: Previous buffer in list | 173 | * @prev: Previous buffer in list |
| 174 | * @list: List we are on | ||
| 175 | * @sk: Socket we are owned by | 174 | * @sk: Socket we are owned by |
| 176 | * @tstamp: Time we arrived | 175 | * @tstamp: Time we arrived |
| 177 | * @dev: Device we arrived on/are leaving by | 176 | * @dev: Device we arrived on/are leaving by |
| @@ -190,6 +189,7 @@ enum { | |||
| 190 | * @cloned: Head may be cloned (check refcnt to be sure) | 189 | * @cloned: Head may be cloned (check refcnt to be sure) |
| 191 | * @nohdr: Payload reference only, must not modify header | 190 | * @nohdr: Payload reference only, must not modify header |
| 192 | * @pkt_type: Packet class | 191 | * @pkt_type: Packet class |
| 192 | * @fclone: skbuff clone status | ||
| 193 | * @ip_summed: Driver fed us an IP checksum | 193 | * @ip_summed: Driver fed us an IP checksum |
| 194 | * @priority: Packet queueing priority | 194 | * @priority: Packet queueing priority |
| 195 | * @users: User count - see {datagram,tcp}.c | 195 | * @users: User count - see {datagram,tcp}.c |
| @@ -202,6 +202,7 @@ enum { | |||
| 202 | * @destructor: Destruct function | 202 | * @destructor: Destruct function |
| 203 | * @nfmark: Can be used for communication between hooks | 203 | * @nfmark: Can be used for communication between hooks |
| 204 | * @nfct: Associated connection, if any | 204 | * @nfct: Associated connection, if any |
| 205 | * @ipvs_property: skbuff is owned by ipvs | ||
| 205 | * @nfctinfo: Relationship of this skb to the connection | 206 | * @nfctinfo: Relationship of this skb to the connection |
| 206 | * @nf_bridge: Saved data about a bridged frame - see br_netfilter.c | 207 | * @nf_bridge: Saved data about a bridged frame - see br_netfilter.c |
| 207 | * @tc_index: Traffic control index | 208 | * @tc_index: Traffic control index |
diff --git a/include/linux/slab.h b/include/linux/slab.h index 5fc04a16ecb0..09b9aa60063d 100644 --- a/include/linux/slab.h +++ b/include/linux/slab.h | |||
| @@ -121,7 +121,7 @@ extern unsigned int ksize(const void *); | |||
| 121 | extern void *kmem_cache_alloc_node(kmem_cache_t *, gfp_t flags, int node); | 121 | extern void *kmem_cache_alloc_node(kmem_cache_t *, gfp_t flags, int node); |
| 122 | extern void *kmalloc_node(size_t size, gfp_t flags, int node); | 122 | extern void *kmalloc_node(size_t size, gfp_t flags, int node); |
| 123 | #else | 123 | #else |
| 124 | static inline void *kmem_cache_alloc_node(kmem_cache_t *cachep, int flags, int node) | 124 | static inline void *kmem_cache_alloc_node(kmem_cache_t *cachep, gfp_t flags, int node) |
| 125 | { | 125 | { |
| 126 | return kmem_cache_alloc(cachep, flags); | 126 | return kmem_cache_alloc(cachep, flags); |
| 127 | } | 127 | } |
diff --git a/include/linux/sunrpc/auth.h b/include/linux/sunrpc/auth.h index 04ebc24db348..b68c11a2d6dd 100644 --- a/include/linux/sunrpc/auth.h +++ b/include/linux/sunrpc/auth.h | |||
| @@ -66,7 +66,12 @@ struct rpc_cred_cache { | |||
| 66 | 66 | ||
| 67 | struct rpc_auth { | 67 | struct rpc_auth { |
| 68 | unsigned int au_cslack; /* call cred size estimate */ | 68 | unsigned int au_cslack; /* call cred size estimate */ |
| 69 | unsigned int au_rslack; /* reply verf size guess */ | 69 | /* guess at number of u32's auth adds before |
| 70 | * reply data; normally the verifier size: */ | ||
| 71 | unsigned int au_rslack; | ||
| 72 | /* for gss, used to calculate au_rslack: */ | ||
| 73 | unsigned int au_verfsize; | ||
| 74 | |||
| 70 | unsigned int au_flags; /* various flags */ | 75 | unsigned int au_flags; /* various flags */ |
| 71 | struct rpc_authops * au_ops; /* operations */ | 76 | struct rpc_authops * au_ops; /* operations */ |
| 72 | rpc_authflavor_t au_flavor; /* pseudoflavor (note may | 77 | rpc_authflavor_t au_flavor; /* pseudoflavor (note may |
diff --git a/include/linux/sunrpc/debug.h b/include/linux/sunrpc/debug.h index eadb31e3c198..1a42d902bc11 100644 --- a/include/linux/sunrpc/debug.h +++ b/include/linux/sunrpc/debug.h | |||
| @@ -32,6 +32,7 @@ | |||
| 32 | #define RPCDBG_AUTH 0x0010 | 32 | #define RPCDBG_AUTH 0x0010 |
| 33 | #define RPCDBG_PMAP 0x0020 | 33 | #define RPCDBG_PMAP 0x0020 |
| 34 | #define RPCDBG_SCHED 0x0040 | 34 | #define RPCDBG_SCHED 0x0040 |
| 35 | #define RPCDBG_TRANS 0x0080 | ||
| 35 | #define RPCDBG_SVCSOCK 0x0100 | 36 | #define RPCDBG_SVCSOCK 0x0100 |
| 36 | #define RPCDBG_SVCDSP 0x0200 | 37 | #define RPCDBG_SVCDSP 0x0200 |
| 37 | #define RPCDBG_MISC 0x0400 | 38 | #define RPCDBG_MISC 0x0400 |
| @@ -94,6 +95,8 @@ enum { | |||
| 94 | CTL_NLMDEBUG, | 95 | CTL_NLMDEBUG, |
| 95 | CTL_SLOTTABLE_UDP, | 96 | CTL_SLOTTABLE_UDP, |
| 96 | CTL_SLOTTABLE_TCP, | 97 | CTL_SLOTTABLE_TCP, |
| 98 | CTL_MIN_RESVPORT, | ||
| 99 | CTL_MAX_RESVPORT, | ||
| 97 | }; | 100 | }; |
| 98 | 101 | ||
| 99 | #endif /* _LINUX_SUNRPC_DEBUG_H_ */ | 102 | #endif /* _LINUX_SUNRPC_DEBUG_H_ */ |
diff --git a/include/linux/sunrpc/gss_api.h b/include/linux/sunrpc/gss_api.h index 689262f63059..9b8bcf125c18 100644 --- a/include/linux/sunrpc/gss_api.h +++ b/include/linux/sunrpc/gss_api.h | |||
| @@ -40,14 +40,21 @@ int gss_import_sec_context( | |||
| 40 | struct gss_ctx **ctx_id); | 40 | struct gss_ctx **ctx_id); |
| 41 | u32 gss_get_mic( | 41 | u32 gss_get_mic( |
| 42 | struct gss_ctx *ctx_id, | 42 | struct gss_ctx *ctx_id, |
| 43 | u32 qop, | ||
| 44 | struct xdr_buf *message, | 43 | struct xdr_buf *message, |
| 45 | struct xdr_netobj *mic_token); | 44 | struct xdr_netobj *mic_token); |
| 46 | u32 gss_verify_mic( | 45 | u32 gss_verify_mic( |
| 47 | struct gss_ctx *ctx_id, | 46 | struct gss_ctx *ctx_id, |
| 48 | struct xdr_buf *message, | 47 | struct xdr_buf *message, |
| 49 | struct xdr_netobj *mic_token, | 48 | struct xdr_netobj *mic_token); |
| 50 | u32 *qstate); | 49 | u32 gss_wrap( |
| 50 | struct gss_ctx *ctx_id, | ||
| 51 | int offset, | ||
| 52 | struct xdr_buf *outbuf, | ||
| 53 | struct page **inpages); | ||
| 54 | u32 gss_unwrap( | ||
| 55 | struct gss_ctx *ctx_id, | ||
| 56 | int offset, | ||
| 57 | struct xdr_buf *inbuf); | ||
| 51 | u32 gss_delete_sec_context( | 58 | u32 gss_delete_sec_context( |
| 52 | struct gss_ctx **ctx_id); | 59 | struct gss_ctx **ctx_id); |
| 53 | 60 | ||
| @@ -56,7 +63,6 @@ char *gss_service_to_auth_domain_name(struct gss_api_mech *, u32 service); | |||
| 56 | 63 | ||
| 57 | struct pf_desc { | 64 | struct pf_desc { |
| 58 | u32 pseudoflavor; | 65 | u32 pseudoflavor; |
| 59 | u32 qop; | ||
| 60 | u32 service; | 66 | u32 service; |
| 61 | char *name; | 67 | char *name; |
| 62 | char *auth_domain_name; | 68 | char *auth_domain_name; |
| @@ -85,14 +91,21 @@ struct gss_api_ops { | |||
| 85 | struct gss_ctx *ctx_id); | 91 | struct gss_ctx *ctx_id); |
| 86 | u32 (*gss_get_mic)( | 92 | u32 (*gss_get_mic)( |
| 87 | struct gss_ctx *ctx_id, | 93 | struct gss_ctx *ctx_id, |
| 88 | u32 qop, | ||
| 89 | struct xdr_buf *message, | 94 | struct xdr_buf *message, |
| 90 | struct xdr_netobj *mic_token); | 95 | struct xdr_netobj *mic_token); |
| 91 | u32 (*gss_verify_mic)( | 96 | u32 (*gss_verify_mic)( |
| 92 | struct gss_ctx *ctx_id, | 97 | struct gss_ctx *ctx_id, |
| 93 | struct xdr_buf *message, | 98 | struct xdr_buf *message, |
| 94 | struct xdr_netobj *mic_token, | 99 | struct xdr_netobj *mic_token); |
| 95 | u32 *qstate); | 100 | u32 (*gss_wrap)( |
| 101 | struct gss_ctx *ctx_id, | ||
| 102 | int offset, | ||
| 103 | struct xdr_buf *outbuf, | ||
| 104 | struct page **inpages); | ||
| 105 | u32 (*gss_unwrap)( | ||
| 106 | struct gss_ctx *ctx_id, | ||
| 107 | int offset, | ||
| 108 | struct xdr_buf *buf); | ||
| 96 | void (*gss_delete_sec_context)( | 109 | void (*gss_delete_sec_context)( |
| 97 | void *internal_ctx_id); | 110 | void *internal_ctx_id); |
| 98 | }; | 111 | }; |
diff --git a/include/linux/sunrpc/gss_err.h b/include/linux/sunrpc/gss_err.h index 92608a2e574c..a6807867bd21 100644 --- a/include/linux/sunrpc/gss_err.h +++ b/include/linux/sunrpc/gss_err.h | |||
| @@ -66,16 +66,6 @@ typedef unsigned int OM_uint32; | |||
| 66 | 66 | ||
| 67 | 67 | ||
| 68 | /* | 68 | /* |
| 69 | * Define the default Quality of Protection for per-message services. Note | ||
| 70 | * that an implementation that offers multiple levels of QOP may either reserve | ||
| 71 | * a value (for example zero, as assumed here) to mean "default protection", or | ||
| 72 | * alternatively may simply equate GSS_C_QOP_DEFAULT to a specific explicit | ||
| 73 | * QOP value. However a value of 0 should always be interpreted by a GSSAPI | ||
| 74 | * implementation as a request for the default protection level. | ||
| 75 | */ | ||
| 76 | #define GSS_C_QOP_DEFAULT 0 | ||
| 77 | |||
| 78 | /* | ||
| 79 | * Expiration time of 2^32-1 seconds means infinite lifetime for a | 69 | * Expiration time of 2^32-1 seconds means infinite lifetime for a |
| 80 | * credential or security context | 70 | * credential or security context |
| 81 | */ | 71 | */ |
diff --git a/include/linux/sunrpc/gss_krb5.h b/include/linux/sunrpc/gss_krb5.h index ffe31d2eb9ec..2c3601d31045 100644 --- a/include/linux/sunrpc/gss_krb5.h +++ b/include/linux/sunrpc/gss_krb5.h | |||
| @@ -116,18 +116,22 @@ enum seal_alg { | |||
| 116 | 116 | ||
| 117 | s32 | 117 | s32 |
| 118 | make_checksum(s32 cksumtype, char *header, int hdrlen, struct xdr_buf *body, | 118 | make_checksum(s32 cksumtype, char *header, int hdrlen, struct xdr_buf *body, |
| 119 | struct xdr_netobj *cksum); | 119 | int body_offset, struct xdr_netobj *cksum); |
| 120 | |||
| 121 | u32 gss_get_mic_kerberos(struct gss_ctx *, struct xdr_buf *, | ||
| 122 | struct xdr_netobj *); | ||
| 123 | |||
| 124 | u32 gss_verify_mic_kerberos(struct gss_ctx *, struct xdr_buf *, | ||
| 125 | struct xdr_netobj *); | ||
| 120 | 126 | ||
| 121 | u32 | 127 | u32 |
| 122 | krb5_make_token(struct krb5_ctx *context_handle, int qop_req, | 128 | gss_wrap_kerberos(struct gss_ctx *ctx_id, int offset, |
| 123 | struct xdr_buf *input_message_buffer, | 129 | struct xdr_buf *outbuf, struct page **pages); |
| 124 | struct xdr_netobj *output_message_buffer, int toktype); | ||
| 125 | 130 | ||
| 126 | u32 | 131 | u32 |
| 127 | krb5_read_token(struct krb5_ctx *context_handle, | 132 | gss_unwrap_kerberos(struct gss_ctx *ctx_id, int offset, |
| 128 | struct xdr_netobj *input_token_buffer, | 133 | struct xdr_buf *buf); |
| 129 | struct xdr_buf *message_buffer, | 134 | |
| 130 | int *qop_state, int toktype); | ||
| 131 | 135 | ||
| 132 | u32 | 136 | u32 |
| 133 | krb5_encrypt(struct crypto_tfm * key, | 137 | krb5_encrypt(struct crypto_tfm * key, |
| @@ -137,6 +141,13 @@ u32 | |||
| 137 | krb5_decrypt(struct crypto_tfm * key, | 141 | krb5_decrypt(struct crypto_tfm * key, |
| 138 | void *iv, void *in, void *out, int length); | 142 | void *iv, void *in, void *out, int length); |
| 139 | 143 | ||
| 144 | int | ||
| 145 | gss_encrypt_xdr_buf(struct crypto_tfm *tfm, struct xdr_buf *outbuf, int offset, | ||
| 146 | struct page **pages); | ||
| 147 | |||
| 148 | int | ||
| 149 | gss_decrypt_xdr_buf(struct crypto_tfm *tfm, struct xdr_buf *inbuf, int offset); | ||
| 150 | |||
| 140 | s32 | 151 | s32 |
| 141 | krb5_make_seq_num(struct crypto_tfm * key, | 152 | krb5_make_seq_num(struct crypto_tfm * key, |
| 142 | int direction, | 153 | int direction, |
diff --git a/include/linux/sunrpc/gss_spkm3.h b/include/linux/sunrpc/gss_spkm3.h index b5c9968c3c17..0beb2cf00a84 100644 --- a/include/linux/sunrpc/gss_spkm3.h +++ b/include/linux/sunrpc/gss_spkm3.h | |||
| @@ -41,9 +41,9 @@ struct spkm3_ctx { | |||
| 41 | #define SPKM_WRAP_TOK 5 | 41 | #define SPKM_WRAP_TOK 5 |
| 42 | #define SPKM_DEL_TOK 6 | 42 | #define SPKM_DEL_TOK 6 |
| 43 | 43 | ||
| 44 | u32 spkm3_make_token(struct spkm3_ctx *ctx, int qop_req, struct xdr_buf * text, struct xdr_netobj * token, int toktype); | 44 | u32 spkm3_make_token(struct spkm3_ctx *ctx, struct xdr_buf * text, struct xdr_netobj * token, int toktype); |
| 45 | 45 | ||
| 46 | u32 spkm3_read_token(struct spkm3_ctx *ctx, struct xdr_netobj *read_token, struct xdr_buf *message_buffer, int *qop_state, int toktype); | 46 | u32 spkm3_read_token(struct spkm3_ctx *ctx, struct xdr_netobj *read_token, struct xdr_buf *message_buffer, int toktype); |
| 47 | 47 | ||
| 48 | #define CKSUMTYPE_RSA_MD5 0x0007 | 48 | #define CKSUMTYPE_RSA_MD5 0x0007 |
| 49 | 49 | ||
diff --git a/include/linux/sunrpc/msg_prot.h b/include/linux/sunrpc/msg_prot.h index 15f115332389..f43f237360ae 100644 --- a/include/linux/sunrpc/msg_prot.h +++ b/include/linux/sunrpc/msg_prot.h | |||
| @@ -76,5 +76,30 @@ enum rpc_auth_stat { | |||
| 76 | 76 | ||
| 77 | #define RPC_MAXNETNAMELEN 256 | 77 | #define RPC_MAXNETNAMELEN 256 |
| 78 | 78 | ||
| 79 | /* | ||
| 80 | * From RFC 1831: | ||
| 81 | * | ||
| 82 | * "A record is composed of one or more record fragments. A record | ||
| 83 | * fragment is a four-byte header followed by 0 to (2**31) - 1 bytes of | ||
| 84 | * fragment data. The bytes encode an unsigned binary number; as with | ||
| 85 | * XDR integers, the byte order is from highest to lowest. The number | ||
| 86 | * encodes two values -- a boolean which indicates whether the fragment | ||
| 87 | * is the last fragment of the record (bit value 1 implies the fragment | ||
| 88 | * is the last fragment) and a 31-bit unsigned binary value which is the | ||
| 89 | * length in bytes of the fragment's data. The boolean value is the | ||
| 90 | * highest-order bit of the header; the length is the 31 low-order bits. | ||
| 91 | * (Note that this record specification is NOT in XDR standard form!)" | ||
| 92 | * | ||
| 93 | * The Linux RPC client always sends its requests in a single record | ||
| 94 | * fragment, limiting the maximum payload size for stream transports to | ||
| 95 | * 2GB. | ||
| 96 | */ | ||
| 97 | |||
| 98 | typedef u32 rpc_fraghdr; | ||
| 99 | |||
| 100 | #define RPC_LAST_STREAM_FRAGMENT (1U << 31) | ||
| 101 | #define RPC_FRAGMENT_SIZE_MASK (~RPC_LAST_STREAM_FRAGMENT) | ||
| 102 | #define RPC_MAX_FRAGMENT_SIZE ((1U << 31) - 1) | ||
| 103 | |||
| 79 | #endif /* __KERNEL__ */ | 104 | #endif /* __KERNEL__ */ |
| 80 | #endif /* _LINUX_SUNRPC_MSGPROT_H_ */ | 105 | #endif /* _LINUX_SUNRPC_MSGPROT_H_ */ |
diff --git a/include/linux/sunrpc/xdr.h b/include/linux/sunrpc/xdr.h index 23448d0fb5bc..5da968729cf8 100644 --- a/include/linux/sunrpc/xdr.h +++ b/include/linux/sunrpc/xdr.h | |||
| @@ -161,14 +161,10 @@ typedef struct { | |||
| 161 | 161 | ||
| 162 | typedef size_t (*skb_read_actor_t)(skb_reader_t *desc, void *to, size_t len); | 162 | typedef size_t (*skb_read_actor_t)(skb_reader_t *desc, void *to, size_t len); |
| 163 | 163 | ||
| 164 | extern int csum_partial_copy_to_xdr(struct xdr_buf *, struct sk_buff *); | ||
| 164 | extern ssize_t xdr_partial_copy_from_skb(struct xdr_buf *, unsigned int, | 165 | extern ssize_t xdr_partial_copy_from_skb(struct xdr_buf *, unsigned int, |
| 165 | skb_reader_t *, skb_read_actor_t); | 166 | skb_reader_t *, skb_read_actor_t); |
| 166 | 167 | ||
| 167 | struct socket; | ||
| 168 | struct sockaddr; | ||
| 169 | extern int xdr_sendpages(struct socket *, struct sockaddr *, int, | ||
| 170 | struct xdr_buf *, unsigned int, int); | ||
| 171 | |||
| 172 | extern int xdr_encode_word(struct xdr_buf *, int, u32); | 168 | extern int xdr_encode_word(struct xdr_buf *, int, u32); |
| 173 | extern int xdr_decode_word(struct xdr_buf *, int, u32 *); | 169 | extern int xdr_decode_word(struct xdr_buf *, int, u32 *); |
| 174 | 170 | ||
diff --git a/include/linux/sunrpc/xprt.h b/include/linux/sunrpc/xprt.h index e618c1649814..3b8b6e823c70 100644 --- a/include/linux/sunrpc/xprt.h +++ b/include/linux/sunrpc/xprt.h | |||
| @@ -1,5 +1,5 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * linux/include/linux/sunrpc/clnt_xprt.h | 2 | * linux/include/linux/sunrpc/xprt.h |
| 3 | * | 3 | * |
| 4 | * Declarations for the RPC transport interface. | 4 | * Declarations for the RPC transport interface. |
| 5 | * | 5 | * |
| @@ -15,20 +15,6 @@ | |||
| 15 | #include <linux/sunrpc/sched.h> | 15 | #include <linux/sunrpc/sched.h> |
| 16 | #include <linux/sunrpc/xdr.h> | 16 | #include <linux/sunrpc/xdr.h> |
| 17 | 17 | ||
| 18 | /* | ||
| 19 | * The transport code maintains an estimate on the maximum number of out- | ||
| 20 | * standing RPC requests, using a smoothed version of the congestion | ||
| 21 | * avoidance implemented in 44BSD. This is basically the Van Jacobson | ||
| 22 | * congestion algorithm: If a retransmit occurs, the congestion window is | ||
| 23 | * halved; otherwise, it is incremented by 1/cwnd when | ||
| 24 | * | ||
| 25 | * - a reply is received and | ||
| 26 | * - a full number of requests are outstanding and | ||
| 27 | * - the congestion window hasn't been updated recently. | ||
| 28 | * | ||
| 29 | * Upper procedures may check whether a request would block waiting for | ||
| 30 | * a free RPC slot by using the RPC_CONGESTED() macro. | ||
| 31 | */ | ||
| 32 | extern unsigned int xprt_udp_slot_table_entries; | 18 | extern unsigned int xprt_udp_slot_table_entries; |
| 33 | extern unsigned int xprt_tcp_slot_table_entries; | 19 | extern unsigned int xprt_tcp_slot_table_entries; |
| 34 | 20 | ||
| @@ -36,34 +22,23 @@ extern unsigned int xprt_tcp_slot_table_entries; | |||
| 36 | #define RPC_DEF_SLOT_TABLE (16U) | 22 | #define RPC_DEF_SLOT_TABLE (16U) |
| 37 | #define RPC_MAX_SLOT_TABLE (128U) | 23 | #define RPC_MAX_SLOT_TABLE (128U) |
| 38 | 24 | ||
| 39 | #define RPC_CWNDSHIFT (8U) | ||
| 40 | #define RPC_CWNDSCALE (1U << RPC_CWNDSHIFT) | ||
| 41 | #define RPC_INITCWND RPC_CWNDSCALE | ||
| 42 | #define RPC_MAXCWND(xprt) ((xprt)->max_reqs << RPC_CWNDSHIFT) | ||
| 43 | #define RPCXPRT_CONGESTED(xprt) ((xprt)->cong >= (xprt)->cwnd) | ||
| 44 | |||
| 45 | /* Default timeout values */ | ||
| 46 | #define RPC_MAX_UDP_TIMEOUT (60*HZ) | ||
| 47 | #define RPC_MAX_TCP_TIMEOUT (600*HZ) | ||
| 48 | |||
| 49 | /* | 25 | /* |
| 50 | * Wait duration for an RPC TCP connection to be established. Solaris | 26 | * RPC call and reply header size as number of 32bit words (verifier |
| 51 | * NFS over TCP uses 60 seconds, for example, which is in line with how | 27 | * size computed separately) |
| 52 | * long a server takes to reboot. | ||
| 53 | */ | 28 | */ |
| 54 | #define RPC_CONNECT_TIMEOUT (60*HZ) | 29 | #define RPC_CALLHDRSIZE 6 |
| 30 | #define RPC_REPHDRSIZE 4 | ||
| 55 | 31 | ||
| 56 | /* | 32 | /* |
| 57 | * Delay an arbitrary number of seconds before attempting to reconnect | 33 | * Parameters for choosing a free port |
| 58 | * after an error. | ||
| 59 | */ | 34 | */ |
| 60 | #define RPC_REESTABLISH_TIMEOUT (15*HZ) | 35 | extern unsigned int xprt_min_resvport; |
| 36 | extern unsigned int xprt_max_resvport; | ||
| 61 | 37 | ||
| 62 | /* RPC call and reply header size as number of 32bit words (verifier | 38 | #define RPC_MIN_RESVPORT (1U) |
| 63 | * size computed separately) | 39 | #define RPC_MAX_RESVPORT (65535U) |
| 64 | */ | 40 | #define RPC_DEF_MIN_RESVPORT (650U) |
| 65 | #define RPC_CALLHDRSIZE 6 | 41 | #define RPC_DEF_MAX_RESVPORT (1023U) |
| 66 | #define RPC_REPHDRSIZE 4 | ||
| 67 | 42 | ||
| 68 | /* | 43 | /* |
| 69 | * This describes a timeout strategy | 44 | * This describes a timeout strategy |
| @@ -76,6 +51,9 @@ struct rpc_timeout { | |||
| 76 | unsigned char to_exponential; | 51 | unsigned char to_exponential; |
| 77 | }; | 52 | }; |
| 78 | 53 | ||
| 54 | struct rpc_task; | ||
| 55 | struct rpc_xprt; | ||
| 56 | |||
| 79 | /* | 57 | /* |
| 80 | * This describes a complete RPC request | 58 | * This describes a complete RPC request |
| 81 | */ | 59 | */ |
| @@ -95,7 +73,10 @@ struct rpc_rqst { | |||
| 95 | int rq_cong; /* has incremented xprt->cong */ | 73 | int rq_cong; /* has incremented xprt->cong */ |
| 96 | int rq_received; /* receive completed */ | 74 | int rq_received; /* receive completed */ |
| 97 | u32 rq_seqno; /* gss seq no. used on req. */ | 75 | u32 rq_seqno; /* gss seq no. used on req. */ |
| 98 | 76 | int rq_enc_pages_num; | |
| 77 | struct page **rq_enc_pages; /* scratch pages for use by | ||
| 78 | gss privacy code */ | ||
| 79 | void (*rq_release_snd_buf)(struct rpc_rqst *); /* release rq_enc_pages */ | ||
| 99 | struct list_head rq_list; | 80 | struct list_head rq_list; |
| 100 | 81 | ||
| 101 | struct xdr_buf rq_private_buf; /* The receive buffer | 82 | struct xdr_buf rq_private_buf; /* The receive buffer |
| @@ -121,12 +102,21 @@ struct rpc_rqst { | |||
| 121 | #define rq_svec rq_snd_buf.head | 102 | #define rq_svec rq_snd_buf.head |
| 122 | #define rq_slen rq_snd_buf.len | 103 | #define rq_slen rq_snd_buf.len |
| 123 | 104 | ||
| 124 | #define XPRT_LAST_FRAG (1 << 0) | 105 | struct rpc_xprt_ops { |
| 125 | #define XPRT_COPY_RECM (1 << 1) | 106 | void (*set_buffer_size)(struct rpc_xprt *xprt, size_t sndsize, size_t rcvsize); |
| 126 | #define XPRT_COPY_XID (1 << 2) | 107 | int (*reserve_xprt)(struct rpc_task *task); |
| 127 | #define XPRT_COPY_DATA (1 << 3) | 108 | void (*release_xprt)(struct rpc_xprt *xprt, struct rpc_task *task); |
| 109 | void (*connect)(struct rpc_task *task); | ||
| 110 | int (*send_request)(struct rpc_task *task); | ||
| 111 | void (*set_retrans_timeout)(struct rpc_task *task); | ||
| 112 | void (*timer)(struct rpc_task *task); | ||
| 113 | void (*release_request)(struct rpc_task *task); | ||
| 114 | void (*close)(struct rpc_xprt *xprt); | ||
| 115 | void (*destroy)(struct rpc_xprt *xprt); | ||
| 116 | }; | ||
| 128 | 117 | ||
| 129 | struct rpc_xprt { | 118 | struct rpc_xprt { |
| 119 | struct rpc_xprt_ops * ops; /* transport methods */ | ||
| 130 | struct socket * sock; /* BSD socket layer */ | 120 | struct socket * sock; /* BSD socket layer */ |
| 131 | struct sock * inet; /* INET layer */ | 121 | struct sock * inet; /* INET layer */ |
| 132 | 122 | ||
| @@ -137,11 +127,13 @@ struct rpc_xprt { | |||
| 137 | unsigned long cong; /* current congestion */ | 127 | unsigned long cong; /* current congestion */ |
| 138 | unsigned long cwnd; /* congestion window */ | 128 | unsigned long cwnd; /* congestion window */ |
| 139 | 129 | ||
| 140 | unsigned int rcvsize, /* socket receive buffer size */ | 130 | size_t rcvsize, /* transport rcv buffer size */ |
| 141 | sndsize; /* socket send buffer size */ | 131 | sndsize; /* transport send buffer size */ |
| 142 | 132 | ||
| 143 | size_t max_payload; /* largest RPC payload size, | 133 | size_t max_payload; /* largest RPC payload size, |
| 144 | in bytes */ | 134 | in bytes */ |
| 135 | unsigned int tsh_size; /* size of transport specific | ||
| 136 | header */ | ||
| 145 | 137 | ||
| 146 | struct rpc_wait_queue sending; /* requests waiting to send */ | 138 | struct rpc_wait_queue sending; /* requests waiting to send */ |
| 147 | struct rpc_wait_queue resend; /* requests waiting to resend */ | 139 | struct rpc_wait_queue resend; /* requests waiting to resend */ |
| @@ -150,11 +142,9 @@ struct rpc_xprt { | |||
| 150 | struct list_head free; /* free slots */ | 142 | struct list_head free; /* free slots */ |
| 151 | struct rpc_rqst * slot; /* slot table storage */ | 143 | struct rpc_rqst * slot; /* slot table storage */ |
| 152 | unsigned int max_reqs; /* total slots */ | 144 | unsigned int max_reqs; /* total slots */ |
| 153 | unsigned long sockstate; /* Socket state */ | 145 | unsigned long state; /* transport state */ |
| 154 | unsigned char shutdown : 1, /* being shut down */ | 146 | unsigned char shutdown : 1, /* being shut down */ |
| 155 | nocong : 1, /* no congestion control */ | 147 | resvport : 1; /* use a reserved port */ |
| 156 | resvport : 1, /* use a reserved port */ | ||
| 157 | stream : 1; /* TCP */ | ||
| 158 | 148 | ||
| 159 | /* | 149 | /* |
| 160 | * XID | 150 | * XID |
| @@ -171,22 +161,27 @@ struct rpc_xprt { | |||
| 171 | unsigned long tcp_copied, /* copied to request */ | 161 | unsigned long tcp_copied, /* copied to request */ |
| 172 | tcp_flags; | 162 | tcp_flags; |
| 173 | /* | 163 | /* |
| 174 | * Connection of sockets | 164 | * Connection of transports |
| 175 | */ | 165 | */ |
| 176 | struct work_struct sock_connect; | 166 | unsigned long connect_timeout, |
| 167 | bind_timeout, | ||
| 168 | reestablish_timeout; | ||
| 169 | struct work_struct connect_worker; | ||
| 177 | unsigned short port; | 170 | unsigned short port; |
| 171 | |||
| 178 | /* | 172 | /* |
| 179 | * Disconnection of idle sockets | 173 | * Disconnection of idle transports |
| 180 | */ | 174 | */ |
| 181 | struct work_struct task_cleanup; | 175 | struct work_struct task_cleanup; |
| 182 | struct timer_list timer; | 176 | struct timer_list timer; |
| 183 | unsigned long last_used; | 177 | unsigned long last_used, |
| 178 | idle_timeout; | ||
| 184 | 179 | ||
| 185 | /* | 180 | /* |
| 186 | * Send stuff | 181 | * Send stuff |
| 187 | */ | 182 | */ |
| 188 | spinlock_t sock_lock; /* lock socket info */ | 183 | spinlock_t transport_lock; /* lock transport info */ |
| 189 | spinlock_t xprt_lock; /* lock xprt info */ | 184 | spinlock_t reserve_lock; /* lock slot table */ |
| 190 | struct rpc_task * snd_task; /* Task blocked in send */ | 185 | struct rpc_task * snd_task; /* Task blocked in send */ |
| 191 | 186 | ||
| 192 | struct list_head recv; | 187 | struct list_head recv; |
| @@ -195,37 +190,111 @@ struct rpc_xprt { | |||
| 195 | void (*old_data_ready)(struct sock *, int); | 190 | void (*old_data_ready)(struct sock *, int); |
| 196 | void (*old_state_change)(struct sock *); | 191 | void (*old_state_change)(struct sock *); |
| 197 | void (*old_write_space)(struct sock *); | 192 | void (*old_write_space)(struct sock *); |
| 198 | |||
| 199 | wait_queue_head_t cong_wait; | ||
| 200 | }; | 193 | }; |
| 201 | 194 | ||
| 195 | #define XPRT_LAST_FRAG (1 << 0) | ||
| 196 | #define XPRT_COPY_RECM (1 << 1) | ||
| 197 | #define XPRT_COPY_XID (1 << 2) | ||
| 198 | #define XPRT_COPY_DATA (1 << 3) | ||
| 199 | |||
| 202 | #ifdef __KERNEL__ | 200 | #ifdef __KERNEL__ |
| 203 | 201 | ||
| 204 | struct rpc_xprt * xprt_create_proto(int proto, struct sockaddr_in *addr, | 202 | /* |
| 205 | struct rpc_timeout *toparms); | 203 | * Transport operations used by ULPs |
| 206 | int xprt_destroy(struct rpc_xprt *); | 204 | */ |
| 207 | void xprt_set_timeout(struct rpc_timeout *, unsigned int, | 205 | struct rpc_xprt * xprt_create_proto(int proto, struct sockaddr_in *addr, struct rpc_timeout *to); |
| 208 | unsigned long); | 206 | void xprt_set_timeout(struct rpc_timeout *to, unsigned int retr, unsigned long incr); |
| 209 | 207 | ||
| 210 | void xprt_reserve(struct rpc_task *); | 208 | /* |
| 211 | int xprt_prepare_transmit(struct rpc_task *); | 209 | * Generic internal transport functions |
| 212 | void xprt_transmit(struct rpc_task *); | 210 | */ |
| 213 | void xprt_receive(struct rpc_task *); | 211 | void xprt_connect(struct rpc_task *task); |
| 212 | void xprt_reserve(struct rpc_task *task); | ||
| 213 | int xprt_reserve_xprt(struct rpc_task *task); | ||
| 214 | int xprt_reserve_xprt_cong(struct rpc_task *task); | ||
| 215 | int xprt_prepare_transmit(struct rpc_task *task); | ||
| 216 | void xprt_transmit(struct rpc_task *task); | ||
| 217 | void xprt_abort_transmit(struct rpc_task *task); | ||
| 214 | int xprt_adjust_timeout(struct rpc_rqst *req); | 218 | int xprt_adjust_timeout(struct rpc_rqst *req); |
| 215 | void xprt_release(struct rpc_task *); | 219 | void xprt_release_xprt(struct rpc_xprt *xprt, struct rpc_task *task); |
| 216 | void xprt_connect(struct rpc_task *); | 220 | void xprt_release_xprt_cong(struct rpc_xprt *xprt, struct rpc_task *task); |
| 217 | void xprt_sock_setbufsize(struct rpc_xprt *); | 221 | void xprt_release(struct rpc_task *task); |
| 218 | 222 | int xprt_destroy(struct rpc_xprt *xprt); | |
| 219 | #define XPRT_LOCKED 0 | 223 | |
| 220 | #define XPRT_CONNECT 1 | 224 | static inline u32 *xprt_skip_transport_header(struct rpc_xprt *xprt, u32 *p) |
| 221 | #define XPRT_CONNECTING 2 | 225 | { |
| 222 | 226 | return p + xprt->tsh_size; | |
| 223 | #define xprt_connected(xp) (test_bit(XPRT_CONNECT, &(xp)->sockstate)) | 227 | } |
| 224 | #define xprt_set_connected(xp) (set_bit(XPRT_CONNECT, &(xp)->sockstate)) | 228 | |
| 225 | #define xprt_test_and_set_connected(xp) (test_and_set_bit(XPRT_CONNECT, &(xp)->sockstate)) | 229 | /* |
| 226 | #define xprt_test_and_clear_connected(xp) \ | 230 | * Transport switch helper functions |
| 227 | (test_and_clear_bit(XPRT_CONNECT, &(xp)->sockstate)) | 231 | */ |
| 228 | #define xprt_clear_connected(xp) (clear_bit(XPRT_CONNECT, &(xp)->sockstate)) | 232 | void xprt_set_retrans_timeout_def(struct rpc_task *task); |
| 233 | void xprt_set_retrans_timeout_rtt(struct rpc_task *task); | ||
| 234 | void xprt_wake_pending_tasks(struct rpc_xprt *xprt, int status); | ||
| 235 | void xprt_wait_for_buffer_space(struct rpc_task *task); | ||
| 236 | void xprt_write_space(struct rpc_xprt *xprt); | ||
| 237 | void xprt_update_rtt(struct rpc_task *task); | ||
| 238 | void xprt_adjust_cwnd(struct rpc_task *task, int result); | ||
| 239 | struct rpc_rqst * xprt_lookup_rqst(struct rpc_xprt *xprt, u32 xid); | ||
| 240 | void xprt_complete_rqst(struct rpc_task *task, int copied); | ||
| 241 | void xprt_release_rqst_cong(struct rpc_task *task); | ||
| 242 | void xprt_disconnect(struct rpc_xprt *xprt); | ||
| 243 | |||
| 244 | /* | ||
| 245 | * Socket transport setup operations | ||
| 246 | */ | ||
| 247 | int xs_setup_udp(struct rpc_xprt *xprt, struct rpc_timeout *to); | ||
| 248 | int xs_setup_tcp(struct rpc_xprt *xprt, struct rpc_timeout *to); | ||
| 249 | |||
| 250 | /* | ||
| 251 | * Reserved bit positions in xprt->state | ||
| 252 | */ | ||
| 253 | #define XPRT_LOCKED (0) | ||
| 254 | #define XPRT_CONNECTED (1) | ||
| 255 | #define XPRT_CONNECTING (2) | ||
| 256 | |||
| 257 | static inline void xprt_set_connected(struct rpc_xprt *xprt) | ||
| 258 | { | ||
| 259 | set_bit(XPRT_CONNECTED, &xprt->state); | ||
| 260 | } | ||
| 261 | |||
| 262 | static inline void xprt_clear_connected(struct rpc_xprt *xprt) | ||
| 263 | { | ||
| 264 | clear_bit(XPRT_CONNECTED, &xprt->state); | ||
| 265 | } | ||
| 266 | |||
| 267 | static inline int xprt_connected(struct rpc_xprt *xprt) | ||
| 268 | { | ||
| 269 | return test_bit(XPRT_CONNECTED, &xprt->state); | ||
| 270 | } | ||
| 271 | |||
| 272 | static inline int xprt_test_and_set_connected(struct rpc_xprt *xprt) | ||
| 273 | { | ||
| 274 | return test_and_set_bit(XPRT_CONNECTED, &xprt->state); | ||
| 275 | } | ||
| 276 | |||
| 277 | static inline int xprt_test_and_clear_connected(struct rpc_xprt *xprt) | ||
| 278 | { | ||
| 279 | return test_and_clear_bit(XPRT_CONNECTED, &xprt->state); | ||
| 280 | } | ||
| 281 | |||
| 282 | static inline void xprt_clear_connecting(struct rpc_xprt *xprt) | ||
| 283 | { | ||
| 284 | smp_mb__before_clear_bit(); | ||
| 285 | clear_bit(XPRT_CONNECTING, &xprt->state); | ||
| 286 | smp_mb__after_clear_bit(); | ||
| 287 | } | ||
| 288 | |||
| 289 | static inline int xprt_connecting(struct rpc_xprt *xprt) | ||
| 290 | { | ||
| 291 | return test_bit(XPRT_CONNECTING, &xprt->state); | ||
| 292 | } | ||
| 293 | |||
| 294 | static inline int xprt_test_and_set_connecting(struct rpc_xprt *xprt) | ||
| 295 | { | ||
| 296 | return test_and_set_bit(XPRT_CONNECTING, &xprt->state); | ||
| 297 | } | ||
| 229 | 298 | ||
| 230 | #endif /* __KERNEL__*/ | 299 | #endif /* __KERNEL__*/ |
| 231 | 300 | ||
diff --git a/include/linux/suspend.h b/include/linux/suspend.h index ad15a54806d8..ba448c760168 100644 --- a/include/linux/suspend.h +++ b/include/linux/suspend.h | |||
| @@ -71,7 +71,7 @@ void restore_processor_state(void); | |||
| 71 | struct saved_context; | 71 | struct saved_context; |
| 72 | void __save_processor_state(struct saved_context *ctxt); | 72 | void __save_processor_state(struct saved_context *ctxt); |
| 73 | void __restore_processor_state(struct saved_context *ctxt); | 73 | void __restore_processor_state(struct saved_context *ctxt); |
| 74 | extern unsigned long get_usable_page(unsigned gfp_mask); | 74 | extern unsigned long get_usable_page(gfp_t gfp_mask); |
| 75 | extern void free_eaten_memory(void); | 75 | extern void free_eaten_memory(void); |
| 76 | 76 | ||
| 77 | #endif /* _LINUX_SWSUSP_H */ | 77 | #endif /* _LINUX_SWSUSP_H */ |
diff --git a/include/linux/swap.h b/include/linux/swap.h index a7bf1a3b1496..20c975642cab 100644 --- a/include/linux/swap.h +++ b/include/linux/swap.h | |||
| @@ -171,8 +171,8 @@ extern int rotate_reclaimable_page(struct page *page); | |||
| 171 | extern void swap_setup(void); | 171 | extern void swap_setup(void); |
| 172 | 172 | ||
| 173 | /* linux/mm/vmscan.c */ | 173 | /* linux/mm/vmscan.c */ |
| 174 | extern int try_to_free_pages(struct zone **, unsigned int); | 174 | extern int try_to_free_pages(struct zone **, gfp_t); |
| 175 | extern int zone_reclaim(struct zone *, unsigned int, unsigned int); | 175 | extern int zone_reclaim(struct zone *, gfp_t, unsigned int); |
| 176 | extern int shrink_all_memory(int); | 176 | extern int shrink_all_memory(int); |
| 177 | extern int vm_swappiness; | 177 | extern int vm_swappiness; |
| 178 | 178 | ||
diff --git a/include/linux/textsearch.h b/include/linux/textsearch.h index 515046d1b2f4..fc5bb4e91a58 100644 --- a/include/linux/textsearch.h +++ b/include/linux/textsearch.h | |||
| @@ -40,7 +40,7 @@ struct ts_state | |||
| 40 | struct ts_ops | 40 | struct ts_ops |
| 41 | { | 41 | { |
| 42 | const char *name; | 42 | const char *name; |
| 43 | struct ts_config * (*init)(const void *, unsigned int, int); | 43 | struct ts_config * (*init)(const void *, unsigned int, gfp_t); |
| 44 | unsigned int (*find)(struct ts_config *, | 44 | unsigned int (*find)(struct ts_config *, |
| 45 | struct ts_state *); | 45 | struct ts_state *); |
| 46 | void (*destroy)(struct ts_config *); | 46 | void (*destroy)(struct ts_config *); |
| @@ -148,7 +148,7 @@ static inline unsigned int textsearch_get_pattern_len(struct ts_config *conf) | |||
| 148 | extern int textsearch_register(struct ts_ops *); | 148 | extern int textsearch_register(struct ts_ops *); |
| 149 | extern int textsearch_unregister(struct ts_ops *); | 149 | extern int textsearch_unregister(struct ts_ops *); |
| 150 | extern struct ts_config *textsearch_prepare(const char *, const void *, | 150 | extern struct ts_config *textsearch_prepare(const char *, const void *, |
| 151 | unsigned int, int, int); | 151 | unsigned int, gfp_t, int); |
| 152 | extern void textsearch_destroy(struct ts_config *conf); | 152 | extern void textsearch_destroy(struct ts_config *conf); |
| 153 | extern unsigned int textsearch_find_continuous(struct ts_config *, | 153 | extern unsigned int textsearch_find_continuous(struct ts_config *, |
| 154 | struct ts_state *, | 154 | struct ts_state *, |
diff --git a/include/linux/types.h b/include/linux/types.h index 0aee34f9da9f..21b9ce803644 100644 --- a/include/linux/types.h +++ b/include/linux/types.h | |||
| @@ -151,7 +151,12 @@ typedef unsigned long sector_t; | |||
| 151 | */ | 151 | */ |
| 152 | 152 | ||
| 153 | #ifdef __CHECKER__ | 153 | #ifdef __CHECKER__ |
| 154 | #define __bitwise __attribute__((bitwise)) | 154 | #define __bitwise__ __attribute__((bitwise)) |
| 155 | #else | ||
| 156 | #define __bitwise__ | ||
| 157 | #endif | ||
| 158 | #ifdef __CHECK_ENDIAN__ | ||
| 159 | #define __bitwise __bitwise__ | ||
| 155 | #else | 160 | #else |
| 156 | #define __bitwise | 161 | #define __bitwise |
| 157 | #endif | 162 | #endif |
| @@ -166,7 +171,7 @@ typedef __u64 __bitwise __be64; | |||
| 166 | #endif | 171 | #endif |
| 167 | 172 | ||
| 168 | #ifdef __KERNEL__ | 173 | #ifdef __KERNEL__ |
| 169 | typedef unsigned __nocast gfp_t; | 174 | typedef unsigned __bitwise__ gfp_t; |
| 170 | #endif | 175 | #endif |
| 171 | 176 | ||
| 172 | struct ustat { | 177 | struct ustat { |
diff --git a/include/linux/usb.h b/include/linux/usb.h index 4dbe580f9335..8f731e8f2821 100644 --- a/include/linux/usb.h +++ b/include/linux/usb.h | |||
| @@ -933,17 +933,17 @@ static inline void usb_fill_int_urb (struct urb *urb, | |||
| 933 | } | 933 | } |
| 934 | 934 | ||
| 935 | extern void usb_init_urb(struct urb *urb); | 935 | extern void usb_init_urb(struct urb *urb); |
| 936 | extern struct urb *usb_alloc_urb(int iso_packets, unsigned mem_flags); | 936 | extern struct urb *usb_alloc_urb(int iso_packets, gfp_t mem_flags); |
| 937 | extern void usb_free_urb(struct urb *urb); | 937 | extern void usb_free_urb(struct urb *urb); |
| 938 | #define usb_put_urb usb_free_urb | 938 | #define usb_put_urb usb_free_urb |
| 939 | extern struct urb *usb_get_urb(struct urb *urb); | 939 | extern struct urb *usb_get_urb(struct urb *urb); |
| 940 | extern int usb_submit_urb(struct urb *urb, unsigned mem_flags); | 940 | extern int usb_submit_urb(struct urb *urb, gfp_t mem_flags); |
| 941 | extern int usb_unlink_urb(struct urb *urb); | 941 | extern int usb_unlink_urb(struct urb *urb); |
| 942 | extern void usb_kill_urb(struct urb *urb); | 942 | extern void usb_kill_urb(struct urb *urb); |
| 943 | 943 | ||
| 944 | #define HAVE_USB_BUFFERS | 944 | #define HAVE_USB_BUFFERS |
| 945 | void *usb_buffer_alloc (struct usb_device *dev, size_t size, | 945 | void *usb_buffer_alloc (struct usb_device *dev, size_t size, |
| 946 | unsigned mem_flags, dma_addr_t *dma); | 946 | gfp_t mem_flags, dma_addr_t *dma); |
| 947 | void usb_buffer_free (struct usb_device *dev, size_t size, | 947 | void usb_buffer_free (struct usb_device *dev, size_t size, |
| 948 | void *addr, dma_addr_t dma); | 948 | void *addr, dma_addr_t dma); |
| 949 | 949 | ||
| @@ -1050,7 +1050,7 @@ int usb_sg_init ( | |||
| 1050 | struct scatterlist *sg, | 1050 | struct scatterlist *sg, |
| 1051 | int nents, | 1051 | int nents, |
| 1052 | size_t length, | 1052 | size_t length, |
| 1053 | unsigned mem_flags | 1053 | gfp_t mem_flags |
| 1054 | ); | 1054 | ); |
| 1055 | void usb_sg_cancel (struct usb_sg_request *io); | 1055 | void usb_sg_cancel (struct usb_sg_request *io); |
| 1056 | void usb_sg_wait (struct usb_sg_request *io); | 1056 | void usb_sg_wait (struct usb_sg_request *io); |
diff --git a/include/linux/usb_gadget.h b/include/linux/usb_gadget.h index 71e608607324..ff81117eb733 100644 --- a/include/linux/usb_gadget.h +++ b/include/linux/usb_gadget.h | |||
| @@ -107,18 +107,18 @@ struct usb_ep_ops { | |||
| 107 | int (*disable) (struct usb_ep *ep); | 107 | int (*disable) (struct usb_ep *ep); |
| 108 | 108 | ||
| 109 | struct usb_request *(*alloc_request) (struct usb_ep *ep, | 109 | struct usb_request *(*alloc_request) (struct usb_ep *ep, |
| 110 | unsigned gfp_flags); | 110 | gfp_t gfp_flags); |
| 111 | void (*free_request) (struct usb_ep *ep, struct usb_request *req); | 111 | void (*free_request) (struct usb_ep *ep, struct usb_request *req); |
| 112 | 112 | ||
| 113 | void *(*alloc_buffer) (struct usb_ep *ep, unsigned bytes, | 113 | void *(*alloc_buffer) (struct usb_ep *ep, unsigned bytes, |
| 114 | dma_addr_t *dma, unsigned gfp_flags); | 114 | dma_addr_t *dma, gfp_t gfp_flags); |
| 115 | void (*free_buffer) (struct usb_ep *ep, void *buf, dma_addr_t dma, | 115 | void (*free_buffer) (struct usb_ep *ep, void *buf, dma_addr_t dma, |
| 116 | unsigned bytes); | 116 | unsigned bytes); |
| 117 | // NOTE: on 2.6, drivers may also use dma_map() and | 117 | // NOTE: on 2.6, drivers may also use dma_map() and |
| 118 | // dma_sync_single_*() to directly manage dma overhead. | 118 | // dma_sync_single_*() to directly manage dma overhead. |
| 119 | 119 | ||
| 120 | int (*queue) (struct usb_ep *ep, struct usb_request *req, | 120 | int (*queue) (struct usb_ep *ep, struct usb_request *req, |
| 121 | unsigned gfp_flags); | 121 | gfp_t gfp_flags); |
| 122 | int (*dequeue) (struct usb_ep *ep, struct usb_request *req); | 122 | int (*dequeue) (struct usb_ep *ep, struct usb_request *req); |
| 123 | 123 | ||
| 124 | int (*set_halt) (struct usb_ep *ep, int value); | 124 | int (*set_halt) (struct usb_ep *ep, int value); |
| @@ -214,7 +214,7 @@ usb_ep_disable (struct usb_ep *ep) | |||
| 214 | * Returns the request, or null if one could not be allocated. | 214 | * Returns the request, or null if one could not be allocated. |
| 215 | */ | 215 | */ |
| 216 | static inline struct usb_request * | 216 | static inline struct usb_request * |
| 217 | usb_ep_alloc_request (struct usb_ep *ep, unsigned gfp_flags) | 217 | usb_ep_alloc_request (struct usb_ep *ep, gfp_t gfp_flags) |
| 218 | { | 218 | { |
| 219 | return ep->ops->alloc_request (ep, gfp_flags); | 219 | return ep->ops->alloc_request (ep, gfp_flags); |
| 220 | } | 220 | } |
| @@ -254,7 +254,7 @@ usb_ep_free_request (struct usb_ep *ep, struct usb_request *req) | |||
| 254 | */ | 254 | */ |
| 255 | static inline void * | 255 | static inline void * |
| 256 | usb_ep_alloc_buffer (struct usb_ep *ep, unsigned len, dma_addr_t *dma, | 256 | usb_ep_alloc_buffer (struct usb_ep *ep, unsigned len, dma_addr_t *dma, |
| 257 | unsigned gfp_flags) | 257 | gfp_t gfp_flags) |
| 258 | { | 258 | { |
| 259 | return ep->ops->alloc_buffer (ep, len, dma, gfp_flags); | 259 | return ep->ops->alloc_buffer (ep, len, dma, gfp_flags); |
| 260 | } | 260 | } |
| @@ -330,7 +330,7 @@ usb_ep_free_buffer (struct usb_ep *ep, void *buf, dma_addr_t dma, unsigned len) | |||
| 330 | * reported when the usb peripheral is disconnected. | 330 | * reported when the usb peripheral is disconnected. |
| 331 | */ | 331 | */ |
| 332 | static inline int | 332 | static inline int |
| 333 | usb_ep_queue (struct usb_ep *ep, struct usb_request *req, unsigned gfp_flags) | 333 | usb_ep_queue (struct usb_ep *ep, struct usb_request *req, gfp_t gfp_flags) |
| 334 | { | 334 | { |
| 335 | return ep->ops->queue (ep, req, gfp_flags); | 335 | return ep->ops->queue (ep, req, gfp_flags); |
| 336 | } | 336 | } |
diff --git a/include/linux/wanpipe.h b/include/linux/wanpipe.h index 167d956c492b..dae9860091dd 100644 --- a/include/linux/wanpipe.h +++ b/include/linux/wanpipe.h | |||
| @@ -265,15 +265,6 @@ typedef struct { | |||
| 265 | #include <linux/tty_driver.h> | 265 | #include <linux/tty_driver.h> |
| 266 | #include <linux/tty_flip.h> | 266 | #include <linux/tty_flip.h> |
| 267 | 267 | ||
| 268 | |||
| 269 | #define is_digit(ch) (((ch)>=(unsigned)'0'&&(ch)<=(unsigned)'9')?1:0) | ||
| 270 | #define is_alpha(ch) ((((ch)>=(unsigned)'a'&&(ch)<=(unsigned)'z')||\ | ||
| 271 | ((ch)>=(unsigned)'A'&&(ch)<=(unsigned)'Z'))?1:0) | ||
| 272 | #define is_hex_digit(ch) ((((ch)>=(unsigned)'0'&&(ch)<=(unsigned)'9')||\ | ||
| 273 | ((ch)>=(unsigned)'a'&&(ch)<=(unsigned)'f')||\ | ||
| 274 | ((ch)>=(unsigned)'A'&&(ch)<=(unsigned)'F'))?1:0) | ||
| 275 | |||
| 276 | |||
| 277 | /****** Data Structures *****************************************************/ | 268 | /****** Data Structures *****************************************************/ |
| 278 | 269 | ||
| 279 | /* Adapter Data Space. | 270 | /* Adapter Data Space. |
diff --git a/include/net/dst.h b/include/net/dst.h index 4a056a682435..6c196a5baf24 100644 --- a/include/net/dst.h +++ b/include/net/dst.h | |||
| @@ -94,7 +94,6 @@ struct dst_ops | |||
| 94 | struct dst_entry * (*negative_advice)(struct dst_entry *); | 94 | struct dst_entry * (*negative_advice)(struct dst_entry *); |
| 95 | void (*link_failure)(struct sk_buff *); | 95 | void (*link_failure)(struct sk_buff *); |
| 96 | void (*update_pmtu)(struct dst_entry *dst, u32 mtu); | 96 | void (*update_pmtu)(struct dst_entry *dst, u32 mtu); |
| 97 | int (*get_mss)(struct dst_entry *dst, u32 mtu); | ||
| 98 | int entry_size; | 97 | int entry_size; |
| 99 | 98 | ||
| 100 | atomic_t entries; | 99 | atomic_t entries; |
diff --git a/include/net/ieee80211.h b/include/net/ieee80211.h index dc36b1be6745..5e38dca1d082 100644 --- a/include/net/ieee80211.h +++ b/include/net/ieee80211.h | |||
| @@ -11,19 +11,26 @@ | |||
| 11 | * | 11 | * |
| 12 | * Adaption to a generic IEEE 802.11 stack by James Ketrenos | 12 | * Adaption to a generic IEEE 802.11 stack by James Ketrenos |
| 13 | * <jketreno@linux.intel.com> | 13 | * <jketreno@linux.intel.com> |
| 14 | * Copyright (c) 2004, Intel Corporation | 14 | * Copyright (c) 2004-2005, Intel Corporation |
| 15 | * | 15 | * |
| 16 | * This program is free software; you can redistribute it and/or modify | 16 | * This program is free software; you can redistribute it and/or modify |
| 17 | * it under the terms of the GNU General Public License version 2 as | 17 | * it under the terms of the GNU General Public License version 2 as |
| 18 | * published by the Free Software Foundation. See README and COPYING for | 18 | * published by the Free Software Foundation. See README and COPYING for |
| 19 | * more details. | 19 | * more details. |
| 20 | * | ||
| 21 | * API Version History | ||
| 22 | * 1.0.x -- Initial version | ||
| 23 | * 1.1.x -- Added radiotap, QoS, TIM, ieee80211_geo APIs, | ||
| 24 | * various structure changes, and crypto API init method | ||
| 20 | */ | 25 | */ |
| 21 | #ifndef IEEE80211_H | 26 | #ifndef IEEE80211_H |
| 22 | #define IEEE80211_H | 27 | #define IEEE80211_H |
| 23 | #include <linux/if_ether.h> /* ETH_ALEN */ | 28 | #include <linux/if_ether.h> /* ETH_ALEN */ |
| 24 | #include <linux/kernel.h> /* ARRAY_SIZE */ | 29 | #include <linux/kernel.h> /* ARRAY_SIZE */ |
| 25 | #include <linux/wireless.h> | 30 | #include <linux/wireless.h> |
| 26 | 31 | ||
| 32 | #define IEEE80211_VERSION "git-1.1.6" | ||
| 33 | |||
| 27 | #define IEEE80211_DATA_LEN 2304 | 34 | #define IEEE80211_DATA_LEN 2304 |
| 28 | /* Maximum size for the MA-UNITDATA primitive, 802.11 standard section | 35 | /* Maximum size for the MA-UNITDATA primitive, 802.11 standard section |
| 29 | 6.2.1.1.2. | 36 | 6.2.1.1.2. |
| @@ -33,34 +40,13 @@ | |||
| 33 | represents the 2304 bytes of real data, plus a possible 8 bytes of | 40 | represents the 2304 bytes of real data, plus a possible 8 bytes of |
| 34 | WEP IV and ICV. (this interpretation suggested by Ramiro Barreiro) */ | 41 | WEP IV and ICV. (this interpretation suggested by Ramiro Barreiro) */ |
| 35 | 42 | ||
| 36 | |||
| 37 | #define IEEE80211_HLEN 30 | ||
| 38 | #define IEEE80211_FRAME_LEN (IEEE80211_DATA_LEN + IEEE80211_HLEN) | ||
| 39 | |||
| 40 | struct ieee80211_hdr { | ||
| 41 | __le16 frame_ctl; | ||
| 42 | __le16 duration_id; | ||
| 43 | u8 addr1[ETH_ALEN]; | ||
| 44 | u8 addr2[ETH_ALEN]; | ||
| 45 | u8 addr3[ETH_ALEN]; | ||
| 46 | __le16 seq_ctl; | ||
| 47 | u8 addr4[ETH_ALEN]; | ||
| 48 | } __attribute__ ((packed)); | ||
| 49 | |||
| 50 | struct ieee80211_hdr_3addr { | ||
| 51 | __le16 frame_ctl; | ||
| 52 | __le16 duration_id; | ||
| 53 | u8 addr1[ETH_ALEN]; | ||
| 54 | u8 addr2[ETH_ALEN]; | ||
| 55 | u8 addr3[ETH_ALEN]; | ||
| 56 | __le16 seq_ctl; | ||
| 57 | } __attribute__ ((packed)); | ||
| 58 | |||
| 59 | #define IEEE80211_1ADDR_LEN 10 | 43 | #define IEEE80211_1ADDR_LEN 10 |
| 60 | #define IEEE80211_2ADDR_LEN 16 | 44 | #define IEEE80211_2ADDR_LEN 16 |
| 61 | #define IEEE80211_3ADDR_LEN 24 | 45 | #define IEEE80211_3ADDR_LEN 24 |
| 62 | #define IEEE80211_4ADDR_LEN 30 | 46 | #define IEEE80211_4ADDR_LEN 30 |
| 63 | #define IEEE80211_FCS_LEN 4 | 47 | #define IEEE80211_FCS_LEN 4 |
| 48 | #define IEEE80211_HLEN (IEEE80211_4ADDR_LEN) | ||
| 49 | #define IEEE80211_FRAME_LEN (IEEE80211_DATA_LEN + IEEE80211_HLEN) | ||
| 64 | 50 | ||
| 65 | #define MIN_FRAG_THRESHOLD 256U | 51 | #define MIN_FRAG_THRESHOLD 256U |
| 66 | #define MAX_FRAG_THRESHOLD 2346U | 52 | #define MAX_FRAG_THRESHOLD 2346U |
| @@ -113,11 +99,11 @@ struct ieee80211_hdr_3addr { | |||
| 113 | #define IEEE80211_STYPE_CFACK 0x0050 | 99 | #define IEEE80211_STYPE_CFACK 0x0050 |
| 114 | #define IEEE80211_STYPE_CFPOLL 0x0060 | 100 | #define IEEE80211_STYPE_CFPOLL 0x0060 |
| 115 | #define IEEE80211_STYPE_CFACKPOLL 0x0070 | 101 | #define IEEE80211_STYPE_CFACKPOLL 0x0070 |
| 102 | #define IEEE80211_STYPE_QOS_DATA 0x0080 | ||
| 116 | 103 | ||
| 117 | #define IEEE80211_SCTL_FRAG 0x000F | 104 | #define IEEE80211_SCTL_FRAG 0x000F |
| 118 | #define IEEE80211_SCTL_SEQ 0xFFF0 | 105 | #define IEEE80211_SCTL_SEQ 0xFFF0 |
| 119 | 106 | ||
| 120 | |||
| 121 | /* debug macros */ | 107 | /* debug macros */ |
| 122 | 108 | ||
| 123 | #ifdef CONFIG_IEEE80211_DEBUG | 109 | #ifdef CONFIG_IEEE80211_DEBUG |
| @@ -128,8 +114,7 @@ do { if (ieee80211_debug_level & (level)) \ | |||
| 128 | in_interrupt() ? 'I' : 'U', __FUNCTION__ , ## args); } while (0) | 114 | in_interrupt() ? 'I' : 'U', __FUNCTION__ , ## args); } while (0) |
| 129 | #else | 115 | #else |
| 130 | #define IEEE80211_DEBUG(level, fmt, args...) do {} while (0) | 116 | #define IEEE80211_DEBUG(level, fmt, args...) do {} while (0) |
| 131 | #endif /* CONFIG_IEEE80211_DEBUG */ | 117 | #endif /* CONFIG_IEEE80211_DEBUG */ |
| 132 | |||
| 133 | 118 | ||
| 134 | /* debug macros not dependent on CONFIG_IEEE80211_DEBUG */ | 119 | /* debug macros not dependent on CONFIG_IEEE80211_DEBUG */ |
| 135 | 120 | ||
| @@ -140,7 +125,6 @@ do { if (ieee80211_debug_level & (level)) \ | |||
| 140 | * messages. It should never be used for passing essid to user space. */ | 125 | * messages. It should never be used for passing essid to user space. */ |
| 141 | const char *escape_essid(const char *essid, u8 essid_len); | 126 | const char *escape_essid(const char *essid, u8 essid_len); |
| 142 | 127 | ||
| 143 | |||
| 144 | /* | 128 | /* |
| 145 | * To use the debug system: | 129 | * To use the debug system: |
| 146 | * | 130 | * |
| @@ -177,6 +161,7 @@ const char *escape_essid(const char *essid, u8 essid_len); | |||
| 177 | 161 | ||
| 178 | #define IEEE80211_DL_TX (1<<8) | 162 | #define IEEE80211_DL_TX (1<<8) |
| 179 | #define IEEE80211_DL_RX (1<<9) | 163 | #define IEEE80211_DL_RX (1<<9) |
| 164 | #define IEEE80211_DL_QOS (1<<31) | ||
| 180 | 165 | ||
| 181 | #define IEEE80211_ERROR(f, a...) printk(KERN_ERR "ieee80211: " f, ## a) | 166 | #define IEEE80211_ERROR(f, a...) printk(KERN_ERR "ieee80211: " f, ## a) |
| 182 | #define IEEE80211_WARNING(f, a...) printk(KERN_WARNING "ieee80211: " f, ## a) | 167 | #define IEEE80211_WARNING(f, a...) printk(KERN_WARNING "ieee80211: " f, ## a) |
| @@ -190,9 +175,10 @@ const char *escape_essid(const char *essid, u8 essid_len); | |||
| 190 | #define IEEE80211_DEBUG_DROP(f, a...) IEEE80211_DEBUG(IEEE80211_DL_DROP, f, ## a) | 175 | #define IEEE80211_DEBUG_DROP(f, a...) IEEE80211_DEBUG(IEEE80211_DL_DROP, f, ## a) |
| 191 | #define IEEE80211_DEBUG_TX(f, a...) IEEE80211_DEBUG(IEEE80211_DL_TX, f, ## a) | 176 | #define IEEE80211_DEBUG_TX(f, a...) IEEE80211_DEBUG(IEEE80211_DL_TX, f, ## a) |
| 192 | #define IEEE80211_DEBUG_RX(f, a...) IEEE80211_DEBUG(IEEE80211_DL_RX, f, ## a) | 177 | #define IEEE80211_DEBUG_RX(f, a...) IEEE80211_DEBUG(IEEE80211_DL_RX, f, ## a) |
| 178 | #define IEEE80211_DEBUG_QOS(f, a...) IEEE80211_DEBUG(IEEE80211_DL_QOS, f, ## a) | ||
| 193 | #include <linux/netdevice.h> | 179 | #include <linux/netdevice.h> |
| 194 | #include <linux/wireless.h> | 180 | #include <linux/wireless.h> |
| 195 | #include <linux/if_arp.h> /* ARPHRD_ETHER */ | 181 | #include <linux/if_arp.h> /* ARPHRD_ETHER */ |
| 196 | 182 | ||
| 197 | #ifndef WIRELESS_SPY | 183 | #ifndef WIRELESS_SPY |
| 198 | #define WIRELESS_SPY /* enable iwspy support */ | 184 | #define WIRELESS_SPY /* enable iwspy support */ |
| @@ -200,10 +186,10 @@ const char *escape_essid(const char *essid, u8 essid_len); | |||
| 200 | #include <net/iw_handler.h> /* new driver API */ | 186 | #include <net/iw_handler.h> /* new driver API */ |
| 201 | 187 | ||
| 202 | #ifndef ETH_P_PAE | 188 | #ifndef ETH_P_PAE |
| 203 | #define ETH_P_PAE 0x888E /* Port Access Entity (IEEE 802.1X) */ | 189 | #define ETH_P_PAE 0x888E /* Port Access Entity (IEEE 802.1X) */ |
| 204 | #endif /* ETH_P_PAE */ | 190 | #endif /* ETH_P_PAE */ |
| 205 | 191 | ||
| 206 | #define ETH_P_PREAUTH 0x88C7 /* IEEE 802.11i pre-authentication */ | 192 | #define ETH_P_PREAUTH 0x88C7 /* IEEE 802.11i pre-authentication */ |
| 207 | 193 | ||
| 208 | #ifndef ETH_P_80211_RAW | 194 | #ifndef ETH_P_80211_RAW |
| 209 | #define ETH_P_80211_RAW (ETH_P_ECONET + 1) | 195 | #define ETH_P_80211_RAW (ETH_P_ECONET + 1) |
| @@ -215,10 +201,10 @@ const char *escape_essid(const char *essid, u8 essid_len); | |||
| 215 | 201 | ||
| 216 | struct ieee80211_snap_hdr { | 202 | struct ieee80211_snap_hdr { |
| 217 | 203 | ||
| 218 | u8 dsap; /* always 0xAA */ | 204 | u8 dsap; /* always 0xAA */ |
| 219 | u8 ssap; /* always 0xAA */ | 205 | u8 ssap; /* always 0xAA */ |
| 220 | u8 ctrl; /* always 0x03 */ | 206 | u8 ctrl; /* always 0x03 */ |
| 221 | u8 oui[P80211_OUI_LEN]; /* organizational universal id */ | 207 | u8 oui[P80211_OUI_LEN]; /* organizational universal id */ |
| 222 | 208 | ||
| 223 | } __attribute__ ((packed)); | 209 | } __attribute__ ((packed)); |
| 224 | 210 | ||
| @@ -246,8 +232,9 @@ struct ieee80211_snap_hdr { | |||
| 246 | #define WLAN_CAPABILITY_PBCC (1<<6) | 232 | #define WLAN_CAPABILITY_PBCC (1<<6) |
| 247 | #define WLAN_CAPABILITY_CHANNEL_AGILITY (1<<7) | 233 | #define WLAN_CAPABILITY_CHANNEL_AGILITY (1<<7) |
| 248 | #define WLAN_CAPABILITY_SPECTRUM_MGMT (1<<8) | 234 | #define WLAN_CAPABILITY_SPECTRUM_MGMT (1<<8) |
| 235 | #define WLAN_CAPABILITY_QOS (1<<9) | ||
| 249 | #define WLAN_CAPABILITY_SHORT_SLOT_TIME (1<<10) | 236 | #define WLAN_CAPABILITY_SHORT_SLOT_TIME (1<<10) |
| 250 | #define WLAN_CAPABILITY_OSSS_OFDM (1<<13) | 237 | #define WLAN_CAPABILITY_DSSS_OFDM (1<<13) |
| 251 | 238 | ||
| 252 | /* Status codes */ | 239 | /* Status codes */ |
| 253 | enum ieee80211_statuscode { | 240 | enum ieee80211_statuscode { |
| @@ -312,14 +299,12 @@ enum ieee80211_reasoncode { | |||
| 312 | WLAN_REASON_CIPHER_SUITE_REJECTED = 24, | 299 | WLAN_REASON_CIPHER_SUITE_REJECTED = 24, |
| 313 | }; | 300 | }; |
| 314 | 301 | ||
| 315 | |||
| 316 | #define IEEE80211_STATMASK_SIGNAL (1<<0) | 302 | #define IEEE80211_STATMASK_SIGNAL (1<<0) |
| 317 | #define IEEE80211_STATMASK_RSSI (1<<1) | 303 | #define IEEE80211_STATMASK_RSSI (1<<1) |
| 318 | #define IEEE80211_STATMASK_NOISE (1<<2) | 304 | #define IEEE80211_STATMASK_NOISE (1<<2) |
| 319 | #define IEEE80211_STATMASK_RATE (1<<3) | 305 | #define IEEE80211_STATMASK_RATE (1<<3) |
| 320 | #define IEEE80211_STATMASK_WEMASK 0x7 | 306 | #define IEEE80211_STATMASK_WEMASK 0x7 |
| 321 | 307 | ||
| 322 | |||
| 323 | #define IEEE80211_CCK_MODULATION (1<<0) | 308 | #define IEEE80211_CCK_MODULATION (1<<0) |
| 324 | #define IEEE80211_OFDM_MODULATION (1<<1) | 309 | #define IEEE80211_OFDM_MODULATION (1<<1) |
| 325 | 310 | ||
| @@ -377,9 +362,6 @@ enum ieee80211_reasoncode { | |||
| 377 | #define IEEE80211_NUM_CCK_RATES 4 | 362 | #define IEEE80211_NUM_CCK_RATES 4 |
| 378 | #define IEEE80211_OFDM_SHIFT_MASK_A 4 | 363 | #define IEEE80211_OFDM_SHIFT_MASK_A 4 |
| 379 | 364 | ||
| 380 | |||
| 381 | |||
| 382 | |||
| 383 | /* NOTE: This data is for statistical purposes; not all hardware provides this | 365 | /* NOTE: This data is for statistical purposes; not all hardware provides this |
| 384 | * information for frames received. Not setting these will not cause | 366 | * information for frames received. Not setting these will not cause |
| 385 | * any adverse affects. */ | 367 | * any adverse affects. */ |
| @@ -388,7 +370,7 @@ struct ieee80211_rx_stats { | |||
| 388 | s8 rssi; | 370 | s8 rssi; |
| 389 | u8 signal; | 371 | u8 signal; |
| 390 | u8 noise; | 372 | u8 noise; |
| 391 | u16 rate; /* in 100 kbps */ | 373 | u16 rate; /* in 100 kbps */ |
| 392 | u8 received_channel; | 374 | u8 received_channel; |
| 393 | u8 control; | 375 | u8 control; |
| 394 | u8 mask; | 376 | u8 mask; |
| @@ -439,38 +421,44 @@ struct ieee80211_device; | |||
| 439 | 421 | ||
| 440 | #include "ieee80211_crypt.h" | 422 | #include "ieee80211_crypt.h" |
| 441 | 423 | ||
| 442 | #define SEC_KEY_1 (1<<0) | 424 | #define SEC_KEY_1 (1<<0) |
| 443 | #define SEC_KEY_2 (1<<1) | 425 | #define SEC_KEY_2 (1<<1) |
| 444 | #define SEC_KEY_3 (1<<2) | 426 | #define SEC_KEY_3 (1<<2) |
| 445 | #define SEC_KEY_4 (1<<3) | 427 | #define SEC_KEY_4 (1<<3) |
| 446 | #define SEC_ACTIVE_KEY (1<<4) | 428 | #define SEC_ACTIVE_KEY (1<<4) |
| 447 | #define SEC_AUTH_MODE (1<<5) | 429 | #define SEC_AUTH_MODE (1<<5) |
| 448 | #define SEC_UNICAST_GROUP (1<<6) | 430 | #define SEC_UNICAST_GROUP (1<<6) |
| 449 | #define SEC_LEVEL (1<<7) | 431 | #define SEC_LEVEL (1<<7) |
| 450 | #define SEC_ENABLED (1<<8) | 432 | #define SEC_ENABLED (1<<8) |
| 451 | 433 | #define SEC_ENCRYPT (1<<9) | |
| 452 | #define SEC_LEVEL_0 0 /* None */ | 434 | |
| 453 | #define SEC_LEVEL_1 1 /* WEP 40 and 104 bit */ | 435 | #define SEC_LEVEL_0 0 /* None */ |
| 454 | #define SEC_LEVEL_2 2 /* Level 1 + TKIP */ | 436 | #define SEC_LEVEL_1 1 /* WEP 40 and 104 bit */ |
| 455 | #define SEC_LEVEL_2_CKIP 3 /* Level 1 + CKIP */ | 437 | #define SEC_LEVEL_2 2 /* Level 1 + TKIP */ |
| 456 | #define SEC_LEVEL_3 4 /* Level 2 + CCMP */ | 438 | #define SEC_LEVEL_2_CKIP 3 /* Level 1 + CKIP */ |
| 457 | 439 | #define SEC_LEVEL_3 4 /* Level 2 + CCMP */ | |
| 458 | #define WEP_KEYS 4 | 440 | |
| 459 | #define WEP_KEY_LEN 13 | 441 | #define SEC_ALG_NONE 0 |
| 442 | #define SEC_ALG_WEP 1 | ||
| 443 | #define SEC_ALG_TKIP 2 | ||
| 444 | #define SEC_ALG_CCMP 3 | ||
| 445 | |||
| 446 | #define WEP_KEYS 4 | ||
| 447 | #define WEP_KEY_LEN 13 | ||
| 448 | #define SCM_KEY_LEN 32 | ||
| 449 | #define SCM_TEMPORAL_KEY_LENGTH 16 | ||
| 460 | 450 | ||
| 461 | struct ieee80211_security { | 451 | struct ieee80211_security { |
| 462 | u16 active_key:2, | 452 | u16 active_key:2, |
| 463 | enabled:1, | 453 | enabled:1, |
| 464 | auth_mode:2, | 454 | auth_mode:2, auth_algo:4, unicast_uses_group:1, encrypt:1; |
| 465 | auth_algo:4, | 455 | u8 encode_alg[WEP_KEYS]; |
| 466 | unicast_uses_group:1; | ||
| 467 | u8 key_sizes[WEP_KEYS]; | 456 | u8 key_sizes[WEP_KEYS]; |
| 468 | u8 keys[WEP_KEYS][WEP_KEY_LEN]; | 457 | u8 keys[WEP_KEYS][SCM_KEY_LEN]; |
| 469 | u8 level; | 458 | u8 level; |
| 470 | u16 flags; | 459 | u16 flags; |
| 471 | } __attribute__ ((packed)); | 460 | } __attribute__ ((packed)); |
| 472 | 461 | ||
| 473 | |||
| 474 | /* | 462 | /* |
| 475 | 463 | ||
| 476 | 802.11 data frame from AP | 464 | 802.11 data frame from AP |
| @@ -494,7 +482,7 @@ enum ieee80211_mfie { | |||
| 494 | MFIE_TYPE_RATES = 1, | 482 | MFIE_TYPE_RATES = 1, |
| 495 | MFIE_TYPE_FH_SET = 2, | 483 | MFIE_TYPE_FH_SET = 2, |
| 496 | MFIE_TYPE_DS_SET = 3, | 484 | MFIE_TYPE_DS_SET = 3, |
| 497 | MFIE_TYPE_CF_SET = 4, | 485 | MFIE_TYPE_CF_SET = 4, |
| 498 | MFIE_TYPE_TIM = 5, | 486 | MFIE_TYPE_TIM = 5, |
| 499 | MFIE_TYPE_IBSS_SET = 6, | 487 | MFIE_TYPE_IBSS_SET = 6, |
| 500 | MFIE_TYPE_COUNTRY = 7, | 488 | MFIE_TYPE_COUNTRY = 7, |
| @@ -516,11 +504,75 @@ enum ieee80211_mfie { | |||
| 516 | MFIE_TYPE_RSN = 48, | 504 | MFIE_TYPE_RSN = 48, |
| 517 | MFIE_TYPE_RATES_EX = 50, | 505 | MFIE_TYPE_RATES_EX = 50, |
| 518 | MFIE_TYPE_GENERIC = 221, | 506 | MFIE_TYPE_GENERIC = 221, |
| 507 | MFIE_TYPE_QOS_PARAMETER = 222, | ||
| 519 | }; | 508 | }; |
| 520 | 509 | ||
| 521 | struct ieee80211_info_element_hdr { | 510 | /* Minimal header; can be used for passing 802.11 frames with sufficient |
| 522 | u8 id; | 511 | * information to determine what type of underlying data type is actually |
| 523 | u8 len; | 512 | * stored in the data. */ |
| 513 | struct ieee80211_hdr { | ||
| 514 | __le16 frame_ctl; | ||
| 515 | __le16 duration_id; | ||
| 516 | u8 payload[0]; | ||
| 517 | } __attribute__ ((packed)); | ||
| 518 | |||
| 519 | struct ieee80211_hdr_1addr { | ||
| 520 | __le16 frame_ctl; | ||
| 521 | __le16 duration_id; | ||
| 522 | u8 addr1[ETH_ALEN]; | ||
| 523 | u8 payload[0]; | ||
| 524 | } __attribute__ ((packed)); | ||
| 525 | |||
| 526 | struct ieee80211_hdr_2addr { | ||
| 527 | __le16 frame_ctl; | ||
| 528 | __le16 duration_id; | ||
| 529 | u8 addr1[ETH_ALEN]; | ||
| 530 | u8 addr2[ETH_ALEN]; | ||
| 531 | u8 payload[0]; | ||
| 532 | } __attribute__ ((packed)); | ||
| 533 | |||
| 534 | struct ieee80211_hdr_3addr { | ||
| 535 | __le16 frame_ctl; | ||
| 536 | __le16 duration_id; | ||
| 537 | u8 addr1[ETH_ALEN]; | ||
| 538 | u8 addr2[ETH_ALEN]; | ||
| 539 | u8 addr3[ETH_ALEN]; | ||
| 540 | __le16 seq_ctl; | ||
| 541 | u8 payload[0]; | ||
| 542 | } __attribute__ ((packed)); | ||
| 543 | |||
| 544 | struct ieee80211_hdr_4addr { | ||
| 545 | __le16 frame_ctl; | ||
| 546 | __le16 duration_id; | ||
| 547 | u8 addr1[ETH_ALEN]; | ||
| 548 | u8 addr2[ETH_ALEN]; | ||
| 549 | u8 addr3[ETH_ALEN]; | ||
| 550 | __le16 seq_ctl; | ||
| 551 | u8 addr4[ETH_ALEN]; | ||
| 552 | u8 payload[0]; | ||
| 553 | } __attribute__ ((packed)); | ||
| 554 | |||
| 555 | struct ieee80211_hdr_3addrqos { | ||
| 556 | __le16 frame_ctl; | ||
| 557 | __le16 duration_id; | ||
| 558 | u8 addr1[ETH_ALEN]; | ||
| 559 | u8 addr2[ETH_ALEN]; | ||
| 560 | u8 addr3[ETH_ALEN]; | ||
| 561 | __le16 seq_ctl; | ||
| 562 | u8 payload[0]; | ||
| 563 | __le16 qos_ctl; | ||
| 564 | } __attribute__ ((packed)); | ||
| 565 | |||
| 566 | struct ieee80211_hdr_4addrqos { | ||
| 567 | __le16 frame_ctl; | ||
| 568 | __le16 duration_id; | ||
| 569 | u8 addr1[ETH_ALEN]; | ||
| 570 | u8 addr2[ETH_ALEN]; | ||
| 571 | u8 addr3[ETH_ALEN]; | ||
| 572 | __le16 seq_ctl; | ||
| 573 | u8 addr4[ETH_ALEN]; | ||
| 574 | u8 payload[0]; | ||
| 575 | __le16 qos_ctl; | ||
| 524 | } __attribute__ ((packed)); | 576 | } __attribute__ ((packed)); |
| 525 | 577 | ||
| 526 | struct ieee80211_info_element { | 578 | struct ieee80211_info_element { |
| @@ -546,49 +598,77 @@ struct ieee80211_info_element { | |||
| 546 | u16 status; | 598 | u16 status; |
| 547 | */ | 599 | */ |
| 548 | 600 | ||
| 549 | struct ieee80211_authentication { | 601 | struct ieee80211_auth { |
| 550 | struct ieee80211_hdr_3addr header; | 602 | struct ieee80211_hdr_3addr header; |
| 551 | __le16 algorithm; | 603 | __le16 algorithm; |
| 552 | __le16 transaction; | 604 | __le16 transaction; |
| 553 | __le16 status; | 605 | __le16 status; |
| 554 | struct ieee80211_info_element info_element; | 606 | /* challenge */ |
| 607 | struct ieee80211_info_element info_element[0]; | ||
| 555 | } __attribute__ ((packed)); | 608 | } __attribute__ ((packed)); |
| 556 | 609 | ||
| 610 | struct ieee80211_disassoc { | ||
| 611 | struct ieee80211_hdr_3addr header; | ||
| 612 | __le16 reason; | ||
| 613 | } __attribute__ ((packed)); | ||
| 614 | |||
| 615 | /* Alias deauth for disassoc */ | ||
| 616 | #define ieee80211_deauth ieee80211_disassoc | ||
| 617 | |||
| 618 | struct ieee80211_probe_request { | ||
| 619 | struct ieee80211_hdr_3addr header; | ||
| 620 | /* SSID, supported rates */ | ||
| 621 | struct ieee80211_info_element info_element[0]; | ||
| 622 | } __attribute__ ((packed)); | ||
| 557 | 623 | ||
| 558 | struct ieee80211_probe_response { | 624 | struct ieee80211_probe_response { |
| 559 | struct ieee80211_hdr_3addr header; | 625 | struct ieee80211_hdr_3addr header; |
| 560 | u32 time_stamp[2]; | 626 | u32 time_stamp[2]; |
| 561 | __le16 beacon_interval; | 627 | __le16 beacon_interval; |
| 562 | __le16 capability; | 628 | __le16 capability; |
| 563 | struct ieee80211_info_element info_element; | 629 | /* SSID, supported rates, FH params, DS params, |
| 630 | * CF params, IBSS params, TIM (if beacon), RSN */ | ||
| 631 | struct ieee80211_info_element info_element[0]; | ||
| 564 | } __attribute__ ((packed)); | 632 | } __attribute__ ((packed)); |
| 565 | 633 | ||
| 566 | struct ieee80211_assoc_request_frame { | 634 | /* Alias beacon for probe_response */ |
| 635 | #define ieee80211_beacon ieee80211_probe_response | ||
| 636 | |||
| 637 | struct ieee80211_assoc_request { | ||
| 638 | struct ieee80211_hdr_3addr header; | ||
| 639 | __le16 capability; | ||
| 640 | __le16 listen_interval; | ||
| 641 | /* SSID, supported rates, RSN */ | ||
| 642 | struct ieee80211_info_element info_element[0]; | ||
| 643 | } __attribute__ ((packed)); | ||
| 644 | |||
| 645 | struct ieee80211_reassoc_request { | ||
| 646 | struct ieee80211_hdr_3addr header; | ||
| 567 | __le16 capability; | 647 | __le16 capability; |
| 568 | __le16 listen_interval; | 648 | __le16 listen_interval; |
| 569 | u8 current_ap[ETH_ALEN]; | 649 | u8 current_ap[ETH_ALEN]; |
| 570 | struct ieee80211_info_element info_element; | 650 | struct ieee80211_info_element info_element[0]; |
| 571 | } __attribute__ ((packed)); | 651 | } __attribute__ ((packed)); |
| 572 | 652 | ||
| 573 | struct ieee80211_assoc_response_frame { | 653 | struct ieee80211_assoc_response { |
| 574 | struct ieee80211_hdr_3addr header; | 654 | struct ieee80211_hdr_3addr header; |
| 575 | __le16 capability; | 655 | __le16 capability; |
| 576 | __le16 status; | 656 | __le16 status; |
| 577 | __le16 aid; | 657 | __le16 aid; |
| 578 | struct ieee80211_info_element info_element; /* supported rates */ | 658 | /* supported rates */ |
| 659 | struct ieee80211_info_element info_element[0]; | ||
| 579 | } __attribute__ ((packed)); | 660 | } __attribute__ ((packed)); |
| 580 | 661 | ||
| 581 | |||
| 582 | struct ieee80211_txb { | 662 | struct ieee80211_txb { |
| 583 | u8 nr_frags; | 663 | u8 nr_frags; |
| 584 | u8 encrypted; | 664 | u8 encrypted; |
| 585 | u16 reserved; | 665 | u8 rts_included; |
| 586 | u16 frag_size; | 666 | u8 reserved; |
| 587 | u16 payload_size; | 667 | __le16 frag_size; |
| 668 | __le16 payload_size; | ||
| 588 | struct sk_buff *fragments[0]; | 669 | struct sk_buff *fragments[0]; |
| 589 | }; | 670 | }; |
| 590 | 671 | ||
| 591 | |||
| 592 | /* SWEEP TABLE ENTRIES NUMBER */ | 672 | /* SWEEP TABLE ENTRIES NUMBER */ |
| 593 | #define MAX_SWEEP_TAB_ENTRIES 42 | 673 | #define MAX_SWEEP_TAB_ENTRIES 42 |
| 594 | #define MAX_SWEEP_TAB_ENTRIES_PER_PACKET 7 | 674 | #define MAX_SWEEP_TAB_ENTRIES_PER_PACKET 7 |
| @@ -604,9 +684,68 @@ struct ieee80211_txb { | |||
| 604 | 684 | ||
| 605 | #define MAX_WPA_IE_LEN 64 | 685 | #define MAX_WPA_IE_LEN 64 |
| 606 | 686 | ||
| 607 | #define NETWORK_EMPTY_ESSID (1<<0) | 687 | #define NETWORK_EMPTY_ESSID (1<<0) |
| 608 | #define NETWORK_HAS_OFDM (1<<1) | 688 | #define NETWORK_HAS_OFDM (1<<1) |
| 609 | #define NETWORK_HAS_CCK (1<<2) | 689 | #define NETWORK_HAS_CCK (1<<2) |
| 690 | |||
| 691 | /* QoS structure */ | ||
| 692 | #define NETWORK_HAS_QOS_PARAMETERS (1<<3) | ||
| 693 | #define NETWORK_HAS_QOS_INFORMATION (1<<4) | ||
| 694 | #define NETWORK_HAS_QOS_MASK (NETWORK_HAS_QOS_PARAMETERS | NETWORK_HAS_QOS_INFORMATION) | ||
| 695 | |||
| 696 | #define QOS_QUEUE_NUM 4 | ||
| 697 | #define QOS_OUI_LEN 3 | ||
| 698 | #define QOS_OUI_TYPE 2 | ||
| 699 | #define QOS_ELEMENT_ID 221 | ||
| 700 | #define QOS_OUI_INFO_SUB_TYPE 0 | ||
| 701 | #define QOS_OUI_PARAM_SUB_TYPE 1 | ||
| 702 | #define QOS_VERSION_1 1 | ||
| 703 | #define QOS_AIFSN_MIN_VALUE 2 | ||
| 704 | |||
| 705 | struct ieee80211_qos_information_element { | ||
| 706 | u8 elementID; | ||
| 707 | u8 length; | ||
| 708 | u8 qui[QOS_OUI_LEN]; | ||
| 709 | u8 qui_type; | ||
| 710 | u8 qui_subtype; | ||
| 711 | u8 version; | ||
| 712 | u8 ac_info; | ||
| 713 | } __attribute__ ((packed)); | ||
| 714 | |||
| 715 | struct ieee80211_qos_ac_parameter { | ||
| 716 | u8 aci_aifsn; | ||
| 717 | u8 ecw_min_max; | ||
| 718 | __le16 tx_op_limit; | ||
| 719 | } __attribute__ ((packed)); | ||
| 720 | |||
| 721 | struct ieee80211_qos_parameter_info { | ||
| 722 | struct ieee80211_qos_information_element info_element; | ||
| 723 | u8 reserved; | ||
| 724 | struct ieee80211_qos_ac_parameter ac_params_record[QOS_QUEUE_NUM]; | ||
| 725 | } __attribute__ ((packed)); | ||
| 726 | |||
| 727 | struct ieee80211_qos_parameters { | ||
| 728 | __le16 cw_min[QOS_QUEUE_NUM]; | ||
| 729 | __le16 cw_max[QOS_QUEUE_NUM]; | ||
| 730 | u8 aifs[QOS_QUEUE_NUM]; | ||
| 731 | u8 flag[QOS_QUEUE_NUM]; | ||
| 732 | __le16 tx_op_limit[QOS_QUEUE_NUM]; | ||
| 733 | } __attribute__ ((packed)); | ||
| 734 | |||
| 735 | struct ieee80211_qos_data { | ||
| 736 | struct ieee80211_qos_parameters parameters; | ||
| 737 | int active; | ||
| 738 | int supported; | ||
| 739 | u8 param_count; | ||
| 740 | u8 old_param_count; | ||
| 741 | }; | ||
| 742 | |||
| 743 | struct ieee80211_tim_parameters { | ||
| 744 | u8 tim_count; | ||
| 745 | u8 tim_period; | ||
| 746 | } __attribute__ ((packed)); | ||
| 747 | |||
| 748 | /*******************************************************/ | ||
| 610 | 749 | ||
| 611 | struct ieee80211_network { | 750 | struct ieee80211_network { |
| 612 | /* These entries are used to identify a unique network */ | 751 | /* These entries are used to identify a unique network */ |
| @@ -616,6 +755,8 @@ struct ieee80211_network { | |||
| 616 | u8 ssid[IW_ESSID_MAX_SIZE + 1]; | 755 | u8 ssid[IW_ESSID_MAX_SIZE + 1]; |
| 617 | u8 ssid_len; | 756 | u8 ssid_len; |
| 618 | 757 | ||
| 758 | struct ieee80211_qos_data qos_data; | ||
| 759 | |||
| 619 | /* These are network statistics */ | 760 | /* These are network statistics */ |
| 620 | struct ieee80211_rx_stats stats; | 761 | struct ieee80211_rx_stats stats; |
| 621 | u16 capability; | 762 | u16 capability; |
| @@ -631,10 +772,12 @@ struct ieee80211_network { | |||
| 631 | u16 beacon_interval; | 772 | u16 beacon_interval; |
| 632 | u16 listen_interval; | 773 | u16 listen_interval; |
| 633 | u16 atim_window; | 774 | u16 atim_window; |
| 775 | u8 erp_value; | ||
| 634 | u8 wpa_ie[MAX_WPA_IE_LEN]; | 776 | u8 wpa_ie[MAX_WPA_IE_LEN]; |
| 635 | size_t wpa_ie_len; | 777 | size_t wpa_ie_len; |
| 636 | u8 rsn_ie[MAX_WPA_IE_LEN]; | 778 | u8 rsn_ie[MAX_WPA_IE_LEN]; |
| 637 | size_t rsn_ie_len; | 779 | size_t rsn_ie_len; |
| 780 | struct ieee80211_tim_parameters tim; | ||
| 638 | struct list_head list; | 781 | struct list_head list; |
| 639 | }; | 782 | }; |
| 640 | 783 | ||
| @@ -651,17 +794,52 @@ enum ieee80211_state { | |||
| 651 | #define DEFAULT_MAX_SCAN_AGE (15 * HZ) | 794 | #define DEFAULT_MAX_SCAN_AGE (15 * HZ) |
| 652 | #define DEFAULT_FTS 2346 | 795 | #define DEFAULT_FTS 2346 |
| 653 | 796 | ||
| 654 | |||
| 655 | #define CFG_IEEE80211_RESERVE_FCS (1<<0) | 797 | #define CFG_IEEE80211_RESERVE_FCS (1<<0) |
| 656 | #define CFG_IEEE80211_COMPUTE_FCS (1<<1) | 798 | #define CFG_IEEE80211_COMPUTE_FCS (1<<1) |
| 799 | #define CFG_IEEE80211_RTS (1<<2) | ||
| 800 | |||
| 801 | #define IEEE80211_24GHZ_MIN_CHANNEL 1 | ||
| 802 | #define IEEE80211_24GHZ_MAX_CHANNEL 14 | ||
| 803 | #define IEEE80211_24GHZ_CHANNELS 14 | ||
| 804 | |||
| 805 | #define IEEE80211_52GHZ_MIN_CHANNEL 36 | ||
| 806 | #define IEEE80211_52GHZ_MAX_CHANNEL 165 | ||
| 807 | #define IEEE80211_52GHZ_CHANNELS 32 | ||
| 808 | |||
| 809 | enum { | ||
| 810 | IEEE80211_CH_PASSIVE_ONLY = (1 << 0), | ||
| 811 | IEEE80211_CH_B_ONLY = (1 << 2), | ||
| 812 | IEEE80211_CH_NO_IBSS = (1 << 3), | ||
| 813 | IEEE80211_CH_UNIFORM_SPREADING = (1 << 4), | ||
| 814 | IEEE80211_CH_RADAR_DETECT = (1 << 5), | ||
| 815 | IEEE80211_CH_INVALID = (1 << 6), | ||
| 816 | }; | ||
| 817 | |||
| 818 | struct ieee80211_channel { | ||
| 819 | u32 freq; | ||
| 820 | u8 channel; | ||
| 821 | u8 flags; | ||
| 822 | u8 max_power; | ||
| 823 | }; | ||
| 824 | |||
| 825 | struct ieee80211_geo { | ||
| 826 | u8 name[4]; | ||
| 827 | u8 bg_channels; | ||
| 828 | u8 a_channels; | ||
| 829 | struct ieee80211_channel bg[IEEE80211_24GHZ_CHANNELS]; | ||
| 830 | struct ieee80211_channel a[IEEE80211_52GHZ_CHANNELS]; | ||
| 831 | }; | ||
| 657 | 832 | ||
| 658 | struct ieee80211_device { | 833 | struct ieee80211_device { |
| 659 | struct net_device *dev; | 834 | struct net_device *dev; |
| 835 | struct ieee80211_security sec; | ||
| 660 | 836 | ||
| 661 | /* Bookkeeping structures */ | 837 | /* Bookkeeping structures */ |
| 662 | struct net_device_stats stats; | 838 | struct net_device_stats stats; |
| 663 | struct ieee80211_stats ieee_stats; | 839 | struct ieee80211_stats ieee_stats; |
| 664 | 840 | ||
| 841 | struct ieee80211_geo geo; | ||
| 842 | |||
| 665 | /* Probe / Beacon management */ | 843 | /* Probe / Beacon management */ |
| 666 | struct list_head network_free_list; | 844 | struct list_head network_free_list; |
| 667 | struct list_head network_list; | 845 | struct list_head network_list; |
| @@ -669,62 +847,102 @@ struct ieee80211_device { | |||
| 669 | int scans; | 847 | int scans; |
| 670 | int scan_age; | 848 | int scan_age; |
| 671 | 849 | ||
| 672 | int iw_mode; /* operating mode (IW_MODE_*) */ | 850 | int iw_mode; /* operating mode (IW_MODE_*) */ |
| 851 | struct iw_spy_data spy_data; /* iwspy support */ | ||
| 673 | 852 | ||
| 674 | spinlock_t lock; | 853 | spinlock_t lock; |
| 675 | 854 | ||
| 676 | int tx_headroom; /* Set to size of any additional room needed at front | 855 | int tx_headroom; /* Set to size of any additional room needed at front |
| 677 | * of allocated Tx SKBs */ | 856 | * of allocated Tx SKBs */ |
| 678 | u32 config; | 857 | u32 config; |
| 679 | 858 | ||
| 680 | /* WEP and other encryption related settings at the device level */ | 859 | /* WEP and other encryption related settings at the device level */ |
| 681 | int open_wep; /* Set to 1 to allow unencrypted frames */ | 860 | int open_wep; /* Set to 1 to allow unencrypted frames */ |
| 682 | 861 | ||
| 683 | int reset_on_keychange; /* Set to 1 if the HW needs to be reset on | 862 | int reset_on_keychange; /* Set to 1 if the HW needs to be reset on |
| 684 | * WEP key changes */ | 863 | * WEP key changes */ |
| 685 | 864 | ||
| 686 | /* If the host performs {en,de}cryption, then set to 1 */ | 865 | /* If the host performs {en,de}cryption, then set to 1 */ |
| 687 | int host_encrypt; | 866 | int host_encrypt; |
| 867 | int host_encrypt_msdu; | ||
| 688 | int host_decrypt; | 868 | int host_decrypt; |
| 689 | int ieee802_1x; /* is IEEE 802.1X used */ | 869 | /* host performs multicast decryption */ |
| 870 | int host_mc_decrypt; | ||
| 871 | |||
| 872 | int host_open_frag; | ||
| 873 | int host_build_iv; | ||
| 874 | int ieee802_1x; /* is IEEE 802.1X used */ | ||
| 690 | 875 | ||
| 691 | /* WPA data */ | 876 | /* WPA data */ |
| 692 | int wpa_enabled; | 877 | int wpa_enabled; |
| 693 | int drop_unencrypted; | 878 | int drop_unencrypted; |
| 694 | int tkip_countermeasures; | ||
| 695 | int privacy_invoked; | 879 | int privacy_invoked; |
| 696 | size_t wpa_ie_len; | 880 | size_t wpa_ie_len; |
| 697 | u8 *wpa_ie; | 881 | u8 *wpa_ie; |
| 698 | 882 | ||
| 699 | struct list_head crypt_deinit_list; | 883 | struct list_head crypt_deinit_list; |
| 700 | struct ieee80211_crypt_data *crypt[WEP_KEYS]; | 884 | struct ieee80211_crypt_data *crypt[WEP_KEYS]; |
| 701 | int tx_keyidx; /* default TX key index (crypt[tx_keyidx]) */ | 885 | int tx_keyidx; /* default TX key index (crypt[tx_keyidx]) */ |
| 702 | struct timer_list crypt_deinit_timer; | 886 | struct timer_list crypt_deinit_timer; |
| 887 | int crypt_quiesced; | ||
| 703 | 888 | ||
| 704 | int bcrx_sta_key; /* use individual keys to override default keys even | 889 | int bcrx_sta_key; /* use individual keys to override default keys even |
| 705 | * with RX of broad/multicast frames */ | 890 | * with RX of broad/multicast frames */ |
| 706 | 891 | ||
| 707 | /* Fragmentation structures */ | 892 | /* Fragmentation structures */ |
| 708 | struct ieee80211_frag_entry frag_cache[IEEE80211_FRAG_CACHE_LEN]; | 893 | struct ieee80211_frag_entry frag_cache[IEEE80211_FRAG_CACHE_LEN]; |
| 709 | unsigned int frag_next_idx; | 894 | unsigned int frag_next_idx; |
| 710 | u16 fts; /* Fragmentation Threshold */ | 895 | u16 fts; /* Fragmentation Threshold */ |
| 896 | u16 rts; /* RTS threshold */ | ||
| 711 | 897 | ||
| 712 | /* Association info */ | 898 | /* Association info */ |
| 713 | u8 bssid[ETH_ALEN]; | 899 | u8 bssid[ETH_ALEN]; |
| 714 | 900 | ||
| 715 | enum ieee80211_state state; | 901 | enum ieee80211_state state; |
| 716 | 902 | ||
| 717 | int mode; /* A, B, G */ | 903 | int mode; /* A, B, G */ |
| 718 | int modulation; /* CCK, OFDM */ | 904 | int modulation; /* CCK, OFDM */ |
| 719 | int freq_band; /* 2.4Ghz, 5.2Ghz, Mixed */ | 905 | int freq_band; /* 2.4Ghz, 5.2Ghz, Mixed */ |
| 720 | int abg_ture; /* ABG flag */ | 906 | int abg_true; /* ABG flag */ |
| 907 | |||
| 908 | int perfect_rssi; | ||
| 909 | int worst_rssi; | ||
| 721 | 910 | ||
| 722 | /* Callback functions */ | 911 | /* Callback functions */ |
| 723 | void (*set_security)(struct net_device *dev, | 912 | void (*set_security) (struct net_device * dev, |
| 724 | struct ieee80211_security *sec); | 913 | struct ieee80211_security * sec); |
| 725 | int (*hard_start_xmit)(struct ieee80211_txb *txb, | 914 | int (*hard_start_xmit) (struct ieee80211_txb * txb, |
| 726 | struct net_device *dev); | 915 | struct net_device * dev, int pri); |
| 727 | int (*reset_port)(struct net_device *dev); | 916 | int (*reset_port) (struct net_device * dev); |
| 917 | int (*is_queue_full) (struct net_device * dev, int pri); | ||
| 918 | |||
| 919 | int (*handle_management) (struct net_device * dev, | ||
| 920 | struct ieee80211_network * network, u16 type); | ||
| 921 | |||
| 922 | /* Typical STA methods */ | ||
| 923 | int (*handle_auth) (struct net_device * dev, | ||
| 924 | struct ieee80211_auth * auth); | ||
| 925 | int (*handle_deauth) (struct net_device * dev, | ||
| 926 | struct ieee80211_auth * auth); | ||
| 927 | int (*handle_disassoc) (struct net_device * dev, | ||
| 928 | struct ieee80211_disassoc * assoc); | ||
| 929 | int (*handle_beacon) (struct net_device * dev, | ||
| 930 | struct ieee80211_beacon * beacon, | ||
| 931 | struct ieee80211_network * network); | ||
| 932 | int (*handle_probe_response) (struct net_device * dev, | ||
| 933 | struct ieee80211_probe_response * resp, | ||
| 934 | struct ieee80211_network * network); | ||
| 935 | int (*handle_probe_request) (struct net_device * dev, | ||
| 936 | struct ieee80211_probe_request * req, | ||
| 937 | struct ieee80211_rx_stats * stats); | ||
| 938 | int (*handle_assoc_response) (struct net_device * dev, | ||
| 939 | struct ieee80211_assoc_response * resp, | ||
| 940 | struct ieee80211_network * network); | ||
| 941 | |||
| 942 | /* Typical AP methods */ | ||
| 943 | int (*handle_assoc_request) (struct net_device * dev); | ||
| 944 | int (*handle_reassoc_request) (struct net_device * dev, | ||
| 945 | struct ieee80211_reassoc_request * req); | ||
| 728 | 946 | ||
| 729 | /* This must be the last item so that it points to the data | 947 | /* This must be the last item so that it points to the data |
| 730 | * allocated beyond this structure by alloc_ieee80211 */ | 948 | * allocated beyond this structure by alloc_ieee80211 */ |
| @@ -736,12 +954,12 @@ struct ieee80211_device { | |||
| 736 | #define IEEE_G (1<<2) | 954 | #define IEEE_G (1<<2) |
| 737 | #define IEEE_MODE_MASK (IEEE_A|IEEE_B|IEEE_G) | 955 | #define IEEE_MODE_MASK (IEEE_A|IEEE_B|IEEE_G) |
| 738 | 956 | ||
| 739 | extern inline void *ieee80211_priv(struct net_device *dev) | 957 | static inline void *ieee80211_priv(struct net_device *dev) |
| 740 | { | 958 | { |
| 741 | return ((struct ieee80211_device *)netdev_priv(dev))->priv; | 959 | return ((struct ieee80211_device *)netdev_priv(dev))->priv; |
| 742 | } | 960 | } |
| 743 | 961 | ||
| 744 | extern inline int ieee80211_is_empty_essid(const char *essid, int essid_len) | 962 | static inline int ieee80211_is_empty_essid(const char *essid, int essid_len) |
| 745 | { | 963 | { |
| 746 | /* Single white space is for Linksys APs */ | 964 | /* Single white space is for Linksys APs */ |
| 747 | if (essid_len == 1 && essid[0] == ' ') | 965 | if (essid_len == 1 && essid[0] == ' ') |
| @@ -757,7 +975,8 @@ extern inline int ieee80211_is_empty_essid(const char *essid, int essid_len) | |||
| 757 | return 1; | 975 | return 1; |
| 758 | } | 976 | } |
| 759 | 977 | ||
| 760 | extern inline int ieee80211_is_valid_mode(struct ieee80211_device *ieee, int mode) | 978 | static inline int ieee80211_is_valid_mode(struct ieee80211_device *ieee, |
| 979 | int mode) | ||
| 761 | { | 980 | { |
| 762 | /* | 981 | /* |
| 763 | * It is possible for both access points and our device to support | 982 | * It is possible for both access points and our device to support |
| @@ -783,14 +1002,17 @@ extern inline int ieee80211_is_valid_mode(struct ieee80211_device *ieee, int mod | |||
| 783 | return 0; | 1002 | return 0; |
| 784 | } | 1003 | } |
| 785 | 1004 | ||
| 786 | extern inline int ieee80211_get_hdrlen(u16 fc) | 1005 | static inline int ieee80211_get_hdrlen(u16 fc) |
| 787 | { | 1006 | { |
| 788 | int hdrlen = IEEE80211_3ADDR_LEN; | 1007 | int hdrlen = IEEE80211_3ADDR_LEN; |
| 1008 | u16 stype = WLAN_FC_GET_STYPE(fc); | ||
| 789 | 1009 | ||
| 790 | switch (WLAN_FC_GET_TYPE(fc)) { | 1010 | switch (WLAN_FC_GET_TYPE(fc)) { |
| 791 | case IEEE80211_FTYPE_DATA: | 1011 | case IEEE80211_FTYPE_DATA: |
| 792 | if ((fc & IEEE80211_FCTL_FROMDS) && (fc & IEEE80211_FCTL_TODS)) | 1012 | if ((fc & IEEE80211_FCTL_FROMDS) && (fc & IEEE80211_FCTL_TODS)) |
| 793 | hdrlen = IEEE80211_4ADDR_LEN; | 1013 | hdrlen = IEEE80211_4ADDR_LEN; |
| 1014 | if (stype & IEEE80211_STYPE_QOS_DATA) | ||
| 1015 | hdrlen += 2; | ||
| 794 | break; | 1016 | break; |
| 795 | case IEEE80211_FTYPE_CTL: | 1017 | case IEEE80211_FTYPE_CTL: |
| 796 | switch (WLAN_FC_GET_STYPE(fc)) { | 1018 | switch (WLAN_FC_GET_STYPE(fc)) { |
| @@ -808,7 +1030,48 @@ extern inline int ieee80211_get_hdrlen(u16 fc) | |||
| 808 | return hdrlen; | 1030 | return hdrlen; |
| 809 | } | 1031 | } |
| 810 | 1032 | ||
| 1033 | static inline u8 *ieee80211_get_payload(struct ieee80211_hdr *hdr) | ||
| 1034 | { | ||
| 1035 | switch (ieee80211_get_hdrlen(le16_to_cpu(hdr->frame_ctl))) { | ||
| 1036 | case IEEE80211_1ADDR_LEN: | ||
| 1037 | return ((struct ieee80211_hdr_1addr *)hdr)->payload; | ||
| 1038 | case IEEE80211_2ADDR_LEN: | ||
| 1039 | return ((struct ieee80211_hdr_2addr *)hdr)->payload; | ||
| 1040 | case IEEE80211_3ADDR_LEN: | ||
| 1041 | return ((struct ieee80211_hdr_3addr *)hdr)->payload; | ||
| 1042 | case IEEE80211_4ADDR_LEN: | ||
| 1043 | return ((struct ieee80211_hdr_4addr *)hdr)->payload; | ||
| 1044 | } | ||
| 1045 | |||
| 1046 | } | ||
| 1047 | |||
| 1048 | static inline int ieee80211_is_ofdm_rate(u8 rate) | ||
| 1049 | { | ||
| 1050 | switch (rate & ~IEEE80211_BASIC_RATE_MASK) { | ||
| 1051 | case IEEE80211_OFDM_RATE_6MB: | ||
| 1052 | case IEEE80211_OFDM_RATE_9MB: | ||
| 1053 | case IEEE80211_OFDM_RATE_12MB: | ||
| 1054 | case IEEE80211_OFDM_RATE_18MB: | ||
| 1055 | case IEEE80211_OFDM_RATE_24MB: | ||
| 1056 | case IEEE80211_OFDM_RATE_36MB: | ||
| 1057 | case IEEE80211_OFDM_RATE_48MB: | ||
| 1058 | case IEEE80211_OFDM_RATE_54MB: | ||
| 1059 | return 1; | ||
| 1060 | } | ||
| 1061 | return 0; | ||
| 1062 | } | ||
| 811 | 1063 | ||
| 1064 | static inline int ieee80211_is_cck_rate(u8 rate) | ||
| 1065 | { | ||
| 1066 | switch (rate & ~IEEE80211_BASIC_RATE_MASK) { | ||
| 1067 | case IEEE80211_CCK_RATE_1MB: | ||
| 1068 | case IEEE80211_CCK_RATE_2MB: | ||
| 1069 | case IEEE80211_CCK_RATE_5MB: | ||
| 1070 | case IEEE80211_CCK_RATE_11MB: | ||
| 1071 | return 1; | ||
| 1072 | } | ||
| 1073 | return 0; | ||
| 1074 | } | ||
| 812 | 1075 | ||
| 813 | /* ieee80211.c */ | 1076 | /* ieee80211.c */ |
| 814 | extern void free_ieee80211(struct net_device *dev); | 1077 | extern void free_ieee80211(struct net_device *dev); |
| @@ -817,18 +1080,30 @@ extern struct net_device *alloc_ieee80211(int sizeof_priv); | |||
| 817 | extern int ieee80211_set_encryption(struct ieee80211_device *ieee); | 1080 | extern int ieee80211_set_encryption(struct ieee80211_device *ieee); |
| 818 | 1081 | ||
| 819 | /* ieee80211_tx.c */ | 1082 | /* ieee80211_tx.c */ |
| 820 | extern int ieee80211_xmit(struct sk_buff *skb, | 1083 | extern int ieee80211_xmit(struct sk_buff *skb, struct net_device *dev); |
| 821 | struct net_device *dev); | ||
| 822 | extern void ieee80211_txb_free(struct ieee80211_txb *); | 1084 | extern void ieee80211_txb_free(struct ieee80211_txb *); |
| 823 | 1085 | extern int ieee80211_tx_frame(struct ieee80211_device *ieee, | |
| 1086 | struct ieee80211_hdr *frame, int len); | ||
| 824 | 1087 | ||
| 825 | /* ieee80211_rx.c */ | 1088 | /* ieee80211_rx.c */ |
| 826 | extern int ieee80211_rx(struct ieee80211_device *ieee, struct sk_buff *skb, | 1089 | extern int ieee80211_rx(struct ieee80211_device *ieee, struct sk_buff *skb, |
| 827 | struct ieee80211_rx_stats *rx_stats); | 1090 | struct ieee80211_rx_stats *rx_stats); |
| 828 | extern void ieee80211_rx_mgt(struct ieee80211_device *ieee, | 1091 | extern void ieee80211_rx_mgt(struct ieee80211_device *ieee, |
| 829 | struct ieee80211_hdr *header, | 1092 | struct ieee80211_hdr_4addr *header, |
| 830 | struct ieee80211_rx_stats *stats); | 1093 | struct ieee80211_rx_stats *stats); |
| 831 | 1094 | ||
| 1095 | /* ieee80211_geo.c */ | ||
| 1096 | extern const struct ieee80211_geo *ieee80211_get_geo(struct ieee80211_device | ||
| 1097 | *ieee); | ||
| 1098 | extern int ieee80211_set_geo(struct ieee80211_device *ieee, | ||
| 1099 | const struct ieee80211_geo *geo); | ||
| 1100 | |||
| 1101 | extern int ieee80211_is_valid_channel(struct ieee80211_device *ieee, | ||
| 1102 | u8 channel); | ||
| 1103 | extern int ieee80211_channel_to_index(struct ieee80211_device *ieee, | ||
| 1104 | u8 channel); | ||
| 1105 | extern u8 ieee80211_freq_to_channel(struct ieee80211_device *ieee, u32 freq); | ||
| 1106 | |||
| 832 | /* ieee80211_wx.c */ | 1107 | /* ieee80211_wx.c */ |
| 833 | extern int ieee80211_wx_get_scan(struct ieee80211_device *ieee, | 1108 | extern int ieee80211_wx_get_scan(struct ieee80211_device *ieee, |
| 834 | struct iw_request_info *info, | 1109 | struct iw_request_info *info, |
| @@ -839,17 +1114,21 @@ extern int ieee80211_wx_set_encode(struct ieee80211_device *ieee, | |||
| 839 | extern int ieee80211_wx_get_encode(struct ieee80211_device *ieee, | 1114 | extern int ieee80211_wx_get_encode(struct ieee80211_device *ieee, |
| 840 | struct iw_request_info *info, | 1115 | struct iw_request_info *info, |
| 841 | union iwreq_data *wrqu, char *key); | 1116 | union iwreq_data *wrqu, char *key); |
| 842 | 1117 | extern int ieee80211_wx_set_encodeext(struct ieee80211_device *ieee, | |
| 843 | 1118 | struct iw_request_info *info, | |
| 844 | extern inline void ieee80211_increment_scans(struct ieee80211_device *ieee) | 1119 | union iwreq_data *wrqu, char *extra); |
| 1120 | extern int ieee80211_wx_get_encodeext(struct ieee80211_device *ieee, | ||
| 1121 | struct iw_request_info *info, | ||
| 1122 | union iwreq_data *wrqu, char *extra); | ||
| 1123 | |||
| 1124 | static inline void ieee80211_increment_scans(struct ieee80211_device *ieee) | ||
| 845 | { | 1125 | { |
| 846 | ieee->scans++; | 1126 | ieee->scans++; |
| 847 | } | 1127 | } |
| 848 | 1128 | ||
| 849 | extern inline int ieee80211_get_scans(struct ieee80211_device *ieee) | 1129 | static inline int ieee80211_get_scans(struct ieee80211_device *ieee) |
| 850 | { | 1130 | { |
| 851 | return ieee->scans; | 1131 | return ieee->scans; |
| 852 | } | 1132 | } |
| 853 | 1133 | ||
| 854 | 1134 | #endif /* IEEE80211_H */ | |
| 855 | #endif /* IEEE80211_H */ | ||
diff --git a/include/net/ieee80211_crypt.h b/include/net/ieee80211_crypt.h index b58a3bcc0dc0..0a1c2d82ca4b 100644 --- a/include/net/ieee80211_crypt.h +++ b/include/net/ieee80211_crypt.h | |||
| @@ -25,16 +25,22 @@ | |||
| 25 | 25 | ||
| 26 | #include <linux/skbuff.h> | 26 | #include <linux/skbuff.h> |
| 27 | 27 | ||
| 28 | enum { | ||
| 29 | IEEE80211_CRYPTO_TKIP_COUNTERMEASURES = (1 << 0), | ||
| 30 | }; | ||
| 31 | |||
| 28 | struct ieee80211_crypto_ops { | 32 | struct ieee80211_crypto_ops { |
| 29 | const char *name; | 33 | const char *name; |
| 30 | 34 | ||
| 31 | /* init new crypto context (e.g., allocate private data space, | 35 | /* init new crypto context (e.g., allocate private data space, |
| 32 | * select IV, etc.); returns NULL on failure or pointer to allocated | 36 | * select IV, etc.); returns NULL on failure or pointer to allocated |
| 33 | * private data on success */ | 37 | * private data on success */ |
| 34 | void * (*init)(int keyidx); | 38 | void *(*init) (int keyidx); |
| 35 | 39 | ||
| 36 | /* deinitialize crypto context and free allocated private data */ | 40 | /* deinitialize crypto context and free allocated private data */ |
| 37 | void (*deinit)(void *priv); | 41 | void (*deinit) (void *priv); |
| 42 | |||
| 43 | int (*build_iv) (struct sk_buff * skb, int hdr_len, void *priv); | ||
| 38 | 44 | ||
| 39 | /* encrypt/decrypt return < 0 on error or >= 0 on success. The return | 45 | /* encrypt/decrypt return < 0 on error or >= 0 on success. The return |
| 40 | * value from decrypt_mpdu is passed as the keyidx value for | 46 | * value from decrypt_mpdu is passed as the keyidx value for |
| @@ -42,34 +48,39 @@ struct ieee80211_crypto_ops { | |||
| 42 | * encryption; if not, error will be returned; these functions are | 48 | * encryption; if not, error will be returned; these functions are |
| 43 | * called for all MPDUs (i.e., fragments). | 49 | * called for all MPDUs (i.e., fragments). |
| 44 | */ | 50 | */ |
| 45 | int (*encrypt_mpdu)(struct sk_buff *skb, int hdr_len, void *priv); | 51 | int (*encrypt_mpdu) (struct sk_buff * skb, int hdr_len, void *priv); |
| 46 | int (*decrypt_mpdu)(struct sk_buff *skb, int hdr_len, void *priv); | 52 | int (*decrypt_mpdu) (struct sk_buff * skb, int hdr_len, void *priv); |
| 47 | 53 | ||
| 48 | /* These functions are called for full MSDUs, i.e. full frames. | 54 | /* These functions are called for full MSDUs, i.e. full frames. |
| 49 | * These can be NULL if full MSDU operations are not needed. */ | 55 | * These can be NULL if full MSDU operations are not needed. */ |
| 50 | int (*encrypt_msdu)(struct sk_buff *skb, int hdr_len, void *priv); | 56 | int (*encrypt_msdu) (struct sk_buff * skb, int hdr_len, void *priv); |
| 51 | int (*decrypt_msdu)(struct sk_buff *skb, int keyidx, int hdr_len, | 57 | int (*decrypt_msdu) (struct sk_buff * skb, int keyidx, int hdr_len, |
| 52 | void *priv); | 58 | void *priv); |
| 53 | 59 | ||
| 54 | int (*set_key)(void *key, int len, u8 *seq, void *priv); | 60 | int (*set_key) (void *key, int len, u8 * seq, void *priv); |
| 55 | int (*get_key)(void *key, int len, u8 *seq, void *priv); | 61 | int (*get_key) (void *key, int len, u8 * seq, void *priv); |
| 56 | 62 | ||
| 57 | /* procfs handler for printing out key information and possible | 63 | /* procfs handler for printing out key information and possible |
| 58 | * statistics */ | 64 | * statistics */ |
| 59 | char * (*print_stats)(char *p, void *priv); | 65 | char *(*print_stats) (char *p, void *priv); |
| 66 | |||
| 67 | /* Crypto specific flag get/set for configuration settings */ | ||
| 68 | unsigned long (*get_flags) (void *priv); | ||
| 69 | unsigned long (*set_flags) (unsigned long flags, void *priv); | ||
| 60 | 70 | ||
| 61 | /* maximum number of bytes added by encryption; encrypt buf is | 71 | /* maximum number of bytes added by encryption; encrypt buf is |
| 62 | * allocated with extra_prefix_len bytes, copy of in_buf, and | 72 | * allocated with extra_prefix_len bytes, copy of in_buf, and |
| 63 | * extra_postfix_len; encrypt need not use all this space, but | 73 | * extra_postfix_len; encrypt need not use all this space, but |
| 64 | * the result must start at the beginning of the buffer and correct | 74 | * the result must start at the beginning of the buffer and correct |
| 65 | * length must be returned */ | 75 | * length must be returned */ |
| 66 | int extra_prefix_len, extra_postfix_len; | 76 | int extra_mpdu_prefix_len, extra_mpdu_postfix_len; |
| 77 | int extra_msdu_prefix_len, extra_msdu_postfix_len; | ||
| 67 | 78 | ||
| 68 | struct module *owner; | 79 | struct module *owner; |
| 69 | }; | 80 | }; |
| 70 | 81 | ||
| 71 | struct ieee80211_crypt_data { | 82 | struct ieee80211_crypt_data { |
| 72 | struct list_head list; /* delayed deletion list */ | 83 | struct list_head list; /* delayed deletion list */ |
| 73 | struct ieee80211_crypto_ops *ops; | 84 | struct ieee80211_crypto_ops *ops; |
| 74 | void *priv; | 85 | void *priv; |
| 75 | atomic_t refcnt; | 86 | atomic_t refcnt; |
| @@ -77,10 +88,11 @@ struct ieee80211_crypt_data { | |||
| 77 | 88 | ||
| 78 | int ieee80211_register_crypto_ops(struct ieee80211_crypto_ops *ops); | 89 | int ieee80211_register_crypto_ops(struct ieee80211_crypto_ops *ops); |
| 79 | int ieee80211_unregister_crypto_ops(struct ieee80211_crypto_ops *ops); | 90 | int ieee80211_unregister_crypto_ops(struct ieee80211_crypto_ops *ops); |
| 80 | struct ieee80211_crypto_ops * ieee80211_get_crypto_ops(const char *name); | 91 | struct ieee80211_crypto_ops *ieee80211_get_crypto_ops(const char *name); |
| 81 | void ieee80211_crypt_deinit_entries(struct ieee80211_device *, int); | 92 | void ieee80211_crypt_deinit_entries(struct ieee80211_device *, int); |
| 82 | void ieee80211_crypt_deinit_handler(unsigned long); | 93 | void ieee80211_crypt_deinit_handler(unsigned long); |
| 83 | void ieee80211_crypt_delayed_deinit(struct ieee80211_device *ieee, | 94 | void ieee80211_crypt_delayed_deinit(struct ieee80211_device *ieee, |
| 84 | struct ieee80211_crypt_data **crypt); | 95 | struct ieee80211_crypt_data **crypt); |
| 96 | void ieee80211_crypt_quiescing(struct ieee80211_device *ieee); | ||
| 85 | 97 | ||
| 86 | #endif | 98 | #endif |
diff --git a/include/net/ieee80211_radiotap.h b/include/net/ieee80211_radiotap.h new file mode 100644 index 000000000000..429b73892a5f --- /dev/null +++ b/include/net/ieee80211_radiotap.h | |||
| @@ -0,0 +1,231 @@ | |||
| 1 | /* $FreeBSD: src/sys/net80211/ieee80211_radiotap.h,v 1.5 2005/01/22 20:12:05 sam Exp $ */ | ||
| 2 | /* $NetBSD: ieee80211_radiotap.h,v 1.11 2005/06/22 06:16:02 dyoung Exp $ */ | ||
| 3 | |||
| 4 | /*- | ||
| 5 | * Copyright (c) 2003, 2004 David Young. All rights reserved. | ||
| 6 | * | ||
| 7 | * Redistribution and use in source and binary forms, with or without | ||
| 8 | * modification, are permitted provided that the following conditions | ||
| 9 | * are met: | ||
| 10 | * 1. Redistributions of source code must retain the above copyright | ||
| 11 | * notice, this list of conditions and the following disclaimer. | ||
| 12 | * 2. Redistributions in binary form must reproduce the above copyright | ||
| 13 | * notice, this list of conditions and the following disclaimer in the | ||
| 14 | * documentation and/or other materials provided with the distribution. | ||
| 15 | * 3. The name of David Young may not be used to endorse or promote | ||
| 16 | * products derived from this software without specific prior | ||
| 17 | * written permission. | ||
| 18 | * | ||
| 19 | * THIS SOFTWARE IS PROVIDED BY DAVID YOUNG ``AS IS'' AND ANY | ||
| 20 | * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, | ||
| 21 | * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A | ||
| 22 | * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL DAVID | ||
| 23 | * YOUNG BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | ||
| 24 | * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED | ||
| 25 | * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||
| 26 | * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||
| 27 | * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | ||
| 28 | * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY | ||
| 29 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY | ||
| 30 | * OF SUCH DAMAGE. | ||
| 31 | */ | ||
| 32 | |||
| 33 | /* | ||
| 34 | * Modifications to fit into the linux IEEE 802.11 stack, | ||
| 35 | * Mike Kershaw (dragorn@kismetwireless.net) | ||
| 36 | */ | ||
| 37 | |||
| 38 | #ifndef IEEE80211RADIOTAP_H | ||
| 39 | #define IEEE80211RADIOTAP_H | ||
| 40 | |||
| 41 | #include <linux/if_ether.h> | ||
| 42 | #include <linux/kernel.h> | ||
| 43 | |||
| 44 | /* Radiotap header version (from official NetBSD feed) */ | ||
| 45 | #define IEEE80211RADIOTAP_VERSION "1.5" | ||
| 46 | /* Base version of the radiotap packet header data */ | ||
| 47 | #define PKTHDR_RADIOTAP_VERSION 0 | ||
| 48 | |||
| 49 | /* A generic radio capture format is desirable. There is one for | ||
| 50 | * Linux, but it is neither rigidly defined (there were not even | ||
| 51 | * units given for some fields) nor easily extensible. | ||
| 52 | * | ||
| 53 | * I suggest the following extensible radio capture format. It is | ||
| 54 | * based on a bitmap indicating which fields are present. | ||
| 55 | * | ||
| 56 | * I am trying to describe precisely what the application programmer | ||
| 57 | * should expect in the following, and for that reason I tell the | ||
| 58 | * units and origin of each measurement (where it applies), or else I | ||
| 59 | * use sufficiently weaselly language ("is a monotonically nondecreasing | ||
| 60 | * function of...") that I cannot set false expectations for lawyerly | ||
| 61 | * readers. | ||
| 62 | */ | ||
| 63 | |||
| 64 | /* XXX tcpdump/libpcap do not tolerate variable-length headers, | ||
| 65 | * yet, so we pad every radiotap header to 64 bytes. Ugh. | ||
| 66 | */ | ||
| 67 | #define IEEE80211_RADIOTAP_HDRLEN 64 | ||
| 68 | |||
| 69 | /* The radio capture header precedes the 802.11 header. */ | ||
| 70 | struct ieee80211_radiotap_header { | ||
| 71 | u8 it_version; /* Version 0. Only increases | ||
| 72 | * for drastic changes, | ||
| 73 | * introduction of compatible | ||
| 74 | * new fields does not count. | ||
| 75 | */ | ||
| 76 | u8 it_pad; | ||
| 77 | u16 it_len; /* length of the whole | ||
| 78 | * header in bytes, including | ||
| 79 | * it_version, it_pad, | ||
| 80 | * it_len, and data fields. | ||
| 81 | */ | ||
| 82 | u32 it_present; /* A bitmap telling which | ||
| 83 | * fields are present. Set bit 31 | ||
| 84 | * (0x80000000) to extend the | ||
| 85 | * bitmap by another 32 bits. | ||
| 86 | * Additional extensions are made | ||
| 87 | * by setting bit 31. | ||
| 88 | */ | ||
| 89 | }; | ||
| 90 | |||
| 91 | /* Name Data type Units | ||
| 92 | * ---- --------- ----- | ||
| 93 | * | ||
| 94 | * IEEE80211_RADIOTAP_TSFT u64 microseconds | ||
| 95 | * | ||
| 96 | * Value in microseconds of the MAC's 64-bit 802.11 Time | ||
| 97 | * Synchronization Function timer when the first bit of the | ||
| 98 | * MPDU arrived at the MAC. For received frames, only. | ||
| 99 | * | ||
| 100 | * IEEE80211_RADIOTAP_CHANNEL 2 x u16 MHz, bitmap | ||
| 101 | * | ||
| 102 | * Tx/Rx frequency in MHz, followed by flags (see below). | ||
| 103 | * | ||
| 104 | * IEEE80211_RADIOTAP_FHSS u16 see below | ||
| 105 | * | ||
| 106 | * For frequency-hopping radios, the hop set (first byte) | ||
| 107 | * and pattern (second byte). | ||
| 108 | * | ||
| 109 | * IEEE80211_RADIOTAP_RATE u8 500kb/s | ||
| 110 | * | ||
| 111 | * Tx/Rx data rate | ||
| 112 | * | ||
| 113 | * IEEE80211_RADIOTAP_DBM_ANTSIGNAL int8_t decibels from | ||
| 114 | * one milliwatt (dBm) | ||
| 115 | * | ||
| 116 | * RF signal power at the antenna, decibel difference from | ||
| 117 | * one milliwatt. | ||
| 118 | * | ||
| 119 | * IEEE80211_RADIOTAP_DBM_ANTNOISE int8_t decibels from | ||
| 120 | * one milliwatt (dBm) | ||
| 121 | * | ||
| 122 | * RF noise power at the antenna, decibel difference from one | ||
| 123 | * milliwatt. | ||
| 124 | * | ||
| 125 | * IEEE80211_RADIOTAP_DB_ANTSIGNAL u8 decibel (dB) | ||
| 126 | * | ||
| 127 | * RF signal power at the antenna, decibel difference from an | ||
| 128 | * arbitrary, fixed reference. | ||
| 129 | * | ||
| 130 | * IEEE80211_RADIOTAP_DB_ANTNOISE u8 decibel (dB) | ||
| 131 | * | ||
| 132 | * RF noise power at the antenna, decibel difference from an | ||
| 133 | * arbitrary, fixed reference point. | ||
| 134 | * | ||
| 135 | * IEEE80211_RADIOTAP_LOCK_QUALITY u16 unitless | ||
| 136 | * | ||
| 137 | * Quality of Barker code lock. Unitless. Monotonically | ||
| 138 | * nondecreasing with "better" lock strength. Called "Signal | ||
| 139 | * Quality" in datasheets. (Is there a standard way to measure | ||
| 140 | * this?) | ||
| 141 | * | ||
| 142 | * IEEE80211_RADIOTAP_TX_ATTENUATION u16 unitless | ||
| 143 | * | ||
| 144 | * Transmit power expressed as unitless distance from max | ||
| 145 | * power set at factory calibration. 0 is max power. | ||
| 146 | * Monotonically nondecreasing with lower power levels. | ||
| 147 | * | ||
| 148 | * IEEE80211_RADIOTAP_DB_TX_ATTENUATION u16 decibels (dB) | ||
| 149 | * | ||
| 150 | * Transmit power expressed as decibel distance from max power | ||
| 151 | * set at factory calibration. 0 is max power. Monotonically | ||
| 152 | * nondecreasing with lower power levels. | ||
| 153 | * | ||
| 154 | * IEEE80211_RADIOTAP_DBM_TX_POWER int8_t decibels from | ||
| 155 | * one milliwatt (dBm) | ||
| 156 | * | ||
| 157 | * Transmit power expressed as dBm (decibels from a 1 milliwatt | ||
| 158 | * reference). This is the absolute power level measured at | ||
| 159 | * the antenna port. | ||
| 160 | * | ||
| 161 | * IEEE80211_RADIOTAP_FLAGS u8 bitmap | ||
| 162 | * | ||
| 163 | * Properties of transmitted and received frames. See flags | ||
| 164 | * defined below. | ||
| 165 | * | ||
| 166 | * IEEE80211_RADIOTAP_ANTENNA u8 antenna index | ||
| 167 | * | ||
| 168 | * Unitless indication of the Rx/Tx antenna for this packet. | ||
| 169 | * The first antenna is antenna 0. | ||
| 170 | * | ||
| 171 | * IEEE80211_RADIOTAP_FCS u32 data | ||
| 172 | * | ||
| 173 | * FCS from frame in network byte order. | ||
| 174 | */ | ||
| 175 | enum ieee80211_radiotap_type { | ||
| 176 | IEEE80211_RADIOTAP_TSFT = 0, | ||
| 177 | IEEE80211_RADIOTAP_FLAGS = 1, | ||
| 178 | IEEE80211_RADIOTAP_RATE = 2, | ||
| 179 | IEEE80211_RADIOTAP_CHANNEL = 3, | ||
| 180 | IEEE80211_RADIOTAP_FHSS = 4, | ||
| 181 | IEEE80211_RADIOTAP_DBM_ANTSIGNAL = 5, | ||
| 182 | IEEE80211_RADIOTAP_DBM_ANTNOISE = 6, | ||
| 183 | IEEE80211_RADIOTAP_LOCK_QUALITY = 7, | ||
| 184 | IEEE80211_RADIOTAP_TX_ATTENUATION = 8, | ||
| 185 | IEEE80211_RADIOTAP_DB_TX_ATTENUATION = 9, | ||
| 186 | IEEE80211_RADIOTAP_DBM_TX_POWER = 10, | ||
| 187 | IEEE80211_RADIOTAP_ANTENNA = 11, | ||
| 188 | IEEE80211_RADIOTAP_DB_ANTSIGNAL = 12, | ||
| 189 | IEEE80211_RADIOTAP_DB_ANTNOISE = 13, | ||
| 190 | IEEE80211_RADIOTAP_EXT = 31, | ||
| 191 | }; | ||
| 192 | |||
| 193 | /* Channel flags. */ | ||
| 194 | #define IEEE80211_CHAN_TURBO 0x0010 /* Turbo channel */ | ||
| 195 | #define IEEE80211_CHAN_CCK 0x0020 /* CCK channel */ | ||
| 196 | #define IEEE80211_CHAN_OFDM 0x0040 /* OFDM channel */ | ||
| 197 | #define IEEE80211_CHAN_2GHZ 0x0080 /* 2 GHz spectrum channel. */ | ||
| 198 | #define IEEE80211_CHAN_5GHZ 0x0100 /* 5 GHz spectrum channel */ | ||
| 199 | #define IEEE80211_CHAN_PASSIVE 0x0200 /* Only passive scan allowed */ | ||
| 200 | #define IEEE80211_CHAN_DYN 0x0400 /* Dynamic CCK-OFDM channel */ | ||
| 201 | #define IEEE80211_CHAN_GFSK 0x0800 /* GFSK channel (FHSS PHY) */ | ||
| 202 | |||
| 203 | /* For IEEE80211_RADIOTAP_FLAGS */ | ||
| 204 | #define IEEE80211_RADIOTAP_F_CFP 0x01 /* sent/received | ||
| 205 | * during CFP | ||
| 206 | */ | ||
| 207 | #define IEEE80211_RADIOTAP_F_SHORTPRE 0x02 /* sent/received | ||
| 208 | * with short | ||
| 209 | * preamble | ||
| 210 | */ | ||
| 211 | #define IEEE80211_RADIOTAP_F_WEP 0x04 /* sent/received | ||
| 212 | * with WEP encryption | ||
| 213 | */ | ||
| 214 | #define IEEE80211_RADIOTAP_F_FRAG 0x08 /* sent/received | ||
| 215 | * with fragmentation | ||
| 216 | */ | ||
| 217 | #define IEEE80211_RADIOTAP_F_FCS 0x10 /* frame includes FCS */ | ||
| 218 | #define IEEE80211_RADIOTAP_F_DATAPAD 0x20 /* frame has padding between | ||
| 219 | * 802.11 header and payload | ||
| 220 | * (to 32-bit boundary) | ||
| 221 | */ | ||
| 222 | |||
| 223 | /* Ugly macro to convert literal channel numbers into their mhz equivalents | ||
| 224 | * There are certianly some conditions that will break this (like feeding it '30') | ||
| 225 | * but they shouldn't arise since nothing talks on channel 30. */ | ||
| 226 | #define ieee80211chan2mhz(x) \ | ||
| 227 | (((x) <= 14) ? \ | ||
| 228 | (((x) == 14) ? 2484 : ((x) * 5) + 2407) : \ | ||
| 229 | ((x) + 1000) * 5) | ||
| 230 | |||
| 231 | #endif /* IEEE80211_RADIOTAP_H */ | ||
diff --git a/include/net/sock.h b/include/net/sock.h index ecb75526cba0..e0498bd36004 100644 --- a/include/net/sock.h +++ b/include/net/sock.h | |||
| @@ -207,7 +207,7 @@ struct sock { | |||
| 207 | struct sk_buff_head sk_write_queue; | 207 | struct sk_buff_head sk_write_queue; |
| 208 | int sk_wmem_queued; | 208 | int sk_wmem_queued; |
| 209 | int sk_forward_alloc; | 209 | int sk_forward_alloc; |
| 210 | unsigned int sk_allocation; | 210 | gfp_t sk_allocation; |
| 211 | int sk_sndbuf; | 211 | int sk_sndbuf; |
| 212 | int sk_route_caps; | 212 | int sk_route_caps; |
| 213 | unsigned long sk_flags; | 213 | unsigned long sk_flags; |
diff --git a/include/net/syncppp.h b/include/net/syncppp.h index 614cb6ba564e..877efa434700 100644 --- a/include/net/syncppp.h +++ b/include/net/syncppp.h | |||
| @@ -86,7 +86,6 @@ static inline struct sppp *sppp_of(struct net_device *dev) | |||
| 86 | 86 | ||
| 87 | void sppp_attach (struct ppp_device *pd); | 87 | void sppp_attach (struct ppp_device *pd); |
| 88 | void sppp_detach (struct net_device *dev); | 88 | void sppp_detach (struct net_device *dev); |
| 89 | void sppp_input (struct net_device *dev, struct sk_buff *m); | ||
| 90 | int sppp_do_ioctl (struct net_device *dev, struct ifreq *ifr, int cmd); | 89 | int sppp_do_ioctl (struct net_device *dev, struct ifreq *ifr, int cmd); |
| 91 | struct sk_buff *sppp_dequeue (struct net_device *dev); | 90 | struct sk_buff *sppp_dequeue (struct net_device *dev); |
| 92 | int sppp_isempty (struct net_device *dev); | 91 | int sppp_isempty (struct net_device *dev); |
diff --git a/include/scsi/scsi_cmnd.h b/include/scsi/scsi_cmnd.h index bed4b7c9be99..e6b61fab66dd 100644 --- a/include/scsi/scsi_cmnd.h +++ b/include/scsi/scsi_cmnd.h | |||
| @@ -146,7 +146,7 @@ struct scsi_cmnd { | |||
| 146 | #define SCSI_STATE_MLQUEUE 0x100b | 146 | #define SCSI_STATE_MLQUEUE 0x100b |
| 147 | 147 | ||
| 148 | 148 | ||
| 149 | extern struct scsi_cmnd *scsi_get_command(struct scsi_device *, int); | 149 | extern struct scsi_cmnd *scsi_get_command(struct scsi_device *, gfp_t); |
| 150 | extern void scsi_put_command(struct scsi_cmnd *); | 150 | extern void scsi_put_command(struct scsi_cmnd *); |
| 151 | extern void scsi_io_completion(struct scsi_cmnd *, unsigned int, unsigned int); | 151 | extern void scsi_io_completion(struct scsi_cmnd *, unsigned int, unsigned int); |
| 152 | extern void scsi_finish_command(struct scsi_cmnd *cmd); | 152 | extern void scsi_finish_command(struct scsi_cmnd *cmd); |
diff --git a/include/scsi/scsi_request.h b/include/scsi/scsi_request.h index 6a140020d7cb..2539debb7993 100644 --- a/include/scsi/scsi_request.h +++ b/include/scsi/scsi_request.h | |||
| @@ -45,7 +45,7 @@ struct scsi_request { | |||
| 45 | level driver) of this request */ | 45 | level driver) of this request */ |
| 46 | }; | 46 | }; |
| 47 | 47 | ||
| 48 | extern struct scsi_request *scsi_allocate_request(struct scsi_device *, int); | 48 | extern struct scsi_request *scsi_allocate_request(struct scsi_device *, gfp_t); |
| 49 | extern void scsi_release_request(struct scsi_request *); | 49 | extern void scsi_release_request(struct scsi_request *); |
| 50 | extern void scsi_wait_req(struct scsi_request *, const void *cmnd, | 50 | extern void scsi_wait_req(struct scsi_request *, const void *cmnd, |
| 51 | void *buffer, unsigned bufflen, | 51 | void *buffer, unsigned bufflen, |
diff --git a/include/sound/memalloc.h b/include/sound/memalloc.h index 3a2fd2cc9f19..83489c3abbaf 100644 --- a/include/sound/memalloc.h +++ b/include/sound/memalloc.h | |||
| @@ -111,7 +111,7 @@ size_t snd_dma_get_reserved_buf(struct snd_dma_buffer *dmab, unsigned int id); | |||
| 111 | int snd_dma_reserve_buf(struct snd_dma_buffer *dmab, unsigned int id); | 111 | int snd_dma_reserve_buf(struct snd_dma_buffer *dmab, unsigned int id); |
| 112 | 112 | ||
| 113 | /* basic memory allocation functions */ | 113 | /* basic memory allocation functions */ |
| 114 | void *snd_malloc_pages(size_t size, unsigned int gfp_flags); | 114 | void *snd_malloc_pages(size_t size, gfp_t gfp_flags); |
| 115 | void snd_free_pages(void *ptr, size_t size); | 115 | void snd_free_pages(void *ptr, size_t size); |
| 116 | 116 | ||
| 117 | #endif /* __SOUND_MEMALLOC_H */ | 117 | #endif /* __SOUND_MEMALLOC_H */ |
