diff options
143 files changed, 3289 insertions, 831 deletions
| @@ -3241,14 +3241,9 @@ S: 12725 SW Millikan Way, Suite 400 | |||
| 3241 | S: Beaverton, Oregon 97005 | 3241 | S: Beaverton, Oregon 97005 | 
| 3242 | S: USA | 3242 | S: USA | 
| 3243 | 3243 | ||
| 3244 | N: Marcelo W. Tosatti | 3244 | N: Marcelo Tosatti | 
| 3245 | E: marcelo.tosatti@cyclades.com | 3245 | E: marcelo@kvack.org | 
| 3246 | D: Miscellaneous kernel hacker | ||
| 3247 | D: v2.4 kernel maintainer | 3246 | D: v2.4 kernel maintainer | 
| 3248 | D: Current pc300/cyclades maintainer | ||
| 3249 | S: Cyclades Corporation | ||
| 3250 | S: Av Cristovao Colombo, 462. Floresta. | ||
| 3251 | S: Porto Alegre | ||
| 3252 | S: Brazil | 3247 | S: Brazil | 
| 3253 | 3248 | ||
| 3254 | N: Stefan Traby | 3249 | N: Stefan Traby | 
| diff --git a/Documentation/devices.txt b/Documentation/devices.txt index 3c406acd4dfa..b369a8c46a73 100644 --- a/Documentation/devices.txt +++ b/Documentation/devices.txt | |||
| @@ -1721,11 +1721,6 @@ Your cooperation is appreciated. | |||
| 1721 | These devices support the same API as the generic SCSI | 1721 | These devices support the same API as the generic SCSI | 
| 1722 | devices. | 1722 | devices. | 
| 1723 | 1723 | ||
| 1724 | 97 block Packet writing for CD/DVD devices | ||
| 1725 | 0 = /dev/pktcdvd0 First packet-writing module | ||
| 1726 | 1 = /dev/pktcdvd1 Second packet-writing module | ||
| 1727 | ... | ||
| 1728 | |||
| 1729 | 98 char Control and Measurement Device (comedi) | 1724 | 98 char Control and Measurement Device (comedi) | 
| 1730 | 0 = /dev/comedi0 First comedi device | 1725 | 0 = /dev/comedi0 First comedi device | 
| 1731 | 1 = /dev/comedi1 Second comedi device | 1726 | 1 = /dev/comedi1 Second comedi device | 
| diff --git a/Documentation/feature-removal-schedule.txt b/Documentation/feature-removal-schedule.txt index 421bcfff6ad2..43ab119963d5 100644 --- a/Documentation/feature-removal-schedule.txt +++ b/Documentation/feature-removal-schedule.txt | |||
| @@ -57,6 +57,15 @@ Who: Jody McIntyre <scjody@steamballoon.com> | |||
| 57 | 57 | ||
| 58 | --------------------------- | 58 | --------------------------- | 
| 59 | 59 | ||
| 60 | What: sbp2: module parameter "force_inquiry_hack" | ||
| 61 | When: July 2006 | ||
| 62 | Why: Superceded by parameter "workarounds". Both parameters are meant to be | ||
| 63 | used ad-hoc and for single devices only, i.e. not in modprobe.conf, | ||
| 64 | therefore the impact of this feature replacement should be low. | ||
| 65 | Who: Stefan Richter <stefanr@s5r6.in-berlin.de> | ||
| 66 | |||
| 67 | --------------------------- | ||
| 68 | |||
| 60 | What: Video4Linux API 1 ioctls and video_decoder.h from Video devices. | 69 | What: Video4Linux API 1 ioctls and video_decoder.h from Video devices. | 
| 61 | When: July 2006 | 70 | When: July 2006 | 
| 62 | Why: V4L1 AP1 was replaced by V4L2 API. during migration from 2.4 to 2.6 | 71 | Why: V4L1 AP1 was replaced by V4L2 API. during migration from 2.4 to 2.6 | 
| diff --git a/Documentation/memory-barriers.txt b/Documentation/memory-barriers.txt index 92f0056d928c..c61d8b876fdb 100644 --- a/Documentation/memory-barriers.txt +++ b/Documentation/memory-barriers.txt | |||
| @@ -1031,7 +1031,7 @@ conflict on any particular lock. | |||
| 1031 | LOCKS VS MEMORY ACCESSES | 1031 | LOCKS VS MEMORY ACCESSES | 
| 1032 | ------------------------ | 1032 | ------------------------ | 
| 1033 | 1033 | ||
| 1034 | Consider the following: the system has a pair of spinlocks (N) and (Q), and | 1034 | Consider the following: the system has a pair of spinlocks (M) and (Q), and | 
| 1035 | three CPUs; then should the following sequence of events occur: | 1035 | three CPUs; then should the following sequence of events occur: | 
| 1036 | 1036 | ||
| 1037 | CPU 1 CPU 2 | 1037 | CPU 1 CPU 2 | 
| @@ -1678,7 +1678,7 @@ CPU's caches by some other cache event: | |||
| 1678 | smp_wmb(); | 1678 | smp_wmb(); | 
| 1679 | <A:modify v=2> <C:busy> | 1679 | <A:modify v=2> <C:busy> | 
| 1680 | <C:queue v=2> | 1680 | <C:queue v=2> | 
| 1681 | p = &b; q = p; | 1681 | p = &v; q = p; | 
| 1682 | <D:request p> | 1682 | <D:request p> | 
| 1683 | <B:modify p=&v> <D:commit p=&v> | 1683 | <B:modify p=&v> <D:commit p=&v> | 
| 1684 | <D:read p> | 1684 | <D:read p> | 
| diff --git a/Documentation/spi/pxa2xx b/Documentation/spi/pxa2xx new file mode 100644 index 000000000000..9c45f3df2e18 --- /dev/null +++ b/Documentation/spi/pxa2xx | |||
| @@ -0,0 +1,234 @@ | |||
| 1 | PXA2xx SPI on SSP driver HOWTO | ||
| 2 | =================================================== | ||
| 3 | This a mini howto on the pxa2xx_spi driver. The driver turns a PXA2xx | ||
| 4 | synchronous serial port into a SPI master controller | ||
| 5 | (see Documentation/spi/spi_summary). The driver has the following features | ||
| 6 | |||
| 7 | - Support for any PXA2xx SSP | ||
| 8 | - SSP PIO and SSP DMA data transfers. | ||
| 9 | - External and Internal (SSPFRM) chip selects. | ||
| 10 | - Per slave device (chip) configuration. | ||
| 11 | - Full suspend, freeze, resume support. | ||
| 12 | |||
| 13 | The driver is built around a "spi_message" fifo serviced by workqueue and a | ||
| 14 | tasklet. The workqueue, "pump_messages", drives message fifo and the tasklet | ||
| 15 | (pump_transfer) is responsible for queuing SPI transactions and setting up and | ||
| 16 | launching the dma/interrupt driven transfers. | ||
| 17 | |||
| 18 | Declaring PXA2xx Master Controllers | ||
| 19 | ----------------------------------- | ||
| 20 | Typically a SPI master is defined in the arch/.../mach-*/board-*.c as a | ||
| 21 | "platform device". The master configuration is passed to the driver via a table | ||
| 22 | found in include/asm-arm/arch-pxa/pxa2xx_spi.h: | ||
| 23 | |||
| 24 | struct pxa2xx_spi_master { | ||
| 25 | enum pxa_ssp_type ssp_type; | ||
| 26 | u32 clock_enable; | ||
| 27 | u16 num_chipselect; | ||
| 28 | u8 enable_dma; | ||
| 29 | }; | ||
| 30 | |||
| 31 | The "pxa2xx_spi_master.ssp_type" field must have a value between 1 and 3 and | ||
| 32 | informs the driver which features a particular SSP supports. | ||
| 33 | |||
| 34 | The "pxa2xx_spi_master.clock_enable" field is used to enable/disable the | ||
| 35 | corresponding SSP peripheral block in the "Clock Enable Register (CKEN"). See | ||
| 36 | the "PXA2xx Developer Manual" section "Clocks and Power Management". | ||
| 37 | |||
| 38 | The "pxa2xx_spi_master.num_chipselect" field is used to determine the number of | ||
| 39 | slave device (chips) attached to this SPI master. | ||
| 40 | |||
| 41 | The "pxa2xx_spi_master.enable_dma" field informs the driver that SSP DMA should | ||
| 42 | be used. This caused the driver to acquire two DMA channels: rx_channel and | ||
| 43 | tx_channel. The rx_channel has a higher DMA service priority the tx_channel. | ||
| 44 | See the "PXA2xx Developer Manual" section "DMA Controller". | ||
| 45 | |||
| 46 | NSSP MASTER SAMPLE | ||
| 47 | ------------------ | ||
| 48 | Below is a sample configuration using the PXA255 NSSP. | ||
| 49 | |||
| 50 | static struct resource pxa_spi_nssp_resources[] = { | ||
| 51 | [0] = { | ||
| 52 | .start = __PREG(SSCR0_P(2)), /* Start address of NSSP */ | ||
| 53 | .end = __PREG(SSCR0_P(2)) + 0x2c, /* Range of registers */ | ||
| 54 | .flags = IORESOURCE_MEM, | ||
| 55 | }, | ||
| 56 | [1] = { | ||
| 57 | .start = IRQ_NSSP, /* NSSP IRQ */ | ||
| 58 | .end = IRQ_NSSP, | ||
| 59 | .flags = IORESOURCE_IRQ, | ||
| 60 | }, | ||
| 61 | }; | ||
| 62 | |||
| 63 | static struct pxa2xx_spi_master pxa_nssp_master_info = { | ||
| 64 | .ssp_type = PXA25x_NSSP, /* Type of SSP */ | ||
| 65 | .clock_enable = CKEN9_NSSP, /* NSSP Peripheral clock */ | ||
| 66 | .num_chipselect = 1, /* Matches the number of chips attached to NSSP */ | ||
| 67 | .enable_dma = 1, /* Enables NSSP DMA */ | ||
| 68 | }; | ||
| 69 | |||
| 70 | static struct platform_device pxa_spi_nssp = { | ||
| 71 | .name = "pxa2xx-spi", /* MUST BE THIS VALUE, so device match driver */ | ||
| 72 | .id = 2, /* Bus number, MUST MATCH SSP number 1..n */ | ||
| 73 | .resource = pxa_spi_nssp_resources, | ||
| 74 | .num_resources = ARRAY_SIZE(pxa_spi_nssp_resources), | ||
| 75 | .dev = { | ||
| 76 | .platform_data = &pxa_nssp_master_info, /* Passed to driver */ | ||
| 77 | }, | ||
| 78 | }; | ||
| 79 | |||
| 80 | static struct platform_device *devices[] __initdata = { | ||
| 81 | &pxa_spi_nssp, | ||
| 82 | }; | ||
| 83 | |||
| 84 | static void __init board_init(void) | ||
| 85 | { | ||
| 86 | (void)platform_add_device(devices, ARRAY_SIZE(devices)); | ||
| 87 | } | ||
| 88 | |||
| 89 | Declaring Slave Devices | ||
| 90 | ----------------------- | ||
| 91 | Typically each SPI slave (chip) is defined in the arch/.../mach-*/board-*.c | ||
| 92 | using the "spi_board_info" structure found in "linux/spi/spi.h". See | ||
| 93 | "Documentation/spi/spi_summary" for additional information. | ||
| 94 | |||
| 95 | Each slave device attached to the PXA must provide slave specific configuration | ||
| 96 | information via the structure "pxa2xx_spi_chip" found in | ||
| 97 | "include/asm-arm/arch-pxa/pxa2xx_spi.h". The pxa2xx_spi master controller driver | ||
| 98 | will uses the configuration whenever the driver communicates with the slave | ||
| 99 | device. | ||
| 100 | |||
| 101 | struct pxa2xx_spi_chip { | ||
| 102 | u8 tx_threshold; | ||
| 103 | u8 rx_threshold; | ||
| 104 | u8 dma_burst_size; | ||
| 105 | u32 timeout_microsecs; | ||
| 106 | u8 enable_loopback; | ||
| 107 | void (*cs_control)(u32 command); | ||
| 108 | }; | ||
| 109 | |||
| 110 | The "pxa2xx_spi_chip.tx_threshold" and "pxa2xx_spi_chip.rx_threshold" fields are | ||
| 111 | used to configure the SSP hardware fifo. These fields are critical to the | ||
| 112 | performance of pxa2xx_spi driver and misconfiguration will result in rx | ||
| 113 | fifo overruns (especially in PIO mode transfers). Good default values are | ||
| 114 | |||
| 115 | .tx_threshold = 12, | ||
| 116 | .rx_threshold = 4, | ||
| 117 | |||
| 118 | The "pxa2xx_spi_chip.dma_burst_size" field is used to configure PXA2xx DMA | ||
| 119 | engine and is related the "spi_device.bits_per_word" field. Read and understand | ||
| 120 | the PXA2xx "Developer Manual" sections on the DMA controller and SSP Controllers | ||
| 121 | to determine the correct value. An SSP configured for byte-wide transfers would | ||
| 122 | use a value of 8. | ||
| 123 | |||
| 124 | The "pxa2xx_spi_chip.timeout_microsecs" fields is used to efficiently handle | ||
| 125 | trailing bytes in the SSP receiver fifo. The correct value for this field is | ||
| 126 | dependent on the SPI bus speed ("spi_board_info.max_speed_hz") and the specific | ||
| 127 | slave device. Please note the the PXA2xx SSP 1 does not support trailing byte | ||
| 128 | timeouts and must busy-wait any trailing bytes. | ||
| 129 | |||
| 130 | The "pxa2xx_spi_chip.enable_loopback" field is used to place the SSP porting | ||
| 131 | into internal loopback mode. In this mode the SSP controller internally | ||
| 132 | connects the SSPTX pin the the SSPRX pin. This is useful for initial setup | ||
| 133 | testing. | ||
| 134 | |||
| 135 | The "pxa2xx_spi_chip.cs_control" field is used to point to a board specific | ||
| 136 | function for asserting/deasserting a slave device chip select. If the field is | ||
| 137 | NULL, the pxa2xx_spi master controller driver assumes that the SSP port is | ||
| 138 | configured to use SSPFRM instead. | ||
| 139 | |||
| 140 | NSSP SALVE SAMPLE | ||
| 141 | ----------------- | ||
| 142 | The pxa2xx_spi_chip structure is passed to the pxa2xx_spi driver in the | ||
| 143 | "spi_board_info.controller_data" field. Below is a sample configuration using | ||
| 144 | the PXA255 NSSP. | ||
| 145 | |||
| 146 | /* Chip Select control for the CS8415A SPI slave device */ | ||
| 147 | static void cs8415a_cs_control(u32 command) | ||
| 148 | { | ||
| 149 | if (command & PXA2XX_CS_ASSERT) | ||
| 150 | GPCR(2) = GPIO_bit(2); | ||
| 151 | else | ||
| 152 | GPSR(2) = GPIO_bit(2); | ||
| 153 | } | ||
| 154 | |||
| 155 | /* Chip Select control for the CS8405A SPI slave device */ | ||
| 156 | static void cs8405a_cs_control(u32 command) | ||
| 157 | { | ||
| 158 | if (command & PXA2XX_CS_ASSERT) | ||
| 159 | GPCR(3) = GPIO_bit(3); | ||
| 160 | else | ||
| 161 | GPSR(3) = GPIO_bit(3); | ||
| 162 | } | ||
| 163 | |||
| 164 | static struct pxa2xx_spi_chip cs8415a_chip_info = { | ||
| 165 | .tx_threshold = 12, /* SSP hardward FIFO threshold */ | ||
| 166 | .rx_threshold = 4, /* SSP hardward FIFO threshold */ | ||
| 167 | .dma_burst_size = 8, /* Byte wide transfers used so 8 byte bursts */ | ||
| 168 | .timeout_microsecs = 64, /* Wait at least 64usec to handle trailing */ | ||
| 169 | .cs_control = cs8415a_cs_control, /* Use external chip select */ | ||
| 170 | }; | ||
| 171 | |||
| 172 | static struct pxa2xx_spi_chip cs8405a_chip_info = { | ||
| 173 | .tx_threshold = 12, /* SSP hardward FIFO threshold */ | ||
| 174 | .rx_threshold = 4, /* SSP hardward FIFO threshold */ | ||
| 175 | .dma_burst_size = 8, /* Byte wide transfers used so 8 byte bursts */ | ||
| 176 | .timeout_microsecs = 64, /* Wait at least 64usec to handle trailing */ | ||
| 177 | .cs_control = cs8405a_cs_control, /* Use external chip select */ | ||
| 178 | }; | ||
| 179 | |||
| 180 | static struct spi_board_info streetracer_spi_board_info[] __initdata = { | ||
| 181 | { | ||
| 182 | .modalias = "cs8415a", /* Name of spi_driver for this device */ | ||
| 183 | .max_speed_hz = 3686400, /* Run SSP as fast a possbile */ | ||
| 184 | .bus_num = 2, /* Framework bus number */ | ||
| 185 | .chip_select = 0, /* Framework chip select */ | ||
| 186 | .platform_data = NULL; /* No spi_driver specific config */ | ||
| 187 | .controller_data = &cs8415a_chip_info, /* Master chip config */ | ||
| 188 | .irq = STREETRACER_APCI_IRQ, /* Slave device interrupt */ | ||
| 189 | }, | ||
| 190 | { | ||
| 191 | .modalias = "cs8405a", /* Name of spi_driver for this device */ | ||
| 192 | .max_speed_hz = 3686400, /* Run SSP as fast a possbile */ | ||
| 193 | .bus_num = 2, /* Framework bus number */ | ||
| 194 | .chip_select = 1, /* Framework chip select */ | ||
| 195 | .controller_data = &cs8405a_chip_info, /* Master chip config */ | ||
| 196 | .irq = STREETRACER_APCI_IRQ, /* Slave device interrupt */ | ||
| 197 | }, | ||
| 198 | }; | ||
| 199 | |||
| 200 | static void __init streetracer_init(void) | ||
| 201 | { | ||
| 202 | spi_register_board_info(streetracer_spi_board_info, | ||
| 203 | ARRAY_SIZE(streetracer_spi_board_info)); | ||
| 204 | } | ||
| 205 | |||
| 206 | |||
| 207 | DMA and PIO I/O Support | ||
| 208 | ----------------------- | ||
| 209 | The pxa2xx_spi driver support both DMA and interrupt driven PIO message | ||
| 210 | transfers. The driver defaults to PIO mode and DMA transfers must enabled by | ||
| 211 | setting the "enable_dma" flag in the "pxa2xx_spi_master" structure and and | ||
| 212 | ensuring that the "pxa2xx_spi_chip.dma_burst_size" field is non-zero. The DMA | ||
| 213 | mode support both coherent and stream based DMA mappings. | ||
| 214 | |||
| 215 | The following logic is used to determine the type of I/O to be used on | ||
| 216 | a per "spi_transfer" basis: | ||
| 217 | |||
| 218 | if !enable_dma or dma_burst_size == 0 then | ||
| 219 | always use PIO transfers | ||
| 220 | |||
| 221 | if spi_message.is_dma_mapped and rx_dma_buf != 0 and tx_dma_buf != 0 then | ||
| 222 | use coherent DMA mode | ||
| 223 | |||
| 224 | if rx_buf and tx_buf are aligned on 8 byte boundary then | ||
| 225 | use streaming DMA mode | ||
| 226 | |||
| 227 | otherwise | ||
| 228 | use PIO transfer | ||
| 229 | |||
| 230 | THANKS TO | ||
| 231 | --------- | ||
| 232 | |||
| 233 | David Brownell and others for mentoring the development of this driver. | ||
| 234 | |||
| diff --git a/Documentation/spi/spi-summary b/Documentation/spi/spi-summary index a5ffba33a351..068732d32276 100644 --- a/Documentation/spi/spi-summary +++ b/Documentation/spi/spi-summary | |||
| @@ -414,7 +414,33 @@ to get the driver-private data allocated for that device. | |||
| 414 | The driver will initialize the fields of that spi_master, including the | 414 | The driver will initialize the fields of that spi_master, including the | 
| 415 | bus number (maybe the same as the platform device ID) and three methods | 415 | bus number (maybe the same as the platform device ID) and three methods | 
| 416 | used to interact with the SPI core and SPI protocol drivers. It will | 416 | used to interact with the SPI core and SPI protocol drivers. It will | 
| 417 | also initialize its own internal state. | 417 | also initialize its own internal state. (See below about bus numbering | 
| 418 | and those methods.) | ||
| 419 | |||
| 420 | After you initialize the spi_master, then use spi_register_master() to | ||
| 421 | publish it to the rest of the system. At that time, device nodes for | ||
| 422 | the controller and any predeclared spi devices will be made available, | ||
| 423 | and the driver model core will take care of binding them to drivers. | ||
| 424 | |||
| 425 | If you need to remove your SPI controller driver, spi_unregister_master() | ||
| 426 | will reverse the effect of spi_register_master(). | ||
| 427 | |||
| 428 | |||
| 429 | BUS NUMBERING | ||
| 430 | |||
| 431 | Bus numbering is important, since that's how Linux identifies a given | ||
| 432 | SPI bus (shared SCK, MOSI, MISO). Valid bus numbers start at zero. On | ||
| 433 | SOC systems, the bus numbers should match the numbers defined by the chip | ||
| 434 | manufacturer. For example, hardware controller SPI2 would be bus number 2, | ||
| 435 | and spi_board_info for devices connected to it would use that number. | ||
| 436 | |||
| 437 | If you don't have such hardware-assigned bus number, and for some reason | ||
| 438 | you can't just assign them, then provide a negative bus number. That will | ||
| 439 | then be replaced by a dynamically assigned number. You'd then need to treat | ||
| 440 | this as a non-static configuration (see above). | ||
| 441 | |||
| 442 | |||
| 443 | SPI MASTER METHODS | ||
| 418 | 444 | ||
| 419 | master->setup(struct spi_device *spi) | 445 | master->setup(struct spi_device *spi) | 
| 420 | This sets up the device clock rate, SPI mode, and word sizes. | 446 | This sets up the device clock rate, SPI mode, and word sizes. | 
| @@ -431,6 +457,9 @@ also initialize its own internal state. | |||
| 431 | state it dynamically associates with that device. If you do that, | 457 | state it dynamically associates with that device. If you do that, | 
| 432 | be sure to provide the cleanup() method to free that state. | 458 | be sure to provide the cleanup() method to free that state. | 
| 433 | 459 | ||
| 460 | |||
| 461 | SPI MESSAGE QUEUE | ||
| 462 | |||
| 434 | The bulk of the driver will be managing the I/O queue fed by transfer(). | 463 | The bulk of the driver will be managing the I/O queue fed by transfer(). | 
| 435 | 464 | ||
| 436 | That queue could be purely conceptual. For example, a driver used only | 465 | That queue could be purely conceptual. For example, a driver used only | 
| @@ -440,6 +469,9 @@ But the queue will probably be very real, using message->queue, PIO, | |||
| 440 | often DMA (especially if the root filesystem is in SPI flash), and | 469 | often DMA (especially if the root filesystem is in SPI flash), and | 
| 441 | execution contexts like IRQ handlers, tasklets, or workqueues (such | 470 | execution contexts like IRQ handlers, tasklets, or workqueues (such | 
| 442 | as keventd). Your driver can be as fancy, or as simple, as you need. | 471 | as keventd). Your driver can be as fancy, or as simple, as you need. | 
| 472 | Such a transfer() method would normally just add the message to a | ||
| 473 | queue, and then start some asynchronous transfer engine (unless it's | ||
| 474 | already running). | ||
| 443 | 475 | ||
| 444 | 476 | ||
| 445 | THANKS TO | 477 | THANKS TO | 
| diff --git a/Documentation/watchdog/watchdog-api.txt b/Documentation/watchdog/watchdog-api.txt index c5beb548cfc4..21ed51173662 100644 --- a/Documentation/watchdog/watchdog-api.txt +++ b/Documentation/watchdog/watchdog-api.txt | |||
| @@ -36,6 +36,9 @@ timeout or margin. The simplest way to ping the watchdog is to write | |||
| 36 | some data to the device. So a very simple watchdog daemon would look | 36 | some data to the device. So a very simple watchdog daemon would look | 
| 37 | like this: | 37 | like this: | 
| 38 | 38 | ||
| 39 | #include <stdlib.h> | ||
| 40 | #include <fcntl.h> | ||
| 41 | |||
| 39 | int main(int argc, const char *argv[]) { | 42 | int main(int argc, const char *argv[]) { | 
| 40 | int fd=open("/dev/watchdog",O_WRONLY); | 43 | int fd=open("/dev/watchdog",O_WRONLY); | 
| 41 | if (fd==-1) { | 44 | if (fd==-1) { | 
| diff --git a/MAINTAINERS b/MAINTAINERS index 5e3355871416..753584cf4e7e 100644 --- a/MAINTAINERS +++ b/MAINTAINERS | |||
| @@ -1603,6 +1603,11 @@ M: James.Bottomley@HansenPartnership.com | |||
| 1603 | L: linux-scsi@vger.kernel.org | 1603 | L: linux-scsi@vger.kernel.org | 
| 1604 | S: Maintained | 1604 | S: Maintained | 
| 1605 | 1605 | ||
| 1606 | LED SUBSYSTEM | ||
| 1607 | P: Richard Purdie | ||
| 1608 | M: rpurdie@rpsys.net | ||
| 1609 | S: Maintained | ||
| 1610 | |||
| 1606 | LEGO USB Tower driver | 1611 | LEGO USB Tower driver | 
| 1607 | P: Juergen Stuber | 1612 | P: Juergen Stuber | 
| 1608 | M: starblue@users.sourceforge.net | 1613 | M: starblue@users.sourceforge.net | 
| @@ -1662,7 +1667,7 @@ S: Maintained | |||
| 1662 | 1667 | ||
| 1663 | LINUX FOR POWERPC EMBEDDED PPC8XX | 1668 | LINUX FOR POWERPC EMBEDDED PPC8XX | 
| 1664 | P: Marcelo Tosatti | 1669 | P: Marcelo Tosatti | 
| 1665 | M: marcelo.tosatti@cyclades.com | 1670 | M: marcelo@kvack.org | 
| 1666 | W: http://www.penguinppc.org/ | 1671 | W: http://www.penguinppc.org/ | 
| 1667 | L: linuxppc-embedded@ozlabs.org | 1672 | L: linuxppc-embedded@ozlabs.org | 
| 1668 | S: Maintained | 1673 | S: Maintained | 
| @@ -2513,6 +2518,12 @@ M: perex@suse.cz | |||
| 2513 | L: alsa-devel@alsa-project.org | 2518 | L: alsa-devel@alsa-project.org | 
| 2514 | S: Maintained | 2519 | S: Maintained | 
| 2515 | 2520 | ||
| 2521 | SPI SUBSYSTEM | ||
| 2522 | P: David Brownell | ||
| 2523 | M: dbrownell@users.sourceforge.net | ||
| 2524 | L: spi-devel-general@lists.sourceforge.net | ||
| 2525 | S: Maintained | ||
| 2526 | |||
| 2516 | TPM DEVICE DRIVER | 2527 | TPM DEVICE DRIVER | 
| 2517 | P: Kylene Hall | 2528 | P: Kylene Hall | 
| 2518 | M: kjhall@us.ibm.com | 2529 | M: kjhall@us.ibm.com | 
| diff --git a/arch/arm/kernel/asm-offsets.c b/arch/arm/kernel/asm-offsets.c index 45fdf4a51a2a..396efba9bacd 100644 --- a/arch/arm/kernel/asm-offsets.c +++ b/arch/arm/kernel/asm-offsets.c | |||
| @@ -99,6 +99,8 @@ int main(void) | |||
| 99 | DEFINE(MACHINFO_NAME, offsetof(struct machine_desc, name)); | 99 | DEFINE(MACHINFO_NAME, offsetof(struct machine_desc, name)); | 
| 100 | DEFINE(MACHINFO_PHYSIO, offsetof(struct machine_desc, phys_io)); | 100 | DEFINE(MACHINFO_PHYSIO, offsetof(struct machine_desc, phys_io)); | 
| 101 | DEFINE(MACHINFO_PGOFFIO, offsetof(struct machine_desc, io_pg_offst)); | 101 | DEFINE(MACHINFO_PGOFFIO, offsetof(struct machine_desc, io_pg_offst)); | 
| 102 | BLANK(); | ||
| 103 | DEFINE(PROC_INFO_SZ, sizeof(struct proc_info_list)); | ||
| 102 | DEFINE(PROCINFO_INITFUNC, offsetof(struct proc_info_list, __cpu_flush)); | 104 | DEFINE(PROCINFO_INITFUNC, offsetof(struct proc_info_list, __cpu_flush)); | 
| 103 | DEFINE(PROCINFO_MMUFLAGS, offsetof(struct proc_info_list, __cpu_mmu_flags)); | 105 | DEFINE(PROCINFO_MMUFLAGS, offsetof(struct proc_info_list, __cpu_mmu_flags)); | 
| 104 | return 0; | 106 | return 0; | 
| diff --git a/arch/arm/kernel/dma-isa.c b/arch/arm/kernel/dma-isa.c index 03532769a97f..0a3e9ad297d8 100644 --- a/arch/arm/kernel/dma-isa.c +++ b/arch/arm/kernel/dma-isa.c | |||
| @@ -143,12 +143,23 @@ static struct dma_ops isa_dma_ops = { | |||
| 143 | .residue = isa_get_dma_residue, | 143 | .residue = isa_get_dma_residue, | 
| 144 | }; | 144 | }; | 
| 145 | 145 | ||
| 146 | static struct resource dma_resources[] = { | 146 | static struct resource dma_resources[] = { { | 
| 147 | { "dma1", 0x0000, 0x000f }, | 147 | .name = "dma1", | 
| 148 | { "dma low page", 0x0080, 0x008f }, | 148 | .start = 0x0000, | 
| 149 | { "dma2", 0x00c0, 0x00df }, | 149 | .end = 0x000f | 
| 150 | { "dma high page", 0x0480, 0x048f } | 150 | }, { | 
| 151 | }; | 151 | .name = "dma low page", | 
| 152 | .start = 0x0080, | ||
| 153 | .end = 0x008f | ||
| 154 | }, { | ||
| 155 | .name = "dma2", | ||
| 156 | .start = 0x00c0, | ||
| 157 | .end = 0x00df | ||
| 158 | }, { | ||
| 159 | .name = "dma high page", | ||
| 160 | .start = 0x0480, | ||
| 161 | .end = 0x048f | ||
| 162 | } }; | ||
| 152 | 163 | ||
| 153 | void __init isa_init_dma(dma_t *dma) | 164 | void __init isa_init_dma(dma_t *dma) | 
| 154 | { | 165 | { | 
| diff --git a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c index 1a1539e3a946..7df6e1aaa323 100644 --- a/arch/arm/kernel/process.c +++ b/arch/arm/kernel/process.c | |||
| @@ -311,7 +311,7 @@ void free_thread_info(struct thread_info *thread) | |||
| 311 | struct thread_info_list *th = &get_cpu_var(thread_info_list); | 311 | struct thread_info_list *th = &get_cpu_var(thread_info_list); | 
| 312 | if (th->nr < EXTRA_TASK_STRUCT) { | 312 | if (th->nr < EXTRA_TASK_STRUCT) { | 
| 313 | unsigned long *p = (unsigned long *)thread; | 313 | unsigned long *p = (unsigned long *)thread; | 
| 314 | p[0] = th->head; | 314 | p[0] = (unsigned long)th->head; | 
| 315 | th->head = p; | 315 | th->head = p; | 
| 316 | th->nr += 1; | 316 | th->nr += 1; | 
| 317 | put_cpu_var(thread_info_list); | 317 | put_cpu_var(thread_info_list); | 
| diff --git a/arch/arm/lib/backtrace.S b/arch/arm/lib/backtrace.S index 3bdc8c6949c5..16153c86c3f8 100644 --- a/arch/arm/lib/backtrace.S +++ b/arch/arm/lib/backtrace.S | |||
| @@ -122,7 +122,7 @@ ENTRY(c_backtrace) | |||
| 122 | #define reg r5 | 122 | #define reg r5 | 
| 123 | #define stack r6 | 123 | #define stack r6 | 
| 124 | 124 | ||
| 125 | .Ldumpstm: stmfd sp!, {instr, reg, stack, r7, lr} | 125 | .Ldumpstm: stmfd sp!, {instr, reg, stack, r7, r8, lr} | 
| 126 | mov stack, r0 | 126 | mov stack, r0 | 
| 127 | mov instr, r1 | 127 | mov instr, r1 | 
| 128 | mov reg, #9 | 128 | mov reg, #9 | 
| @@ -145,7 +145,7 @@ ENTRY(c_backtrace) | |||
| 145 | adrne r0, .Lcr | 145 | adrne r0, .Lcr | 
| 146 | blne printk | 146 | blne printk | 
| 147 | mov r0, stack | 147 | mov r0, stack | 
| 148 | LOADREGS(fd, sp!, {instr, reg, stack, r7, pc}) | 148 | LOADREGS(fd, sp!, {instr, reg, stack, r7, r8, pc}) | 
| 149 | 149 | ||
| 150 | .Lfp: .asciz " r%d = %08X%c" | 150 | .Lfp: .asciz " r%d = %08X%c" | 
| 151 | .Lcr: .asciz "\n" | 151 | .Lcr: .asciz "\n" | 
| diff --git a/arch/arm/lib/div64.S b/arch/arm/lib/div64.S index ec9a1cd6176f..58eef6607629 100644 --- a/arch/arm/lib/div64.S +++ b/arch/arm/lib/div64.S | |||
| @@ -189,12 +189,12 @@ ENTRY(__do_div64) | |||
| 189 | moveq pc, lr | 189 | moveq pc, lr | 
| 190 | 190 | ||
| 191 | @ Division by 0: | 191 | @ Division by 0: | 
| 192 | str lr, [sp, #-4]! | 192 | str lr, [sp, #-8]! | 
| 193 | bl __div0 | 193 | bl __div0 | 
| 194 | 194 | ||
| 195 | @ as wrong as it could be... | 195 | @ as wrong as it could be... | 
| 196 | mov yl, #0 | 196 | mov yl, #0 | 
| 197 | mov yh, #0 | 197 | mov yh, #0 | 
| 198 | mov xh, #0 | 198 | mov xh, #0 | 
| 199 | ldr pc, [sp], #4 | 199 | ldr pc, [sp], #8 | 
| 200 | 200 | ||
| diff --git a/arch/arm/mach-pxa/mainstone.c b/arch/arm/mach-pxa/mainstone.c index 98356f810007..02e188d98e7d 100644 --- a/arch/arm/mach-pxa/mainstone.c +++ b/arch/arm/mach-pxa/mainstone.c | |||
| @@ -95,7 +95,10 @@ static void __init mainstone_init_irq(void) | |||
| 95 | for(irq = MAINSTONE_IRQ(0); irq <= MAINSTONE_IRQ(15); irq++) { | 95 | for(irq = MAINSTONE_IRQ(0); irq <= MAINSTONE_IRQ(15); irq++) { | 
| 96 | set_irq_chip(irq, &mainstone_irq_chip); | 96 | set_irq_chip(irq, &mainstone_irq_chip); | 
| 97 | set_irq_handler(irq, do_level_IRQ); | 97 | set_irq_handler(irq, do_level_IRQ); | 
| 98 | set_irq_flags(irq, IRQF_VALID | IRQF_PROBE); | 98 | if (irq == MAINSTONE_IRQ(10) || irq == MAINSTONE_IRQ(14)) | 
| 99 | set_irq_flags(irq, IRQF_VALID | IRQF_PROBE | IRQF_NOAUTOEN); | ||
| 100 | else | ||
| 101 | set_irq_flags(irq, IRQF_VALID | IRQF_PROBE); | ||
| 99 | } | 102 | } | 
| 100 | set_irq_flags(MAINSTONE_IRQ(8), 0); | 103 | set_irq_flags(MAINSTONE_IRQ(8), 0); | 
| 101 | set_irq_flags(MAINSTONE_IRQ(12), 0); | 104 | set_irq_flags(MAINSTONE_IRQ(12), 0); | 
| diff --git a/arch/arm/mach-realview/realview_eb.c b/arch/arm/mach-realview/realview_eb.c index d4a586e38d5b..693fb1e396e0 100644 --- a/arch/arm/mach-realview/realview_eb.c +++ b/arch/arm/mach-realview/realview_eb.c | |||
| @@ -137,8 +137,11 @@ static struct amba_device *amba_devs[] __initdata = { | |||
| 137 | static void __init gic_init_irq(void) | 137 | static void __init gic_init_irq(void) | 
| 138 | { | 138 | { | 
| 139 | #ifdef CONFIG_REALVIEW_MPCORE | 139 | #ifdef CONFIG_REALVIEW_MPCORE | 
| 140 | unsigned int pldctrl; | ||
| 140 | writel(0x0000a05f, __io_address(REALVIEW_SYS_LOCK)); | 141 | writel(0x0000a05f, __io_address(REALVIEW_SYS_LOCK)); | 
| 141 | writel(0x008003c0, __io_address(REALVIEW_SYS_BASE) + 0xd8); | 142 | pldctrl = readl(__io_address(REALVIEW_SYS_BASE) + 0xd8); | 
| 143 | pldctrl |= 0x00800000; /* New irq mode */ | ||
| 144 | writel(pldctrl, __io_address(REALVIEW_SYS_BASE) + 0xd8); | ||
| 142 | writel(0x00000000, __io_address(REALVIEW_SYS_LOCK)); | 145 | writel(0x00000000, __io_address(REALVIEW_SYS_LOCK)); | 
| 143 | #endif | 146 | #endif | 
| 144 | gic_dist_init(__io_address(REALVIEW_GIC_DIST_BASE)); | 147 | gic_dist_init(__io_address(REALVIEW_GIC_DIST_BASE)); | 
| diff --git a/arch/arm/mach-s3c2410/sleep.S b/arch/arm/mach-s3c2410/sleep.S index 832fb86a03b4..73de2eaca22a 100644 --- a/arch/arm/mach-s3c2410/sleep.S +++ b/arch/arm/mach-s3c2410/sleep.S | |||
| @@ -59,8 +59,7 @@ ENTRY(s3c2410_cpu_suspend) | |||
| 59 | mrc p15, 0, r5, c13, c0, 0 @ PID | 59 | mrc p15, 0, r5, c13, c0, 0 @ PID | 
| 60 | mrc p15, 0, r6, c3, c0, 0 @ Domain ID | 60 | mrc p15, 0, r6, c3, c0, 0 @ Domain ID | 
| 61 | mrc p15, 0, r7, c2, c0, 0 @ translation table base address | 61 | mrc p15, 0, r7, c2, c0, 0 @ translation table base address | 
| 62 | mrc p15, 0, r8, c2, c0, 0 @ auxiliary control register | 62 | mrc p15, 0, r8, c1, c0, 0 @ control register | 
| 63 | mrc p15, 0, r9, c1, c0, 0 @ control register | ||
| 64 | 63 | ||
| 65 | stmia r0, { r4 - r13 } | 64 | stmia r0, { r4 - r13 } | 
| 66 | 65 | ||
| @@ -165,7 +164,6 @@ ENTRY(s3c2410_cpu_resume) | |||
| 165 | mcr p15, 0, r5, c13, c0, 0 @ PID | 164 | mcr p15, 0, r5, c13, c0, 0 @ PID | 
| 166 | mcr p15, 0, r6, c3, c0, 0 @ Domain ID | 165 | mcr p15, 0, r6, c3, c0, 0 @ Domain ID | 
| 167 | mcr p15, 0, r7, c2, c0, 0 @ translation table base | 166 | mcr p15, 0, r7, c2, c0, 0 @ translation table base | 
| 168 | mcr p15, 0, r8, c1, c1, 0 @ auxilliary control | ||
| 169 | 167 | ||
| 170 | #ifdef CONFIG_DEBUG_RESUME | 168 | #ifdef CONFIG_DEBUG_RESUME | 
| 171 | mov r3, #'R' | 169 | mov r3, #'R' | 
| @@ -173,7 +171,7 @@ ENTRY(s3c2410_cpu_resume) | |||
| 173 | #endif | 171 | #endif | 
| 174 | 172 | ||
| 175 | ldr r2, =resume_with_mmu | 173 | ldr r2, =resume_with_mmu | 
| 176 | mcr p15, 0, r9, c1, c0, 0 @ turn on MMU, etc | 174 | mcr p15, 0, r8, c1, c0, 0 @ turn on MMU, etc | 
| 177 | nop @ second-to-last before mmu | 175 | nop @ second-to-last before mmu | 
| 178 | mov pc, r2 @ go back to virtual address | 176 | mov pc, r2 @ go back to virtual address | 
| 179 | 177 | ||
| diff --git a/arch/arm/mm/ioremap.c b/arch/arm/mm/ioremap.c index 25e0ca3e598c..c1f7180c7bed 100644 --- a/arch/arm/mm/ioremap.c +++ b/arch/arm/mm/ioremap.c | |||
| @@ -141,7 +141,7 @@ __ioremap_pfn(unsigned long pfn, unsigned long offset, size_t size, | |||
| 141 | return NULL; | 141 | return NULL; | 
| 142 | addr = (unsigned long)area->addr; | 142 | addr = (unsigned long)area->addr; | 
| 143 | if (remap_area_pages(addr, pfn, size, flags)) { | 143 | if (remap_area_pages(addr, pfn, size, flags)) { | 
| 144 | vfree((void *)addr); | 144 | vunmap((void *)addr); | 
| 145 | return NULL; | 145 | return NULL; | 
| 146 | } | 146 | } | 
| 147 | return (void __iomem *) (offset + (char *)addr); | 147 | return (void __iomem *) (offset + (char *)addr); | 
| @@ -173,7 +173,7 @@ EXPORT_SYMBOL(__ioremap); | |||
| 173 | 173 | ||
| 174 | void __iounmap(void __iomem *addr) | 174 | void __iounmap(void __iomem *addr) | 
| 175 | { | 175 | { | 
| 176 | vfree((void *) (PAGE_MASK & (unsigned long) addr)); | 176 | vunmap((void *)(PAGE_MASK & (unsigned long)addr)); | 
| 177 | } | 177 | } | 
| 178 | EXPORT_SYMBOL(__iounmap); | 178 | EXPORT_SYMBOL(__iounmap); | 
| 179 | 179 | ||
| diff --git a/arch/i386/Kconfig b/arch/i386/Kconfig index c6fe99e57a05..8dfa3054f10f 100644 --- a/arch/i386/Kconfig +++ b/arch/i386/Kconfig | |||
| @@ -758,10 +758,10 @@ config HOTPLUG_CPU | |||
| 758 | bool "Support for hot-pluggable CPUs (EXPERIMENTAL)" | 758 | bool "Support for hot-pluggable CPUs (EXPERIMENTAL)" | 
| 759 | depends on SMP && HOTPLUG && EXPERIMENTAL && !X86_VOYAGER | 759 | depends on SMP && HOTPLUG && EXPERIMENTAL && !X86_VOYAGER | 
| 760 | ---help--- | 760 | ---help--- | 
| 761 | Say Y here to experiment with turning CPUs off and on. CPUs | 761 | Say Y here to experiment with turning CPUs off and on, and to | 
| 762 | can be controlled through /sys/devices/system/cpu. | 762 | enable suspend on SMP systems. CPUs can be controlled through | 
| 763 | /sys/devices/system/cpu. | ||
| 763 | 764 | ||
| 764 | Say N. | ||
| 765 | 765 | ||
| 766 | endmenu | 766 | endmenu | 
| 767 | 767 | ||
| diff --git a/arch/i386/kernel/acpi/boot.c b/arch/i386/kernel/acpi/boot.c index 40e5aba3ad3d..daee69579b1c 100644 --- a/arch/i386/kernel/acpi/boot.c +++ b/arch/i386/kernel/acpi/boot.c | |||
| @@ -1066,6 +1066,14 @@ static struct dmi_system_id __initdata acpi_dmi_table[] = { | |||
| 1066 | DMI_MATCH(DMI_PRODUCT_NAME, "TravelMate 360"), | 1066 | DMI_MATCH(DMI_PRODUCT_NAME, "TravelMate 360"), | 
| 1067 | }, | 1067 | }, | 
| 1068 | }, | 1068 | }, | 
| 1069 | { | ||
| 1070 | .callback = disable_acpi_pci, | ||
| 1071 | .ident = "HP xw9300", | ||
| 1072 | .matches = { | ||
| 1073 | DMI_MATCH(DMI_SYS_VENDOR, "Hewlett-Packard"), | ||
| 1074 | DMI_MATCH(DMI_PRODUCT_NAME, "HP xw9300 Workstation"), | ||
| 1075 | }, | ||
| 1076 | }, | ||
| 1069 | {} | 1077 | {} | 
| 1070 | }; | 1078 | }; | 
| 1071 | 1079 | ||
| diff --git a/arch/i386/oprofile/nmi_int.c b/arch/i386/oprofile/nmi_int.c index 1a2076ce6f6a..ec0fd3cfa774 100644 --- a/arch/i386/oprofile/nmi_int.c +++ b/arch/i386/oprofile/nmi_int.c | |||
| @@ -332,10 +332,11 @@ static int __init ppro_init(char ** cpu_type) | |||
| 332 | { | 332 | { | 
| 333 | __u8 cpu_model = boot_cpu_data.x86_model; | 333 | __u8 cpu_model = boot_cpu_data.x86_model; | 
| 334 | 334 | ||
| 335 | if (cpu_model > 0xd) | 335 | if (cpu_model == 14) | 
| 336 | *cpu_type = "i386/core"; | ||
| 337 | else if (cpu_model > 0xd) | ||
| 336 | return 0; | 338 | return 0; | 
| 337 | 339 | else if (cpu_model == 9) { | |
| 338 | if (cpu_model == 9) { | ||
| 339 | *cpu_type = "i386/p6_mobile"; | 340 | *cpu_type = "i386/p6_mobile"; | 
| 340 | } else if (cpu_model > 5) { | 341 | } else if (cpu_model > 5) { | 
| 341 | *cpu_type = "i386/piii"; | 342 | *cpu_type = "i386/piii"; | 
| diff --git a/arch/ia64/configs/sn2_defconfig b/arch/ia64/configs/sn2_defconfig index f6a8853cd1b4..9ea35398e10d 100644 --- a/arch/ia64/configs/sn2_defconfig +++ b/arch/ia64/configs/sn2_defconfig | |||
| @@ -134,7 +134,7 @@ CONFIG_ARCH_FLATMEM_ENABLE=y | |||
| 134 | CONFIG_ARCH_SPARSEMEM_ENABLE=y | 134 | CONFIG_ARCH_SPARSEMEM_ENABLE=y | 
| 135 | CONFIG_ARCH_DISCONTIGMEM_DEFAULT=y | 135 | CONFIG_ARCH_DISCONTIGMEM_DEFAULT=y | 
| 136 | CONFIG_NUMA=y | 136 | CONFIG_NUMA=y | 
| 137 | CONFIG_NODES_SHIFT=8 | 137 | CONFIG_NODES_SHIFT=10 | 
| 138 | CONFIG_VIRTUAL_MEM_MAP=y | 138 | CONFIG_VIRTUAL_MEM_MAP=y | 
| 139 | CONFIG_HOLES_IN_ZONE=y | 139 | CONFIG_HOLES_IN_ZONE=y | 
| 140 | CONFIG_HAVE_ARCH_EARLY_PFN_TO_NID=y | 140 | CONFIG_HAVE_ARCH_EARLY_PFN_TO_NID=y | 
| @@ -1159,7 +1159,7 @@ CONFIG_DETECT_SOFTLOCKUP=y | |||
| 1159 | # CONFIG_SCHEDSTATS is not set | 1159 | # CONFIG_SCHEDSTATS is not set | 
| 1160 | # CONFIG_DEBUG_SLAB is not set | 1160 | # CONFIG_DEBUG_SLAB is not set | 
| 1161 | CONFIG_DEBUG_PREEMPT=y | 1161 | CONFIG_DEBUG_PREEMPT=y | 
| 1162 | CONFIG_DEBUG_MUTEXES=y | 1162 | # CONFIG_DEBUG_MUTEXES is not set | 
| 1163 | # CONFIG_DEBUG_SPINLOCK is not set | 1163 | # CONFIG_DEBUG_SPINLOCK is not set | 
| 1164 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 1164 | # CONFIG_DEBUG_SPINLOCK_SLEEP is not set | 
| 1165 | # CONFIG_DEBUG_KOBJECT is not set | 1165 | # CONFIG_DEBUG_KOBJECT is not set | 
| diff --git a/arch/ia64/kernel/iosapic.c b/arch/ia64/kernel/iosapic.c index 7956eb9058fc..d58c1c5c903a 100644 --- a/arch/ia64/kernel/iosapic.c +++ b/arch/ia64/kernel/iosapic.c | |||
| @@ -416,7 +416,7 @@ iosapic_end_level_irq (unsigned int irq) | |||
| 416 | ia64_vector vec = irq_to_vector(irq); | 416 | ia64_vector vec = irq_to_vector(irq); | 
| 417 | struct iosapic_rte_info *rte; | 417 | struct iosapic_rte_info *rte; | 
| 418 | 418 | ||
| 419 | move_irq(irq); | 419 | move_native_irq(irq); | 
| 420 | list_for_each_entry(rte, &iosapic_intr_info[vec].rtes, rte_list) | 420 | list_for_each_entry(rte, &iosapic_intr_info[vec].rtes, rte_list) | 
| 421 | iosapic_eoi(rte->addr, vec); | 421 | iosapic_eoi(rte->addr, vec); | 
| 422 | } | 422 | } | 
| @@ -458,7 +458,7 @@ iosapic_ack_edge_irq (unsigned int irq) | |||
| 458 | { | 458 | { | 
| 459 | irq_desc_t *idesc = irq_descp(irq); | 459 | irq_desc_t *idesc = irq_descp(irq); | 
| 460 | 460 | ||
| 461 | move_irq(irq); | 461 | move_native_irq(irq); | 
| 462 | /* | 462 | /* | 
| 463 | * Once we have recorded IRQ_PENDING already, we can mask the | 463 | * Once we have recorded IRQ_PENDING already, we can mask the | 
| 464 | * interrupt for real. This prevents IRQ storms from unhandled | 464 | * interrupt for real. This prevents IRQ storms from unhandled | 
| diff --git a/arch/ia64/kernel/irq.c b/arch/ia64/kernel/irq.c index 5ce908ef9c95..9c72ea3f6432 100644 --- a/arch/ia64/kernel/irq.c +++ b/arch/ia64/kernel/irq.c | |||
| @@ -101,7 +101,6 @@ void set_irq_affinity_info (unsigned int irq, int hwid, int redir) | |||
| 101 | 101 | ||
| 102 | if (irq < NR_IRQS) { | 102 | if (irq < NR_IRQS) { | 
| 103 | irq_affinity[irq] = mask; | 103 | irq_affinity[irq] = mask; | 
| 104 | set_irq_info(irq, mask); | ||
| 105 | irq_redir[irq] = (char) (redir & 0xff); | 104 | irq_redir[irq] = (char) (redir & 0xff); | 
| 106 | } | 105 | } | 
| 107 | } | 106 | } | 
| diff --git a/arch/powerpc/kernel/prom_init.c b/arch/powerpc/kernel/prom_init.c index 078fb5533541..2d80653aa2af 100644 --- a/arch/powerpc/kernel/prom_init.c +++ b/arch/powerpc/kernel/prom_init.c | |||
| @@ -1636,7 +1636,7 @@ static int __init prom_find_machine_type(void) | |||
| 1636 | compat, sizeof(compat)-1); | 1636 | compat, sizeof(compat)-1); | 
| 1637 | if (len <= 0) | 1637 | if (len <= 0) | 
| 1638 | return PLATFORM_GENERIC; | 1638 | return PLATFORM_GENERIC; | 
| 1639 | if (strncmp(compat, RELOC("chrp"), 4)) | 1639 | if (strcmp(compat, RELOC("chrp"))) | 
| 1640 | return PLATFORM_GENERIC; | 1640 | return PLATFORM_GENERIC; | 
| 1641 | 1641 | ||
| 1642 | /* Default to pSeries. We need to know if we are running LPAR */ | 1642 | /* Default to pSeries. We need to know if we are running LPAR */ | 
| diff --git a/arch/powerpc/platforms/pseries/setup.c b/arch/powerpc/platforms/pseries/setup.c index 5eb55ef1c91c..5f79f01c44f2 100644 --- a/arch/powerpc/platforms/pseries/setup.c +++ b/arch/powerpc/platforms/pseries/setup.c | |||
| @@ -255,7 +255,7 @@ static int __init pSeries_init_panel(void) | |||
| 255 | { | 255 | { | 
| 256 | /* Manually leave the kernel version on the panel. */ | 256 | /* Manually leave the kernel version on the panel. */ | 
| 257 | ppc_md.progress("Linux ppc64\n", 0); | 257 | ppc_md.progress("Linux ppc64\n", 0); | 
| 258 | ppc_md.progress(system_utsname.version, 0); | 258 | ppc_md.progress(system_utsname.release, 0); | 
| 259 | 259 | ||
| 260 | return 0; | 260 | return 0; | 
| 261 | } | 261 | } | 
| diff --git a/arch/s390/kernel/compat_wrapper.S b/arch/s390/kernel/compat_wrapper.S index ef5b9c44b86b..4d53b2739357 100644 --- a/arch/s390/kernel/compat_wrapper.S +++ b/arch/s390/kernel/compat_wrapper.S | |||
| @@ -1650,3 +1650,11 @@ sys_tee_wrapper: | |||
| 1650 | llgfr %r4,%r4 # size_t | 1650 | llgfr %r4,%r4 # size_t | 
| 1651 | llgfr %r5,%r5 # unsigned int | 1651 | llgfr %r5,%r5 # unsigned int | 
| 1652 | jg sys_tee | 1652 | jg sys_tee | 
| 1653 | |||
| 1654 | .globl compat_sys_vmsplice_wrapper | ||
| 1655 | compat_sys_vmsplice_wrapper: | ||
| 1656 | lgfr %r2,%r2 # int | ||
| 1657 | llgtr %r3,%r3 # compat_iovec * | ||
| 1658 | llgfr %r4,%r4 # unsigned int | ||
| 1659 | llgfr %r5,%r5 # unsigned int | ||
| 1660 | jg compat_sys_vmsplice | ||
| diff --git a/arch/s390/kernel/syscalls.S b/arch/s390/kernel/syscalls.S index fc2c0767202b..93be1d56c036 100644 --- a/arch/s390/kernel/syscalls.S +++ b/arch/s390/kernel/syscalls.S | |||
| @@ -317,3 +317,4 @@ SYSCALL(sys_get_robust_list,sys_get_robust_list,compat_sys_get_robust_list_wrapp | |||
| 317 | SYSCALL(sys_splice,sys_splice,sys_splice_wrapper) | 317 | SYSCALL(sys_splice,sys_splice,sys_splice_wrapper) | 
| 318 | SYSCALL(sys_sync_file_range,sys_sync_file_range,sys_sync_file_range_wrapper) | 318 | SYSCALL(sys_sync_file_range,sys_sync_file_range,sys_sync_file_range_wrapper) | 
| 319 | SYSCALL(sys_tee,sys_tee,sys_tee_wrapper) | 319 | SYSCALL(sys_tee,sys_tee,sys_tee_wrapper) | 
| 320 | SYSCALL(sys_vmsplice,sys_vmsplice,compat_sys_vmsplice_wrapper) | ||
| diff --git a/arch/s390/kernel/time.c b/arch/s390/kernel/time.c index fea043b69b91..029f09901b85 100644 --- a/arch/s390/kernel/time.c +++ b/arch/s390/kernel/time.c | |||
| @@ -249,18 +249,19 @@ static inline void stop_hz_timer(void) | |||
| 249 | unsigned long flags; | 249 | unsigned long flags; | 
| 250 | unsigned long seq, next; | 250 | unsigned long seq, next; | 
| 251 | __u64 timer, todval; | 251 | __u64 timer, todval; | 
| 252 | int cpu = smp_processor_id(); | ||
| 252 | 253 | ||
| 253 | if (sysctl_hz_timer != 0) | 254 | if (sysctl_hz_timer != 0) | 
| 254 | return; | 255 | return; | 
| 255 | 256 | ||
| 256 | cpu_set(smp_processor_id(), nohz_cpu_mask); | 257 | cpu_set(cpu, nohz_cpu_mask); | 
| 257 | 258 | ||
| 258 | /* | 259 | /* | 
| 259 | * Leave the clock comparator set up for the next timer | 260 | * Leave the clock comparator set up for the next timer | 
| 260 | * tick if either rcu or a softirq is pending. | 261 | * tick if either rcu or a softirq is pending. | 
| 261 | */ | 262 | */ | 
| 262 | if (rcu_pending(smp_processor_id()) || local_softirq_pending()) { | 263 | if (rcu_needs_cpu(cpu) || local_softirq_pending()) { | 
| 263 | cpu_clear(smp_processor_id(), nohz_cpu_mask); | 264 | cpu_clear(cpu, nohz_cpu_mask); | 
| 264 | return; | 265 | return; | 
| 265 | } | 266 | } | 
| 266 | 267 | ||
| diff --git a/arch/x86_64/kernel/pci-nommu.c b/arch/x86_64/kernel/pci-nommu.c index 44adcc2d5e5b..1f6ecc62061d 100644 --- a/arch/x86_64/kernel/pci-nommu.c +++ b/arch/x86_64/kernel/pci-nommu.c | |||
| @@ -12,9 +12,10 @@ static int | |||
| 12 | check_addr(char *name, struct device *hwdev, dma_addr_t bus, size_t size) | 12 | check_addr(char *name, struct device *hwdev, dma_addr_t bus, size_t size) | 
| 13 | { | 13 | { | 
| 14 | if (hwdev && bus + size > *hwdev->dma_mask) { | 14 | if (hwdev && bus + size > *hwdev->dma_mask) { | 
| 15 | printk(KERN_ERR | 15 | if (*hwdev->dma_mask >= 0xffffffffULL) | 
| 16 | "nommu_%s: overflow %Lx+%lu of device mask %Lx\n", | 16 | printk(KERN_ERR | 
| 17 | name, (long long)bus, size, (long long)*hwdev->dma_mask); | 17 | "nommu_%s: overflow %Lx+%lu of device mask %Lx\n", | 
| 18 | name, (long long)bus, size, (long long)*hwdev->dma_mask); | ||
| 18 | return 0; | 19 | return 0; | 
| 19 | } | 20 | } | 
| 20 | return 1; | 21 | return 1; | 
| diff --git a/arch/x86_64/kernel/traps.c b/arch/x86_64/kernel/traps.c index 6b87268c5c2e..cea335e8746c 100644 --- a/arch/x86_64/kernel/traps.c +++ b/arch/x86_64/kernel/traps.c | |||
| @@ -102,6 +102,8 @@ static inline void preempt_conditional_cli(struct pt_regs *regs) | |||
| 102 | { | 102 | { | 
| 103 | if (regs->eflags & X86_EFLAGS_IF) | 103 | if (regs->eflags & X86_EFLAGS_IF) | 
| 104 | local_irq_disable(); | 104 | local_irq_disable(); | 
| 105 | /* Make sure to not schedule here because we could be running | ||
| 106 | on an exception stack. */ | ||
| 105 | preempt_enable_no_resched(); | 107 | preempt_enable_no_resched(); | 
| 106 | } | 108 | } | 
| 107 | 109 | ||
| @@ -483,8 +485,6 @@ static void __kprobes do_trap(int trapnr, int signr, char *str, | |||
| 483 | { | 485 | { | 
| 484 | struct task_struct *tsk = current; | 486 | struct task_struct *tsk = current; | 
| 485 | 487 | ||
| 486 | conditional_sti(regs); | ||
| 487 | |||
| 488 | tsk->thread.error_code = error_code; | 488 | tsk->thread.error_code = error_code; | 
| 489 | tsk->thread.trap_no = trapnr; | 489 | tsk->thread.trap_no = trapnr; | 
| 490 | 490 | ||
| @@ -521,6 +521,7 @@ asmlinkage void do_##name(struct pt_regs * regs, long error_code) \ | |||
| 521 | if (notify_die(DIE_TRAP, str, regs, error_code, trapnr, signr) \ | 521 | if (notify_die(DIE_TRAP, str, regs, error_code, trapnr, signr) \ | 
| 522 | == NOTIFY_STOP) \ | 522 | == NOTIFY_STOP) \ | 
| 523 | return; \ | 523 | return; \ | 
| 524 | conditional_sti(regs); \ | ||
| 524 | do_trap(trapnr, signr, str, regs, error_code, NULL); \ | 525 | do_trap(trapnr, signr, str, regs, error_code, NULL); \ | 
| 525 | } | 526 | } | 
| 526 | 527 | ||
| @@ -535,6 +536,7 @@ asmlinkage void do_##name(struct pt_regs * regs, long error_code) \ | |||
| 535 | if (notify_die(DIE_TRAP, str, regs, error_code, trapnr, signr) \ | 536 | if (notify_die(DIE_TRAP, str, regs, error_code, trapnr, signr) \ | 
| 536 | == NOTIFY_STOP) \ | 537 | == NOTIFY_STOP) \ | 
| 537 | return; \ | 538 | return; \ | 
| 539 | conditional_sti(regs); \ | ||
| 538 | do_trap(trapnr, signr, str, regs, error_code, &info); \ | 540 | do_trap(trapnr, signr, str, regs, error_code, &info); \ | 
| 539 | } | 541 | } | 
| 540 | 542 | ||
| @@ -548,7 +550,17 @@ DO_ERROR(10, SIGSEGV, "invalid TSS", invalid_TSS) | |||
| 548 | DO_ERROR(11, SIGBUS, "segment not present", segment_not_present) | 550 | DO_ERROR(11, SIGBUS, "segment not present", segment_not_present) | 
| 549 | DO_ERROR_INFO(17, SIGBUS, "alignment check", alignment_check, BUS_ADRALN, 0) | 551 | DO_ERROR_INFO(17, SIGBUS, "alignment check", alignment_check, BUS_ADRALN, 0) | 
| 550 | DO_ERROR(18, SIGSEGV, "reserved", reserved) | 552 | DO_ERROR(18, SIGSEGV, "reserved", reserved) | 
| 551 | DO_ERROR(12, SIGBUS, "stack segment", stack_segment) | 553 | |
| 554 | /* Runs on IST stack */ | ||
| 555 | asmlinkage void do_stack_segment(struct pt_regs *regs, long error_code) | ||
| 556 | { | ||
| 557 | if (notify_die(DIE_TRAP, "stack segment", regs, error_code, | ||
| 558 | 12, SIGBUS) == NOTIFY_STOP) | ||
| 559 | return; | ||
| 560 | preempt_conditional_sti(regs); | ||
| 561 | do_trap(12, SIGBUS, "stack segment", regs, error_code, NULL); | ||
| 562 | preempt_conditional_cli(regs); | ||
| 563 | } | ||
| 552 | 564 | ||
| 553 | asmlinkage void do_double_fault(struct pt_regs * regs, long error_code) | 565 | asmlinkage void do_double_fault(struct pt_regs * regs, long error_code) | 
| 554 | { | 566 | { | 
| @@ -682,8 +694,9 @@ asmlinkage void __kprobes do_int3(struct pt_regs * regs, long error_code) | |||
| 682 | if (notify_die(DIE_INT3, "int3", regs, error_code, 3, SIGTRAP) == NOTIFY_STOP) { | 694 | if (notify_die(DIE_INT3, "int3", regs, error_code, 3, SIGTRAP) == NOTIFY_STOP) { | 
| 683 | return; | 695 | return; | 
| 684 | } | 696 | } | 
| 697 | preempt_conditional_sti(regs); | ||
| 685 | do_trap(3, SIGTRAP, "int3", regs, error_code, NULL); | 698 | do_trap(3, SIGTRAP, "int3", regs, error_code, NULL); | 
| 686 | return; | 699 | preempt_conditional_cli(regs); | 
| 687 | } | 700 | } | 
| 688 | 701 | ||
| 689 | /* Help handler running on IST stack to switch back to user stack | 702 | /* Help handler running on IST stack to switch back to user stack | 
| diff --git a/arch/x86_64/mm/srat.c b/arch/x86_64/mm/srat.c index 15ae9fcd65a7..e1513532df29 100644 --- a/arch/x86_64/mm/srat.c +++ b/arch/x86_64/mm/srat.c | |||
| @@ -34,7 +34,10 @@ static nodemask_t nodes_found __initdata; | |||
| 34 | static struct bootnode nodes[MAX_NUMNODES] __initdata; | 34 | static struct bootnode nodes[MAX_NUMNODES] __initdata; | 
| 35 | static struct bootnode nodes_add[MAX_NUMNODES] __initdata; | 35 | static struct bootnode nodes_add[MAX_NUMNODES] __initdata; | 
| 36 | static int found_add_area __initdata; | 36 | static int found_add_area __initdata; | 
| 37 | int hotadd_percent __initdata = 10; | 37 | int hotadd_percent __initdata = 0; | 
| 38 | #ifndef RESERVE_HOTADD | ||
| 39 | #define hotadd_percent 0 /* Ignore all settings */ | ||
| 40 | #endif | ||
| 38 | static u8 pxm2node[256] = { [0 ... 255] = 0xff }; | 41 | static u8 pxm2node[256] = { [0 ... 255] = 0xff }; | 
| 39 | 42 | ||
| 40 | /* Too small nodes confuse the VM badly. Usually they result | 43 | /* Too small nodes confuse the VM badly. Usually they result | 
| @@ -103,6 +106,7 @@ static __init void bad_srat(void) | |||
| 103 | int i; | 106 | int i; | 
| 104 | printk(KERN_ERR "SRAT: SRAT not used.\n"); | 107 | printk(KERN_ERR "SRAT: SRAT not used.\n"); | 
| 105 | acpi_numa = -1; | 108 | acpi_numa = -1; | 
| 109 | found_add_area = 0; | ||
| 106 | for (i = 0; i < MAX_LOCAL_APIC; i++) | 110 | for (i = 0; i < MAX_LOCAL_APIC; i++) | 
| 107 | apicid_to_node[i] = NUMA_NO_NODE; | 111 | apicid_to_node[i] = NUMA_NO_NODE; | 
| 108 | for (i = 0; i < MAX_NUMNODES; i++) | 112 | for (i = 0; i < MAX_NUMNODES; i++) | 
| @@ -154,7 +158,8 @@ acpi_numa_processor_affinity_init(struct acpi_table_processor_affinity *pa) | |||
| 154 | int pxm, node; | 158 | int pxm, node; | 
| 155 | if (srat_disabled()) | 159 | if (srat_disabled()) | 
| 156 | return; | 160 | return; | 
| 157 | if (pa->header.length != sizeof(struct acpi_table_processor_affinity)) { bad_srat(); | 161 | if (pa->header.length != sizeof(struct acpi_table_processor_affinity)) { | 
| 162 | bad_srat(); | ||
| 158 | return; | 163 | return; | 
| 159 | } | 164 | } | 
| 160 | if (pa->flags.enabled == 0) | 165 | if (pa->flags.enabled == 0) | 
| @@ -191,15 +196,17 @@ static int hotadd_enough_memory(struct bootnode *nd) | |||
| 191 | allowed = (end_pfn - e820_hole_size(0, end_pfn)) * PAGE_SIZE; | 196 | allowed = (end_pfn - e820_hole_size(0, end_pfn)) * PAGE_SIZE; | 
| 192 | allowed = (allowed / 100) * hotadd_percent; | 197 | allowed = (allowed / 100) * hotadd_percent; | 
| 193 | if (allocated + mem > allowed) { | 198 | if (allocated + mem > allowed) { | 
| 199 | unsigned long range; | ||
| 194 | /* Give them at least part of their hotadd memory upto hotadd_percent | 200 | /* Give them at least part of their hotadd memory upto hotadd_percent | 
| 195 | It would be better to spread the limit out | 201 | It would be better to spread the limit out | 
| 196 | over multiple hotplug areas, but that is too complicated | 202 | over multiple hotplug areas, but that is too complicated | 
| 197 | right now */ | 203 | right now */ | 
| 198 | if (allocated >= allowed) | 204 | if (allocated >= allowed) | 
| 199 | return 0; | 205 | return 0; | 
| 200 | pages = (allowed - allocated + mem) / sizeof(struct page); | 206 | range = allowed - allocated; | 
| 207 | pages = (range / PAGE_SIZE); | ||
| 201 | mem = pages * sizeof(struct page); | 208 | mem = pages * sizeof(struct page); | 
| 202 | nd->end = nd->start + pages*PAGE_SIZE; | 209 | nd->end = nd->start + range; | 
| 203 | } | 210 | } | 
| 204 | /* Not completely fool proof, but a good sanity check */ | 211 | /* Not completely fool proof, but a good sanity check */ | 
| 205 | addr = find_e820_area(last_area_end, end_pfn<<PAGE_SHIFT, mem); | 212 | addr = find_e820_area(last_area_end, end_pfn<<PAGE_SHIFT, mem); | 
| diff --git a/drivers/char/Kconfig b/drivers/char/Kconfig index 402296670d3a..78d928f9d9f1 100644 --- a/drivers/char/Kconfig +++ b/drivers/char/Kconfig | |||
| @@ -291,7 +291,7 @@ config SX | |||
| 291 | 291 | ||
| 292 | config RIO | 292 | config RIO | 
| 293 | tristate "Specialix RIO system support" | 293 | tristate "Specialix RIO system support" | 
| 294 | depends on SERIAL_NONSTANDARD && !64BIT | 294 | depends on SERIAL_NONSTANDARD | 
| 295 | help | 295 | help | 
| 296 | This is a driver for the Specialix RIO, a smart serial card which | 296 | This is a driver for the Specialix RIO, a smart serial card which | 
| 297 | drives an outboard box that can support up to 128 ports. Product | 297 | drives an outboard box that can support up to 128 ports. Product | 
| diff --git a/drivers/char/rio/host.h b/drivers/char/rio/host.h index 3ec73d1a279a..179cdbea712b 100644 --- a/drivers/char/rio/host.h +++ b/drivers/char/rio/host.h | |||
| @@ -33,12 +33,6 @@ | |||
| 33 | #ifndef __rio_host_h__ | 33 | #ifndef __rio_host_h__ | 
| 34 | #define __rio_host_h__ | 34 | #define __rio_host_h__ | 
| 35 | 35 | ||
| 36 | #ifdef SCCS_LABELS | ||
| 37 | #ifndef lint | ||
| 38 | static char *_host_h_sccs_ = "@(#)host.h 1.2"; | ||
| 39 | #endif | ||
| 40 | #endif | ||
| 41 | |||
| 42 | /* | 36 | /* | 
| 43 | ** the host structure - one per host card in the system. | 37 | ** the host structure - one per host card in the system. | 
| 44 | */ | 38 | */ | 
| @@ -77,9 +71,6 @@ struct Host { | |||
| 77 | #define RC_STARTUP 1 | 71 | #define RC_STARTUP 1 | 
| 78 | #define RC_RUNNING 2 | 72 | #define RC_RUNNING 2 | 
| 79 | #define RC_STUFFED 3 | 73 | #define RC_STUFFED 3 | 
| 80 | #define RC_SOMETHING 4 | ||
| 81 | #define RC_SOMETHING_NEW 5 | ||
| 82 | #define RC_SOMETHING_ELSE 6 | ||
| 83 | #define RC_READY 7 | 74 | #define RC_READY 7 | 
| 84 | #define RUN_STATE 7 | 75 | #define RUN_STATE 7 | 
| 85 | /* | 76 | /* | 
| diff --git a/drivers/char/rio/rioboot.c b/drivers/char/rio/rioboot.c index acda9326c2ef..290143addd34 100644 --- a/drivers/char/rio/rioboot.c +++ b/drivers/char/rio/rioboot.c | |||
| @@ -34,6 +34,7 @@ | |||
| 34 | #include <linux/slab.h> | 34 | #include <linux/slab.h> | 
| 35 | #include <linux/termios.h> | 35 | #include <linux/termios.h> | 
| 36 | #include <linux/serial.h> | 36 | #include <linux/serial.h> | 
| 37 | #include <linux/vmalloc.h> | ||
| 37 | #include <asm/semaphore.h> | 38 | #include <asm/semaphore.h> | 
| 38 | #include <linux/generic_serial.h> | 39 | #include <linux/generic_serial.h> | 
| 39 | #include <linux/errno.h> | 40 | #include <linux/errno.h> | 
| diff --git a/drivers/char/rio/rioctrl.c b/drivers/char/rio/rioctrl.c index d31aba62bb7f..75b2557c37ec 100644 --- a/drivers/char/rio/rioctrl.c +++ b/drivers/char/rio/rioctrl.c | |||
| @@ -1394,14 +1394,17 @@ int RIOPreemptiveCmd(struct rio_info *p, struct Port *PortP, u8 Cmd) | |||
| 1394 | return RIO_FAIL; | 1394 | return RIO_FAIL; | 
| 1395 | } | 1395 | } | 
| 1396 | 1396 | ||
| 1397 | if (((int) ((char) PortP->InUse) == -1) || !(CmdBlkP = RIOGetCmdBlk())) { | 1397 | if ((PortP->InUse == (typeof(PortP->InUse))-1) || | 
| 1398 | rio_dprintk(RIO_DEBUG_CTRL, "Cannot allocate command block for command %d on port %d\n", Cmd, PortP->PortNum); | 1398 | !(CmdBlkP = RIOGetCmdBlk())) { | 
| 1399 | rio_dprintk(RIO_DEBUG_CTRL, "Cannot allocate command block " | ||
| 1400 | "for command %d on port %d\n", Cmd, PortP->PortNum); | ||
| 1399 | return RIO_FAIL; | 1401 | return RIO_FAIL; | 
| 1400 | } | 1402 | } | 
| 1401 | 1403 | ||
| 1402 | rio_dprintk(RIO_DEBUG_CTRL, "Command blk %p - InUse now %d\n", CmdBlkP, PortP->InUse); | 1404 | rio_dprintk(RIO_DEBUG_CTRL, "Command blk %p - InUse now %d\n", | 
| 1405 | CmdBlkP, PortP->InUse); | ||
| 1403 | 1406 | ||
| 1404 | PktCmdP = (struct PktCmd_M *) &CmdBlkP->Packet.data[0]; | 1407 | PktCmdP = (struct PktCmd_M *)&CmdBlkP->Packet.data[0]; | 
| 1405 | 1408 | ||
| 1406 | CmdBlkP->Packet.src_unit = 0; | 1409 | CmdBlkP->Packet.src_unit = 0; | 
| 1407 | if (PortP->SecondBlock) | 1410 | if (PortP->SecondBlock) | 
| @@ -1425,38 +1428,46 @@ int RIOPreemptiveCmd(struct rio_info *p, struct Port *PortP, u8 Cmd) | |||
| 1425 | 1428 | ||
| 1426 | switch (Cmd) { | 1429 | switch (Cmd) { | 
| 1427 | case MEMDUMP: | 1430 | case MEMDUMP: | 
| 1428 | rio_dprintk(RIO_DEBUG_CTRL, "Queue MEMDUMP command blk %p (addr 0x%x)\n", CmdBlkP, (int) SubCmd.Addr); | 1431 | rio_dprintk(RIO_DEBUG_CTRL, "Queue MEMDUMP command blk %p " | 
| 1432 | "(addr 0x%x)\n", CmdBlkP, (int) SubCmd.Addr); | ||
| 1429 | PktCmdP->SubCommand = MEMDUMP; | 1433 | PktCmdP->SubCommand = MEMDUMP; | 
| 1430 | PktCmdP->SubAddr = SubCmd.Addr; | 1434 | PktCmdP->SubAddr = SubCmd.Addr; | 
| 1431 | break; | 1435 | break; | 
| 1432 | case FCLOSE: | 1436 | case FCLOSE: | 
| 1433 | rio_dprintk(RIO_DEBUG_CTRL, "Queue FCLOSE command blk %p\n", CmdBlkP); | 1437 | rio_dprintk(RIO_DEBUG_CTRL, "Queue FCLOSE command blk %p\n", | 
| 1438 | CmdBlkP); | ||
| 1434 | break; | 1439 | break; | 
| 1435 | case READ_REGISTER: | 1440 | case READ_REGISTER: | 
| 1436 | rio_dprintk(RIO_DEBUG_CTRL, "Queue READ_REGISTER (0x%x) command blk %p\n", (int) SubCmd.Addr, CmdBlkP); | 1441 | rio_dprintk(RIO_DEBUG_CTRL, "Queue READ_REGISTER (0x%x) " | 
| 1442 | "command blk %p\n", (int) SubCmd.Addr, CmdBlkP); | ||
| 1437 | PktCmdP->SubCommand = READ_REGISTER; | 1443 | PktCmdP->SubCommand = READ_REGISTER; | 
| 1438 | PktCmdP->SubAddr = SubCmd.Addr; | 1444 | PktCmdP->SubAddr = SubCmd.Addr; | 
| 1439 | break; | 1445 | break; | 
| 1440 | case RESUME: | 1446 | case RESUME: | 
| 1441 | rio_dprintk(RIO_DEBUG_CTRL, "Queue RESUME command blk %p\n", CmdBlkP); | 1447 | rio_dprintk(RIO_DEBUG_CTRL, "Queue RESUME command blk %p\n", | 
| 1448 | CmdBlkP); | ||
| 1442 | break; | 1449 | break; | 
| 1443 | case RFLUSH: | 1450 | case RFLUSH: | 
| 1444 | rio_dprintk(RIO_DEBUG_CTRL, "Queue RFLUSH command blk %p\n", CmdBlkP); | 1451 | rio_dprintk(RIO_DEBUG_CTRL, "Queue RFLUSH command blk %p\n", | 
| 1452 | CmdBlkP); | ||
| 1445 | CmdBlkP->PostFuncP = RIORFlushEnable; | 1453 | CmdBlkP->PostFuncP = RIORFlushEnable; | 
| 1446 | break; | 1454 | break; | 
| 1447 | case SUSPEND: | 1455 | case SUSPEND: | 
| 1448 | rio_dprintk(RIO_DEBUG_CTRL, "Queue SUSPEND command blk %p\n", CmdBlkP); | 1456 | rio_dprintk(RIO_DEBUG_CTRL, "Queue SUSPEND command blk %p\n", | 
| 1457 | CmdBlkP); | ||
| 1449 | break; | 1458 | break; | 
| 1450 | 1459 | ||
| 1451 | case MGET: | 1460 | case MGET: | 
| 1452 | rio_dprintk(RIO_DEBUG_CTRL, "Queue MGET command blk %p\n", CmdBlkP); | 1461 | rio_dprintk(RIO_DEBUG_CTRL, "Queue MGET command blk %p\n", | 
| 1462 | CmdBlkP); | ||
| 1453 | break; | 1463 | break; | 
| 1454 | 1464 | ||
| 1455 | case MSET: | 1465 | case MSET: | 
| 1456 | case MBIC: | 1466 | case MBIC: | 
| 1457 | case MBIS: | 1467 | case MBIS: | 
| 1458 | CmdBlkP->Packet.data[4] = (char) PortP->ModemLines; | 1468 | CmdBlkP->Packet.data[4] = (char) PortP->ModemLines; | 
| 1459 | rio_dprintk(RIO_DEBUG_CTRL, "Queue MSET/MBIC/MBIS command blk %p\n", CmdBlkP); | 1469 | rio_dprintk(RIO_DEBUG_CTRL, "Queue MSET/MBIC/MBIS command " | 
| 1470 | "blk %p\n", CmdBlkP); | ||
| 1460 | break; | 1471 | break; | 
| 1461 | 1472 | ||
| 1462 | case WFLUSH: | 1473 | case WFLUSH: | 
| @@ -1465,12 +1476,14 @@ int RIOPreemptiveCmd(struct rio_info *p, struct Port *PortP, u8 Cmd) | |||
| 1465 | ** allowed then we should not bother sending any more to the | 1476 | ** allowed then we should not bother sending any more to the | 
| 1466 | ** RTA. | 1477 | ** RTA. | 
| 1467 | */ | 1478 | */ | 
| 1468 | if ((int) ((char) PortP->WflushFlag) == (int) -1) { | 1479 | if (PortP->WflushFlag == (typeof(PortP->WflushFlag))-1) { | 
| 1469 | rio_dprintk(RIO_DEBUG_CTRL, "Trashed WFLUSH, WflushFlag about to wrap!"); | 1480 | rio_dprintk(RIO_DEBUG_CTRL, "Trashed WFLUSH, " | 
| 1481 | "WflushFlag about to wrap!"); | ||
| 1470 | RIOFreeCmdBlk(CmdBlkP); | 1482 | RIOFreeCmdBlk(CmdBlkP); | 
| 1471 | return (RIO_FAIL); | 1483 | return (RIO_FAIL); | 
| 1472 | } else { | 1484 | } else { | 
| 1473 | rio_dprintk(RIO_DEBUG_CTRL, "Queue WFLUSH command blk %p\n", CmdBlkP); | 1485 | rio_dprintk(RIO_DEBUG_CTRL, "Queue WFLUSH command " | 
| 1486 | "blk %p\n", CmdBlkP); | ||
| 1474 | CmdBlkP->PostFuncP = RIOWFlushMark; | 1487 | CmdBlkP->PostFuncP = RIOWFlushMark; | 
| 1475 | } | 1488 | } | 
| 1476 | break; | 1489 | break; | 
| diff --git a/drivers/char/rio/rioioctl.h b/drivers/char/rio/rioioctl.h index 14b83fae75c8..e8af5b30519e 100644 --- a/drivers/char/rio/rioioctl.h +++ b/drivers/char/rio/rioioctl.h | |||
| @@ -33,10 +33,6 @@ | |||
| 33 | #ifndef __rioioctl_h__ | 33 | #ifndef __rioioctl_h__ | 
| 34 | #define __rioioctl_h__ | 34 | #define __rioioctl_h__ | 
| 35 | 35 | ||
| 36 | #ifdef SCCS_LABELS | ||
| 37 | static char *_rioioctl_h_sccs_ = "@(#)rioioctl.h 1.2"; | ||
| 38 | #endif | ||
| 39 | |||
| 40 | /* | 36 | /* | 
| 41 | ** RIO device driver - user ioctls and associated structures. | 37 | ** RIO device driver - user ioctls and associated structures. | 
| 42 | */ | 38 | */ | 
| @@ -44,55 +40,13 @@ static char *_rioioctl_h_sccs_ = "@(#)rioioctl.h 1.2"; | |||
| 44 | struct portStats { | 40 | struct portStats { | 
| 45 | int port; | 41 | int port; | 
| 46 | int gather; | 42 | int gather; | 
| 47 | ulong txchars; | 43 | unsigned long txchars; | 
| 48 | ulong rxchars; | 44 | unsigned long rxchars; | 
| 49 | ulong opens; | 45 | unsigned long opens; | 
| 50 | ulong closes; | 46 | unsigned long closes; | 
| 51 | ulong ioctls; | 47 | unsigned long ioctls; | 
| 52 | }; | 48 | }; | 
| 53 | 49 | ||
| 54 | |||
| 55 | #define rIOC ('r'<<8) | ||
| 56 | #define TCRIOSTATE (rIOC | 1) | ||
| 57 | #define TCRIOXPON (rIOC | 2) | ||
| 58 | #define TCRIOXPOFF (rIOC | 3) | ||
| 59 | #define TCRIOXPCPS (rIOC | 4) | ||
| 60 | #define TCRIOXPRINT (rIOC | 5) | ||
| 61 | #define TCRIOIXANYON (rIOC | 6) | ||
| 62 | #define TCRIOIXANYOFF (rIOC | 7) | ||
| 63 | #define TCRIOIXONON (rIOC | 8) | ||
| 64 | #define TCRIOIXONOFF (rIOC | 9) | ||
| 65 | #define TCRIOMBIS (rIOC | 10) | ||
| 66 | #define TCRIOMBIC (rIOC | 11) | ||
| 67 | #define TCRIOTRIAD (rIOC | 12) | ||
| 68 | #define TCRIOTSTATE (rIOC | 13) | ||
| 69 | |||
| 70 | /* | ||
| 71 | ** 15.10.1998 ARG - ESIL 0761 part fix | ||
| 72 | ** Add RIO ioctls for manipulating RTS and CTS flow control, (as LynxOS | ||
| 73 | ** appears to not support hardware flow control). | ||
| 74 | */ | ||
| 75 | #define TCRIOCTSFLOWEN (rIOC | 14) /* enable CTS flow control */ | ||
| 76 | #define TCRIOCTSFLOWDIS (rIOC | 15) /* disable CTS flow control */ | ||
| 77 | #define TCRIORTSFLOWEN (rIOC | 16) /* enable RTS flow control */ | ||
| 78 | #define TCRIORTSFLOWDIS (rIOC | 17) /* disable RTS flow control */ | ||
| 79 | |||
| 80 | /* | ||
| 81 | ** 09.12.1998 ARG - ESIL 0776 part fix | ||
| 82 | ** Definition for 'RIOC' also appears in daemon.h, so we'd better do a | ||
| 83 | ** #ifndef here first. | ||
| 84 | ** 'RIO_QUICK_CHECK' also #define'd here as this ioctl is now | ||
| 85 | ** allowed to be used by customers. | ||
| 86 | ** | ||
| 87 | ** 05.02.1999 ARG - | ||
| 88 | ** This is what I've decied to do with ioctls etc., which are intended to be | ||
| 89 | ** invoked from users applications : | ||
| 90 | ** Anything that needs to be defined here will be removed from daemon.h, that | ||
| 91 | ** way it won't end up having to be defined/maintained in two places. The only | ||
| 92 | ** consequence of this is that this file should now be #include'd by daemon.h | ||
| 93 | ** | ||
| 94 | ** 'stats' ioctls now #define'd here as they are to be used by customers. | ||
| 95 | */ | ||
| 96 | #define RIOC ('R'<<8)|('i'<<16)|('o'<<24) | 50 | #define RIOC ('R'<<8)|('i'<<16)|('o'<<24) | 
| 97 | 51 | ||
| 98 | #define RIO_QUICK_CHECK (RIOC | 105) | 52 | #define RIO_QUICK_CHECK (RIOC | 105) | 
| diff --git a/drivers/char/tpm/Kconfig b/drivers/char/tpm/Kconfig index 1efde3b27619..fe00c7dfb649 100644 --- a/drivers/char/tpm/Kconfig +++ b/drivers/char/tpm/Kconfig | |||
| @@ -22,7 +22,7 @@ config TCG_TPM | |||
| 22 | 22 | ||
| 23 | config TCG_TIS | 23 | config TCG_TIS | 
| 24 | tristate "TPM Interface Specification 1.2 Interface" | 24 | tristate "TPM Interface Specification 1.2 Interface" | 
| 25 | depends on TCG_TPM | 25 | depends on TCG_TPM && PNPACPI | 
| 26 | ---help--- | 26 | ---help--- | 
| 27 | If you have a TPM security chip that is compliant with the | 27 | If you have a TPM security chip that is compliant with the | 
| 28 | TCG TIS 1.2 TPM specification say Yes and it will be accessible | 28 | TCG TIS 1.2 TPM specification say Yes and it will be accessible | 
| diff --git a/drivers/char/tpm/tpm.h b/drivers/char/tpm/tpm.h index 54a4c804e25f..050ced247f68 100644 --- a/drivers/char/tpm/tpm.h +++ b/drivers/char/tpm/tpm.h | |||
| @@ -140,7 +140,7 @@ extern int tpm_pm_resume(struct device *); | |||
| 140 | extern struct dentry ** tpm_bios_log_setup(char *); | 140 | extern struct dentry ** tpm_bios_log_setup(char *); | 
| 141 | extern void tpm_bios_log_teardown(struct dentry **); | 141 | extern void tpm_bios_log_teardown(struct dentry **); | 
| 142 | #else | 142 | #else | 
| 143 | static inline struct dentry* tpm_bios_log_setup(char *name) | 143 | static inline struct dentry ** tpm_bios_log_setup(char *name) | 
| 144 | { | 144 | { | 
| 145 | return NULL; | 145 | return NULL; | 
| 146 | } | 146 | } | 
| diff --git a/drivers/char/tpm/tpm_tis.c b/drivers/char/tpm/tpm_tis.c index b9cae9a238bb..f621168f38ae 100644 --- a/drivers/char/tpm/tpm_tis.c +++ b/drivers/char/tpm/tpm_tis.c | |||
| @@ -55,7 +55,7 @@ enum tis_int_flags { | |||
| 55 | }; | 55 | }; | 
| 56 | 56 | ||
| 57 | enum tis_defaults { | 57 | enum tis_defaults { | 
| 58 | TIS_MEM_BASE = 0xFED4000, | 58 | TIS_MEM_BASE = 0xFED40000, | 
| 59 | TIS_MEM_LEN = 0x5000, | 59 | TIS_MEM_LEN = 0x5000, | 
| 60 | TIS_SHORT_TIMEOUT = 750, /* ms */ | 60 | TIS_SHORT_TIMEOUT = 750, /* ms */ | 
| 61 | TIS_LONG_TIMEOUT = 2000, /* 2 sec */ | 61 | TIS_LONG_TIMEOUT = 2000, /* 2 sec */ | 
| diff --git a/drivers/char/watchdog/i8xx_tco.c b/drivers/char/watchdog/i8xx_tco.c index a13395e2c372..fa2ba9ebe42a 100644 --- a/drivers/char/watchdog/i8xx_tco.c +++ b/drivers/char/watchdog/i8xx_tco.c | |||
| @@ -33,11 +33,6 @@ | |||
| 33 | * 82801E (C-ICH) : document number 273599-001, 273645-002, | 33 | * 82801E (C-ICH) : document number 273599-001, 273645-002, | 
| 34 | * 82801EB (ICH5) : document number 252516-001, 252517-003, | 34 | * 82801EB (ICH5) : document number 252516-001, 252517-003, | 
| 35 | * 82801ER (ICH5R) : document number 252516-001, 252517-003, | 35 | * 82801ER (ICH5R) : document number 252516-001, 252517-003, | 
| 36 | * 82801FB (ICH6) : document number 301473-002, 301474-007, | ||
| 37 | * 82801FR (ICH6R) : document number 301473-002, 301474-007, | ||
| 38 | * 82801FBM (ICH6-M) : document number 301473-002, 301474-007, | ||
| 39 | * 82801FW (ICH6W) : document number 301473-001, 301474-007, | ||
| 40 | * 82801FRW (ICH6RW) : document number 301473-001, 301474-007 | ||
| 41 | * | 36 | * | 
| 42 | * 20000710 Nils Faerber | 37 | * 20000710 Nils Faerber | 
| 43 | * Initial Version 0.01 | 38 | * Initial Version 0.01 | 
| @@ -66,6 +61,10 @@ | |||
| 66 | * 20050807 Wim Van Sebroeck <wim@iguana.be> | 61 | * 20050807 Wim Van Sebroeck <wim@iguana.be> | 
| 67 | * 0.08 Make sure that the watchdog is only "armed" when started. | 62 | * 0.08 Make sure that the watchdog is only "armed" when started. | 
| 68 | * (Kernel Bug 4251) | 63 | * (Kernel Bug 4251) | 
| 64 | * 20060416 Wim Van Sebroeck <wim@iguana.be> | ||
| 65 | * 0.09 Remove support for the ICH6, ICH6R, ICH6-M, ICH6W and ICH6RW and | ||
| 66 | * ICH7 chipsets. (See Kernel Bug 6031 - other code will support these | ||
| 67 | * chipsets) | ||
| 69 | */ | 68 | */ | 
| 70 | 69 | ||
| 71 | /* | 70 | /* | 
| @@ -90,7 +89,7 @@ | |||
| 90 | #include "i8xx_tco.h" | 89 | #include "i8xx_tco.h" | 
| 91 | 90 | ||
| 92 | /* Module and version information */ | 91 | /* Module and version information */ | 
| 93 | #define TCO_VERSION "0.08" | 92 | #define TCO_VERSION "0.09" | 
| 94 | #define TCO_MODULE_NAME "i8xx TCO timer" | 93 | #define TCO_MODULE_NAME "i8xx TCO timer" | 
| 95 | #define TCO_DRIVER_NAME TCO_MODULE_NAME ", v" TCO_VERSION | 94 | #define TCO_DRIVER_NAME TCO_MODULE_NAME ", v" TCO_VERSION | 
| 96 | #define PFX TCO_MODULE_NAME ": " | 95 | #define PFX TCO_MODULE_NAME ": " | 
| @@ -391,11 +390,6 @@ static struct pci_device_id i8xx_tco_pci_tbl[] = { | |||
| 391 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801DB_12, PCI_ANY_ID, PCI_ANY_ID, }, | 390 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801DB_12, PCI_ANY_ID, PCI_ANY_ID, }, | 
| 392 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801E_0, PCI_ANY_ID, PCI_ANY_ID, }, | 391 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801E_0, PCI_ANY_ID, PCI_ANY_ID, }, | 
| 393 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801EB_0, PCI_ANY_ID, PCI_ANY_ID, }, | 392 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_82801EB_0, PCI_ANY_ID, PCI_ANY_ID, }, | 
| 394 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH6_0, PCI_ANY_ID, PCI_ANY_ID, }, | ||
| 395 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH6_1, PCI_ANY_ID, PCI_ANY_ID, }, | ||
| 396 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH6_2, PCI_ANY_ID, PCI_ANY_ID, }, | ||
| 397 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH7_0, PCI_ANY_ID, PCI_ANY_ID, }, | ||
| 398 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH7_1, PCI_ANY_ID, PCI_ANY_ID, }, | ||
| 399 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ESB_1, PCI_ANY_ID, PCI_ANY_ID, }, | 393 | { PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ESB_1, PCI_ANY_ID, PCI_ANY_ID, }, | 
| 400 | { 0, }, /* End of list */ | 394 | { 0, }, /* End of list */ | 
| 401 | }; | 395 | }; | 
| diff --git a/drivers/char/watchdog/s3c2410_wdt.c b/drivers/char/watchdog/s3c2410_wdt.c index 9dc54736e4eb..1ea04e9b2b0b 100644 --- a/drivers/char/watchdog/s3c2410_wdt.c +++ b/drivers/char/watchdog/s3c2410_wdt.c | |||
| @@ -423,6 +423,12 @@ static int s3c2410wdt_probe(struct platform_device *pdev) | |||
| 423 | if (tmr_atboot && started == 0) { | 423 | if (tmr_atboot && started == 0) { | 
| 424 | printk(KERN_INFO PFX "Starting Watchdog Timer\n"); | 424 | printk(KERN_INFO PFX "Starting Watchdog Timer\n"); | 
| 425 | s3c2410wdt_start(); | 425 | s3c2410wdt_start(); | 
| 426 | } else if (!tmr_atboot) { | ||
| 427 | /* if we're not enabling the watchdog, then ensure it is | ||
| 428 | * disabled if it has been left running from the bootloader | ||
| 429 | * or other source */ | ||
| 430 | |||
| 431 | s3c2410wdt_stop(); | ||
| 426 | } | 432 | } | 
| 427 | 433 | ||
| 428 | return 0; | 434 | return 0; | 
| diff --git a/drivers/char/watchdog/sc1200wdt.c b/drivers/char/watchdog/sc1200wdt.c index 515ce7572049..20b88f9b7be2 100644 --- a/drivers/char/watchdog/sc1200wdt.c +++ b/drivers/char/watchdog/sc1200wdt.c | |||
| @@ -377,7 +377,7 @@ static int __init sc1200wdt_init(void) | |||
| 377 | { | 377 | { | 
| 378 | int ret; | 378 | int ret; | 
| 379 | 379 | ||
| 380 | printk(banner); | 380 | printk("%s\n", banner); | 
| 381 | 381 | ||
| 382 | spin_lock_init(&sc1200wdt_lock); | 382 | spin_lock_init(&sc1200wdt_lock); | 
| 383 | sema_init(&open_sem, 1); | 383 | sema_init(&open_sem, 1); | 
| diff --git a/drivers/ide/legacy/ide-cs.c b/drivers/ide/legacy/ide-cs.c index 4961f1e764a7..602797a44208 100644 --- a/drivers/ide/legacy/ide-cs.c +++ b/drivers/ide/legacy/ide-cs.c | |||
| @@ -392,6 +392,7 @@ static struct pcmcia_device_id ide_ids[] = { | |||
| 392 | PCMCIA_DEVICE_PROD_ID12("FREECOM", "PCCARD-IDE", 0x5714cbf7, 0x48e0ab8e), | 392 | PCMCIA_DEVICE_PROD_ID12("FREECOM", "PCCARD-IDE", 0x5714cbf7, 0x48e0ab8e), | 
| 393 | PCMCIA_DEVICE_PROD_ID12("HITACHI", "FLASH", 0xf4f43949, 0x9eb86aae), | 393 | PCMCIA_DEVICE_PROD_ID12("HITACHI", "FLASH", 0xf4f43949, 0x9eb86aae), | 
| 394 | PCMCIA_DEVICE_PROD_ID12("HITACHI", "microdrive", 0xf4f43949, 0xa6d76178), | 394 | PCMCIA_DEVICE_PROD_ID12("HITACHI", "microdrive", 0xf4f43949, 0xa6d76178), | 
| 395 | PCMCIA_DEVICE_PROD_ID12("IBM", "microdrive", 0xb569a6e5, 0xa6d76178), | ||
| 395 | PCMCIA_DEVICE_PROD_ID12("IBM", "IBM17JSSFP20", 0xb569a6e5, 0xf2508753), | 396 | PCMCIA_DEVICE_PROD_ID12("IBM", "IBM17JSSFP20", 0xb569a6e5, 0xf2508753), | 
| 396 | PCMCIA_DEVICE_PROD_ID12("IO DATA", "CBIDE2 ", 0x547e66dc, 0x8671043b), | 397 | PCMCIA_DEVICE_PROD_ID12("IO DATA", "CBIDE2 ", 0x547e66dc, 0x8671043b), | 
| 397 | PCMCIA_DEVICE_PROD_ID12("IO DATA", "PCIDE", 0x547e66dc, 0x5c5ab149), | 398 | PCMCIA_DEVICE_PROD_ID12("IO DATA", "PCIDE", 0x547e66dc, 0x5c5ab149), | 
| diff --git a/drivers/ieee1394/ohci1394.c b/drivers/ieee1394/ohci1394.c index 19222878aae9..11f13778f139 100644 --- a/drivers/ieee1394/ohci1394.c +++ b/drivers/ieee1394/ohci1394.c | |||
| @@ -553,7 +553,7 @@ static void ohci_initialize(struct ti_ohci *ohci) | |||
| 553 | * register content. | 553 | * register content. | 
| 554 | * To actually enable physical responses is the job of our interrupt | 554 | * To actually enable physical responses is the job of our interrupt | 
| 555 | * handler which programs the physical request filter. */ | 555 | * handler which programs the physical request filter. */ | 
| 556 | reg_write(ohci, OHCI1394_PhyUpperBound, 0xffff0000); | 556 | reg_write(ohci, OHCI1394_PhyUpperBound, 0x01000000); | 
| 557 | 557 | ||
| 558 | DBGMSG("physUpperBoundOffset=%08x", | 558 | DBGMSG("physUpperBoundOffset=%08x", | 
| 559 | reg_read(ohci, OHCI1394_PhyUpperBound)); | 559 | reg_read(ohci, OHCI1394_PhyUpperBound)); | 
| diff --git a/drivers/ieee1394/sbp2.c b/drivers/ieee1394/sbp2.c index f4206604db03..8a23fb54c693 100644 --- a/drivers/ieee1394/sbp2.c +++ b/drivers/ieee1394/sbp2.c | |||
| @@ -42,6 +42,7 @@ | |||
| 42 | #include <linux/kernel.h> | 42 | #include <linux/kernel.h> | 
| 43 | #include <linux/list.h> | 43 | #include <linux/list.h> | 
| 44 | #include <linux/string.h> | 44 | #include <linux/string.h> | 
| 45 | #include <linux/stringify.h> | ||
| 45 | #include <linux/slab.h> | 46 | #include <linux/slab.h> | 
| 46 | #include <linux/interrupt.h> | 47 | #include <linux/interrupt.h> | 
| 47 | #include <linux/fs.h> | 48 | #include <linux/fs.h> | 
| @@ -117,7 +118,8 @@ MODULE_PARM_DESC(serialize_io, "Serialize I/O coming from scsi drivers (default | |||
| 117 | */ | 118 | */ | 
| 118 | static int max_sectors = SBP2_MAX_SECTORS; | 119 | static int max_sectors = SBP2_MAX_SECTORS; | 
| 119 | module_param(max_sectors, int, 0444); | 120 | module_param(max_sectors, int, 0444); | 
| 120 | MODULE_PARM_DESC(max_sectors, "Change max sectors per I/O supported (default = 255)"); | 121 | MODULE_PARM_DESC(max_sectors, "Change max sectors per I/O supported (default = " | 
| 122 | __stringify(SBP2_MAX_SECTORS) ")"); | ||
| 121 | 123 | ||
| 122 | /* | 124 | /* | 
| 123 | * Exclusive login to sbp2 device? In most cases, the sbp2 driver should | 125 | * Exclusive login to sbp2 device? In most cases, the sbp2 driver should | 
| @@ -135,18 +137,45 @@ module_param(exclusive_login, int, 0644); | |||
| 135 | MODULE_PARM_DESC(exclusive_login, "Exclusive login to sbp2 device (default = 1)"); | 137 | MODULE_PARM_DESC(exclusive_login, "Exclusive login to sbp2 device (default = 1)"); | 
| 136 | 138 | ||
| 137 | /* | 139 | /* | 
| 138 | * SCSI inquiry hack for really badly behaved sbp2 devices. Turn this on | 140 | * If any of the following workarounds is required for your device to work, | 
| 139 | * if your sbp2 device is not properly handling the SCSI inquiry command. | 141 | * please submit the kernel messages logged by sbp2 to the linux1394-devel | 
| 140 | * This hack makes the inquiry look more like a typical MS Windows inquiry | 142 | * mailing list. | 
| 141 | * by enforcing 36 byte inquiry and avoiding access to mode_sense page 8. | ||
| 142 | * | 143 | * | 
| 143 | * If force_inquiry_hack=1 is required for your device to work, | 144 | * - 128kB max transfer | 
| 144 | * please submit the logged sbp2_firmware_revision value of this device to | 145 | * Limit transfer size. Necessary for some old bridges. | 
| 145 | * the linux1394-devel mailing list. | 146 | * | 
| 147 | * - 36 byte inquiry | ||
| 148 | * When scsi_mod probes the device, let the inquiry command look like that | ||
| 149 | * from MS Windows. | ||
| 150 | * | ||
| 151 | * - skip mode page 8 | ||
| 152 | * Suppress sending of mode_sense for mode page 8 if the device pretends to | ||
| 153 | * support the SCSI Primary Block commands instead of Reduced Block Commands. | ||
| 154 | * | ||
| 155 | * - fix capacity | ||
| 156 | * Tell sd_mod to correct the last sector number reported by read_capacity. | ||
| 157 | * Avoids access beyond actual disk limits on devices with an off-by-one bug. | ||
| 158 | * Don't use this with devices which don't have this bug. | ||
| 159 | * | ||
| 160 | * - override internal blacklist | ||
| 161 | * Instead of adding to the built-in blacklist, use only the workarounds | ||
| 162 | * specified in the module load parameter. | ||
| 163 | * Useful if a blacklist entry interfered with a non-broken device. | ||
| 146 | */ | 164 | */ | 
| 165 | static int sbp2_default_workarounds; | ||
| 166 | module_param_named(workarounds, sbp2_default_workarounds, int, 0644); | ||
| 167 | MODULE_PARM_DESC(workarounds, "Work around device bugs (default = 0" | ||
| 168 | ", 128kB max transfer = " __stringify(SBP2_WORKAROUND_128K_MAX_TRANS) | ||
| 169 | ", 36 byte inquiry = " __stringify(SBP2_WORKAROUND_INQUIRY_36) | ||
| 170 | ", skip mode page 8 = " __stringify(SBP2_WORKAROUND_MODE_SENSE_8) | ||
| 171 | ", fix capacity = " __stringify(SBP2_WORKAROUND_FIX_CAPACITY) | ||
| 172 | ", override internal blacklist = " __stringify(SBP2_WORKAROUND_OVERRIDE) | ||
| 173 | ", or a combination)"); | ||
| 174 | |||
| 175 | /* legacy parameter */ | ||
| 147 | static int force_inquiry_hack; | 176 | static int force_inquiry_hack; | 
| 148 | module_param(force_inquiry_hack, int, 0644); | 177 | module_param(force_inquiry_hack, int, 0644); | 
| 149 | MODULE_PARM_DESC(force_inquiry_hack, "Force SCSI inquiry hack (default = 0)"); | 178 | MODULE_PARM_DESC(force_inquiry_hack, "Deprecated, use 'workarounds'"); | 
| 150 | 179 | ||
| 151 | /* | 180 | /* | 
| 152 | * Export information about protocols/devices supported by this driver. | 181 | * Export information about protocols/devices supported by this driver. | 
| @@ -266,14 +295,55 @@ static struct hpsb_protocol_driver sbp2_driver = { | |||
| 266 | }; | 295 | }; | 
| 267 | 296 | ||
| 268 | /* | 297 | /* | 
| 269 | * List of device firmwares that require the inquiry hack. | 298 | * List of devices with known bugs. | 
| 270 | * Yields a few false positives but did not break other devices so far. | 299 | * | 
| 300 | * The firmware_revision field, masked with 0xffff00, is the best indicator | ||
| 301 | * for the type of bridge chip of a device. It yields a few false positives | ||
| 302 | * but this did not break correctly behaving devices so far. | ||
| 271 | */ | 303 | */ | 
| 272 | static u32 sbp2_broken_inquiry_list[] = { | 304 | static const struct { | 
| 273 | 0x00002800, /* Stefan Richter <stefanr@s5r6.in-berlin.de> */ | 305 | u32 firmware_revision; | 
| 274 | /* DViCO Momobay CX-1 */ | 306 | u32 model_id; | 
| 275 | 0x00000200 /* Andreas Plesch <plesch@fas.harvard.edu> */ | 307 | unsigned workarounds; | 
| 276 | /* QPS Fire DVDBurner */ | 308 | } sbp2_workarounds_table[] = { | 
| 309 | /* TSB42AA9 */ { | ||
| 310 | .firmware_revision = 0x002800, | ||
| 311 | .workarounds = SBP2_WORKAROUND_INQUIRY_36 | | ||
| 312 | SBP2_WORKAROUND_MODE_SENSE_8, | ||
| 313 | }, | ||
| 314 | /* Initio bridges, actually only needed for some older ones */ { | ||
| 315 | .firmware_revision = 0x000200, | ||
| 316 | .workarounds = SBP2_WORKAROUND_INQUIRY_36, | ||
| 317 | }, | ||
| 318 | /* Symbios bridge */ { | ||
| 319 | .firmware_revision = 0xa0b800, | ||
| 320 | .workarounds = SBP2_WORKAROUND_128K_MAX_TRANS, | ||
| 321 | }, | ||
| 322 | /* | ||
| 323 | * Note about the following Apple iPod blacklist entries: | ||
| 324 | * | ||
| 325 | * There are iPods (2nd gen, 3rd gen) with model_id==0. Since our | ||
| 326 | * matching logic treats 0 as a wildcard, we cannot match this ID | ||
| 327 | * without rewriting the matching routine. Fortunately these iPods | ||
| 328 | * do not feature the read_capacity bug according to one report. | ||
| 329 | * Read_capacity behaviour as well as model_id could change due to | ||
| 330 | * Apple-supplied firmware updates though. | ||
| 331 | */ | ||
| 332 | /* iPod 4th generation */ { | ||
| 333 | .firmware_revision = 0x0a2700, | ||
| 334 | .model_id = 0x000021, | ||
| 335 | .workarounds = SBP2_WORKAROUND_FIX_CAPACITY, | ||
| 336 | }, | ||
| 337 | /* iPod mini */ { | ||
| 338 | .firmware_revision = 0x0a2700, | ||
| 339 | .model_id = 0x000023, | ||
| 340 | .workarounds = SBP2_WORKAROUND_FIX_CAPACITY, | ||
| 341 | }, | ||
| 342 | /* iPod Photo */ { | ||
| 343 | .firmware_revision = 0x0a2700, | ||
| 344 | .model_id = 0x00007e, | ||
| 345 | .workarounds = SBP2_WORKAROUND_FIX_CAPACITY, | ||
| 346 | } | ||
| 277 | }; | 347 | }; | 
| 278 | 348 | ||
| 279 | /************************************** | 349 | /************************************** | 
| @@ -765,11 +835,16 @@ static struct scsi_id_instance_data *sbp2_alloc_device(struct unit_directory *ud | |||
| 765 | 835 | ||
| 766 | /* Register the status FIFO address range. We could use the same FIFO | 836 | /* Register the status FIFO address range. We could use the same FIFO | 
| 767 | * for targets at different nodes. However we need different FIFOs per | 837 | * for targets at different nodes. However we need different FIFOs per | 
| 768 | * target in order to support multi-unit devices. */ | 838 | * target in order to support multi-unit devices. | 
| 839 | * The FIFO is located out of the local host controller's physical range | ||
| 840 | * but, if possible, within the posted write area. Status writes will | ||
| 841 | * then be performed as unified transactions. This slightly reduces | ||
| 842 | * bandwidth usage, and some Prolific based devices seem to require it. | ||
| 843 | */ | ||
| 769 | scsi_id->status_fifo_addr = hpsb_allocate_and_register_addrspace( | 844 | scsi_id->status_fifo_addr = hpsb_allocate_and_register_addrspace( | 
| 770 | &sbp2_highlevel, ud->ne->host, &sbp2_ops, | 845 | &sbp2_highlevel, ud->ne->host, &sbp2_ops, | 
| 771 | sizeof(struct sbp2_status_block), sizeof(quadlet_t), | 846 | sizeof(struct sbp2_status_block), sizeof(quadlet_t), | 
| 772 | ~0ULL, ~0ULL); | 847 | 0x010000000000ULL, CSR1212_ALL_SPACE_END); | 
| 773 | if (!scsi_id->status_fifo_addr) { | 848 | if (!scsi_id->status_fifo_addr) { | 
| 774 | SBP2_ERR("failed to allocate status FIFO address range"); | 849 | SBP2_ERR("failed to allocate status FIFO address range"); | 
| 775 | goto failed_alloc; | 850 | goto failed_alloc; | 
| @@ -1450,7 +1525,8 @@ static void sbp2_parse_unit_directory(struct scsi_id_instance_data *scsi_id, | |||
| 1450 | struct csr1212_dentry *dentry; | 1525 | struct csr1212_dentry *dentry; | 
| 1451 | u64 management_agent_addr; | 1526 | u64 management_agent_addr; | 
| 1452 | u32 command_set_spec_id, command_set, unit_characteristics, | 1527 | u32 command_set_spec_id, command_set, unit_characteristics, | 
| 1453 | firmware_revision, workarounds; | 1528 | firmware_revision; | 
| 1529 | unsigned workarounds; | ||
| 1454 | int i; | 1530 | int i; | 
| 1455 | 1531 | ||
| 1456 | SBP2_DEBUG_ENTER(); | 1532 | SBP2_DEBUG_ENTER(); | 
| @@ -1506,12 +1582,8 @@ static void sbp2_parse_unit_directory(struct scsi_id_instance_data *scsi_id, | |||
| 1506 | case SBP2_FIRMWARE_REVISION_KEY: | 1582 | case SBP2_FIRMWARE_REVISION_KEY: | 
| 1507 | /* Firmware revision */ | 1583 | /* Firmware revision */ | 
| 1508 | firmware_revision = kv->value.immediate; | 1584 | firmware_revision = kv->value.immediate; | 
| 1509 | if (force_inquiry_hack) | 1585 | SBP2_DEBUG("sbp2_firmware_revision = %x", | 
| 1510 | SBP2_INFO("sbp2_firmware_revision = %x", | 1586 | (unsigned int)firmware_revision); | 
| 1511 | (unsigned int)firmware_revision); | ||
| 1512 | else | ||
| 1513 | SBP2_DEBUG("sbp2_firmware_revision = %x", | ||
| 1514 | (unsigned int)firmware_revision); | ||
| 1515 | break; | 1587 | break; | 
| 1516 | 1588 | ||
| 1517 | default: | 1589 | default: | 
| @@ -1519,41 +1591,44 @@ static void sbp2_parse_unit_directory(struct scsi_id_instance_data *scsi_id, | |||
| 1519 | } | 1591 | } | 
| 1520 | } | 1592 | } | 
| 1521 | 1593 | ||
| 1522 | /* This is the start of our broken device checking. We try to hack | 1594 | workarounds = sbp2_default_workarounds; | 
| 1523 | * around oddities and known defects. */ | 1595 | if (force_inquiry_hack) { | 
| 1524 | workarounds = 0x0; | 1596 | SBP2_WARN("force_inquiry_hack is deprecated. " | 
| 1597 | "Use parameter 'workarounds' instead."); | ||
| 1598 | workarounds |= SBP2_WORKAROUND_INQUIRY_36; | ||
| 1599 | } | ||
| 1525 | 1600 | ||
| 1526 | /* If the vendor id is 0xa0b8 (Symbios vendor id), then we have a | 1601 | if (!(workarounds & SBP2_WORKAROUND_OVERRIDE)) | 
| 1527 | * bridge with 128KB max transfer size limitation. For sanity, we | 1602 | for (i = 0; i < ARRAY_SIZE(sbp2_workarounds_table); i++) { | 
| 1528 | * only voice this when the current max_sectors setting | 1603 | if (sbp2_workarounds_table[i].firmware_revision && | 
| 1529 | * exceeds the 128k limit. By default, that is not the case. | 1604 | sbp2_workarounds_table[i].firmware_revision != | 
| 1530 | * | 1605 | (firmware_revision & 0xffff00)) | 
| 1531 | * It would be really nice if we could detect this before the scsi | 1606 | continue; | 
| 1532 | * host gets initialized. That way we can down-force the | 1607 | if (sbp2_workarounds_table[i].model_id && | 
| 1533 | * max_sectors to account for it. That is not currently | 1608 | sbp2_workarounds_table[i].model_id != ud->model_id) | 
| 1534 | * possible. */ | 1609 | continue; | 
| 1535 | if ((firmware_revision & 0xffff00) == | 1610 | workarounds |= sbp2_workarounds_table[i].workarounds; | 
| 1536 | SBP2_128KB_BROKEN_FIRMWARE && | 1611 | break; | 
| 1537 | (max_sectors * 512) > (128*1024)) { | ||
| 1538 | SBP2_WARN("Node " NODE_BUS_FMT ": Bridge only supports 128KB max transfer size.", | ||
| 1539 | NODE_BUS_ARGS(ud->ne->host, ud->ne->nodeid)); | ||
| 1540 | SBP2_WARN("WARNING: Current max_sectors setting is larger than 128KB (%d sectors)!", | ||
| 1541 | max_sectors); | ||
| 1542 | workarounds |= SBP2_BREAKAGE_128K_MAX_TRANSFER; | ||
| 1543 | } | ||
| 1544 | |||
| 1545 | /* Check for a blacklisted set of devices that require us to force | ||
| 1546 | * a 36 byte host inquiry. This can be overriden as a module param | ||
| 1547 | * (to force all hosts). */ | ||
| 1548 | for (i = 0; i < ARRAY_SIZE(sbp2_broken_inquiry_list); i++) { | ||
| 1549 | if ((firmware_revision & 0xffff00) == | ||
| 1550 | sbp2_broken_inquiry_list[i]) { | ||
| 1551 | SBP2_WARN("Node " NODE_BUS_FMT ": Using 36byte inquiry workaround", | ||
| 1552 | NODE_BUS_ARGS(ud->ne->host, ud->ne->nodeid)); | ||
| 1553 | workarounds |= SBP2_BREAKAGE_INQUIRY_HACK; | ||
| 1554 | break; /* No need to continue. */ | ||
| 1555 | } | 1612 | } | 
| 1556 | } | 1613 | |
| 1614 | if (workarounds) | ||
| 1615 | SBP2_INFO("Workarounds for node " NODE_BUS_FMT ": 0x%x " | ||
| 1616 | "(firmware_revision 0x%06x, vendor_id 0x%06x," | ||
| 1617 | " model_id 0x%06x)", | ||
| 1618 | NODE_BUS_ARGS(ud->ne->host, ud->ne->nodeid), | ||
| 1619 | workarounds, firmware_revision, | ||
| 1620 | ud->vendor_id ? ud->vendor_id : ud->ne->vendor_id, | ||
| 1621 | ud->model_id); | ||
| 1622 | |||
| 1623 | /* We would need one SCSI host template for each target to adjust | ||
| 1624 | * max_sectors on the fly, therefore warn only. */ | ||
| 1625 | if (workarounds & SBP2_WORKAROUND_128K_MAX_TRANS && | ||
| 1626 | (max_sectors * 512) > (128 * 1024)) | ||
| 1627 | SBP2_WARN("Node " NODE_BUS_FMT ": Bridge only supports 128KB " | ||
| 1628 | "max transfer size. WARNING: Current max_sectors " | ||
| 1629 | "setting is larger than 128KB (%d sectors)", | ||
| 1630 | NODE_BUS_ARGS(ud->ne->host, ud->ne->nodeid), | ||
| 1631 | max_sectors); | ||
| 1557 | 1632 | ||
| 1558 | /* If this is a logical unit directory entry, process the parent | 1633 | /* If this is a logical unit directory entry, process the parent | 
| 1559 | * to get the values. */ | 1634 | * to get the values. */ | 
| @@ -2447,19 +2522,25 @@ static int sbp2scsi_slave_alloc(struct scsi_device *sdev) | |||
| 2447 | 2522 | ||
| 2448 | scsi_id->sdev = sdev; | 2523 | scsi_id->sdev = sdev; | 
| 2449 | 2524 | ||
| 2450 | if (force_inquiry_hack || | 2525 | if (scsi_id->workarounds & SBP2_WORKAROUND_INQUIRY_36) | 
| 2451 | scsi_id->workarounds & SBP2_BREAKAGE_INQUIRY_HACK) { | ||
| 2452 | sdev->inquiry_len = 36; | 2526 | sdev->inquiry_len = 36; | 
| 2453 | sdev->skip_ms_page_8 = 1; | ||
| 2454 | } | ||
| 2455 | return 0; | 2527 | return 0; | 
| 2456 | } | 2528 | } | 
| 2457 | 2529 | ||
| 2458 | static int sbp2scsi_slave_configure(struct scsi_device *sdev) | 2530 | static int sbp2scsi_slave_configure(struct scsi_device *sdev) | 
| 2459 | { | 2531 | { | 
| 2532 | struct scsi_id_instance_data *scsi_id = | ||
| 2533 | (struct scsi_id_instance_data *)sdev->host->hostdata[0]; | ||
| 2534 | |||
| 2460 | blk_queue_dma_alignment(sdev->request_queue, (512 - 1)); | 2535 | blk_queue_dma_alignment(sdev->request_queue, (512 - 1)); | 
| 2461 | sdev->use_10_for_rw = 1; | 2536 | sdev->use_10_for_rw = 1; | 
| 2462 | sdev->use_10_for_ms = 1; | 2537 | sdev->use_10_for_ms = 1; | 
| 2538 | |||
| 2539 | if (sdev->type == TYPE_DISK && | ||
| 2540 | scsi_id->workarounds & SBP2_WORKAROUND_MODE_SENSE_8) | ||
| 2541 | sdev->skip_ms_page_8 = 1; | ||
| 2542 | if (scsi_id->workarounds & SBP2_WORKAROUND_FIX_CAPACITY) | ||
| 2543 | sdev->fix_capacity = 1; | ||
| 2463 | return 0; | 2544 | return 0; | 
| 2464 | } | 2545 | } | 
| 2465 | 2546 | ||
| @@ -2603,7 +2684,9 @@ static int sbp2_module_init(void) | |||
| 2603 | scsi_driver_template.cmd_per_lun = 1; | 2684 | scsi_driver_template.cmd_per_lun = 1; | 
| 2604 | } | 2685 | } | 
| 2605 | 2686 | ||
| 2606 | /* Set max sectors (module load option). Default is 255 sectors. */ | 2687 | if (sbp2_default_workarounds & SBP2_WORKAROUND_128K_MAX_TRANS && | 
| 2688 | (max_sectors * 512) > (128 * 1024)) | ||
| 2689 | max_sectors = 128 * 1024 / 512; | ||
| 2607 | scsi_driver_template.max_sectors = max_sectors; | 2690 | scsi_driver_template.max_sectors = max_sectors; | 
| 2608 | 2691 | ||
| 2609 | /* Register our high level driver with 1394 stack */ | 2692 | /* Register our high level driver with 1394 stack */ | 
| diff --git a/drivers/ieee1394/sbp2.h b/drivers/ieee1394/sbp2.h index e2d357a9ea3a..f4ccc9d0fba4 100644 --- a/drivers/ieee1394/sbp2.h +++ b/drivers/ieee1394/sbp2.h | |||
| @@ -227,11 +227,6 @@ struct sbp2_status_block { | |||
| 227 | #define SBP2_SW_VERSION_ENTRY 0x00010483 | 227 | #define SBP2_SW_VERSION_ENTRY 0x00010483 | 
| 228 | 228 | ||
| 229 | /* | 229 | /* | 
| 230 | * Other misc defines | ||
| 231 | */ | ||
| 232 | #define SBP2_128KB_BROKEN_FIRMWARE 0xa0b800 | ||
| 233 | |||
| 234 | /* | ||
| 235 | * SCSI specific stuff | 230 | * SCSI specific stuff | 
| 236 | */ | 231 | */ | 
| 237 | 232 | ||
| @@ -239,6 +234,13 @@ struct sbp2_status_block { | |||
| 239 | #define SBP2_MAX_SECTORS 255 /* Max sectors supported */ | 234 | #define SBP2_MAX_SECTORS 255 /* Max sectors supported */ | 
| 240 | #define SBP2_MAX_CMDS 8 /* This should be safe */ | 235 | #define SBP2_MAX_CMDS 8 /* This should be safe */ | 
| 241 | 236 | ||
| 237 | /* Flags for detected oddities and brokeness */ | ||
| 238 | #define SBP2_WORKAROUND_128K_MAX_TRANS 0x1 | ||
| 239 | #define SBP2_WORKAROUND_INQUIRY_36 0x2 | ||
| 240 | #define SBP2_WORKAROUND_MODE_SENSE_8 0x4 | ||
| 241 | #define SBP2_WORKAROUND_FIX_CAPACITY 0x8 | ||
| 242 | #define SBP2_WORKAROUND_OVERRIDE 0x100 | ||
| 243 | |||
| 242 | /* This is the two dma types we use for cmd_dma below */ | 244 | /* This is the two dma types we use for cmd_dma below */ | 
| 243 | enum cmd_dma_types { | 245 | enum cmd_dma_types { | 
| 244 | CMD_DMA_NONE, | 246 | CMD_DMA_NONE, | 
| @@ -268,10 +270,6 @@ struct sbp2_command_info { | |||
| 268 | 270 | ||
| 269 | }; | 271 | }; | 
| 270 | 272 | ||
| 271 | /* A list of flags for detected oddities and brokeness. */ | ||
| 272 | #define SBP2_BREAKAGE_128K_MAX_TRANSFER 0x1 | ||
| 273 | #define SBP2_BREAKAGE_INQUIRY_HACK 0x2 | ||
| 274 | |||
| 275 | struct sbp2scsi_host_info; | 273 | struct sbp2scsi_host_info; | 
| 276 | 274 | ||
| 277 | /* | 275 | /* | 
| @@ -345,7 +343,7 @@ struct scsi_id_instance_data { | |||
| 345 | struct Scsi_Host *scsi_host; | 343 | struct Scsi_Host *scsi_host; | 
| 346 | 344 | ||
| 347 | /* Device specific workarounds/brokeness */ | 345 | /* Device specific workarounds/brokeness */ | 
| 348 | u32 workarounds; | 346 | unsigned workarounds; | 
| 349 | }; | 347 | }; | 
| 350 | 348 | ||
| 351 | /* Sbp2 host data structure (one per IEEE1394 host) */ | 349 | /* Sbp2 host data structure (one per IEEE1394 host) */ | 
| diff --git a/drivers/infiniband/core/uverbs_mem.c b/drivers/infiniband/core/uverbs_mem.c index 36a32c315668..efe147dbeb42 100644 --- a/drivers/infiniband/core/uverbs_mem.c +++ b/drivers/infiniband/core/uverbs_mem.c | |||
| @@ -211,8 +211,10 @@ void ib_umem_release_on_close(struct ib_device *dev, struct ib_umem *umem) | |||
| 211 | */ | 211 | */ | 
| 212 | 212 | ||
| 213 | work = kmalloc(sizeof *work, GFP_KERNEL); | 213 | work = kmalloc(sizeof *work, GFP_KERNEL); | 
| 214 | if (!work) | 214 | if (!work) { | 
| 215 | mmput(mm); | ||
| 215 | return; | 216 | return; | 
| 217 | } | ||
| 216 | 218 | ||
| 217 | INIT_WORK(&work->work, ib_umem_account, work); | 219 | INIT_WORK(&work->work, ib_umem_account, work); | 
| 218 | work->mm = mm; | 220 | work->mm = mm; | 
| diff --git a/drivers/infiniband/hw/mthca/mthca_cmd.c b/drivers/infiniband/hw/mthca/mthca_cmd.c index 1985b5dfa481..798e13e14faf 100644 --- a/drivers/infiniband/hw/mthca/mthca_cmd.c +++ b/drivers/infiniband/hw/mthca/mthca_cmd.c | |||
| @@ -182,7 +182,7 @@ struct mthca_cmd_context { | |||
| 182 | u8 status; | 182 | u8 status; | 
| 183 | }; | 183 | }; | 
| 184 | 184 | ||
| 185 | static int fw_cmd_doorbell = 1; | 185 | static int fw_cmd_doorbell = 0; | 
| 186 | module_param(fw_cmd_doorbell, int, 0644); | 186 | module_param(fw_cmd_doorbell, int, 0644); | 
| 187 | MODULE_PARM_DESC(fw_cmd_doorbell, "post FW commands through doorbell page if nonzero " | 187 | MODULE_PARM_DESC(fw_cmd_doorbell, "post FW commands through doorbell page if nonzero " | 
| 188 | "(and supported by FW)"); | 188 | "(and supported by FW)"); | 
| diff --git a/drivers/infiniband/hw/mthca/mthca_qp.c b/drivers/infiniband/hw/mthca/mthca_qp.c index 19765f6f8d58..07c13be07a4a 100644 --- a/drivers/infiniband/hw/mthca/mthca_qp.c +++ b/drivers/infiniband/hw/mthca/mthca_qp.c | |||
| @@ -1727,23 +1727,7 @@ int mthca_tavor_post_receive(struct ib_qp *ibqp, struct ib_recv_wr *wr, | |||
| 1727 | 1727 | ||
| 1728 | ind = qp->rq.next_ind; | 1728 | ind = qp->rq.next_ind; | 
| 1729 | 1729 | ||
| 1730 | for (nreq = 0; wr; ++nreq, wr = wr->next) { | 1730 | for (nreq = 0; wr; wr = wr->next) { | 
| 1731 | if (unlikely(nreq == MTHCA_TAVOR_MAX_WQES_PER_RECV_DB)) { | ||
| 1732 | nreq = 0; | ||
| 1733 | |||
| 1734 | doorbell[0] = cpu_to_be32((qp->rq.next_ind << qp->rq.wqe_shift) | size0); | ||
| 1735 | doorbell[1] = cpu_to_be32(qp->qpn << 8); | ||
| 1736 | |||
| 1737 | wmb(); | ||
| 1738 | |||
| 1739 | mthca_write64(doorbell, | ||
| 1740 | dev->kar + MTHCA_RECEIVE_DOORBELL, | ||
| 1741 | MTHCA_GET_DOORBELL_LOCK(&dev->doorbell_lock)); | ||
| 1742 | |||
| 1743 | qp->rq.head += MTHCA_TAVOR_MAX_WQES_PER_RECV_DB; | ||
| 1744 | size0 = 0; | ||
| 1745 | } | ||
| 1746 | |||
| 1747 | if (mthca_wq_overflow(&qp->rq, nreq, qp->ibqp.recv_cq)) { | 1731 | if (mthca_wq_overflow(&qp->rq, nreq, qp->ibqp.recv_cq)) { | 
| 1748 | mthca_err(dev, "RQ %06x full (%u head, %u tail," | 1732 | mthca_err(dev, "RQ %06x full (%u head, %u tail," | 
| 1749 | " %d max, %d nreq)\n", qp->qpn, | 1733 | " %d max, %d nreq)\n", qp->qpn, | 
| @@ -1797,6 +1781,23 @@ int mthca_tavor_post_receive(struct ib_qp *ibqp, struct ib_recv_wr *wr, | |||
| 1797 | ++ind; | 1781 | ++ind; | 
| 1798 | if (unlikely(ind >= qp->rq.max)) | 1782 | if (unlikely(ind >= qp->rq.max)) | 
| 1799 | ind -= qp->rq.max; | 1783 | ind -= qp->rq.max; | 
| 1784 | |||
| 1785 | ++nreq; | ||
| 1786 | if (unlikely(nreq == MTHCA_TAVOR_MAX_WQES_PER_RECV_DB)) { | ||
| 1787 | nreq = 0; | ||
| 1788 | |||
| 1789 | doorbell[0] = cpu_to_be32((qp->rq.next_ind << qp->rq.wqe_shift) | size0); | ||
| 1790 | doorbell[1] = cpu_to_be32(qp->qpn << 8); | ||
| 1791 | |||
| 1792 | wmb(); | ||
| 1793 | |||
| 1794 | mthca_write64(doorbell, | ||
| 1795 | dev->kar + MTHCA_RECEIVE_DOORBELL, | ||
| 1796 | MTHCA_GET_DOORBELL_LOCK(&dev->doorbell_lock)); | ||
| 1797 | |||
| 1798 | qp->rq.head += MTHCA_TAVOR_MAX_WQES_PER_RECV_DB; | ||
| 1799 | size0 = 0; | ||
| 1800 | } | ||
| 1800 | } | 1801 | } | 
| 1801 | 1802 | ||
| 1802 | out: | 1803 | out: | 
| diff --git a/drivers/infiniband/ulp/srp/ib_srp.c b/drivers/infiniband/ulp/srp/ib_srp.c index c32ce4348e1b..9cbdffa08dc2 100644 --- a/drivers/infiniband/ulp/srp/ib_srp.c +++ b/drivers/infiniband/ulp/srp/ib_srp.c | |||
| @@ -340,7 +340,10 @@ static void srp_disconnect_target(struct srp_target_port *target) | |||
| 340 | /* XXX should send SRP_I_LOGOUT request */ | 340 | /* XXX should send SRP_I_LOGOUT request */ | 
| 341 | 341 | ||
| 342 | init_completion(&target->done); | 342 | init_completion(&target->done); | 
| 343 | ib_send_cm_dreq(target->cm_id, NULL, 0); | 343 | if (ib_send_cm_dreq(target->cm_id, NULL, 0)) { | 
| 344 | printk(KERN_DEBUG PFX "Sending CM DREQ failed\n"); | ||
| 345 | return; | ||
| 346 | } | ||
| 344 | wait_for_completion(&target->done); | 347 | wait_for_completion(&target->done); | 
| 345 | } | 348 | } | 
| 346 | 349 | ||
| @@ -351,7 +354,6 @@ static void srp_remove_work(void *target_ptr) | |||
| 351 | spin_lock_irq(target->scsi_host->host_lock); | 354 | spin_lock_irq(target->scsi_host->host_lock); | 
| 352 | if (target->state != SRP_TARGET_DEAD) { | 355 | if (target->state != SRP_TARGET_DEAD) { | 
| 353 | spin_unlock_irq(target->scsi_host->host_lock); | 356 | spin_unlock_irq(target->scsi_host->host_lock); | 
| 354 | scsi_host_put(target->scsi_host); | ||
| 355 | return; | 357 | return; | 
| 356 | } | 358 | } | 
| 357 | target->state = SRP_TARGET_REMOVED; | 359 | target->state = SRP_TARGET_REMOVED; | 
| @@ -365,8 +367,6 @@ static void srp_remove_work(void *target_ptr) | |||
| 365 | ib_destroy_cm_id(target->cm_id); | 367 | ib_destroy_cm_id(target->cm_id); | 
| 366 | srp_free_target_ib(target); | 368 | srp_free_target_ib(target); | 
| 367 | scsi_host_put(target->scsi_host); | 369 | scsi_host_put(target->scsi_host); | 
| 368 | /* And another put to really free the target port... */ | ||
| 369 | scsi_host_put(target->scsi_host); | ||
| 370 | } | 370 | } | 
| 371 | 371 | ||
| 372 | static int srp_connect_target(struct srp_target_port *target) | 372 | static int srp_connect_target(struct srp_target_port *target) | 
| @@ -1241,7 +1241,7 @@ static int srp_reset_device(struct scsi_cmnd *scmnd) | |||
| 1241 | list_for_each_entry_safe(req, tmp, &target->req_queue, list) | 1241 | list_for_each_entry_safe(req, tmp, &target->req_queue, list) | 
| 1242 | if (req->scmnd->device == scmnd->device) { | 1242 | if (req->scmnd->device == scmnd->device) { | 
| 1243 | req->scmnd->result = DID_RESET << 16; | 1243 | req->scmnd->result = DID_RESET << 16; | 
| 1244 | scmnd->scsi_done(scmnd); | 1244 | req->scmnd->scsi_done(req->scmnd); | 
| 1245 | srp_remove_req(target, req); | 1245 | srp_remove_req(target, req); | 
| 1246 | } | 1246 | } | 
| 1247 | 1247 | ||
| diff --git a/drivers/isdn/capi/capi.c b/drivers/isdn/capi/capi.c index 9b493f0becc4..173c899a1fb4 100644 --- a/drivers/isdn/capi/capi.c +++ b/drivers/isdn/capi/capi.c | |||
| @@ -1499,7 +1499,6 @@ static int __init capi_init(void) | |||
| 1499 | printk(KERN_ERR "capi20: unable to get major %d\n", capi_major); | 1499 | printk(KERN_ERR "capi20: unable to get major %d\n", capi_major); | 
| 1500 | return major_ret; | 1500 | return major_ret; | 
| 1501 | } | 1501 | } | 
| 1502 | capi_major = major_ret; | ||
| 1503 | capi_class = class_create(THIS_MODULE, "capi"); | 1502 | capi_class = class_create(THIS_MODULE, "capi"); | 
| 1504 | if (IS_ERR(capi_class)) { | 1503 | if (IS_ERR(capi_class)) { | 
| 1505 | unregister_chrdev(capi_major, "capi20"); | 1504 | unregister_chrdev(capi_major, "capi20"); | 
| diff --git a/drivers/isdn/gigaset/usb-gigaset.c b/drivers/isdn/gigaset/usb-gigaset.c index bfb73fd5077e..d86ab68114b0 100644 --- a/drivers/isdn/gigaset/usb-gigaset.c +++ b/drivers/isdn/gigaset/usb-gigaset.c | |||
| @@ -710,8 +710,8 @@ static int gigaset_probe(struct usb_interface *interface, | |||
| 710 | retval = -ENODEV; //FIXME | 710 | retval = -ENODEV; //FIXME | 
| 711 | 711 | ||
| 712 | /* See if the device offered us matches what we can accept */ | 712 | /* See if the device offered us matches what we can accept */ | 
| 713 | if ((le16_to_cpu(udev->descriptor.idVendor != USB_M105_VENDOR_ID)) || | 713 | if ((le16_to_cpu(udev->descriptor.idVendor) != USB_M105_VENDOR_ID) || | 
| 714 | (le16_to_cpu(udev->descriptor.idProduct != USB_M105_PRODUCT_ID))) | 714 | (le16_to_cpu(udev->descriptor.idProduct) != USB_M105_PRODUCT_ID)) | 
| 715 | return -ENODEV; | 715 | return -ENODEV; | 
| 716 | 716 | ||
| 717 | /* this starts to become ascii art... */ | 717 | /* this starts to become ascii art... */ | 
| diff --git a/drivers/leds/Kconfig b/drivers/leds/Kconfig index 3f5b64794542..626506234b76 100644 --- a/drivers/leds/Kconfig +++ b/drivers/leds/Kconfig | |||
| @@ -4,8 +4,11 @@ menu "LED devices" | |||
| 4 | config NEW_LEDS | 4 | config NEW_LEDS | 
| 5 | bool "LED Support" | 5 | bool "LED Support" | 
| 6 | help | 6 | help | 
| 7 | Say Y to enable Linux LED support. This is not related to standard | 7 | Say Y to enable Linux LED support. This allows control of supported | 
| 8 | keyboard LEDs which are controlled via the input system. | 8 | LEDs from both userspace and optionally, by kernel events (triggers). | 
| 9 | |||
| 10 | This is not related to standard keyboard LEDs which are controlled | ||
| 11 | via the input system. | ||
| 9 | 12 | ||
| 10 | config LEDS_CLASS | 13 | config LEDS_CLASS | 
| 11 | tristate "LED Class Support" | 14 | tristate "LED Class Support" | 
| diff --git a/drivers/leds/led-class.c b/drivers/leds/led-class.c index b0b5d05fadd6..c75d0ef1609c 100644 --- a/drivers/leds/led-class.c +++ b/drivers/leds/led-class.c | |||
| @@ -19,6 +19,7 @@ | |||
| 19 | #include <linux/sysdev.h> | 19 | #include <linux/sysdev.h> | 
| 20 | #include <linux/timer.h> | 20 | #include <linux/timer.h> | 
| 21 | #include <linux/err.h> | 21 | #include <linux/err.h> | 
| 22 | #include <linux/ctype.h> | ||
| 22 | #include <linux/leds.h> | 23 | #include <linux/leds.h> | 
| 23 | #include "leds.h" | 24 | #include "leds.h" | 
| 24 | 25 | ||
| @@ -43,9 +44,13 @@ static ssize_t led_brightness_store(struct class_device *dev, | |||
| 43 | ssize_t ret = -EINVAL; | 44 | ssize_t ret = -EINVAL; | 
| 44 | char *after; | 45 | char *after; | 
| 45 | unsigned long state = simple_strtoul(buf, &after, 10); | 46 | unsigned long state = simple_strtoul(buf, &after, 10); | 
| 47 | size_t count = after - buf; | ||
| 46 | 48 | ||
| 47 | if (after - buf > 0) { | 49 | if (*after && isspace(*after)) | 
| 48 | ret = after - buf; | 50 | count++; | 
| 51 | |||
| 52 | if (count == size) { | ||
| 53 | ret = count; | ||
| 49 | led_set_brightness(led_cdev, state); | 54 | led_set_brightness(led_cdev, state); | 
| 50 | } | 55 | } | 
| 51 | 56 | ||
| diff --git a/drivers/leds/ledtrig-timer.c b/drivers/leds/ledtrig-timer.c index f484b5d6dbf8..fbf141ef46ec 100644 --- a/drivers/leds/ledtrig-timer.c +++ b/drivers/leds/ledtrig-timer.c | |||
| @@ -20,6 +20,7 @@ | |||
| 20 | #include <linux/device.h> | 20 | #include <linux/device.h> | 
| 21 | #include <linux/sysdev.h> | 21 | #include <linux/sysdev.h> | 
| 22 | #include <linux/timer.h> | 22 | #include <linux/timer.h> | 
| 23 | #include <linux/ctype.h> | ||
| 23 | #include <linux/leds.h> | 24 | #include <linux/leds.h> | 
| 24 | #include "leds.h" | 25 | #include "leds.h" | 
| 25 | 26 | ||
| @@ -69,11 +70,15 @@ static ssize_t led_delay_on_store(struct class_device *dev, const char *buf, | |||
| 69 | int ret = -EINVAL; | 70 | int ret = -EINVAL; | 
| 70 | char *after; | 71 | char *after; | 
| 71 | unsigned long state = simple_strtoul(buf, &after, 10); | 72 | unsigned long state = simple_strtoul(buf, &after, 10); | 
| 73 | size_t count = after - buf; | ||
| 72 | 74 | ||
| 73 | if (after - buf > 0) { | 75 | if (*after && isspace(*after)) | 
| 76 | count++; | ||
| 77 | |||
| 78 | if (count == size) { | ||
| 74 | timer_data->delay_on = state; | 79 | timer_data->delay_on = state; | 
| 75 | mod_timer(&timer_data->timer, jiffies + 1); | 80 | mod_timer(&timer_data->timer, jiffies + 1); | 
| 76 | ret = after - buf; | 81 | ret = count; | 
| 77 | } | 82 | } | 
| 78 | 83 | ||
| 79 | return ret; | 84 | return ret; | 
| @@ -97,11 +102,15 @@ static ssize_t led_delay_off_store(struct class_device *dev, const char *buf, | |||
| 97 | int ret = -EINVAL; | 102 | int ret = -EINVAL; | 
| 98 | char *after; | 103 | char *after; | 
| 99 | unsigned long state = simple_strtoul(buf, &after, 10); | 104 | unsigned long state = simple_strtoul(buf, &after, 10); | 
| 105 | size_t count = after - buf; | ||
| 106 | |||
| 107 | if (*after && isspace(*after)) | ||
| 108 | count++; | ||
| 100 | 109 | ||
| 101 | if (after - buf > 0) { | 110 | if (count == size) { | 
| 102 | timer_data->delay_off = state; | 111 | timer_data->delay_off = state; | 
| 103 | mod_timer(&timer_data->timer, jiffies + 1); | 112 | mod_timer(&timer_data->timer, jiffies + 1); | 
| 104 | ret = after - buf; | 113 | ret = count; | 
| 105 | } | 114 | } | 
| 106 | 115 | ||
| 107 | return ret; | 116 | return ret; | 
| diff --git a/drivers/mmc/au1xmmc.c b/drivers/mmc/au1xmmc.c index 914d62b24064..5dc4bee7abeb 100644 --- a/drivers/mmc/au1xmmc.c +++ b/drivers/mmc/au1xmmc.c | |||
| @@ -310,7 +310,7 @@ static void au1xmmc_data_complete(struct au1xmmc_host *host, u32 status) | |||
| 310 | } | 310 | } | 
| 311 | else | 311 | else | 
| 312 | data->bytes_xfered = | 312 | data->bytes_xfered = | 
| 313 | (data->blocks * (1 << data->blksz_bits)) - | 313 | (data->blocks * data->blksz) - | 
| 314 | host->pio.len; | 314 | host->pio.len; | 
| 315 | } | 315 | } | 
| 316 | 316 | ||
| @@ -575,7 +575,7 @@ static int | |||
| 575 | au1xmmc_prepare_data(struct au1xmmc_host *host, struct mmc_data *data) | 575 | au1xmmc_prepare_data(struct au1xmmc_host *host, struct mmc_data *data) | 
| 576 | { | 576 | { | 
| 577 | 577 | ||
| 578 | int datalen = data->blocks * (1 << data->blksz_bits); | 578 | int datalen = data->blocks * data->blksz; | 
| 579 | 579 | ||
| 580 | if (dma != 0) | 580 | if (dma != 0) | 
| 581 | host->flags |= HOST_F_DMA; | 581 | host->flags |= HOST_F_DMA; | 
| @@ -596,7 +596,7 @@ au1xmmc_prepare_data(struct au1xmmc_host *host, struct mmc_data *data) | |||
| 596 | if (host->dma.len == 0) | 596 | if (host->dma.len == 0) | 
| 597 | return MMC_ERR_TIMEOUT; | 597 | return MMC_ERR_TIMEOUT; | 
| 598 | 598 | ||
| 599 | au_writel((1 << data->blksz_bits) - 1, HOST_BLKSIZE(host)); | 599 | au_writel(data->blksz - 1, HOST_BLKSIZE(host)); | 
| 600 | 600 | ||
| 601 | if (host->flags & HOST_F_DMA) { | 601 | if (host->flags & HOST_F_DMA) { | 
| 602 | int i; | 602 | int i; | 
| diff --git a/drivers/mmc/imxmmc.c b/drivers/mmc/imxmmc.c index 79358e223f57..a4eb1d0e7a71 100644 --- a/drivers/mmc/imxmmc.c +++ b/drivers/mmc/imxmmc.c | |||
| @@ -218,8 +218,10 @@ static int imxmci_busy_wait_for_status(struct imxmci_host *host, | |||
| 218 | if(!loops) | 218 | if(!loops) | 
| 219 | return 0; | 219 | return 0; | 
| 220 | 220 | ||
| 221 | dev_info(mmc_dev(host->mmc), "busy wait for %d usec in %s, STATUS = 0x%x (0x%x)\n", | 221 | /* The busy-wait is expected there for clock <8MHz due to SDHC hardware flaws */ | 
| 222 | loops, where, *pstat, stat_mask); | 222 | if(!(stat_mask & STATUS_END_CMD_RESP) || (host->mmc->ios.clock>=8000000)) | 
| 223 | dev_info(mmc_dev(host->mmc), "busy wait for %d usec in %s, STATUS = 0x%x (0x%x)\n", | ||
| 224 | loops, where, *pstat, stat_mask); | ||
| 223 | return loops; | 225 | return loops; | 
| 224 | } | 226 | } | 
| 225 | 227 | ||
| @@ -333,6 +335,9 @@ static void imxmci_start_cmd(struct imxmci_host *host, struct mmc_command *cmd, | |||
| 333 | WARN_ON(host->cmd != NULL); | 335 | WARN_ON(host->cmd != NULL); | 
| 334 | host->cmd = cmd; | 336 | host->cmd = cmd; | 
| 335 | 337 | ||
| 338 | /* Ensure, that clock are stopped else command programming and start fails */ | ||
| 339 | imxmci_stop_clock(host); | ||
| 340 | |||
| 336 | if (cmd->flags & MMC_RSP_BUSY) | 341 | if (cmd->flags & MMC_RSP_BUSY) | 
| 337 | cmdat |= CMD_DAT_CONT_BUSY; | 342 | cmdat |= CMD_DAT_CONT_BUSY; | 
| 338 | 343 | ||
| @@ -553,7 +558,7 @@ static int imxmci_cpu_driven_data(struct imxmci_host *host, unsigned int *pstat) | |||
| 553 | int trans_done = 0; | 558 | int trans_done = 0; | 
| 554 | unsigned int stat = *pstat; | 559 | unsigned int stat = *pstat; | 
| 555 | 560 | ||
| 556 | if(host->actual_bus_width == MMC_BUS_WIDTH_4) | 561 | if(host->actual_bus_width != MMC_BUS_WIDTH_4) | 
| 557 | burst_len = 16; | 562 | burst_len = 16; | 
| 558 | else | 563 | else | 
| 559 | burst_len = 64; | 564 | burst_len = 64; | 
| @@ -591,8 +596,7 @@ static int imxmci_cpu_driven_data(struct imxmci_host *host, unsigned int *pstat) | |||
| 591 | stat = MMC_STATUS; | 596 | stat = MMC_STATUS; | 
| 592 | 597 | ||
| 593 | /* Flush extra bytes from FIFO */ | 598 | /* Flush extra bytes from FIFO */ | 
| 594 | while(flush_len >= 2){ | 599 | while(flush_len && !(stat & STATUS_DATA_TRANS_DONE)){ | 
| 595 | flush_len -= 2; | ||
| 596 | i = MMC_BUFFER_ACCESS; | 600 | i = MMC_BUFFER_ACCESS; | 
| 597 | stat = MMC_STATUS; | 601 | stat = MMC_STATUS; | 
| 598 | stat &= ~STATUS_CRC_READ_ERR; /* Stupid but required there */ | 602 | stat &= ~STATUS_CRC_READ_ERR; /* Stupid but required there */ | 
| @@ -746,10 +750,6 @@ static void imxmci_tasklet_fnc(unsigned long data) | |||
| 746 | data_dir_mask = STATUS_DATA_TRANS_DONE; | 750 | data_dir_mask = STATUS_DATA_TRANS_DONE; | 
| 747 | } | 751 | } | 
| 748 | 752 | ||
| 749 | imxmci_busy_wait_for_status(host, &stat, | ||
| 750 | data_dir_mask, | ||
| 751 | 50, "imxmci_tasklet_fnc data"); | ||
| 752 | |||
| 753 | if(stat & data_dir_mask) { | 753 | if(stat & data_dir_mask) { | 
| 754 | clear_bit(IMXMCI_PEND_DMA_END_b, &host->pending_events); | 754 | clear_bit(IMXMCI_PEND_DMA_END_b, &host->pending_events); | 
| 755 | imxmci_data_done(host, stat); | 755 | imxmci_data_done(host, stat); | 
| @@ -865,7 +865,11 @@ static void imxmci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios) | |||
| 865 | 865 | ||
| 866 | imxmci_stop_clock(host); | 866 | imxmci_stop_clock(host); | 
| 867 | MMC_CLK_RATE = (prescaler<<3) | clk; | 867 | MMC_CLK_RATE = (prescaler<<3) | clk; | 
| 868 | imxmci_start_clock(host); | 868 | /* | 
| 869 | * Under my understanding, clock should not be started there, because it would | ||
| 870 | * initiate SDHC sequencer and send last or random command into card | ||
| 871 | */ | ||
| 872 | /*imxmci_start_clock(host);*/ | ||
| 869 | 873 | ||
| 870 | dev_dbg(mmc_dev(host->mmc), "MMC_CLK_RATE: 0x%08x\n", MMC_CLK_RATE); | 874 | dev_dbg(mmc_dev(host->mmc), "MMC_CLK_RATE: 0x%08x\n", MMC_CLK_RATE); | 
| 871 | } else { | 875 | } else { | 
| diff --git a/drivers/mmc/mmc.c b/drivers/mmc/mmc.c index 1ca2c8b9c9b5..6201f3086a02 100644 --- a/drivers/mmc/mmc.c +++ b/drivers/mmc/mmc.c | |||
| @@ -951,6 +951,7 @@ static void mmc_read_scrs(struct mmc_host *host) | |||
| 951 | data.timeout_ns = card->csd.tacc_ns * 10; | 951 | data.timeout_ns = card->csd.tacc_ns * 10; | 
| 952 | data.timeout_clks = card->csd.tacc_clks * 10; | 952 | data.timeout_clks = card->csd.tacc_clks * 10; | 
| 953 | data.blksz_bits = 3; | 953 | data.blksz_bits = 3; | 
| 954 | data.blksz = 1 << 3; | ||
| 954 | data.blocks = 1; | 955 | data.blocks = 1; | 
| 955 | data.flags = MMC_DATA_READ; | 956 | data.flags = MMC_DATA_READ; | 
| 956 | data.sg = &sg; | 957 | data.sg = &sg; | 
| diff --git a/drivers/mmc/mmc_block.c b/drivers/mmc/mmc_block.c index 06bd1f4cb9b1..e39cc05c64c2 100644 --- a/drivers/mmc/mmc_block.c +++ b/drivers/mmc/mmc_block.c | |||
| @@ -175,6 +175,7 @@ static int mmc_blk_issue_rq(struct mmc_queue *mq, struct request *req) | |||
| 175 | brq.data.timeout_ns = card->csd.tacc_ns * 10; | 175 | brq.data.timeout_ns = card->csd.tacc_ns * 10; | 
| 176 | brq.data.timeout_clks = card->csd.tacc_clks * 10; | 176 | brq.data.timeout_clks = card->csd.tacc_clks * 10; | 
| 177 | brq.data.blksz_bits = md->block_bits; | 177 | brq.data.blksz_bits = md->block_bits; | 
| 178 | brq.data.blksz = 1 << md->block_bits; | ||
| 178 | brq.data.blocks = req->nr_sectors >> (md->block_bits - 9); | 179 | brq.data.blocks = req->nr_sectors >> (md->block_bits - 9); | 
| 179 | brq.stop.opcode = MMC_STOP_TRANSMISSION; | 180 | brq.stop.opcode = MMC_STOP_TRANSMISSION; | 
| 180 | brq.stop.arg = 0; | 181 | brq.stop.arg = 0; | 
| diff --git a/drivers/mmc/pxamci.c b/drivers/mmc/pxamci.c index f97b472085cb..b49368fd96b8 100644 --- a/drivers/mmc/pxamci.c +++ b/drivers/mmc/pxamci.c | |||
| @@ -119,7 +119,7 @@ static void pxamci_setup_data(struct pxamci_host *host, struct mmc_data *data) | |||
| 119 | nob = 0xffff; | 119 | nob = 0xffff; | 
| 120 | 120 | ||
| 121 | writel(nob, host->base + MMC_NOB); | 121 | writel(nob, host->base + MMC_NOB); | 
| 122 | writel(1 << data->blksz_bits, host->base + MMC_BLKLEN); | 122 | writel(data->blksz, host->base + MMC_BLKLEN); | 
| 123 | 123 | ||
| 124 | clks = (unsigned long long)data->timeout_ns * CLOCKRATE; | 124 | clks = (unsigned long long)data->timeout_ns * CLOCKRATE; | 
| 125 | do_div(clks, 1000000000UL); | 125 | do_div(clks, 1000000000UL); | 
| @@ -283,7 +283,7 @@ static int pxamci_data_done(struct pxamci_host *host, unsigned int stat) | |||
| 283 | * data blocks as being in error. | 283 | * data blocks as being in error. | 
| 284 | */ | 284 | */ | 
| 285 | if (data->error == MMC_ERR_NONE) | 285 | if (data->error == MMC_ERR_NONE) | 
| 286 | data->bytes_xfered = data->blocks << data->blksz_bits; | 286 | data->bytes_xfered = data->blocks * data->blksz; | 
| 287 | else | 287 | else | 
| 288 | data->bytes_xfered = 0; | 288 | data->bytes_xfered = 0; | 
| 289 | 289 | ||
| diff --git a/drivers/mmc/wbsd.c b/drivers/mmc/wbsd.c index 39b3d97f891e..8167332d4013 100644 --- a/drivers/mmc/wbsd.c +++ b/drivers/mmc/wbsd.c | |||
| @@ -662,14 +662,14 @@ static void wbsd_prepare_data(struct wbsd_host *host, struct mmc_data *data) | |||
| 662 | unsigned long dmaflags; | 662 | unsigned long dmaflags; | 
| 663 | 663 | ||
| 664 | DBGF("blksz %04x blks %04x flags %08x\n", | 664 | DBGF("blksz %04x blks %04x flags %08x\n", | 
| 665 | 1 << data->blksz_bits, data->blocks, data->flags); | 665 | data->blksz, data->blocks, data->flags); | 
| 666 | DBGF("tsac %d ms nsac %d clk\n", | 666 | DBGF("tsac %d ms nsac %d clk\n", | 
| 667 | data->timeout_ns / 1000000, data->timeout_clks); | 667 | data->timeout_ns / 1000000, data->timeout_clks); | 
| 668 | 668 | ||
| 669 | /* | 669 | /* | 
| 670 | * Calculate size. | 670 | * Calculate size. | 
| 671 | */ | 671 | */ | 
| 672 | host->size = data->blocks << data->blksz_bits; | 672 | host->size = data->blocks * data->blksz; | 
| 673 | 673 | ||
| 674 | /* | 674 | /* | 
| 675 | * Check timeout values for overflow. | 675 | * Check timeout values for overflow. | 
| @@ -696,12 +696,12 @@ static void wbsd_prepare_data(struct wbsd_host *host, struct mmc_data *data) | |||
| 696 | * Two bytes are needed for each data line. | 696 | * Two bytes are needed for each data line. | 
| 697 | */ | 697 | */ | 
| 698 | if (host->bus_width == MMC_BUS_WIDTH_1) { | 698 | if (host->bus_width == MMC_BUS_WIDTH_1) { | 
| 699 | blksize = (1 << data->blksz_bits) + 2; | 699 | blksize = data->blksz + 2; | 
| 700 | 700 | ||
| 701 | wbsd_write_index(host, WBSD_IDX_PBSMSB, (blksize >> 4) & 0xF0); | 701 | wbsd_write_index(host, WBSD_IDX_PBSMSB, (blksize >> 4) & 0xF0); | 
| 702 | wbsd_write_index(host, WBSD_IDX_PBSLSB, blksize & 0xFF); | 702 | wbsd_write_index(host, WBSD_IDX_PBSLSB, blksize & 0xFF); | 
| 703 | } else if (host->bus_width == MMC_BUS_WIDTH_4) { | 703 | } else if (host->bus_width == MMC_BUS_WIDTH_4) { | 
| 704 | blksize = (1 << data->blksz_bits) + 2 * 4; | 704 | blksize = data->blksz + 2 * 4; | 
| 705 | 705 | ||
| 706 | wbsd_write_index(host, WBSD_IDX_PBSMSB, | 706 | wbsd_write_index(host, WBSD_IDX_PBSMSB, | 
| 707 | ((blksize >> 4) & 0xF0) | WBSD_DATA_WIDTH); | 707 | ((blksize >> 4) & 0xF0) | WBSD_DATA_WIDTH); | 
| diff --git a/drivers/net/b44.c b/drivers/net/b44.c index 3d306681919e..d8233e0b7899 100644 --- a/drivers/net/b44.c +++ b/drivers/net/b44.c | |||
| @@ -650,9 +650,11 @@ static int b44_alloc_rx_skb(struct b44 *bp, int src_idx, u32 dest_idx_unmasked) | |||
| 650 | 650 | ||
| 651 | /* Hardware bug work-around, the chip is unable to do PCI DMA | 651 | /* Hardware bug work-around, the chip is unable to do PCI DMA | 
| 652 | to/from anything above 1GB :-( */ | 652 | to/from anything above 1GB :-( */ | 
| 653 | if (mapping + RX_PKT_BUF_SZ > B44_DMA_MASK) { | 653 | if (dma_mapping_error(mapping) || | 
| 654 | mapping + RX_PKT_BUF_SZ > B44_DMA_MASK) { | ||
| 654 | /* Sigh... */ | 655 | /* Sigh... */ | 
| 655 | pci_unmap_single(bp->pdev, mapping, RX_PKT_BUF_SZ,PCI_DMA_FROMDEVICE); | 656 | if (!dma_mapping_error(mapping)) | 
| 657 | pci_unmap_single(bp->pdev, mapping, RX_PKT_BUF_SZ,PCI_DMA_FROMDEVICE); | ||
| 656 | dev_kfree_skb_any(skb); | 658 | dev_kfree_skb_any(skb); | 
| 657 | skb = __dev_alloc_skb(RX_PKT_BUF_SZ,GFP_DMA); | 659 | skb = __dev_alloc_skb(RX_PKT_BUF_SZ,GFP_DMA); | 
| 658 | if (skb == NULL) | 660 | if (skb == NULL) | 
| @@ -660,8 +662,10 @@ static int b44_alloc_rx_skb(struct b44 *bp, int src_idx, u32 dest_idx_unmasked) | |||
| 660 | mapping = pci_map_single(bp->pdev, skb->data, | 662 | mapping = pci_map_single(bp->pdev, skb->data, | 
| 661 | RX_PKT_BUF_SZ, | 663 | RX_PKT_BUF_SZ, | 
| 662 | PCI_DMA_FROMDEVICE); | 664 | PCI_DMA_FROMDEVICE); | 
| 663 | if (mapping + RX_PKT_BUF_SZ > B44_DMA_MASK) { | 665 | if (dma_mapping_error(mapping) || | 
| 664 | pci_unmap_single(bp->pdev, mapping, RX_PKT_BUF_SZ,PCI_DMA_FROMDEVICE); | 666 | mapping + RX_PKT_BUF_SZ > B44_DMA_MASK) { | 
| 667 | if (!dma_mapping_error(mapping)) | ||
| 668 | pci_unmap_single(bp->pdev, mapping, RX_PKT_BUF_SZ,PCI_DMA_FROMDEVICE); | ||
| 665 | dev_kfree_skb_any(skb); | 669 | dev_kfree_skb_any(skb); | 
| 666 | return -ENOMEM; | 670 | return -ENOMEM; | 
| 667 | } | 671 | } | 
| @@ -967,9 +971,10 @@ static int b44_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 967 | } | 971 | } | 
| 968 | 972 | ||
| 969 | mapping = pci_map_single(bp->pdev, skb->data, len, PCI_DMA_TODEVICE); | 973 | mapping = pci_map_single(bp->pdev, skb->data, len, PCI_DMA_TODEVICE); | 
| 970 | if (mapping + len > B44_DMA_MASK) { | 974 | if (dma_mapping_error(mapping) || mapping + len > B44_DMA_MASK) { | 
| 971 | /* Chip can't handle DMA to/from >1GB, use bounce buffer */ | 975 | /* Chip can't handle DMA to/from >1GB, use bounce buffer */ | 
| 972 | pci_unmap_single(bp->pdev, mapping, len, PCI_DMA_TODEVICE); | 976 | if (!dma_mapping_error(mapping)) | 
| 977 | pci_unmap_single(bp->pdev, mapping, len, PCI_DMA_TODEVICE); | ||
| 973 | 978 | ||
| 974 | bounce_skb = __dev_alloc_skb(TX_PKT_BUF_SZ, | 979 | bounce_skb = __dev_alloc_skb(TX_PKT_BUF_SZ, | 
| 975 | GFP_ATOMIC|GFP_DMA); | 980 | GFP_ATOMIC|GFP_DMA); | 
| @@ -978,8 +983,9 @@ static int b44_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 978 | 983 | ||
| 979 | mapping = pci_map_single(bp->pdev, bounce_skb->data, | 984 | mapping = pci_map_single(bp->pdev, bounce_skb->data, | 
| 980 | len, PCI_DMA_TODEVICE); | 985 | len, PCI_DMA_TODEVICE); | 
| 981 | if (mapping + len > B44_DMA_MASK) { | 986 | if (dma_mapping_error(mapping) || mapping + len > B44_DMA_MASK) { | 
| 982 | pci_unmap_single(bp->pdev, mapping, | 987 | if (!dma_mapping_error(mapping)) | 
| 988 | pci_unmap_single(bp->pdev, mapping, | ||
| 983 | len, PCI_DMA_TODEVICE); | 989 | len, PCI_DMA_TODEVICE); | 
| 984 | dev_kfree_skb_any(bounce_skb); | 990 | dev_kfree_skb_any(bounce_skb); | 
| 985 | goto err_out; | 991 | goto err_out; | 
| @@ -1203,7 +1209,8 @@ static int b44_alloc_consistent(struct b44 *bp) | |||
| 1203 | DMA_TABLE_BYTES, | 1209 | DMA_TABLE_BYTES, | 
| 1204 | DMA_BIDIRECTIONAL); | 1210 | DMA_BIDIRECTIONAL); | 
| 1205 | 1211 | ||
| 1206 | if (rx_ring_dma + size > B44_DMA_MASK) { | 1212 | if (dma_mapping_error(rx_ring_dma) || | 
| 1213 | rx_ring_dma + size > B44_DMA_MASK) { | ||
| 1207 | kfree(rx_ring); | 1214 | kfree(rx_ring); | 
| 1208 | goto out_err; | 1215 | goto out_err; | 
| 1209 | } | 1216 | } | 
| @@ -1229,7 +1236,8 @@ static int b44_alloc_consistent(struct b44 *bp) | |||
| 1229 | DMA_TABLE_BYTES, | 1236 | DMA_TABLE_BYTES, | 
| 1230 | DMA_TO_DEVICE); | 1237 | DMA_TO_DEVICE); | 
| 1231 | 1238 | ||
| 1232 | if (tx_ring_dma + size > B44_DMA_MASK) { | 1239 | if (dma_mapping_error(tx_ring_dma) || | 
| 1240 | tx_ring_dma + size > B44_DMA_MASK) { | ||
| 1233 | kfree(tx_ring); | 1241 | kfree(tx_ring); | 
| 1234 | goto out_err; | 1242 | goto out_err; | 
| 1235 | } | 1243 | } | 
| diff --git a/drivers/net/dl2k.c b/drivers/net/dl2k.c index 1ddefd281213..038447fb5c5e 100644 --- a/drivers/net/dl2k.c +++ b/drivers/net/dl2k.c | |||
| @@ -53,6 +53,7 @@ | |||
| 53 | #define DRV_VERSION "v1.17b" | 53 | #define DRV_VERSION "v1.17b" | 
| 54 | #define DRV_RELDATE "2006/03/10" | 54 | #define DRV_RELDATE "2006/03/10" | 
| 55 | #include "dl2k.h" | 55 | #include "dl2k.h" | 
| 56 | #include <linux/dma-mapping.h> | ||
| 56 | 57 | ||
| 57 | static char version[] __devinitdata = | 58 | static char version[] __devinitdata = | 
| 58 | KERN_INFO DRV_NAME " " DRV_VERSION " " DRV_RELDATE "\n"; | 59 | KERN_INFO DRV_NAME " " DRV_VERSION " " DRV_RELDATE "\n"; | 
| diff --git a/drivers/net/ixp2000/enp2611.c b/drivers/net/ixp2000/enp2611.c index 6f7dce8eba51..b67f586d7392 100644 --- a/drivers/net/ixp2000/enp2611.c +++ b/drivers/net/ixp2000/enp2611.c | |||
| @@ -149,6 +149,8 @@ static void enp2611_check_link_status(unsigned long __dummy) | |||
| 149 | int status; | 149 | int status; | 
| 150 | 150 | ||
| 151 | dev = nds[i]; | 151 | dev = nds[i]; | 
| 152 | if (dev == NULL) | ||
| 153 | continue; | ||
| 152 | 154 | ||
| 153 | status = pm3386_is_link_up(i); | 155 | status = pm3386_is_link_up(i); | 
| 154 | if (status && !netif_carrier_ok(dev)) { | 156 | if (status && !netif_carrier_ok(dev)) { | 
| @@ -191,6 +193,7 @@ static void enp2611_set_port_admin_status(int port, int up) | |||
| 191 | 193 | ||
| 192 | static int __init enp2611_init_module(void) | 194 | static int __init enp2611_init_module(void) | 
| 193 | { | 195 | { | 
| 196 | int ports; | ||
| 194 | int i; | 197 | int i; | 
| 195 | 198 | ||
| 196 | if (!machine_is_enp2611()) | 199 | if (!machine_is_enp2611()) | 
| @@ -199,7 +202,8 @@ static int __init enp2611_init_module(void) | |||
| 199 | caleb_reset(); | 202 | caleb_reset(); | 
| 200 | pm3386_reset(); | 203 | pm3386_reset(); | 
| 201 | 204 | ||
| 202 | for (i = 0; i < 3; i++) { | 205 | ports = pm3386_port_count(); | 
| 206 | for (i = 0; i < ports; i++) { | ||
| 203 | nds[i] = ixpdev_alloc(i, sizeof(struct enp2611_ixpdev_priv)); | 207 | nds[i] = ixpdev_alloc(i, sizeof(struct enp2611_ixpdev_priv)); | 
| 204 | if (nds[i] == NULL) { | 208 | if (nds[i] == NULL) { | 
| 205 | while (--i >= 0) | 209 | while (--i >= 0) | 
| @@ -215,9 +219,10 @@ static int __init enp2611_init_module(void) | |||
| 215 | 219 | ||
| 216 | ixp2400_msf_init(&enp2611_msf_parameters); | 220 | ixp2400_msf_init(&enp2611_msf_parameters); | 
| 217 | 221 | ||
| 218 | if (ixpdev_init(3, nds, enp2611_set_port_admin_status)) { | 222 | if (ixpdev_init(ports, nds, enp2611_set_port_admin_status)) { | 
| 219 | for (i = 0; i < 3; i++) | 223 | for (i = 0; i < ports; i++) | 
| 220 | free_netdev(nds[i]); | 224 | if (nds[i]) | 
| 225 | free_netdev(nds[i]); | ||
| 221 | return -EINVAL; | 226 | return -EINVAL; | 
| 222 | } | 227 | } | 
| 223 | 228 | ||
| diff --git a/drivers/net/ixp2000/pm3386.c b/drivers/net/ixp2000/pm3386.c index 5c7ab7564053..5224651c9aac 100644 --- a/drivers/net/ixp2000/pm3386.c +++ b/drivers/net/ixp2000/pm3386.c | |||
| @@ -86,40 +86,53 @@ static void pm3386_port_reg_write(int port, int _reg, int spacing, u16 value) | |||
| 86 | pm3386_reg_write(port >> 1, reg, value); | 86 | pm3386_reg_write(port >> 1, reg, value); | 
| 87 | } | 87 | } | 
| 88 | 88 | ||
| 89 | int pm3386_secondary_present(void) | ||
| 90 | { | ||
| 91 | return pm3386_reg_read(1, 0) == 0x3386; | ||
| 92 | } | ||
| 89 | 93 | ||
| 90 | void pm3386_reset(void) | 94 | void pm3386_reset(void) | 
| 91 | { | 95 | { | 
| 92 | u8 mac[3][6]; | 96 | u8 mac[3][6]; | 
| 97 | int secondary; | ||
| 98 | |||
| 99 | secondary = pm3386_secondary_present(); | ||
| 93 | 100 | ||
| 94 | /* Save programmed MAC addresses. */ | 101 | /* Save programmed MAC addresses. */ | 
| 95 | pm3386_get_mac(0, mac[0]); | 102 | pm3386_get_mac(0, mac[0]); | 
| 96 | pm3386_get_mac(1, mac[1]); | 103 | pm3386_get_mac(1, mac[1]); | 
| 97 | pm3386_get_mac(2, mac[2]); | 104 | if (secondary) | 
| 105 | pm3386_get_mac(2, mac[2]); | ||
| 98 | 106 | ||
| 99 | /* Assert analog and digital reset. */ | 107 | /* Assert analog and digital reset. */ | 
| 100 | pm3386_reg_write(0, 0x002, 0x0060); | 108 | pm3386_reg_write(0, 0x002, 0x0060); | 
| 101 | pm3386_reg_write(1, 0x002, 0x0060); | 109 | if (secondary) | 
| 110 | pm3386_reg_write(1, 0x002, 0x0060); | ||
| 102 | mdelay(1); | 111 | mdelay(1); | 
| 103 | 112 | ||
| 104 | /* Deassert analog reset. */ | 113 | /* Deassert analog reset. */ | 
| 105 | pm3386_reg_write(0, 0x002, 0x0062); | 114 | pm3386_reg_write(0, 0x002, 0x0062); | 
| 106 | pm3386_reg_write(1, 0x002, 0x0062); | 115 | if (secondary) | 
| 116 | pm3386_reg_write(1, 0x002, 0x0062); | ||
| 107 | mdelay(10); | 117 | mdelay(10); | 
| 108 | 118 | ||
| 109 | /* Deassert digital reset. */ | 119 | /* Deassert digital reset. */ | 
| 110 | pm3386_reg_write(0, 0x002, 0x0063); | 120 | pm3386_reg_write(0, 0x002, 0x0063); | 
| 111 | pm3386_reg_write(1, 0x002, 0x0063); | 121 | if (secondary) | 
| 122 | pm3386_reg_write(1, 0x002, 0x0063); | ||
| 112 | mdelay(10); | 123 | mdelay(10); | 
| 113 | 124 | ||
| 114 | /* Restore programmed MAC addresses. */ | 125 | /* Restore programmed MAC addresses. */ | 
| 115 | pm3386_set_mac(0, mac[0]); | 126 | pm3386_set_mac(0, mac[0]); | 
| 116 | pm3386_set_mac(1, mac[1]); | 127 | pm3386_set_mac(1, mac[1]); | 
| 117 | pm3386_set_mac(2, mac[2]); | 128 | if (secondary) | 
| 129 | pm3386_set_mac(2, mac[2]); | ||
| 118 | 130 | ||
| 119 | /* Disable carrier on all ports. */ | 131 | /* Disable carrier on all ports. */ | 
| 120 | pm3386_set_carrier(0, 0); | 132 | pm3386_set_carrier(0, 0); | 
| 121 | pm3386_set_carrier(1, 0); | 133 | pm3386_set_carrier(1, 0); | 
| 122 | pm3386_set_carrier(2, 0); | 134 | if (secondary) | 
| 135 | pm3386_set_carrier(2, 0); | ||
| 123 | } | 136 | } | 
| 124 | 137 | ||
| 125 | static u16 swaph(u16 x) | 138 | static u16 swaph(u16 x) | 
| @@ -127,6 +140,11 @@ static u16 swaph(u16 x) | |||
| 127 | return ((x << 8) | (x >> 8)) & 0xffff; | 140 | return ((x << 8) | (x >> 8)) & 0xffff; | 
| 128 | } | 141 | } | 
| 129 | 142 | ||
| 143 | int pm3386_port_count(void) | ||
| 144 | { | ||
| 145 | return 2 + pm3386_secondary_present(); | ||
| 146 | } | ||
| 147 | |||
| 130 | void pm3386_init_port(int port) | 148 | void pm3386_init_port(int port) | 
| 131 | { | 149 | { | 
| 132 | int pm = port >> 1; | 150 | int pm = port >> 1; | 
| diff --git a/drivers/net/ixp2000/pm3386.h b/drivers/net/ixp2000/pm3386.h index fe92bb056ac4..cc4183dca911 100644 --- a/drivers/net/ixp2000/pm3386.h +++ b/drivers/net/ixp2000/pm3386.h | |||
| @@ -13,6 +13,7 @@ | |||
| 13 | #define __PM3386_H | 13 | #define __PM3386_H | 
| 14 | 14 | ||
| 15 | void pm3386_reset(void); | 15 | void pm3386_reset(void); | 
| 16 | int pm3386_port_count(void); | ||
| 16 | void pm3386_init_port(int port); | 17 | void pm3386_init_port(int port); | 
| 17 | void pm3386_get_mac(int port, u8 *mac); | 18 | void pm3386_get_mac(int port, u8 *mac); | 
| 18 | void pm3386_set_mac(int port, u8 *mac); | 19 | void pm3386_set_mac(int port, u8 *mac); | 
| diff --git a/drivers/net/sky2.c b/drivers/net/sky2.c index ffd267fab21d..62be6d99d05c 100644 --- a/drivers/net/sky2.c +++ b/drivers/net/sky2.c | |||
| @@ -1020,8 +1020,19 @@ static int sky2_up(struct net_device *dev) | |||
| 1020 | struct sky2_hw *hw = sky2->hw; | 1020 | struct sky2_hw *hw = sky2->hw; | 
| 1021 | unsigned port = sky2->port; | 1021 | unsigned port = sky2->port; | 
| 1022 | u32 ramsize, rxspace, imask; | 1022 | u32 ramsize, rxspace, imask; | 
| 1023 | int err = -ENOMEM; | 1023 | int err; | 
| 1024 | struct net_device *otherdev = hw->dev[sky2->port^1]; | ||
| 1024 | 1025 | ||
| 1026 | /* Block bringing up both ports at the same time on a dual port card. | ||
| 1027 | * There is an unfixed bug where receiver gets confused and picks up | ||
| 1028 | * packets out of order. Until this is fixed, prevent data corruption. | ||
| 1029 | */ | ||
| 1030 | if (otherdev && netif_running(otherdev)) { | ||
| 1031 | printk(KERN_INFO PFX "dual port support is disabled.\n"); | ||
| 1032 | return -EBUSY; | ||
| 1033 | } | ||
| 1034 | |||
| 1035 | err = -ENOMEM; | ||
| 1025 | if (netif_msg_ifup(sky2)) | 1036 | if (netif_msg_ifup(sky2)) | 
| 1026 | printk(KERN_INFO PFX "%s: enabling interface\n", dev->name); | 1037 | printk(KERN_INFO PFX "%s: enabling interface\n", dev->name); | 
| 1027 | 1038 | ||
| diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index 19e2b174d33c..d378478612fb 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c | |||
| @@ -634,6 +634,9 @@ DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C686_4, quirk_vi | |||
| 634 | * non-x86 architectures (yes Via exists on PPC among other places), | 634 | * non-x86 architectures (yes Via exists on PPC among other places), | 
| 635 | * we must mask the PCI_INTERRUPT_LINE value versus 0xf to get | 635 | * we must mask the PCI_INTERRUPT_LINE value versus 0xf to get | 
| 636 | * interrupts delivered properly. | 636 | * interrupts delivered properly. | 
| 637 | * | ||
| 638 | * Some of the on-chip devices are actually '586 devices' so they are | ||
| 639 | * listed here. | ||
| 637 | */ | 640 | */ | 
| 638 | static void quirk_via_irq(struct pci_dev *dev) | 641 | static void quirk_via_irq(struct pci_dev *dev) | 
| 639 | { | 642 | { | 
| @@ -648,6 +651,10 @@ static void quirk_via_irq(struct pci_dev *dev) | |||
| 648 | pci_write_config_byte(dev, PCI_INTERRUPT_LINE, new_irq); | 651 | pci_write_config_byte(dev, PCI_INTERRUPT_LINE, new_irq); | 
| 649 | } | 652 | } | 
| 650 | } | 653 | } | 
| 654 | DECLARE_PCI_FIXUP_ENABLE(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C586_0, quirk_via_irq); | ||
| 655 | DECLARE_PCI_FIXUP_ENABLE(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C586_1, quirk_via_irq); | ||
| 656 | DECLARE_PCI_FIXUP_ENABLE(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C586_2, quirk_via_irq); | ||
| 657 | DECLARE_PCI_FIXUP_ENABLE(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C586_3, quirk_via_irq); | ||
| 651 | DECLARE_PCI_FIXUP_ENABLE(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C686, quirk_via_irq); | 658 | DECLARE_PCI_FIXUP_ENABLE(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C686, quirk_via_irq); | 
| 652 | DECLARE_PCI_FIXUP_ENABLE(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C686_4, quirk_via_irq); | 659 | DECLARE_PCI_FIXUP_ENABLE(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C686_4, quirk_via_irq); | 
| 653 | DECLARE_PCI_FIXUP_ENABLE(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C686_5, quirk_via_irq); | 660 | DECLARE_PCI_FIXUP_ENABLE(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C686_5, quirk_via_irq); | 
| @@ -895,6 +902,7 @@ static void __init k8t_sound_hostbridge(struct pci_dev *dev) | |||
| 895 | } | 902 | } | 
| 896 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_8237, k8t_sound_hostbridge); | 903 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_8237, k8t_sound_hostbridge); | 
| 897 | 904 | ||
| 905 | #ifndef CONFIG_ACPI_SLEEP | ||
| 898 | /* | 906 | /* | 
| 899 | * On ASUS P4B boards, the SMBus PCI Device within the ICH2/4 southbridge | 907 | * On ASUS P4B boards, the SMBus PCI Device within the ICH2/4 southbridge | 
| 900 | * is not activated. The myth is that Asus said that they do not want the | 908 | * is not activated. The myth is that Asus said that they do not want the | 
| @@ -906,8 +914,12 @@ DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_8237, k8t_sound_ho | |||
| 906 | * bridge. Unfortunately, this device has no subvendor/subdevice ID. So it | 914 | * bridge. Unfortunately, this device has no subvendor/subdevice ID. So it | 
| 907 | * becomes necessary to do this tweak in two steps -- I've chosen the Host | 915 | * becomes necessary to do this tweak in two steps -- I've chosen the Host | 
| 908 | * bridge as trigger. | 916 | * bridge as trigger. | 
| 917 | * | ||
| 918 | * Actually, leaving it unhidden and not redoing the quirk over suspend2ram | ||
| 919 | * will cause thermal management to break down, and causing machine to | ||
| 920 | * overheat. | ||
| 909 | */ | 921 | */ | 
| 910 | static int __initdata asus_hides_smbus = 0; | 922 | static int __initdata asus_hides_smbus; | 
| 911 | 923 | ||
| 912 | static void __init asus_hides_smbus_hostbridge(struct pci_dev *dev) | 924 | static void __init asus_hides_smbus_hostbridge(struct pci_dev *dev) | 
| 913 | { | 925 | { | 
| @@ -1050,6 +1062,8 @@ static void __init asus_hides_smbus_lpc_ich6(struct pci_dev *dev) | |||
| 1050 | } | 1062 | } | 
| 1051 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH6_1, asus_hides_smbus_lpc_ich6 ); | 1063 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_ICH6_1, asus_hides_smbus_lpc_ich6 ); | 
| 1052 | 1064 | ||
| 1065 | #endif | ||
| 1066 | |||
| 1053 | /* | 1067 | /* | 
| 1054 | * SiS 96x south bridge: BIOS typically hides SMBus device... | 1068 | * SiS 96x south bridge: BIOS typically hides SMBus device... | 
| 1055 | */ | 1069 | */ | 
| diff --git a/drivers/pcmcia/pcmcia_ioctl.c b/drivers/pcmcia/pcmcia_ioctl.c index c53db7ceda5e..738b1ef595a3 100644 --- a/drivers/pcmcia/pcmcia_ioctl.c +++ b/drivers/pcmcia/pcmcia_ioctl.c | |||
| @@ -426,7 +426,7 @@ static int ds_open(struct inode *inode, struct file *file) | |||
| 426 | 426 | ||
| 427 | if (!warning_printed) { | 427 | if (!warning_printed) { | 
| 428 | printk(KERN_INFO "pcmcia: Detected deprecated PCMCIA ioctl " | 428 | printk(KERN_INFO "pcmcia: Detected deprecated PCMCIA ioctl " | 
| 429 | "usage.\n"); | 429 | "usage from process: %s.\n", current->comm); | 
| 430 | printk(KERN_INFO "pcmcia: This interface will soon be removed from " | 430 | printk(KERN_INFO "pcmcia: This interface will soon be removed from " | 
| 431 | "the kernel; please expect breakage unless you upgrade " | 431 | "the kernel; please expect breakage unless you upgrade " | 
| 432 | "to new tools.\n"); | 432 | "to new tools.\n"); | 
| @@ -601,8 +601,12 @@ static int ds_ioctl(struct inode * inode, struct file * file, | |||
| 601 | ret = CS_BAD_ARGS; | 601 | ret = CS_BAD_ARGS; | 
| 602 | else { | 602 | else { | 
| 603 | struct pcmcia_device *p_dev = get_pcmcia_device(s, buf->config.Function); | 603 | struct pcmcia_device *p_dev = get_pcmcia_device(s, buf->config.Function); | 
| 604 | ret = pccard_get_configuration_info(s, p_dev, &buf->config); | 604 | if (p_dev == NULL) | 
| 605 | pcmcia_put_dev(p_dev); | 605 | ret = CS_BAD_ARGS; | 
| 606 | else { | ||
| 607 | ret = pccard_get_configuration_info(s, p_dev, &buf->config); | ||
| 608 | pcmcia_put_dev(p_dev); | ||
| 609 | } | ||
| 606 | } | 610 | } | 
| 607 | break; | 611 | break; | 
| 608 | case DS_GET_FIRST_TUPLE: | 612 | case DS_GET_FIRST_TUPLE: | 
| @@ -632,8 +636,12 @@ static int ds_ioctl(struct inode * inode, struct file * file, | |||
| 632 | ret = CS_BAD_ARGS; | 636 | ret = CS_BAD_ARGS; | 
| 633 | else { | 637 | else { | 
| 634 | struct pcmcia_device *p_dev = get_pcmcia_device(s, buf->status.Function); | 638 | struct pcmcia_device *p_dev = get_pcmcia_device(s, buf->status.Function); | 
| 635 | ret = pccard_get_status(s, p_dev, &buf->status); | 639 | if (p_dev == NULL) | 
| 636 | pcmcia_put_dev(p_dev); | 640 | ret = CS_BAD_ARGS; | 
| 641 | else { | ||
| 642 | ret = pccard_get_status(s, p_dev, &buf->status); | ||
| 643 | pcmcia_put_dev(p_dev); | ||
| 644 | } | ||
| 637 | } | 645 | } | 
| 638 | break; | 646 | break; | 
| 639 | case DS_VALIDATE_CIS: | 647 | case DS_VALIDATE_CIS: | 
| @@ -665,9 +673,10 @@ static int ds_ioctl(struct inode * inode, struct file * file, | |||
| 665 | if (!(buf->conf_reg.Function && | 673 | if (!(buf->conf_reg.Function && | 
| 666 | (buf->conf_reg.Function >= s->functions))) { | 674 | (buf->conf_reg.Function >= s->functions))) { | 
| 667 | struct pcmcia_device *p_dev = get_pcmcia_device(s, buf->conf_reg.Function); | 675 | struct pcmcia_device *p_dev = get_pcmcia_device(s, buf->conf_reg.Function); | 
| 668 | if (p_dev) | 676 | if (p_dev) { | 
| 669 | ret = pcmcia_access_configuration_register(p_dev, &buf->conf_reg); | 677 | ret = pcmcia_access_configuration_register(p_dev, &buf->conf_reg); | 
| 670 | pcmcia_put_dev(p_dev); | 678 | pcmcia_put_dev(p_dev); | 
| 679 | } | ||
| 671 | } | 680 | } | 
| 672 | break; | 681 | break; | 
| 673 | case DS_GET_FIRST_REGION: | 682 | case DS_GET_FIRST_REGION: | 
| diff --git a/drivers/s390/net/lcs.c b/drivers/s390/net/lcs.c index 5d6b7a57b02f..e65da921a827 100644 --- a/drivers/s390/net/lcs.c +++ b/drivers/s390/net/lcs.c | |||
| @@ -1348,7 +1348,7 @@ lcs_irq(struct ccw_device *cdev, unsigned long intparm, struct irb *irb) | |||
| 1348 | index = (struct ccw1 *) __va((addr_t) irb->scsw.cpa) | 1348 | index = (struct ccw1 *) __va((addr_t) irb->scsw.cpa) | 
| 1349 | - channel->ccws; | 1349 | - channel->ccws; | 
| 1350 | if ((irb->scsw.actl & SCSW_ACTL_SUSPENDED) || | 1350 | if ((irb->scsw.actl & SCSW_ACTL_SUSPENDED) || | 
| 1351 | (irb->scsw.cstat | SCHN_STAT_PCI)) | 1351 | (irb->scsw.cstat & SCHN_STAT_PCI)) | 
| 1352 | /* Bloody io subsystem tells us lies about cpa... */ | 1352 | /* Bloody io subsystem tells us lies about cpa... */ | 
| 1353 | index = (index - 1) & (LCS_NUM_BUFFS - 1); | 1353 | index = (index - 1) & (LCS_NUM_BUFFS - 1); | 
| 1354 | while (channel->io_idx != index) { | 1354 | while (channel->io_idx != index) { | 
| diff --git a/drivers/scsi/libata-core.c b/drivers/scsi/libata-core.c index 9051b6821c1c..00881226f8dd 100644 --- a/drivers/scsi/libata-core.c +++ b/drivers/scsi/libata-core.c | |||
| @@ -875,6 +875,9 @@ static unsigned int ata_id_xfermask(const u16 *id) | |||
| 875 | /** | 875 | /** | 
| 876 | * ata_port_queue_task - Queue port_task | 876 | * ata_port_queue_task - Queue port_task | 
| 877 | * @ap: The ata_port to queue port_task for | 877 | * @ap: The ata_port to queue port_task for | 
| 878 | * @fn: workqueue function to be scheduled | ||
| 879 | * @data: data value to pass to workqueue function | ||
| 880 | * @delay: delay time for workqueue function | ||
| 878 | * | 881 | * | 
| 879 | * Schedule @fn(@data) for execution after @delay jiffies using | 882 | * Schedule @fn(@data) for execution after @delay jiffies using | 
| 880 | * port_task. There is one port_task per port and it's the | 883 | * port_task. There is one port_task per port and it's the | 
| @@ -3091,8 +3094,8 @@ static unsigned int ata_dev_set_xfermode(struct ata_device *dev) | |||
| 3091 | /** | 3094 | /** | 
| 3092 | * ata_dev_init_params - Issue INIT DEV PARAMS command | 3095 | * ata_dev_init_params - Issue INIT DEV PARAMS command | 
| 3093 | * @dev: Device to which command will be sent | 3096 | * @dev: Device to which command will be sent | 
| 3094 | * @heads: Number of heads | 3097 | * @heads: Number of heads (taskfile parameter) | 
| 3095 | * @sectors: Number of sectors | 3098 | * @sectors: Number of sectors (taskfile parameter) | 
| 3096 | * | 3099 | * | 
| 3097 | * LOCKING: | 3100 | * LOCKING: | 
| 3098 | * Kernel thread context (may sleep) | 3101 | * Kernel thread context (may sleep) | 
| @@ -5007,6 +5010,7 @@ int ata_device_resume(struct ata_device *dev) | |||
| 5007 | /** | 5010 | /** | 
| 5008 | * ata_device_suspend - prepare a device for suspend | 5011 | * ata_device_suspend - prepare a device for suspend | 
| 5009 | * @dev: the device to suspend | 5012 | * @dev: the device to suspend | 
| 5013 | * @state: target power management state | ||
| 5010 | * | 5014 | * | 
| 5011 | * Flush the cache on the drive, if appropriate, then issue a | 5015 | * Flush the cache on the drive, if appropriate, then issue a | 
| 5012 | * standbynow command. | 5016 | * standbynow command. | 
| diff --git a/drivers/scsi/sata_mv.c b/drivers/scsi/sata_mv.c index e6d141dd0385..bfe817fc7520 100644 --- a/drivers/scsi/sata_mv.c +++ b/drivers/scsi/sata_mv.c | |||
| @@ -37,7 +37,7 @@ | |||
| 37 | #include <asm/io.h> | 37 | #include <asm/io.h> | 
| 38 | 38 | ||
| 39 | #define DRV_NAME "sata_mv" | 39 | #define DRV_NAME "sata_mv" | 
| 40 | #define DRV_VERSION "0.6" | 40 | #define DRV_VERSION "0.7" | 
| 41 | 41 | ||
| 42 | enum { | 42 | enum { | 
| 43 | /* BAR's are enumerated in terms of pci_resource_start() terms */ | 43 | /* BAR's are enumerated in terms of pci_resource_start() terms */ | 
| @@ -50,6 +50,12 @@ enum { | |||
| 50 | 50 | ||
| 51 | MV_PCI_REG_BASE = 0, | 51 | MV_PCI_REG_BASE = 0, | 
| 52 | MV_IRQ_COAL_REG_BASE = 0x18000, /* 6xxx part only */ | 52 | MV_IRQ_COAL_REG_BASE = 0x18000, /* 6xxx part only */ | 
| 53 | MV_IRQ_COAL_CAUSE = (MV_IRQ_COAL_REG_BASE + 0x08), | ||
| 54 | MV_IRQ_COAL_CAUSE_LO = (MV_IRQ_COAL_REG_BASE + 0x88), | ||
| 55 | MV_IRQ_COAL_CAUSE_HI = (MV_IRQ_COAL_REG_BASE + 0x8c), | ||
| 56 | MV_IRQ_COAL_THRESHOLD = (MV_IRQ_COAL_REG_BASE + 0xcc), | ||
| 57 | MV_IRQ_COAL_TIME_THRESHOLD = (MV_IRQ_COAL_REG_BASE + 0xd0), | ||
| 58 | |||
| 53 | MV_SATAHC0_REG_BASE = 0x20000, | 59 | MV_SATAHC0_REG_BASE = 0x20000, | 
| 54 | MV_FLASH_CTL = 0x1046c, | 60 | MV_FLASH_CTL = 0x1046c, | 
| 55 | MV_GPIO_PORT_CTL = 0x104f0, | 61 | MV_GPIO_PORT_CTL = 0x104f0, | 
| @@ -302,9 +308,6 @@ struct mv_port_priv { | |||
| 302 | dma_addr_t crpb_dma; | 308 | dma_addr_t crpb_dma; | 
| 303 | struct mv_sg *sg_tbl; | 309 | struct mv_sg *sg_tbl; | 
| 304 | dma_addr_t sg_tbl_dma; | 310 | dma_addr_t sg_tbl_dma; | 
| 305 | |||
| 306 | unsigned req_producer; /* cp of req_in_ptr */ | ||
| 307 | unsigned rsp_consumer; /* cp of rsp_out_ptr */ | ||
| 308 | u32 pp_flags; | 311 | u32 pp_flags; | 
| 309 | }; | 312 | }; | 
| 310 | 313 | ||
| @@ -937,8 +940,6 @@ static int mv_port_start(struct ata_port *ap) | |||
| 937 | writelfl(pp->crpb_dma & EDMA_RSP_Q_BASE_LO_MASK, | 940 | writelfl(pp->crpb_dma & EDMA_RSP_Q_BASE_LO_MASK, | 
| 938 | port_mmio + EDMA_RSP_Q_OUT_PTR_OFS); | 941 | port_mmio + EDMA_RSP_Q_OUT_PTR_OFS); | 
| 939 | 942 | ||
| 940 | pp->req_producer = pp->rsp_consumer = 0; | ||
| 941 | |||
| 942 | /* Don't turn on EDMA here...do it before DMA commands only. Else | 943 | /* Don't turn on EDMA here...do it before DMA commands only. Else | 
| 943 | * we'll be unable to send non-data, PIO, etc due to restricted access | 944 | * we'll be unable to send non-data, PIO, etc due to restricted access | 
| 944 | * to shadow regs. | 945 | * to shadow regs. | 
| @@ -1022,16 +1023,16 @@ static void mv_fill_sg(struct ata_queued_cmd *qc) | |||
| 1022 | } | 1023 | } | 
| 1023 | } | 1024 | } | 
| 1024 | 1025 | ||
| 1025 | static inline unsigned mv_inc_q_index(unsigned *index) | 1026 | static inline unsigned mv_inc_q_index(unsigned index) | 
| 1026 | { | 1027 | { | 
| 1027 | *index = (*index + 1) & MV_MAX_Q_DEPTH_MASK; | 1028 | return (index + 1) & MV_MAX_Q_DEPTH_MASK; | 
| 1028 | return *index; | ||
| 1029 | } | 1029 | } | 
| 1030 | 1030 | ||
| 1031 | static inline void mv_crqb_pack_cmd(u16 *cmdw, u8 data, u8 addr, unsigned last) | 1031 | static inline void mv_crqb_pack_cmd(u16 *cmdw, u8 data, u8 addr, unsigned last) | 
| 1032 | { | 1032 | { | 
| 1033 | *cmdw = data | (addr << CRQB_CMD_ADDR_SHIFT) | CRQB_CMD_CS | | 1033 | u16 tmp = data | (addr << CRQB_CMD_ADDR_SHIFT) | CRQB_CMD_CS | | 
| 1034 | (last ? CRQB_CMD_LAST : 0); | 1034 | (last ? CRQB_CMD_LAST : 0); | 
| 1035 | *cmdw = cpu_to_le16(tmp); | ||
| 1035 | } | 1036 | } | 
| 1036 | 1037 | ||
| 1037 | /** | 1038 | /** | 
| @@ -1053,15 +1054,11 @@ static void mv_qc_prep(struct ata_queued_cmd *qc) | |||
| 1053 | u16 *cw; | 1054 | u16 *cw; | 
| 1054 | struct ata_taskfile *tf; | 1055 | struct ata_taskfile *tf; | 
| 1055 | u16 flags = 0; | 1056 | u16 flags = 0; | 
| 1057 | unsigned in_index; | ||
| 1056 | 1058 | ||
| 1057 | if (ATA_PROT_DMA != qc->tf.protocol) | 1059 | if (ATA_PROT_DMA != qc->tf.protocol) | 
| 1058 | return; | 1060 | return; | 
| 1059 | 1061 | ||
| 1060 | /* the req producer index should be the same as we remember it */ | ||
| 1061 | WARN_ON(((readl(mv_ap_base(qc->ap) + EDMA_REQ_Q_IN_PTR_OFS) >> | ||
| 1062 | EDMA_REQ_Q_PTR_SHIFT) & MV_MAX_Q_DEPTH_MASK) != | ||
| 1063 | pp->req_producer); | ||
| 1064 | |||
| 1065 | /* Fill in command request block | 1062 | /* Fill in command request block | 
| 1066 | */ | 1063 | */ | 
| 1067 | if (!(qc->tf.flags & ATA_TFLAG_WRITE)) | 1064 | if (!(qc->tf.flags & ATA_TFLAG_WRITE)) | 
| @@ -1069,13 +1066,17 @@ static void mv_qc_prep(struct ata_queued_cmd *qc) | |||
| 1069 | WARN_ON(MV_MAX_Q_DEPTH <= qc->tag); | 1066 | WARN_ON(MV_MAX_Q_DEPTH <= qc->tag); | 
| 1070 | flags |= qc->tag << CRQB_TAG_SHIFT; | 1067 | flags |= qc->tag << CRQB_TAG_SHIFT; | 
| 1071 | 1068 | ||
| 1072 | pp->crqb[pp->req_producer].sg_addr = | 1069 | /* get current queue index from hardware */ | 
| 1070 | in_index = (readl(mv_ap_base(ap) + EDMA_REQ_Q_IN_PTR_OFS) | ||
| 1071 | >> EDMA_REQ_Q_PTR_SHIFT) & MV_MAX_Q_DEPTH_MASK; | ||
| 1072 | |||
| 1073 | pp->crqb[in_index].sg_addr = | ||
| 1073 | cpu_to_le32(pp->sg_tbl_dma & 0xffffffff); | 1074 | cpu_to_le32(pp->sg_tbl_dma & 0xffffffff); | 
| 1074 | pp->crqb[pp->req_producer].sg_addr_hi = | 1075 | pp->crqb[in_index].sg_addr_hi = | 
| 1075 | cpu_to_le32((pp->sg_tbl_dma >> 16) >> 16); | 1076 | cpu_to_le32((pp->sg_tbl_dma >> 16) >> 16); | 
| 1076 | pp->crqb[pp->req_producer].ctrl_flags = cpu_to_le16(flags); | 1077 | pp->crqb[in_index].ctrl_flags = cpu_to_le16(flags); | 
| 1077 | 1078 | ||
| 1078 | cw = &pp->crqb[pp->req_producer].ata_cmd[0]; | 1079 | cw = &pp->crqb[in_index].ata_cmd[0]; | 
| 1079 | tf = &qc->tf; | 1080 | tf = &qc->tf; | 
| 1080 | 1081 | ||
| 1081 | /* Sadly, the CRQB cannot accomodate all registers--there are | 1082 | /* Sadly, the CRQB cannot accomodate all registers--there are | 
| @@ -1144,16 +1145,12 @@ static void mv_qc_prep_iie(struct ata_queued_cmd *qc) | |||
| 1144 | struct mv_port_priv *pp = ap->private_data; | 1145 | struct mv_port_priv *pp = ap->private_data; | 
| 1145 | struct mv_crqb_iie *crqb; | 1146 | struct mv_crqb_iie *crqb; | 
| 1146 | struct ata_taskfile *tf; | 1147 | struct ata_taskfile *tf; | 
| 1148 | unsigned in_index; | ||
| 1147 | u32 flags = 0; | 1149 | u32 flags = 0; | 
| 1148 | 1150 | ||
| 1149 | if (ATA_PROT_DMA != qc->tf.protocol) | 1151 | if (ATA_PROT_DMA != qc->tf.protocol) | 
| 1150 | return; | 1152 | return; | 
| 1151 | 1153 | ||
| 1152 | /* the req producer index should be the same as we remember it */ | ||
| 1153 | WARN_ON(((readl(mv_ap_base(qc->ap) + EDMA_REQ_Q_IN_PTR_OFS) >> | ||
| 1154 | EDMA_REQ_Q_PTR_SHIFT) & MV_MAX_Q_DEPTH_MASK) != | ||
| 1155 | pp->req_producer); | ||
| 1156 | |||
| 1157 | /* Fill in Gen IIE command request block | 1154 | /* Fill in Gen IIE command request block | 
| 1158 | */ | 1155 | */ | 
| 1159 | if (!(qc->tf.flags & ATA_TFLAG_WRITE)) | 1156 | if (!(qc->tf.flags & ATA_TFLAG_WRITE)) | 
| @@ -1162,7 +1159,11 @@ static void mv_qc_prep_iie(struct ata_queued_cmd *qc) | |||
| 1162 | WARN_ON(MV_MAX_Q_DEPTH <= qc->tag); | 1159 | WARN_ON(MV_MAX_Q_DEPTH <= qc->tag); | 
| 1163 | flags |= qc->tag << CRQB_TAG_SHIFT; | 1160 | flags |= qc->tag << CRQB_TAG_SHIFT; | 
| 1164 | 1161 | ||
| 1165 | crqb = (struct mv_crqb_iie *) &pp->crqb[pp->req_producer]; | 1162 | /* get current queue index from hardware */ | 
| 1163 | in_index = (readl(mv_ap_base(ap) + EDMA_REQ_Q_IN_PTR_OFS) | ||
| 1164 | >> EDMA_REQ_Q_PTR_SHIFT) & MV_MAX_Q_DEPTH_MASK; | ||
| 1165 | |||
| 1166 | crqb = (struct mv_crqb_iie *) &pp->crqb[in_index]; | ||
| 1166 | crqb->addr = cpu_to_le32(pp->sg_tbl_dma & 0xffffffff); | 1167 | crqb->addr = cpu_to_le32(pp->sg_tbl_dma & 0xffffffff); | 
| 1167 | crqb->addr_hi = cpu_to_le32((pp->sg_tbl_dma >> 16) >> 16); | 1168 | crqb->addr_hi = cpu_to_le32((pp->sg_tbl_dma >> 16) >> 16); | 
| 1168 | crqb->flags = cpu_to_le32(flags); | 1169 | crqb->flags = cpu_to_le32(flags); | 
| @@ -1210,6 +1211,7 @@ static unsigned int mv_qc_issue(struct ata_queued_cmd *qc) | |||
| 1210 | { | 1211 | { | 
| 1211 | void __iomem *port_mmio = mv_ap_base(qc->ap); | 1212 | void __iomem *port_mmio = mv_ap_base(qc->ap); | 
| 1212 | struct mv_port_priv *pp = qc->ap->private_data; | 1213 | struct mv_port_priv *pp = qc->ap->private_data; | 
| 1214 | unsigned in_index; | ||
| 1213 | u32 in_ptr; | 1215 | u32 in_ptr; | 
| 1214 | 1216 | ||
| 1215 | if (ATA_PROT_DMA != qc->tf.protocol) { | 1217 | if (ATA_PROT_DMA != qc->tf.protocol) { | 
| @@ -1221,23 +1223,20 @@ static unsigned int mv_qc_issue(struct ata_queued_cmd *qc) | |||
| 1221 | return ata_qc_issue_prot(qc); | 1223 | return ata_qc_issue_prot(qc); | 
| 1222 | } | 1224 | } | 
| 1223 | 1225 | ||
| 1224 | in_ptr = readl(port_mmio + EDMA_REQ_Q_IN_PTR_OFS); | 1226 | in_ptr = readl(port_mmio + EDMA_REQ_Q_IN_PTR_OFS); | 
| 1227 | in_index = (in_ptr >> EDMA_REQ_Q_PTR_SHIFT) & MV_MAX_Q_DEPTH_MASK; | ||
| 1225 | 1228 | ||
| 1226 | /* the req producer index should be the same as we remember it */ | ||
| 1227 | WARN_ON(((in_ptr >> EDMA_REQ_Q_PTR_SHIFT) & MV_MAX_Q_DEPTH_MASK) != | ||
| 1228 | pp->req_producer); | ||
| 1229 | /* until we do queuing, the queue should be empty at this point */ | 1229 | /* until we do queuing, the queue should be empty at this point */ | 
| 1230 | WARN_ON(((in_ptr >> EDMA_REQ_Q_PTR_SHIFT) & MV_MAX_Q_DEPTH_MASK) != | 1230 | WARN_ON(in_index != ((readl(port_mmio + EDMA_REQ_Q_OUT_PTR_OFS) | 
| 1231 | ((readl(port_mmio + EDMA_REQ_Q_OUT_PTR_OFS) >> | 1231 | >> EDMA_REQ_Q_PTR_SHIFT) & MV_MAX_Q_DEPTH_MASK)); | 
| 1232 | EDMA_REQ_Q_PTR_SHIFT) & MV_MAX_Q_DEPTH_MASK)); | ||
| 1233 | 1232 | ||
| 1234 | mv_inc_q_index(&pp->req_producer); /* now incr producer index */ | 1233 | in_index = mv_inc_q_index(in_index); /* now incr producer index */ | 
| 1235 | 1234 | ||
| 1236 | mv_start_dma(port_mmio, pp); | 1235 | mv_start_dma(port_mmio, pp); | 
| 1237 | 1236 | ||
| 1238 | /* and write the request in pointer to kick the EDMA to life */ | 1237 | /* and write the request in pointer to kick the EDMA to life */ | 
| 1239 | in_ptr &= EDMA_REQ_Q_BASE_LO_MASK; | 1238 | in_ptr &= EDMA_REQ_Q_BASE_LO_MASK; | 
| 1240 | in_ptr |= pp->req_producer << EDMA_REQ_Q_PTR_SHIFT; | 1239 | in_ptr |= in_index << EDMA_REQ_Q_PTR_SHIFT; | 
| 1241 | writelfl(in_ptr, port_mmio + EDMA_REQ_Q_IN_PTR_OFS); | 1240 | writelfl(in_ptr, port_mmio + EDMA_REQ_Q_IN_PTR_OFS); | 
| 1242 | 1241 | ||
| 1243 | return 0; | 1242 | return 0; | 
| @@ -1260,28 +1259,26 @@ static u8 mv_get_crpb_status(struct ata_port *ap) | |||
| 1260 | { | 1259 | { | 
| 1261 | void __iomem *port_mmio = mv_ap_base(ap); | 1260 | void __iomem *port_mmio = mv_ap_base(ap); | 
| 1262 | struct mv_port_priv *pp = ap->private_data; | 1261 | struct mv_port_priv *pp = ap->private_data; | 
| 1262 | unsigned out_index; | ||
| 1263 | u32 out_ptr; | 1263 | u32 out_ptr; | 
| 1264 | u8 ata_status; | 1264 | u8 ata_status; | 
| 1265 | 1265 | ||
| 1266 | out_ptr = readl(port_mmio + EDMA_RSP_Q_OUT_PTR_OFS); | 1266 | out_ptr = readl(port_mmio + EDMA_RSP_Q_OUT_PTR_OFS); | 
| 1267 | out_index = (out_ptr >> EDMA_RSP_Q_PTR_SHIFT) & MV_MAX_Q_DEPTH_MASK; | ||
| 1267 | 1268 | ||
| 1268 | /* the response consumer index should be the same as we remember it */ | 1269 | ata_status = le16_to_cpu(pp->crpb[out_index].flags) | 
| 1269 | WARN_ON(((out_ptr >> EDMA_RSP_Q_PTR_SHIFT) & MV_MAX_Q_DEPTH_MASK) != | 1270 | >> CRPB_FLAG_STATUS_SHIFT; | 
| 1270 | pp->rsp_consumer); | ||
| 1271 | |||
| 1272 | ata_status = pp->crpb[pp->rsp_consumer].flags >> CRPB_FLAG_STATUS_SHIFT; | ||
| 1273 | 1271 | ||
| 1274 | /* increment our consumer index... */ | 1272 | /* increment our consumer index... */ | 
| 1275 | pp->rsp_consumer = mv_inc_q_index(&pp->rsp_consumer); | 1273 | out_index = mv_inc_q_index(out_index); | 
| 1276 | 1274 | ||
| 1277 | /* and, until we do NCQ, there should only be 1 CRPB waiting */ | 1275 | /* and, until we do NCQ, there should only be 1 CRPB waiting */ | 
| 1278 | WARN_ON(((readl(port_mmio + EDMA_RSP_Q_IN_PTR_OFS) >> | 1276 | WARN_ON(out_index != ((readl(port_mmio + EDMA_RSP_Q_IN_PTR_OFS) | 
| 1279 | EDMA_RSP_Q_PTR_SHIFT) & MV_MAX_Q_DEPTH_MASK) != | 1277 | >> EDMA_RSP_Q_PTR_SHIFT) & MV_MAX_Q_DEPTH_MASK)); | 
| 1280 | pp->rsp_consumer); | ||
| 1281 | 1278 | ||
| 1282 | /* write out our inc'd consumer index so EDMA knows we're caught up */ | 1279 | /* write out our inc'd consumer index so EDMA knows we're caught up */ | 
| 1283 | out_ptr &= EDMA_RSP_Q_BASE_LO_MASK; | 1280 | out_ptr &= EDMA_RSP_Q_BASE_LO_MASK; | 
| 1284 | out_ptr |= pp->rsp_consumer << EDMA_RSP_Q_PTR_SHIFT; | 1281 | out_ptr |= out_index << EDMA_RSP_Q_PTR_SHIFT; | 
| 1285 | writelfl(out_ptr, port_mmio + EDMA_RSP_Q_OUT_PTR_OFS); | 1282 | writelfl(out_ptr, port_mmio + EDMA_RSP_Q_OUT_PTR_OFS); | 
| 1286 | 1283 | ||
| 1287 | /* Return ATA status register for completed CRPB */ | 1284 | /* Return ATA status register for completed CRPB */ | 
| @@ -1291,6 +1288,7 @@ static u8 mv_get_crpb_status(struct ata_port *ap) | |||
| 1291 | /** | 1288 | /** | 
| 1292 | * mv_err_intr - Handle error interrupts on the port | 1289 | * mv_err_intr - Handle error interrupts on the port | 
| 1293 | * @ap: ATA channel to manipulate | 1290 | * @ap: ATA channel to manipulate | 
| 1291 | * @reset_allowed: bool: 0 == don't trigger from reset here | ||
| 1294 | * | 1292 | * | 
| 1295 | * In most cases, just clear the interrupt and move on. However, | 1293 | * In most cases, just clear the interrupt and move on. However, | 
| 1296 | * some cases require an eDMA reset, which is done right before | 1294 | * some cases require an eDMA reset, which is done right before | 
| @@ -1301,7 +1299,7 @@ static u8 mv_get_crpb_status(struct ata_port *ap) | |||
| 1301 | * LOCKING: | 1299 | * LOCKING: | 
| 1302 | * Inherited from caller. | 1300 | * Inherited from caller. | 
| 1303 | */ | 1301 | */ | 
| 1304 | static void mv_err_intr(struct ata_port *ap) | 1302 | static void mv_err_intr(struct ata_port *ap, int reset_allowed) | 
| 1305 | { | 1303 | { | 
| 1306 | void __iomem *port_mmio = mv_ap_base(ap); | 1304 | void __iomem *port_mmio = mv_ap_base(ap); | 
| 1307 | u32 edma_err_cause, serr = 0; | 1305 | u32 edma_err_cause, serr = 0; | 
| @@ -1323,9 +1321,8 @@ static void mv_err_intr(struct ata_port *ap) | |||
| 1323 | writelfl(0, port_mmio + EDMA_ERR_IRQ_CAUSE_OFS); | 1321 | writelfl(0, port_mmio + EDMA_ERR_IRQ_CAUSE_OFS); | 
| 1324 | 1322 | ||
| 1325 | /* check for fatal here and recover if needed */ | 1323 | /* check for fatal here and recover if needed */ | 
| 1326 | if (EDMA_ERR_FATAL & edma_err_cause) { | 1324 | if (reset_allowed && (EDMA_ERR_FATAL & edma_err_cause)) | 
| 1327 | mv_stop_and_reset(ap); | 1325 | mv_stop_and_reset(ap); | 
| 1328 | } | ||
| 1329 | } | 1326 | } | 
| 1330 | 1327 | ||
| 1331 | /** | 1328 | /** | 
| @@ -1374,12 +1371,12 @@ static void mv_host_intr(struct ata_host_set *host_set, u32 relevant, | |||
| 1374 | struct ata_port *ap = host_set->ports[port]; | 1371 | struct ata_port *ap = host_set->ports[port]; | 
| 1375 | struct mv_port_priv *pp = ap->private_data; | 1372 | struct mv_port_priv *pp = ap->private_data; | 
| 1376 | 1373 | ||
| 1377 | hard_port = port & MV_PORT_MASK; /* range 0-3 */ | 1374 | hard_port = mv_hardport_from_port(port); /* range 0..3 */ | 
| 1378 | handled = 0; /* ensure ata_status is set if handled++ */ | 1375 | handled = 0; /* ensure ata_status is set if handled++ */ | 
| 1379 | 1376 | ||
| 1380 | /* Note that DEV_IRQ might happen spuriously during EDMA, | 1377 | /* Note that DEV_IRQ might happen spuriously during EDMA, | 
| 1381 | * and should be ignored in such cases. We could mask it, | 1378 | * and should be ignored in such cases. | 
| 1382 | * but it's pretty rare and may not be worth the overhead. | 1379 | * The cause of this is still under investigation. | 
| 1383 | */ | 1380 | */ | 
| 1384 | if (pp->pp_flags & MV_PP_FLAG_EDMA_EN) { | 1381 | if (pp->pp_flags & MV_PP_FLAG_EDMA_EN) { | 
| 1385 | /* EDMA: check for response queue interrupt */ | 1382 | /* EDMA: check for response queue interrupt */ | 
| @@ -1393,6 +1390,11 @@ static void mv_host_intr(struct ata_host_set *host_set, u32 relevant, | |||
| 1393 | ata_status = readb((void __iomem *) | 1390 | ata_status = readb((void __iomem *) | 
| 1394 | ap->ioaddr.status_addr); | 1391 | ap->ioaddr.status_addr); | 
| 1395 | handled = 1; | 1392 | handled = 1; | 
| 1393 | /* ignore spurious intr if drive still BUSY */ | ||
| 1394 | if (ata_status & ATA_BUSY) { | ||
| 1395 | ata_status = 0; | ||
| 1396 | handled = 0; | ||
| 1397 | } | ||
| 1396 | } | 1398 | } | 
| 1397 | } | 1399 | } | 
| 1398 | 1400 | ||
| @@ -1406,7 +1408,7 @@ static void mv_host_intr(struct ata_host_set *host_set, u32 relevant, | |||
| 1406 | shift++; /* skip bit 8 in the HC Main IRQ reg */ | 1408 | shift++; /* skip bit 8 in the HC Main IRQ reg */ | 
| 1407 | } | 1409 | } | 
| 1408 | if ((PORT0_ERR << shift) & relevant) { | 1410 | if ((PORT0_ERR << shift) & relevant) { | 
| 1409 | mv_err_intr(ap); | 1411 | mv_err_intr(ap, 1); | 
| 1410 | err_mask |= AC_ERR_OTHER; | 1412 | err_mask |= AC_ERR_OTHER; | 
| 1411 | handled = 1; | 1413 | handled = 1; | 
| 1412 | } | 1414 | } | 
| @@ -1448,6 +1450,7 @@ static irqreturn_t mv_interrupt(int irq, void *dev_instance, | |||
| 1448 | struct ata_host_set *host_set = dev_instance; | 1450 | struct ata_host_set *host_set = dev_instance; | 
| 1449 | unsigned int hc, handled = 0, n_hcs; | 1451 | unsigned int hc, handled = 0, n_hcs; | 
| 1450 | void __iomem *mmio = host_set->mmio_base; | 1452 | void __iomem *mmio = host_set->mmio_base; | 
| 1453 | struct mv_host_priv *hpriv; | ||
| 1451 | u32 irq_stat; | 1454 | u32 irq_stat; | 
| 1452 | 1455 | ||
| 1453 | irq_stat = readl(mmio + HC_MAIN_IRQ_CAUSE_OFS); | 1456 | irq_stat = readl(mmio + HC_MAIN_IRQ_CAUSE_OFS); | 
| @@ -1469,6 +1472,17 @@ static irqreturn_t mv_interrupt(int irq, void *dev_instance, | |||
| 1469 | handled++; | 1472 | handled++; | 
| 1470 | } | 1473 | } | 
| 1471 | } | 1474 | } | 
| 1475 | |||
| 1476 | hpriv = host_set->private_data; | ||
| 1477 | if (IS_60XX(hpriv)) { | ||
| 1478 | /* deal with the interrupt coalescing bits */ | ||
| 1479 | if (irq_stat & (TRAN_LO_DONE | TRAN_HI_DONE | PORTS_0_7_COAL_DONE)) { | ||
| 1480 | writelfl(0, mmio + MV_IRQ_COAL_CAUSE_LO); | ||
| 1481 | writelfl(0, mmio + MV_IRQ_COAL_CAUSE_HI); | ||
| 1482 | writelfl(0, mmio + MV_IRQ_COAL_CAUSE); | ||
| 1483 | } | ||
| 1484 | } | ||
| 1485 | |||
| 1472 | if (PCI_ERR & irq_stat) { | 1486 | if (PCI_ERR & irq_stat) { | 
| 1473 | printk(KERN_ERR DRV_NAME ": PCI ERROR; PCI IRQ cause=0x%08x\n", | 1487 | printk(KERN_ERR DRV_NAME ": PCI ERROR; PCI IRQ cause=0x%08x\n", | 
| 1474 | readl(mmio + PCI_IRQ_CAUSE_OFS)); | 1488 | readl(mmio + PCI_IRQ_CAUSE_OFS)); | 
| @@ -1867,7 +1881,8 @@ static void mv_channel_reset(struct mv_host_priv *hpriv, void __iomem *mmio, | |||
| 1867 | 1881 | ||
| 1868 | if (IS_60XX(hpriv)) { | 1882 | if (IS_60XX(hpriv)) { | 
| 1869 | u32 ifctl = readl(port_mmio + SATA_INTERFACE_CTL); | 1883 | u32 ifctl = readl(port_mmio + SATA_INTERFACE_CTL); | 
| 1870 | ifctl |= (1 << 12) | (1 << 7); | 1884 | ifctl |= (1 << 7); /* enable gen2i speed */ | 
| 1885 | ifctl = (ifctl & 0xfff) | 0x9b1000; /* from chip spec */ | ||
| 1871 | writelfl(ifctl, port_mmio + SATA_INTERFACE_CTL); | 1886 | writelfl(ifctl, port_mmio + SATA_INTERFACE_CTL); | 
| 1872 | } | 1887 | } | 
| 1873 | 1888 | ||
| @@ -2033,11 +2048,14 @@ static void mv_eng_timeout(struct ata_port *ap) | |||
| 2033 | ap->host_set->mmio_base, ap, qc, qc->scsicmd, | 2048 | ap->host_set->mmio_base, ap, qc, qc->scsicmd, | 
| 2034 | &qc->scsicmd->cmnd); | 2049 | &qc->scsicmd->cmnd); | 
| 2035 | 2050 | ||
| 2036 | mv_err_intr(ap); | 2051 | mv_err_intr(ap, 0); | 
| 2037 | mv_stop_and_reset(ap); | 2052 | mv_stop_and_reset(ap); | 
| 2038 | 2053 | ||
| 2039 | qc->err_mask |= AC_ERR_TIMEOUT; | 2054 | WARN_ON(!(qc->flags & ATA_QCFLAG_ACTIVE)); | 
| 2040 | ata_eh_qc_complete(qc); | 2055 | if (qc->flags & ATA_QCFLAG_ACTIVE) { | 
| 2056 | qc->err_mask |= AC_ERR_TIMEOUT; | ||
| 2057 | ata_eh_qc_complete(qc); | ||
| 2058 | } | ||
| 2041 | } | 2059 | } | 
| 2042 | 2060 | ||
| 2043 | /** | 2061 | /** | 
| @@ -2231,7 +2249,8 @@ static int mv_init_host(struct pci_dev *pdev, struct ata_probe_ent *probe_ent, | |||
| 2231 | void __iomem *port_mmio = mv_port_base(mmio, port); | 2249 | void __iomem *port_mmio = mv_port_base(mmio, port); | 
| 2232 | 2250 | ||
| 2233 | u32 ifctl = readl(port_mmio + SATA_INTERFACE_CTL); | 2251 | u32 ifctl = readl(port_mmio + SATA_INTERFACE_CTL); | 
| 2234 | ifctl |= (1 << 12); | 2252 | ifctl |= (1 << 7); /* enable gen2i speed */ | 
| 2253 | ifctl = (ifctl & 0xfff) | 0x9b1000; /* from chip spec */ | ||
| 2235 | writelfl(ifctl, port_mmio + SATA_INTERFACE_CTL); | 2254 | writelfl(ifctl, port_mmio + SATA_INTERFACE_CTL); | 
| 2236 | } | 2255 | } | 
| 2237 | 2256 | ||
| @@ -2332,6 +2351,7 @@ static int mv_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 2332 | if (rc) { | 2351 | if (rc) { | 
| 2333 | return rc; | 2352 | return rc; | 
| 2334 | } | 2353 | } | 
| 2354 | pci_set_master(pdev); | ||
| 2335 | 2355 | ||
| 2336 | rc = pci_request_regions(pdev, DRV_NAME); | 2356 | rc = pci_request_regions(pdev, DRV_NAME); | 
| 2337 | if (rc) { | 2357 | if (rc) { | 
| diff --git a/drivers/serial/serial_core.c b/drivers/serial/serial_core.c index aeb8153ccf24..17839e753e4c 100644 --- a/drivers/serial/serial_core.c +++ b/drivers/serial/serial_core.c | |||
| @@ -1907,9 +1907,12 @@ uart_set_options(struct uart_port *port, struct console *co, | |||
| 1907 | static void uart_change_pm(struct uart_state *state, int pm_state) | 1907 | static void uart_change_pm(struct uart_state *state, int pm_state) | 
| 1908 | { | 1908 | { | 
| 1909 | struct uart_port *port = state->port; | 1909 | struct uart_port *port = state->port; | 
| 1910 | if (port->ops->pm) | 1910 | |
| 1911 | port->ops->pm(port, pm_state, state->pm_state); | 1911 | if (state->pm_state != pm_state) { | 
| 1912 | state->pm_state = pm_state; | 1912 | if (port->ops->pm) | 
| 1913 | port->ops->pm(port, pm_state, state->pm_state); | ||
| 1914 | state->pm_state = pm_state; | ||
| 1915 | } | ||
| 1913 | } | 1916 | } | 
| 1914 | 1917 | ||
| 1915 | int uart_suspend_port(struct uart_driver *drv, struct uart_port *port) | 1918 | int uart_suspend_port(struct uart_driver *drv, struct uart_port *port) | 
| diff --git a/drivers/spi/Kconfig b/drivers/spi/Kconfig index 7a75faeb0526..9ce1d01469b1 100644 --- a/drivers/spi/Kconfig +++ b/drivers/spi/Kconfig | |||
| @@ -75,6 +75,14 @@ config SPI_BUTTERFLY | |||
| 75 | inexpensive battery powered microcontroller evaluation board. | 75 | inexpensive battery powered microcontroller evaluation board. | 
| 76 | This same cable can be used to flash new firmware. | 76 | This same cable can be used to flash new firmware. | 
| 77 | 77 | ||
| 78 | config SPI_PXA2XX | ||
| 79 | tristate "PXA2xx SSP SPI master" | ||
| 80 | depends on SPI_MASTER && ARCH_PXA && EXPERIMENTAL | ||
| 81 | help | ||
| 82 | This enables using a PXA2xx SSP port as a SPI master controller. | ||
| 83 | The driver can be configured to use any SSP port and additional | ||
| 84 | documentation can be found a Documentation/spi/pxa2xx. | ||
| 85 | |||
| 78 | # | 86 | # | 
| 79 | # Add new SPI master controllers in alphabetical order above this line | 87 | # Add new SPI master controllers in alphabetical order above this line | 
| 80 | # | 88 | # | 
| diff --git a/drivers/spi/Makefile b/drivers/spi/Makefile index c2c87e845abf..1bca5f95de25 100644 --- a/drivers/spi/Makefile +++ b/drivers/spi/Makefile | |||
| @@ -13,6 +13,7 @@ obj-$(CONFIG_SPI_MASTER) += spi.o | |||
| 13 | # SPI master controller drivers (bus) | 13 | # SPI master controller drivers (bus) | 
| 14 | obj-$(CONFIG_SPI_BITBANG) += spi_bitbang.o | 14 | obj-$(CONFIG_SPI_BITBANG) += spi_bitbang.o | 
| 15 | obj-$(CONFIG_SPI_BUTTERFLY) += spi_butterfly.o | 15 | obj-$(CONFIG_SPI_BUTTERFLY) += spi_butterfly.o | 
| 16 | obj-$(CONFIG_SPI_PXA2XX) += pxa2xx_spi.o | ||
| 16 | # ... add above this line ... | 17 | # ... add above this line ... | 
| 17 | 18 | ||
| 18 | # SPI protocol drivers (device/link on bus) | 19 | # SPI protocol drivers (device/link on bus) | 
| diff --git a/drivers/spi/pxa2xx_spi.c b/drivers/spi/pxa2xx_spi.c new file mode 100644 index 000000000000..596bf820b70c --- /dev/null +++ b/drivers/spi/pxa2xx_spi.c | |||
| @@ -0,0 +1,1467 @@ | |||
| 1 | /* | ||
| 2 | * Copyright (C) 2005 Stephen Street / StreetFire Sound Labs | ||
| 3 | * | ||
| 4 | * This program is free software; you can redistribute it and/or modify | ||
| 5 | * it under the terms of the GNU General Public License as published by | ||
| 6 | * the Free Software Foundation; either version 2 of the License, or | ||
| 7 | * (at your option) any later version. | ||
| 8 | * | ||
| 9 | * This program is distributed in the hope that it will be useful, | ||
| 10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 12 | * GNU General Public License for more details. | ||
| 13 | * | ||
| 14 | * You should have received a copy of the GNU General Public License | ||
| 15 | * along with this program; if not, write to the Free Software | ||
| 16 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | ||
| 17 | */ | ||
| 18 | |||
| 19 | #include <linux/init.h> | ||
| 20 | #include <linux/module.h> | ||
| 21 | #include <linux/device.h> | ||
| 22 | #include <linux/ioport.h> | ||
| 23 | #include <linux/errno.h> | ||
| 24 | #include <linux/interrupt.h> | ||
| 25 | #include <linux/platform_device.h> | ||
| 26 | #include <linux/dma-mapping.h> | ||
| 27 | #include <linux/spi/spi.h> | ||
| 28 | #include <linux/workqueue.h> | ||
| 29 | #include <linux/errno.h> | ||
| 30 | #include <linux/delay.h> | ||
| 31 | |||
| 32 | #include <asm/io.h> | ||
| 33 | #include <asm/irq.h> | ||
| 34 | #include <asm/hardware.h> | ||
| 35 | #include <asm/delay.h> | ||
| 36 | #include <asm/dma.h> | ||
| 37 | |||
| 38 | #include <asm/arch/hardware.h> | ||
| 39 | #include <asm/arch/pxa-regs.h> | ||
| 40 | #include <asm/arch/pxa2xx_spi.h> | ||
| 41 | |||
| 42 | MODULE_AUTHOR("Stephen Street"); | ||
| 43 | MODULE_DESCRIPTION("PXA2xx SSP SPI Contoller"); | ||
| 44 | MODULE_LICENSE("GPL"); | ||
| 45 | |||
| 46 | #define MAX_BUSES 3 | ||
| 47 | |||
| 48 | #define DMA_INT_MASK (DCSR_ENDINTR | DCSR_STARTINTR | DCSR_BUSERR) | ||
| 49 | #define RESET_DMA_CHANNEL (DCSR_NODESC | DMA_INT_MASK) | ||
| 50 | #define IS_DMA_ALIGNED(x) (((u32)(x)&0x07)==0) | ||
| 51 | |||
| 52 | #define DEFINE_SSP_REG(reg, off) \ | ||
| 53 | static inline u32 read_##reg(void *p) { return __raw_readl(p + (off)); } \ | ||
| 54 | static inline void write_##reg(u32 v, void *p) { __raw_writel(v, p + (off)); } | ||
| 55 | |||
| 56 | DEFINE_SSP_REG(SSCR0, 0x00) | ||
| 57 | DEFINE_SSP_REG(SSCR1, 0x04) | ||
| 58 | DEFINE_SSP_REG(SSSR, 0x08) | ||
| 59 | DEFINE_SSP_REG(SSITR, 0x0c) | ||
| 60 | DEFINE_SSP_REG(SSDR, 0x10) | ||
| 61 | DEFINE_SSP_REG(SSTO, 0x28) | ||
| 62 | DEFINE_SSP_REG(SSPSP, 0x2c) | ||
| 63 | |||
| 64 | #define START_STATE ((void*)0) | ||
| 65 | #define RUNNING_STATE ((void*)1) | ||
| 66 | #define DONE_STATE ((void*)2) | ||
| 67 | #define ERROR_STATE ((void*)-1) | ||
| 68 | |||
| 69 | #define QUEUE_RUNNING 0 | ||
| 70 | #define QUEUE_STOPPED 1 | ||
| 71 | |||
| 72 | struct driver_data { | ||
| 73 | /* Driver model hookup */ | ||
| 74 | struct platform_device *pdev; | ||
| 75 | |||
| 76 | /* SPI framework hookup */ | ||
| 77 | enum pxa_ssp_type ssp_type; | ||
| 78 | struct spi_master *master; | ||
| 79 | |||
| 80 | /* PXA hookup */ | ||
| 81 | struct pxa2xx_spi_master *master_info; | ||
| 82 | |||
| 83 | /* DMA setup stuff */ | ||
| 84 | int rx_channel; | ||
| 85 | int tx_channel; | ||
| 86 | u32 *null_dma_buf; | ||
| 87 | |||
| 88 | /* SSP register addresses */ | ||
| 89 | void *ioaddr; | ||
| 90 | u32 ssdr_physical; | ||
| 91 | |||
| 92 | /* SSP masks*/ | ||
| 93 | u32 dma_cr1; | ||
| 94 | u32 int_cr1; | ||
| 95 | u32 clear_sr; | ||
| 96 | u32 mask_sr; | ||
| 97 | |||
| 98 | /* Driver message queue */ | ||
| 99 | struct workqueue_struct *workqueue; | ||
| 100 | struct work_struct pump_messages; | ||
| 101 | spinlock_t lock; | ||
| 102 | struct list_head queue; | ||
| 103 | int busy; | ||
| 104 | int run; | ||
| 105 | |||
| 106 | /* Message Transfer pump */ | ||
| 107 | struct tasklet_struct pump_transfers; | ||
| 108 | |||
| 109 | /* Current message transfer state info */ | ||
| 110 | struct spi_message* cur_msg; | ||
| 111 | struct spi_transfer* cur_transfer; | ||
| 112 | struct chip_data *cur_chip; | ||
| 113 | size_t len; | ||
| 114 | void *tx; | ||
| 115 | void *tx_end; | ||
| 116 | void *rx; | ||
| 117 | void *rx_end; | ||
| 118 | int dma_mapped; | ||
| 119 | dma_addr_t rx_dma; | ||
| 120 | dma_addr_t tx_dma; | ||
| 121 | size_t rx_map_len; | ||
| 122 | size_t tx_map_len; | ||
| 123 | u8 n_bytes; | ||
| 124 | u32 dma_width; | ||
| 125 | int cs_change; | ||
| 126 | void (*write)(struct driver_data *drv_data); | ||
| 127 | void (*read)(struct driver_data *drv_data); | ||
| 128 | irqreturn_t (*transfer_handler)(struct driver_data *drv_data); | ||
| 129 | void (*cs_control)(u32 command); | ||
| 130 | }; | ||
| 131 | |||
| 132 | struct chip_data { | ||
| 133 | u32 cr0; | ||
| 134 | u32 cr1; | ||
| 135 | u32 to; | ||
| 136 | u32 psp; | ||
| 137 | u32 timeout; | ||
| 138 | u8 n_bytes; | ||
| 139 | u32 dma_width; | ||
| 140 | u32 dma_burst_size; | ||
| 141 | u32 threshold; | ||
| 142 | u32 dma_threshold; | ||
| 143 | u8 enable_dma; | ||
| 144 | u8 bits_per_word; | ||
| 145 | u32 speed_hz; | ||
| 146 | void (*write)(struct driver_data *drv_data); | ||
| 147 | void (*read)(struct driver_data *drv_data); | ||
| 148 | void (*cs_control)(u32 command); | ||
| 149 | }; | ||
| 150 | |||
| 151 | static void pump_messages(void *data); | ||
| 152 | |||
| 153 | static int flush(struct driver_data *drv_data) | ||
| 154 | { | ||
| 155 | unsigned long limit = loops_per_jiffy << 1; | ||
| 156 | |||
| 157 | void *reg = drv_data->ioaddr; | ||
| 158 | |||
| 159 | do { | ||
| 160 | while (read_SSSR(reg) & SSSR_RNE) { | ||
| 161 | read_SSDR(reg); | ||
| 162 | } | ||
| 163 | } while ((read_SSSR(reg) & SSSR_BSY) && limit--); | ||
| 164 | write_SSSR(SSSR_ROR, reg); | ||
| 165 | |||
| 166 | return limit; | ||
| 167 | } | ||
| 168 | |||
| 169 | static void restore_state(struct driver_data *drv_data) | ||
| 170 | { | ||
| 171 | void *reg = drv_data->ioaddr; | ||
| 172 | |||
| 173 | /* Clear status and disable clock */ | ||
| 174 | write_SSSR(drv_data->clear_sr, reg); | ||
| 175 | write_SSCR0(drv_data->cur_chip->cr0 & ~SSCR0_SSE, reg); | ||
| 176 | |||
| 177 | /* Load the registers */ | ||
| 178 | write_SSCR1(drv_data->cur_chip->cr1, reg); | ||
| 179 | write_SSCR0(drv_data->cur_chip->cr0, reg); | ||
| 180 | if (drv_data->ssp_type != PXA25x_SSP) { | ||
| 181 | write_SSTO(0, reg); | ||
| 182 | write_SSPSP(drv_data->cur_chip->psp, reg); | ||
| 183 | } | ||
| 184 | } | ||
| 185 | |||
| 186 | static void null_cs_control(u32 command) | ||
| 187 | { | ||
| 188 | } | ||
| 189 | |||
| 190 | static void null_writer(struct driver_data *drv_data) | ||
| 191 | { | ||
| 192 | void *reg = drv_data->ioaddr; | ||
| 193 | u8 n_bytes = drv_data->n_bytes; | ||
| 194 | |||
| 195 | while ((read_SSSR(reg) & SSSR_TNF) | ||
| 196 | && (drv_data->tx < drv_data->tx_end)) { | ||
| 197 | write_SSDR(0, reg); | ||
| 198 | drv_data->tx += n_bytes; | ||
| 199 | } | ||
| 200 | } | ||
| 201 | |||
| 202 | static void null_reader(struct driver_data *drv_data) | ||
| 203 | { | ||
| 204 | void *reg = drv_data->ioaddr; | ||
| 205 | u8 n_bytes = drv_data->n_bytes; | ||
| 206 | |||
| 207 | while ((read_SSSR(reg) & SSSR_RNE) | ||
| 208 | && (drv_data->rx < drv_data->rx_end)) { | ||
| 209 | read_SSDR(reg); | ||
| 210 | drv_data->rx += n_bytes; | ||
| 211 | } | ||
| 212 | } | ||
| 213 | |||
| 214 | static void u8_writer(struct driver_data *drv_data) | ||
| 215 | { | ||
| 216 | void *reg = drv_data->ioaddr; | ||
| 217 | |||
| 218 | while ((read_SSSR(reg) & SSSR_TNF) | ||
| 219 | && (drv_data->tx < drv_data->tx_end)) { | ||
| 220 | write_SSDR(*(u8 *)(drv_data->tx), reg); | ||
| 221 | ++drv_data->tx; | ||
| 222 | } | ||
| 223 | } | ||
| 224 | |||
| 225 | static void u8_reader(struct driver_data *drv_data) | ||
| 226 | { | ||
| 227 | void *reg = drv_data->ioaddr; | ||
| 228 | |||
| 229 | while ((read_SSSR(reg) & SSSR_RNE) | ||
| 230 | && (drv_data->rx < drv_data->rx_end)) { | ||
| 231 | *(u8 *)(drv_data->rx) = read_SSDR(reg); | ||
| 232 | ++drv_data->rx; | ||
| 233 | } | ||
| 234 | } | ||
| 235 | |||
| 236 | static void u16_writer(struct driver_data *drv_data) | ||
| 237 | { | ||
| 238 | void *reg = drv_data->ioaddr; | ||
| 239 | |||
| 240 | while ((read_SSSR(reg) & SSSR_TNF) | ||
| 241 | && (drv_data->tx < drv_data->tx_end)) { | ||
| 242 | write_SSDR(*(u16 *)(drv_data->tx), reg); | ||
| 243 | drv_data->tx += 2; | ||
| 244 | } | ||
| 245 | } | ||
| 246 | |||
| 247 | static void u16_reader(struct driver_data *drv_data) | ||
| 248 | { | ||
| 249 | void *reg = drv_data->ioaddr; | ||
| 250 | |||
| 251 | while ((read_SSSR(reg) & SSSR_RNE) | ||
| 252 | && (drv_data->rx < drv_data->rx_end)) { | ||
| 253 | *(u16 *)(drv_data->rx) = read_SSDR(reg); | ||
| 254 | drv_data->rx += 2; | ||
| 255 | } | ||
| 256 | } | ||
| 257 | static void u32_writer(struct driver_data *drv_data) | ||
| 258 | { | ||
| 259 | void *reg = drv_data->ioaddr; | ||
| 260 | |||
| 261 | while ((read_SSSR(reg) & SSSR_TNF) | ||
| 262 | && (drv_data->tx < drv_data->tx_end)) { | ||
| 263 | write_SSDR(*(u32 *)(drv_data->tx), reg); | ||
| 264 | drv_data->tx += 4; | ||
| 265 | } | ||
| 266 | } | ||
| 267 | |||
| 268 | static void u32_reader(struct driver_data *drv_data) | ||
| 269 | { | ||
| 270 | void *reg = drv_data->ioaddr; | ||
| 271 | |||
| 272 | while ((read_SSSR(reg) & SSSR_RNE) | ||
| 273 | && (drv_data->rx < drv_data->rx_end)) { | ||
| 274 | *(u32 *)(drv_data->rx) = read_SSDR(reg); | ||
| 275 | drv_data->rx += 4; | ||
| 276 | } | ||
| 277 | } | ||
| 278 | |||
| 279 | static void *next_transfer(struct driver_data *drv_data) | ||
| 280 | { | ||
| 281 | struct spi_message *msg = drv_data->cur_msg; | ||
| 282 | struct spi_transfer *trans = drv_data->cur_transfer; | ||
| 283 | |||
| 284 | /* Move to next transfer */ | ||
| 285 | if (trans->transfer_list.next != &msg->transfers) { | ||
| 286 | drv_data->cur_transfer = | ||
| 287 | list_entry(trans->transfer_list.next, | ||
| 288 | struct spi_transfer, | ||
| 289 | transfer_list); | ||
| 290 | return RUNNING_STATE; | ||
| 291 | } else | ||
| 292 | return DONE_STATE; | ||
| 293 | } | ||
| 294 | |||
| 295 | static int map_dma_buffers(struct driver_data *drv_data) | ||
| 296 | { | ||
| 297 | struct spi_message *msg = drv_data->cur_msg; | ||
| 298 | struct device *dev = &msg->spi->dev; | ||
| 299 | |||
| 300 | if (!drv_data->cur_chip->enable_dma) | ||
| 301 | return 0; | ||
| 302 | |||
| 303 | if (msg->is_dma_mapped) | ||
| 304 | return drv_data->rx_dma && drv_data->tx_dma; | ||
| 305 | |||
| 306 | if (!IS_DMA_ALIGNED(drv_data->rx) || !IS_DMA_ALIGNED(drv_data->tx)) | ||
| 307 | return 0; | ||
| 308 | |||
| 309 | /* Modify setup if rx buffer is null */ | ||
| 310 | if (drv_data->rx == NULL) { | ||
| 311 | *drv_data->null_dma_buf = 0; | ||
| 312 | drv_data->rx = drv_data->null_dma_buf; | ||
| 313 | drv_data->rx_map_len = 4; | ||
| 314 | } else | ||
| 315 | drv_data->rx_map_len = drv_data->len; | ||
| 316 | |||
| 317 | |||
| 318 | /* Modify setup if tx buffer is null */ | ||
| 319 | if (drv_data->tx == NULL) { | ||
| 320 | *drv_data->null_dma_buf = 0; | ||
| 321 | drv_data->tx = drv_data->null_dma_buf; | ||
| 322 | drv_data->tx_map_len = 4; | ||
| 323 | } else | ||
| 324 | drv_data->tx_map_len = drv_data->len; | ||
| 325 | |||
| 326 | /* Stream map the rx buffer */ | ||
| 327 | drv_data->rx_dma = dma_map_single(dev, drv_data->rx, | ||
| 328 | drv_data->rx_map_len, | ||
| 329 | DMA_FROM_DEVICE); | ||
| 330 | if (dma_mapping_error(drv_data->rx_dma)) | ||
| 331 | return 0; | ||
| 332 | |||
| 333 | /* Stream map the tx buffer */ | ||
| 334 | drv_data->tx_dma = dma_map_single(dev, drv_data->tx, | ||
| 335 | drv_data->tx_map_len, | ||
| 336 | DMA_TO_DEVICE); | ||
| 337 | |||
| 338 | if (dma_mapping_error(drv_data->tx_dma)) { | ||
| 339 | dma_unmap_single(dev, drv_data->rx_dma, | ||
| 340 | drv_data->rx_map_len, DMA_FROM_DEVICE); | ||
| 341 | return 0; | ||
| 342 | } | ||
| 343 | |||
| 344 | return 1; | ||
| 345 | } | ||
| 346 | |||
| 347 | static void unmap_dma_buffers(struct driver_data *drv_data) | ||
| 348 | { | ||
| 349 | struct device *dev; | ||
| 350 | |||
| 351 | if (!drv_data->dma_mapped) | ||
| 352 | return; | ||
| 353 | |||
| 354 | if (!drv_data->cur_msg->is_dma_mapped) { | ||
| 355 | dev = &drv_data->cur_msg->spi->dev; | ||
| 356 | dma_unmap_single(dev, drv_data->rx_dma, | ||
| 357 | drv_data->rx_map_len, DMA_FROM_DEVICE); | ||
| 358 | dma_unmap_single(dev, drv_data->tx_dma, | ||
| 359 | drv_data->tx_map_len, DMA_TO_DEVICE); | ||
| 360 | } | ||
| 361 | |||
| 362 | drv_data->dma_mapped = 0; | ||
| 363 | } | ||
| 364 | |||
| 365 | /* caller already set message->status; dma and pio irqs are blocked */ | ||
| 366 | static void giveback(struct spi_message *message, struct driver_data *drv_data) | ||
| 367 | { | ||
| 368 | struct spi_transfer* last_transfer; | ||
| 369 | |||
| 370 | last_transfer = list_entry(message->transfers.prev, | ||
| 371 | struct spi_transfer, | ||
| 372 | transfer_list); | ||
| 373 | |||
| 374 | if (!last_transfer->cs_change) | ||
| 375 | drv_data->cs_control(PXA2XX_CS_DEASSERT); | ||
| 376 | |||
| 377 | message->state = NULL; | ||
| 378 | if (message->complete) | ||
| 379 | message->complete(message->context); | ||
| 380 | |||
| 381 | drv_data->cur_msg = NULL; | ||
| 382 | drv_data->cur_transfer = NULL; | ||
| 383 | drv_data->cur_chip = NULL; | ||
| 384 | queue_work(drv_data->workqueue, &drv_data->pump_messages); | ||
| 385 | } | ||
| 386 | |||
| 387 | static int wait_ssp_rx_stall(void *ioaddr) | ||
| 388 | { | ||
| 389 | unsigned long limit = loops_per_jiffy << 1; | ||
| 390 | |||
| 391 | while ((read_SSSR(ioaddr) & SSSR_BSY) && limit--) | ||
| 392 | cpu_relax(); | ||
| 393 | |||
| 394 | return limit; | ||
| 395 | } | ||
| 396 | |||
| 397 | static int wait_dma_channel_stop(int channel) | ||
| 398 | { | ||
| 399 | unsigned long limit = loops_per_jiffy << 1; | ||
| 400 | |||
| 401 | while (!(DCSR(channel) & DCSR_STOPSTATE) && limit--) | ||
| 402 | cpu_relax(); | ||
| 403 | |||
| 404 | return limit; | ||
| 405 | } | ||
| 406 | |||
| 407 | static void dma_handler(int channel, void *data, struct pt_regs *regs) | ||
| 408 | { | ||
| 409 | struct driver_data *drv_data = data; | ||
| 410 | struct spi_message *msg = drv_data->cur_msg; | ||
| 411 | void *reg = drv_data->ioaddr; | ||
| 412 | u32 irq_status = DCSR(channel) & DMA_INT_MASK; | ||
| 413 | u32 trailing_sssr = 0; | ||
| 414 | |||
| 415 | if (irq_status & DCSR_BUSERR) { | ||
| 416 | |||
| 417 | /* Disable interrupts, clear status and reset DMA */ | ||
| 418 | if (drv_data->ssp_type != PXA25x_SSP) | ||
| 419 | write_SSTO(0, reg); | ||
| 420 | write_SSSR(drv_data->clear_sr, reg); | ||
| 421 | write_SSCR1(read_SSCR1(reg) & ~drv_data->dma_cr1, reg); | ||
| 422 | DCSR(drv_data->rx_channel) = RESET_DMA_CHANNEL; | ||
| 423 | DCSR(drv_data->tx_channel) = RESET_DMA_CHANNEL; | ||
| 424 | |||
| 425 | if (flush(drv_data) == 0) | ||
| 426 | dev_err(&drv_data->pdev->dev, | ||
| 427 | "dma_handler: flush fail\n"); | ||
| 428 | |||
| 429 | unmap_dma_buffers(drv_data); | ||
| 430 | |||
| 431 | if (channel == drv_data->tx_channel) | ||
| 432 | dev_err(&drv_data->pdev->dev, | ||
| 433 | "dma_handler: bad bus address on " | ||
| 434 | "tx channel %d, source %x target = %x\n", | ||
| 435 | channel, DSADR(channel), DTADR(channel)); | ||
| 436 | else | ||
| 437 | dev_err(&drv_data->pdev->dev, | ||
| 438 | "dma_handler: bad bus address on " | ||
| 439 | "rx channel %d, source %x target = %x\n", | ||
| 440 | channel, DSADR(channel), DTADR(channel)); | ||
| 441 | |||
| 442 | msg->state = ERROR_STATE; | ||
| 443 | tasklet_schedule(&drv_data->pump_transfers); | ||
| 444 | } | ||
| 445 | |||
| 446 | /* PXA255x_SSP has no timeout interrupt, wait for tailing bytes */ | ||
| 447 | if ((drv_data->ssp_type == PXA25x_SSP) | ||
| 448 | && (channel == drv_data->tx_channel) | ||
| 449 | && (irq_status & DCSR_ENDINTR)) { | ||
| 450 | |||
| 451 | /* Wait for rx to stall */ | ||
| 452 | if (wait_ssp_rx_stall(drv_data->ioaddr) == 0) | ||
| 453 | dev_err(&drv_data->pdev->dev, | ||
| 454 | "dma_handler: ssp rx stall failed\n"); | ||
| 455 | |||
| 456 | /* Clear and disable interrupts on SSP and DMA channels*/ | ||
| 457 | write_SSSR(drv_data->clear_sr, reg); | ||
| 458 | write_SSCR1(read_SSCR1(reg) & ~drv_data->dma_cr1, reg); | ||
| 459 | DCSR(drv_data->tx_channel) = RESET_DMA_CHANNEL; | ||
| 460 | DCSR(drv_data->rx_channel) = RESET_DMA_CHANNEL; | ||
| 461 | if (wait_dma_channel_stop(drv_data->rx_channel) == 0) | ||
| 462 | dev_err(&drv_data->pdev->dev, | ||
| 463 | "dma_handler: dma rx channel stop failed\n"); | ||
| 464 | |||
| 465 | unmap_dma_buffers(drv_data); | ||
| 466 | |||
| 467 | /* Read trailing bytes */ | ||
| 468 | /* Calculate number of trailing bytes, read them */ | ||
| 469 | trailing_sssr = read_SSSR(reg); | ||
| 470 | if ((trailing_sssr & 0xf008) != 0xf000) { | ||
| 471 | drv_data->rx = drv_data->rx_end - | ||
| 472 | (((trailing_sssr >> 12) & 0x0f) + 1); | ||
| 473 | drv_data->read(drv_data); | ||
| 474 | } | ||
| 475 | msg->actual_length += drv_data->len; | ||
| 476 | |||
| 477 | /* Release chip select if requested, transfer delays are | ||
| 478 | * handled in pump_transfers */ | ||
| 479 | if (drv_data->cs_change) | ||
| 480 | drv_data->cs_control(PXA2XX_CS_DEASSERT); | ||
| 481 | |||
| 482 | /* Move to next transfer */ | ||
| 483 | msg->state = next_transfer(drv_data); | ||
| 484 | |||
| 485 | /* Schedule transfer tasklet */ | ||
| 486 | tasklet_schedule(&drv_data->pump_transfers); | ||
| 487 | } | ||
| 488 | } | ||
| 489 | |||
| 490 | static irqreturn_t dma_transfer(struct driver_data *drv_data) | ||
| 491 | { | ||
| 492 | u32 irq_status; | ||
| 493 | u32 trailing_sssr = 0; | ||
| 494 | struct spi_message *msg = drv_data->cur_msg; | ||
| 495 | void *reg = drv_data->ioaddr; | ||
| 496 | |||
| 497 | irq_status = read_SSSR(reg) & drv_data->mask_sr; | ||
| 498 | if (irq_status & SSSR_ROR) { | ||
| 499 | /* Clear and disable interrupts on SSP and DMA channels*/ | ||
| 500 | if (drv_data->ssp_type != PXA25x_SSP) | ||
| 501 | write_SSTO(0, reg); | ||
| 502 | write_SSSR(drv_data->clear_sr, reg); | ||
| 503 | write_SSCR1(read_SSCR1(reg) & ~drv_data->dma_cr1, reg); | ||
| 504 | DCSR(drv_data->tx_channel) = RESET_DMA_CHANNEL; | ||
| 505 | DCSR(drv_data->rx_channel) = RESET_DMA_CHANNEL; | ||
| 506 | unmap_dma_buffers(drv_data); | ||
| 507 | |||
| 508 | if (flush(drv_data) == 0) | ||
| 509 | dev_err(&drv_data->pdev->dev, | ||
| 510 | "dma_transfer: flush fail\n"); | ||
| 511 | |||
| 512 | dev_warn(&drv_data->pdev->dev, "dma_transfer: fifo overun\n"); | ||
| 513 | |||
| 514 | drv_data->cur_msg->state = ERROR_STATE; | ||
| 515 | tasklet_schedule(&drv_data->pump_transfers); | ||
| 516 | |||
| 517 | return IRQ_HANDLED; | ||
| 518 | } | ||
| 519 | |||
| 520 | /* Check for false positive timeout */ | ||
| 521 | if ((irq_status & SSSR_TINT) && DCSR(drv_data->tx_channel) & DCSR_RUN) { | ||
| 522 | write_SSSR(SSSR_TINT, reg); | ||
| 523 | return IRQ_HANDLED; | ||
| 524 | } | ||
| 525 | |||
| 526 | if (irq_status & SSSR_TINT || drv_data->rx == drv_data->rx_end) { | ||
| 527 | |||
| 528 | /* Clear and disable interrupts on SSP and DMA channels*/ | ||
| 529 | if (drv_data->ssp_type != PXA25x_SSP) | ||
| 530 | write_SSTO(0, reg); | ||
| 531 | write_SSSR(drv_data->clear_sr, reg); | ||
| 532 | write_SSCR1(read_SSCR1(reg) & ~drv_data->dma_cr1, reg); | ||
| 533 | DCSR(drv_data->tx_channel) = RESET_DMA_CHANNEL; | ||
| 534 | DCSR(drv_data->rx_channel) = RESET_DMA_CHANNEL; | ||
| 535 | |||
| 536 | if (wait_dma_channel_stop(drv_data->rx_channel) == 0) | ||
| 537 | dev_err(&drv_data->pdev->dev, | ||
| 538 | "dma_transfer: dma rx channel stop failed\n"); | ||
| 539 | |||
| 540 | if (wait_ssp_rx_stall(drv_data->ioaddr) == 0) | ||
| 541 | dev_err(&drv_data->pdev->dev, | ||
| 542 | "dma_transfer: ssp rx stall failed\n"); | ||
| 543 | |||
| 544 | unmap_dma_buffers(drv_data); | ||
| 545 | |||
| 546 | /* Calculate number of trailing bytes, read them */ | ||
| 547 | trailing_sssr = read_SSSR(reg); | ||
| 548 | if ((trailing_sssr & 0xf008) != 0xf000) { | ||
| 549 | drv_data->rx = drv_data->rx_end - | ||
| 550 | (((trailing_sssr >> 12) & 0x0f) + 1); | ||
| 551 | drv_data->read(drv_data); | ||
| 552 | } | ||
| 553 | msg->actual_length += drv_data->len; | ||
| 554 | |||
| 555 | /* Release chip select if requested, transfer delays are | ||
| 556 | * handled in pump_transfers */ | ||
| 557 | if (drv_data->cs_change) | ||
| 558 | drv_data->cs_control(PXA2XX_CS_DEASSERT); | ||
| 559 | |||
| 560 | /* Move to next transfer */ | ||
| 561 | msg->state = next_transfer(drv_data); | ||
| 562 | |||
| 563 | /* Schedule transfer tasklet */ | ||
| 564 | tasklet_schedule(&drv_data->pump_transfers); | ||
| 565 | |||
| 566 | return IRQ_HANDLED; | ||
| 567 | } | ||
| 568 | |||
| 569 | /* Opps problem detected */ | ||
| 570 | return IRQ_NONE; | ||
| 571 | } | ||
| 572 | |||
| 573 | static irqreturn_t interrupt_transfer(struct driver_data *drv_data) | ||
| 574 | { | ||
| 575 | u32 irq_status; | ||
| 576 | struct spi_message *msg = drv_data->cur_msg; | ||
| 577 | void *reg = drv_data->ioaddr; | ||
| 578 | irqreturn_t handled = IRQ_NONE; | ||
| 579 | unsigned long limit = loops_per_jiffy << 1; | ||
| 580 | |||
| 581 | while ((irq_status = (read_SSSR(reg) & drv_data->mask_sr))) { | ||
| 582 | |||
| 583 | if (irq_status & SSSR_ROR) { | ||
| 584 | |||
| 585 | /* Clear and disable interrupts */ | ||
| 586 | if (drv_data->ssp_type != PXA25x_SSP) | ||
| 587 | write_SSTO(0, reg); | ||
| 588 | write_SSSR(drv_data->clear_sr, reg); | ||
| 589 | write_SSCR1(read_SSCR1(reg) & ~drv_data->int_cr1, reg); | ||
| 590 | |||
| 591 | if (flush(drv_data) == 0) | ||
| 592 | dev_err(&drv_data->pdev->dev, | ||
| 593 | "interrupt_transfer: flush fail\n"); | ||
| 594 | |||
| 595 | dev_warn(&drv_data->pdev->dev, | ||
| 596 | "interrupt_transfer: fifo overun\n"); | ||
| 597 | |||
| 598 | msg->state = ERROR_STATE; | ||
| 599 | tasklet_schedule(&drv_data->pump_transfers); | ||
| 600 | |||
| 601 | return IRQ_HANDLED; | ||
| 602 | } | ||
| 603 | |||
| 604 | /* Look for false positive timeout */ | ||
| 605 | if ((irq_status & SSSR_TINT) | ||
| 606 | && (drv_data->rx < drv_data->rx_end)) | ||
| 607 | write_SSSR(SSSR_TINT, reg); | ||
| 608 | |||
| 609 | /* Pump data */ | ||
| 610 | drv_data->read(drv_data); | ||
| 611 | drv_data->write(drv_data); | ||
| 612 | |||
| 613 | if (drv_data->tx == drv_data->tx_end) { | ||
| 614 | /* Disable tx interrupt */ | ||
| 615 | write_SSCR1(read_SSCR1(reg) & ~SSCR1_TIE, reg); | ||
| 616 | |||
| 617 | /* PXA25x_SSP has no timeout, read trailing bytes */ | ||
| 618 | if (drv_data->ssp_type == PXA25x_SSP) { | ||
| 619 | while ((read_SSSR(reg) & SSSR_BSY) && limit--) | ||
| 620 | drv_data->read(drv_data); | ||
| 621 | |||
| 622 | if (limit == 0) | ||
| 623 | dev_err(&drv_data->pdev->dev, | ||
| 624 | "interrupt_transfer: " | ||
| 625 | "trailing byte read failed\n"); | ||
| 626 | } | ||
| 627 | } | ||
| 628 | |||
| 629 | if ((irq_status & SSSR_TINT) | ||
| 630 | || (drv_data->rx == drv_data->rx_end)) { | ||
| 631 | |||
| 632 | /* Clear timeout */ | ||
| 633 | if (drv_data->ssp_type != PXA25x_SSP) | ||
| 634 | write_SSTO(0, reg); | ||
| 635 | write_SSSR(drv_data->clear_sr, reg); | ||
| 636 | write_SSCR1(read_SSCR1(reg) & ~drv_data->int_cr1, reg); | ||
| 637 | |||
| 638 | /* Update total byte transfered */ | ||
| 639 | msg->actual_length += drv_data->len; | ||
| 640 | |||
| 641 | /* Release chip select if requested, transfer delays are | ||
| 642 | * handled in pump_transfers */ | ||
| 643 | if (drv_data->cs_change) | ||
| 644 | drv_data->cs_control(PXA2XX_CS_DEASSERT); | ||
| 645 | |||
| 646 | /* Move to next transfer */ | ||
| 647 | msg->state = next_transfer(drv_data); | ||
| 648 | |||
| 649 | /* Schedule transfer tasklet */ | ||
| 650 | tasklet_schedule(&drv_data->pump_transfers); | ||
| 651 | |||
| 652 | return IRQ_HANDLED; | ||
| 653 | } | ||
| 654 | |||
| 655 | /* We did something */ | ||
| 656 | handled = IRQ_HANDLED; | ||
| 657 | } | ||
| 658 | |||
| 659 | return handled; | ||
| 660 | } | ||
| 661 | |||
| 662 | static irqreturn_t ssp_int(int irq, void *dev_id, struct pt_regs *regs) | ||
| 663 | { | ||
| 664 | struct driver_data *drv_data = (struct driver_data *)dev_id; | ||
| 665 | |||
| 666 | if (!drv_data->cur_msg) { | ||
| 667 | dev_err(&drv_data->pdev->dev, "bad message state " | ||
| 668 | "in interrupt handler\n"); | ||
| 669 | /* Never fail */ | ||
| 670 | return IRQ_HANDLED; | ||
| 671 | } | ||
| 672 | |||
| 673 | return drv_data->transfer_handler(drv_data); | ||
| 674 | } | ||
| 675 | |||
| 676 | static void pump_transfers(unsigned long data) | ||
| 677 | { | ||
| 678 | struct driver_data *drv_data = (struct driver_data *)data; | ||
| 679 | struct spi_message *message = NULL; | ||
| 680 | struct spi_transfer *transfer = NULL; | ||
| 681 | struct spi_transfer *previous = NULL; | ||
| 682 | struct chip_data *chip = NULL; | ||
| 683 | void *reg = drv_data->ioaddr; | ||
| 684 | u32 clk_div = 0; | ||
| 685 | u8 bits = 0; | ||
| 686 | u32 speed = 0; | ||
| 687 | u32 cr0; | ||
| 688 | |||
| 689 | /* Get current state information */ | ||
| 690 | message = drv_data->cur_msg; | ||
| 691 | transfer = drv_data->cur_transfer; | ||
| 692 | chip = drv_data->cur_chip; | ||
| 693 | |||
| 694 | /* Handle for abort */ | ||
| 695 | if (message->state == ERROR_STATE) { | ||
| 696 | message->status = -EIO; | ||
| 697 | giveback(message, drv_data); | ||
| 698 | return; | ||
| 699 | } | ||
| 700 | |||
| 701 | /* Handle end of message */ | ||
| 702 | if (message->state == DONE_STATE) { | ||
| 703 | message->status = 0; | ||
| 704 | giveback(message, drv_data); | ||
| 705 | return; | ||
| 706 | } | ||
| 707 | |||
| 708 | /* Delay if requested at end of transfer*/ | ||
| 709 | if (message->state == RUNNING_STATE) { | ||
| 710 | previous = list_entry(transfer->transfer_list.prev, | ||
| 711 | struct spi_transfer, | ||
| 712 | transfer_list); | ||
| 713 | if (previous->delay_usecs) | ||
| 714 | udelay(previous->delay_usecs); | ||
| 715 | } | ||
| 716 | |||
| 717 | /* Setup the transfer state based on the type of transfer */ | ||
| 718 | if (flush(drv_data) == 0) { | ||
| 719 | dev_err(&drv_data->pdev->dev, "pump_transfers: flush failed\n"); | ||
| 720 | message->status = -EIO; | ||
| 721 | giveback(message, drv_data); | ||
| 722 | return; | ||
| 723 | } | ||
| 724 | drv_data->n_bytes = chip->n_bytes; | ||
| 725 | drv_data->dma_width = chip->dma_width; | ||
| 726 | drv_data->cs_control = chip->cs_control; | ||
| 727 | drv_data->tx = (void *)transfer->tx_buf; | ||
| 728 | drv_data->tx_end = drv_data->tx + transfer->len; | ||
| 729 | drv_data->rx = transfer->rx_buf; | ||
| 730 | drv_data->rx_end = drv_data->rx + transfer->len; | ||
| 731 | drv_data->rx_dma = transfer->rx_dma; | ||
| 732 | drv_data->tx_dma = transfer->tx_dma; | ||
| 733 | drv_data->len = transfer->len; | ||
| 734 | drv_data->write = drv_data->tx ? chip->write : null_writer; | ||
| 735 | drv_data->read = drv_data->rx ? chip->read : null_reader; | ||
| 736 | drv_data->cs_change = transfer->cs_change; | ||
| 737 | |||
| 738 | /* Change speed and bit per word on a per transfer */ | ||
| 739 | if (transfer->speed_hz || transfer->bits_per_word) { | ||
| 740 | |||
| 741 | /* Disable clock */ | ||
| 742 | write_SSCR0(chip->cr0 & ~SSCR0_SSE, reg); | ||
| 743 | cr0 = chip->cr0; | ||
| 744 | bits = chip->bits_per_word; | ||
| 745 | speed = chip->speed_hz; | ||
| 746 | |||
| 747 | if (transfer->speed_hz) | ||
| 748 | speed = transfer->speed_hz; | ||
| 749 | |||
| 750 | if (transfer->bits_per_word) | ||
| 751 | bits = transfer->bits_per_word; | ||
| 752 | |||
| 753 | if (reg == SSP1_VIRT) | ||
| 754 | clk_div = SSP1_SerClkDiv(speed); | ||
| 755 | else if (reg == SSP2_VIRT) | ||
| 756 | clk_div = SSP2_SerClkDiv(speed); | ||
| 757 | else if (reg == SSP3_VIRT) | ||
| 758 | clk_div = SSP3_SerClkDiv(speed); | ||
| 759 | |||
| 760 | if (bits <= 8) { | ||
| 761 | drv_data->n_bytes = 1; | ||
| 762 | drv_data->dma_width = DCMD_WIDTH1; | ||
| 763 | drv_data->read = drv_data->read != null_reader ? | ||
| 764 | u8_reader : null_reader; | ||
| 765 | drv_data->write = drv_data->write != null_writer ? | ||
| 766 | u8_writer : null_writer; | ||
| 767 | } else if (bits <= 16) { | ||
| 768 | drv_data->n_bytes = 2; | ||
| 769 | drv_data->dma_width = DCMD_WIDTH2; | ||
| 770 | drv_data->read = drv_data->read != null_reader ? | ||
| 771 | u16_reader : null_reader; | ||
| 772 | drv_data->write = drv_data->write != null_writer ? | ||
| 773 | u16_writer : null_writer; | ||
| 774 | } else if (bits <= 32) { | ||
| 775 | drv_data->n_bytes = 4; | ||
| 776 | drv_data->dma_width = DCMD_WIDTH4; | ||
| 777 | drv_data->read = drv_data->read != null_reader ? | ||
| 778 | u32_reader : null_reader; | ||
| 779 | drv_data->write = drv_data->write != null_writer ? | ||
| 780 | u32_writer : null_writer; | ||
| 781 | } | ||
| 782 | |||
| 783 | cr0 = clk_div | ||
| 784 | | SSCR0_Motorola | ||
| 785 | | SSCR0_DataSize(bits & 0x0f) | ||
| 786 | | SSCR0_SSE | ||
| 787 | | (bits > 16 ? SSCR0_EDSS : 0); | ||
| 788 | |||
| 789 | /* Start it back up */ | ||
| 790 | write_SSCR0(cr0, reg); | ||
| 791 | } | ||
| 792 | |||
| 793 | message->state = RUNNING_STATE; | ||
| 794 | |||
| 795 | /* Try to map dma buffer and do a dma transfer if successful */ | ||
| 796 | if ((drv_data->dma_mapped = map_dma_buffers(drv_data))) { | ||
| 797 | |||
| 798 | /* Ensure we have the correct interrupt handler */ | ||
| 799 | drv_data->transfer_handler = dma_transfer; | ||
| 800 | |||
| 801 | /* Setup rx DMA Channel */ | ||
| 802 | DCSR(drv_data->rx_channel) = RESET_DMA_CHANNEL; | ||
| 803 | DSADR(drv_data->rx_channel) = drv_data->ssdr_physical; | ||
| 804 | DTADR(drv_data->rx_channel) = drv_data->rx_dma; | ||
| 805 | if (drv_data->rx == drv_data->null_dma_buf) | ||
| 806 | /* No target address increment */ | ||
| 807 | DCMD(drv_data->rx_channel) = DCMD_FLOWSRC | ||
| 808 | | drv_data->dma_width | ||
| 809 | | chip->dma_burst_size | ||
| 810 | | drv_data->len; | ||
| 811 | else | ||
| 812 | DCMD(drv_data->rx_channel) = DCMD_INCTRGADDR | ||
| 813 | | DCMD_FLOWSRC | ||
| 814 | | drv_data->dma_width | ||
| 815 | | chip->dma_burst_size | ||
| 816 | | drv_data->len; | ||
| 817 | |||
| 818 | /* Setup tx DMA Channel */ | ||
| 819 | DCSR(drv_data->tx_channel) = RESET_DMA_CHANNEL; | ||
| 820 | DSADR(drv_data->tx_channel) = drv_data->tx_dma; | ||
| 821 | DTADR(drv_data->tx_channel) = drv_data->ssdr_physical; | ||
| 822 | if (drv_data->tx == drv_data->null_dma_buf) | ||
| 823 | /* No source address increment */ | ||
| 824 | DCMD(drv_data->tx_channel) = DCMD_FLOWTRG | ||
| 825 | | drv_data->dma_width | ||
| 826 | | chip->dma_burst_size | ||
| 827 | | drv_data->len; | ||
| 828 | else | ||
| 829 | DCMD(drv_data->tx_channel) = DCMD_INCSRCADDR | ||
| 830 | | DCMD_FLOWTRG | ||
| 831 | | drv_data->dma_width | ||
| 832 | | chip->dma_burst_size | ||
| 833 | | drv_data->len; | ||
| 834 | |||
| 835 | /* Enable dma end irqs on SSP to detect end of transfer */ | ||
| 836 | if (drv_data->ssp_type == PXA25x_SSP) | ||
| 837 | DCMD(drv_data->tx_channel) |= DCMD_ENDIRQEN; | ||
| 838 | |||
| 839 | /* Fix me, need to handle cs polarity */ | ||
| 840 | drv_data->cs_control(PXA2XX_CS_ASSERT); | ||
| 841 | |||
| 842 | /* Go baby, go */ | ||
| 843 | write_SSSR(drv_data->clear_sr, reg); | ||
| 844 | DCSR(drv_data->rx_channel) |= DCSR_RUN; | ||
| 845 | DCSR(drv_data->tx_channel) |= DCSR_RUN; | ||
| 846 | if (drv_data->ssp_type != PXA25x_SSP) | ||
| 847 | write_SSTO(chip->timeout, reg); | ||
| 848 | write_SSCR1(chip->cr1 | ||
| 849 | | chip->dma_threshold | ||
| 850 | | drv_data->dma_cr1, | ||
| 851 | reg); | ||
| 852 | } else { | ||
| 853 | /* Ensure we have the correct interrupt handler */ | ||
| 854 | drv_data->transfer_handler = interrupt_transfer; | ||
| 855 | |||
| 856 | /* Fix me, need to handle cs polarity */ | ||
| 857 | drv_data->cs_control(PXA2XX_CS_ASSERT); | ||
| 858 | |||
| 859 | /* Go baby, go */ | ||
| 860 | write_SSSR(drv_data->clear_sr, reg); | ||
| 861 | if (drv_data->ssp_type != PXA25x_SSP) | ||
| 862 | write_SSTO(chip->timeout, reg); | ||
| 863 | write_SSCR1(chip->cr1 | ||
| 864 | | chip->threshold | ||
| 865 | | drv_data->int_cr1, | ||
| 866 | reg); | ||
| 867 | } | ||
| 868 | } | ||
| 869 | |||
| 870 | static void pump_messages(void *data) | ||
| 871 | { | ||
| 872 | struct driver_data *drv_data = data; | ||
| 873 | unsigned long flags; | ||
| 874 | |||
| 875 | /* Lock queue and check for queue work */ | ||
| 876 | spin_lock_irqsave(&drv_data->lock, flags); | ||
| 877 | if (list_empty(&drv_data->queue) || drv_data->run == QUEUE_STOPPED) { | ||
| 878 | drv_data->busy = 0; | ||
| 879 | spin_unlock_irqrestore(&drv_data->lock, flags); | ||
| 880 | return; | ||
| 881 | } | ||
| 882 | |||
| 883 | /* Make sure we are not already running a message */ | ||
| 884 | if (drv_data->cur_msg) { | ||
| 885 | spin_unlock_irqrestore(&drv_data->lock, flags); | ||
| 886 | return; | ||
| 887 | } | ||
| 888 | |||
| 889 | /* Extract head of queue */ | ||
| 890 | drv_data->cur_msg = list_entry(drv_data->queue.next, | ||
| 891 | struct spi_message, queue); | ||
| 892 | list_del_init(&drv_data->cur_msg->queue); | ||
| 893 | drv_data->busy = 1; | ||
| 894 | spin_unlock_irqrestore(&drv_data->lock, flags); | ||
| 895 | |||
| 896 | /* Initial message state*/ | ||
| 897 | drv_data->cur_msg->state = START_STATE; | ||
| 898 | drv_data->cur_transfer = list_entry(drv_data->cur_msg->transfers.next, | ||
| 899 | struct spi_transfer, | ||
| 900 | transfer_list); | ||
| 901 | |||
| 902 | /* Setup the SSP using the per chip configuration */ | ||
| 903 | drv_data->cur_chip = spi_get_ctldata(drv_data->cur_msg->spi); | ||
| 904 | restore_state(drv_data); | ||
| 905 | |||
| 906 | /* Mark as busy and launch transfers */ | ||
| 907 | tasklet_schedule(&drv_data->pump_transfers); | ||
| 908 | } | ||
| 909 | |||
| 910 | static int transfer(struct spi_device *spi, struct spi_message *msg) | ||
| 911 | { | ||
| 912 | struct driver_data *drv_data = spi_master_get_devdata(spi->master); | ||
| 913 | unsigned long flags; | ||
| 914 | |||
| 915 | spin_lock_irqsave(&drv_data->lock, flags); | ||
| 916 | |||
| 917 | if (drv_data->run == QUEUE_STOPPED) { | ||
| 918 | spin_unlock_irqrestore(&drv_data->lock, flags); | ||
| 919 | return -ESHUTDOWN; | ||
| 920 | } | ||
| 921 | |||
| 922 | msg->actual_length = 0; | ||
| 923 | msg->status = -EINPROGRESS; | ||
| 924 | msg->state = START_STATE; | ||
| 925 | |||
| 926 | list_add_tail(&msg->queue, &drv_data->queue); | ||
| 927 | |||
| 928 | if (drv_data->run == QUEUE_RUNNING && !drv_data->busy) | ||
| 929 | queue_work(drv_data->workqueue, &drv_data->pump_messages); | ||
| 930 | |||
| 931 | spin_unlock_irqrestore(&drv_data->lock, flags); | ||
| 932 | |||
| 933 | return 0; | ||
| 934 | } | ||
| 935 | |||
| 936 | static int setup(struct spi_device *spi) | ||
| 937 | { | ||
| 938 | struct pxa2xx_spi_chip *chip_info = NULL; | ||
| 939 | struct chip_data *chip; | ||
| 940 | struct driver_data *drv_data = spi_master_get_devdata(spi->master); | ||
| 941 | unsigned int clk_div; | ||
| 942 | |||
| 943 | if (!spi->bits_per_word) | ||
| 944 | spi->bits_per_word = 8; | ||
| 945 | |||
| 946 | if (drv_data->ssp_type != PXA25x_SSP | ||
| 947 | && (spi->bits_per_word < 4 || spi->bits_per_word > 32)) | ||
| 948 | return -EINVAL; | ||
| 949 | else if (spi->bits_per_word < 4 || spi->bits_per_word > 16) | ||
| 950 | return -EINVAL; | ||
| 951 | |||
| 952 | /* Only alloc (or use chip_info) on first setup */ | ||
| 953 | chip = spi_get_ctldata(spi); | ||
| 954 | if (chip == NULL) { | ||
| 955 | chip = kzalloc(sizeof(struct chip_data), GFP_KERNEL); | ||
| 956 | if (!chip) | ||
| 957 | return -ENOMEM; | ||
| 958 | |||
| 959 | chip->cs_control = null_cs_control; | ||
| 960 | chip->enable_dma = 0; | ||
| 961 | chip->timeout = 5; | ||
| 962 | chip->threshold = SSCR1_RxTresh(1) | SSCR1_TxTresh(1); | ||
| 963 | chip->dma_burst_size = drv_data->master_info->enable_dma ? | ||
| 964 | DCMD_BURST8 : 0; | ||
| 965 | |||
| 966 | chip_info = spi->controller_data; | ||
| 967 | } | ||
| 968 | |||
| 969 | /* chip_info isn't always needed */ | ||
| 970 | if (chip_info) { | ||
| 971 | if (chip_info->cs_control) | ||
| 972 | chip->cs_control = chip_info->cs_control; | ||
| 973 | |||
| 974 | chip->timeout = (chip_info->timeout_microsecs * 10000) / 2712; | ||
| 975 | |||
| 976 | chip->threshold = SSCR1_RxTresh(chip_info->rx_threshold) | ||
| 977 | | SSCR1_TxTresh(chip_info->tx_threshold); | ||
| 978 | |||
| 979 | chip->enable_dma = chip_info->dma_burst_size != 0 | ||
| 980 | && drv_data->master_info->enable_dma; | ||
| 981 | chip->dma_threshold = 0; | ||
| 982 | |||
| 983 | if (chip->enable_dma) { | ||
| 984 | if (chip_info->dma_burst_size <= 8) { | ||
| 985 | chip->dma_threshold = SSCR1_RxTresh(8) | ||
| 986 | | SSCR1_TxTresh(8); | ||
| 987 | chip->dma_burst_size = DCMD_BURST8; | ||
| 988 | } else if (chip_info->dma_burst_size <= 16) { | ||
| 989 | chip->dma_threshold = SSCR1_RxTresh(16) | ||
| 990 | | SSCR1_TxTresh(16); | ||
| 991 | chip->dma_burst_size = DCMD_BURST16; | ||
| 992 | } else { | ||
| 993 | chip->dma_threshold = SSCR1_RxTresh(32) | ||
| 994 | | SSCR1_TxTresh(32); | ||
| 995 | chip->dma_burst_size = DCMD_BURST32; | ||
| 996 | } | ||
| 997 | } | ||
| 998 | |||
| 999 | |||
| 1000 | if (chip_info->enable_loopback) | ||
| 1001 | chip->cr1 = SSCR1_LBM; | ||
| 1002 | } | ||
| 1003 | |||
| 1004 | if (drv_data->ioaddr == SSP1_VIRT) | ||
| 1005 | clk_div = SSP1_SerClkDiv(spi->max_speed_hz); | ||
| 1006 | else if (drv_data->ioaddr == SSP2_VIRT) | ||
| 1007 | clk_div = SSP2_SerClkDiv(spi->max_speed_hz); | ||
| 1008 | else if (drv_data->ioaddr == SSP3_VIRT) | ||
| 1009 | clk_div = SSP3_SerClkDiv(spi->max_speed_hz); | ||
| 1010 | else | ||
| 1011 | return -ENODEV; | ||
| 1012 | chip->speed_hz = spi->max_speed_hz; | ||
| 1013 | |||
| 1014 | chip->cr0 = clk_div | ||
| 1015 | | SSCR0_Motorola | ||
| 1016 | | SSCR0_DataSize(spi->bits_per_word & 0x0f) | ||
| 1017 | | SSCR0_SSE | ||
| 1018 | | (spi->bits_per_word > 16 ? SSCR0_EDSS : 0); | ||
| 1019 | chip->cr1 |= (((spi->mode & SPI_CPHA) != 0) << 4) | ||
| 1020 | | (((spi->mode & SPI_CPOL) != 0) << 3); | ||
| 1021 | |||
| 1022 | /* NOTE: PXA25x_SSP _could_ use external clocking ... */ | ||
| 1023 | if (drv_data->ssp_type != PXA25x_SSP) | ||
| 1024 | dev_dbg(&spi->dev, "%d bits/word, %d Hz, mode %d\n", | ||
| 1025 | spi->bits_per_word, | ||
| 1026 | (CLOCK_SPEED_HZ) | ||
| 1027 | / (1 + ((chip->cr0 & SSCR0_SCR) >> 8)), | ||
| 1028 | spi->mode & 0x3); | ||
| 1029 | else | ||
| 1030 | dev_dbg(&spi->dev, "%d bits/word, %d Hz, mode %d\n", | ||
| 1031 | spi->bits_per_word, | ||
| 1032 | (CLOCK_SPEED_HZ/2) | ||
| 1033 | / (1 + ((chip->cr0 & SSCR0_SCR) >> 8)), | ||
| 1034 | spi->mode & 0x3); | ||
| 1035 | |||
| 1036 | if (spi->bits_per_word <= 8) { | ||
| 1037 | chip->n_bytes = 1; | ||
| 1038 | chip->dma_width = DCMD_WIDTH1; | ||
| 1039 | chip->read = u8_reader; | ||
| 1040 | chip->write = u8_writer; | ||
| 1041 | } else if (spi->bits_per_word <= 16) { | ||
| 1042 | chip->n_bytes = 2; | ||
| 1043 | chip->dma_width = DCMD_WIDTH2; | ||
| 1044 | chip->read = u16_reader; | ||
| 1045 | chip->write = u16_writer; | ||
| 1046 | } else if (spi->bits_per_word <= 32) { | ||
| 1047 | chip->cr0 |= SSCR0_EDSS; | ||
| 1048 | chip->n_bytes = 4; | ||
| 1049 | chip->dma_width = DCMD_WIDTH4; | ||
| 1050 | chip->read = u32_reader; | ||
| 1051 | chip->write = u32_writer; | ||
| 1052 | } else { | ||
| 1053 | dev_err(&spi->dev, "invalid wordsize\n"); | ||
| 1054 | kfree(chip); | ||
| 1055 | return -ENODEV; | ||
| 1056 | } | ||
| 1057 | chip->bits_per_word = spi->bits_per_word; | ||
| 1058 | |||
| 1059 | spi_set_ctldata(spi, chip); | ||
| 1060 | |||
| 1061 | return 0; | ||
| 1062 | } | ||
| 1063 | |||
| 1064 | static void cleanup(const struct spi_device *spi) | ||
| 1065 | { | ||
| 1066 | struct chip_data *chip = spi_get_ctldata((struct spi_device *)spi); | ||
| 1067 | |||
| 1068 | kfree(chip); | ||
| 1069 | } | ||
| 1070 | |||
| 1071 | static int init_queue(struct driver_data *drv_data) | ||
| 1072 | { | ||
| 1073 | INIT_LIST_HEAD(&drv_data->queue); | ||
| 1074 | spin_lock_init(&drv_data->lock); | ||
| 1075 | |||
| 1076 | drv_data->run = QUEUE_STOPPED; | ||
| 1077 | drv_data->busy = 0; | ||
| 1078 | |||
| 1079 | tasklet_init(&drv_data->pump_transfers, | ||
| 1080 | pump_transfers, (unsigned long)drv_data); | ||
| 1081 | |||
| 1082 | INIT_WORK(&drv_data->pump_messages, pump_messages, drv_data); | ||
| 1083 | drv_data->workqueue = create_singlethread_workqueue( | ||
| 1084 | drv_data->master->cdev.dev->bus_id); | ||
| 1085 | if (drv_data->workqueue == NULL) | ||
| 1086 | return -EBUSY; | ||
| 1087 | |||
| 1088 | return 0; | ||
| 1089 | } | ||
| 1090 | |||
| 1091 | static int start_queue(struct driver_data *drv_data) | ||
| 1092 | { | ||
| 1093 | unsigned long flags; | ||
| 1094 | |||
| 1095 | spin_lock_irqsave(&drv_data->lock, flags); | ||
| 1096 | |||
| 1097 | if (drv_data->run == QUEUE_RUNNING || drv_data->busy) { | ||
| 1098 | spin_unlock_irqrestore(&drv_data->lock, flags); | ||
| 1099 | return -EBUSY; | ||
| 1100 | } | ||
| 1101 | |||
| 1102 | drv_data->run = QUEUE_RUNNING; | ||
| 1103 | drv_data->cur_msg = NULL; | ||
| 1104 | drv_data->cur_transfer = NULL; | ||
| 1105 | drv_data->cur_chip = NULL; | ||
| 1106 | spin_unlock_irqrestore(&drv_data->lock, flags); | ||
| 1107 | |||
| 1108 | queue_work(drv_data->workqueue, &drv_data->pump_messages); | ||
| 1109 | |||
| 1110 | return 0; | ||
| 1111 | } | ||
| 1112 | |||
| 1113 | static int stop_queue(struct driver_data *drv_data) | ||
| 1114 | { | ||
| 1115 | unsigned long flags; | ||
| 1116 | unsigned limit = 500; | ||
| 1117 | int status = 0; | ||
| 1118 | |||
| 1119 | spin_lock_irqsave(&drv_data->lock, flags); | ||
| 1120 | |||
| 1121 | /* This is a bit lame, but is optimized for the common execution path. | ||
| 1122 | * A wait_queue on the drv_data->busy could be used, but then the common | ||
| 1123 | * execution path (pump_messages) would be required to call wake_up or | ||
| 1124 | * friends on every SPI message. Do this instead */ | ||
| 1125 | drv_data->run = QUEUE_STOPPED; | ||
| 1126 | while (!list_empty(&drv_data->queue) && drv_data->busy && limit--) { | ||
| 1127 | spin_unlock_irqrestore(&drv_data->lock, flags); | ||
| 1128 | msleep(10); | ||
| 1129 | spin_lock_irqsave(&drv_data->lock, flags); | ||
| 1130 | } | ||
| 1131 | |||
| 1132 | if (!list_empty(&drv_data->queue) || drv_data->busy) | ||
| 1133 | status = -EBUSY; | ||
| 1134 | |||
| 1135 | spin_unlock_irqrestore(&drv_data->lock, flags); | ||
| 1136 | |||
| 1137 | return status; | ||
| 1138 | } | ||
| 1139 | |||
| 1140 | static int destroy_queue(struct driver_data *drv_data) | ||
| 1141 | { | ||
| 1142 | int status; | ||
| 1143 | |||
| 1144 | status = stop_queue(drv_data); | ||
| 1145 | if (status != 0) | ||
| 1146 | return status; | ||
| 1147 | |||
| 1148 | destroy_workqueue(drv_data->workqueue); | ||
| 1149 | |||
| 1150 | return 0; | ||
| 1151 | } | ||
| 1152 | |||
| 1153 | static int pxa2xx_spi_probe(struct platform_device *pdev) | ||
| 1154 | { | ||
| 1155 | struct device *dev = &pdev->dev; | ||
| 1156 | struct pxa2xx_spi_master *platform_info; | ||
| 1157 | struct spi_master *master; | ||
| 1158 | struct driver_data *drv_data = 0; | ||
| 1159 | struct resource *memory_resource; | ||
| 1160 | int irq; | ||
| 1161 | int status = 0; | ||
| 1162 | |||
| 1163 | platform_info = dev->platform_data; | ||
| 1164 | |||
| 1165 | if (platform_info->ssp_type == SSP_UNDEFINED) { | ||
| 1166 | dev_err(&pdev->dev, "undefined SSP\n"); | ||
| 1167 | return -ENODEV; | ||
| 1168 | } | ||
| 1169 | |||
| 1170 | /* Allocate master with space for drv_data and null dma buffer */ | ||
| 1171 | master = spi_alloc_master(dev, sizeof(struct driver_data) + 16); | ||
| 1172 | if (!master) { | ||
| 1173 | dev_err(&pdev->dev, "can not alloc spi_master\n"); | ||
| 1174 | return -ENOMEM; | ||
| 1175 | } | ||
| 1176 | drv_data = spi_master_get_devdata(master); | ||
| 1177 | drv_data->master = master; | ||
| 1178 | drv_data->master_info = platform_info; | ||
| 1179 | drv_data->pdev = pdev; | ||
| 1180 | |||
| 1181 | master->bus_num = pdev->id; | ||
| 1182 | master->num_chipselect = platform_info->num_chipselect; | ||
| 1183 | master->cleanup = cleanup; | ||
| 1184 | master->setup = setup; | ||
| 1185 | master->transfer = transfer; | ||
| 1186 | |||
| 1187 | drv_data->ssp_type = platform_info->ssp_type; | ||
| 1188 | drv_data->null_dma_buf = (u32 *)ALIGN((u32)(drv_data + | ||
| 1189 | sizeof(struct driver_data)), 8); | ||
| 1190 | |||
| 1191 | /* Setup register addresses */ | ||
| 1192 | memory_resource = platform_get_resource(pdev, IORESOURCE_MEM, 0); | ||
| 1193 | if (!memory_resource) { | ||
| 1194 | dev_err(&pdev->dev, "memory resources not defined\n"); | ||
| 1195 | status = -ENODEV; | ||
| 1196 | goto out_error_master_alloc; | ||
| 1197 | } | ||
| 1198 | |||
| 1199 | drv_data->ioaddr = (void *)io_p2v(memory_resource->start); | ||
| 1200 | drv_data->ssdr_physical = memory_resource->start + 0x00000010; | ||
| 1201 | if (platform_info->ssp_type == PXA25x_SSP) { | ||
| 1202 | drv_data->int_cr1 = SSCR1_TIE | SSCR1_RIE; | ||
| 1203 | drv_data->dma_cr1 = 0; | ||
| 1204 | drv_data->clear_sr = SSSR_ROR; | ||
| 1205 | drv_data->mask_sr = SSSR_RFS | SSSR_TFS | SSSR_ROR; | ||
| 1206 | } else { | ||
| 1207 | drv_data->int_cr1 = SSCR1_TIE | SSCR1_RIE | SSCR1_TINTE; | ||
| 1208 | drv_data->dma_cr1 = SSCR1_TSRE | SSCR1_RSRE | SSCR1_TINTE; | ||
| 1209 | drv_data->clear_sr = SSSR_ROR | SSSR_TINT; | ||
| 1210 | drv_data->mask_sr = SSSR_TINT | SSSR_RFS | SSSR_TFS | SSSR_ROR; | ||
| 1211 | } | ||
| 1212 | |||
| 1213 | /* Attach to IRQ */ | ||
| 1214 | irq = platform_get_irq(pdev, 0); | ||
| 1215 | if (irq < 0) { | ||
| 1216 | dev_err(&pdev->dev, "irq resource not defined\n"); | ||
| 1217 | status = -ENODEV; | ||
| 1218 | goto out_error_master_alloc; | ||
| 1219 | } | ||
| 1220 | |||
| 1221 | status = request_irq(irq, ssp_int, SA_INTERRUPT, dev->bus_id, drv_data); | ||
| 1222 | if (status < 0) { | ||
| 1223 | dev_err(&pdev->dev, "can not get IRQ\n"); | ||
| 1224 | goto out_error_master_alloc; | ||
| 1225 | } | ||
| 1226 | |||
| 1227 | /* Setup DMA if requested */ | ||
| 1228 | drv_data->tx_channel = -1; | ||
| 1229 | drv_data->rx_channel = -1; | ||
| 1230 | if (platform_info->enable_dma) { | ||
| 1231 | |||
| 1232 | /* Get two DMA channels (rx and tx) */ | ||
| 1233 | drv_data->rx_channel = pxa_request_dma("pxa2xx_spi_ssp_rx", | ||
| 1234 | DMA_PRIO_HIGH, | ||
| 1235 | dma_handler, | ||
| 1236 | drv_data); | ||
| 1237 | if (drv_data->rx_channel < 0) { | ||
| 1238 | dev_err(dev, "problem (%d) requesting rx channel\n", | ||
| 1239 | drv_data->rx_channel); | ||
| 1240 | status = -ENODEV; | ||
| 1241 | goto out_error_irq_alloc; | ||
| 1242 | } | ||
| 1243 | drv_data->tx_channel = pxa_request_dma("pxa2xx_spi_ssp_tx", | ||
| 1244 | DMA_PRIO_MEDIUM, | ||
| 1245 | dma_handler, | ||
| 1246 | drv_data); | ||
| 1247 | if (drv_data->tx_channel < 0) { | ||
| 1248 | dev_err(dev, "problem (%d) requesting tx channel\n", | ||
| 1249 | drv_data->tx_channel); | ||
| 1250 | status = -ENODEV; | ||
| 1251 | goto out_error_dma_alloc; | ||
| 1252 | } | ||
| 1253 | |||
| 1254 | if (drv_data->ioaddr == SSP1_VIRT) { | ||
| 1255 | DRCMRRXSSDR = DRCMR_MAPVLD | ||
| 1256 | | drv_data->rx_channel; | ||
| 1257 | DRCMRTXSSDR = DRCMR_MAPVLD | ||
| 1258 | | drv_data->tx_channel; | ||
| 1259 | } else if (drv_data->ioaddr == SSP2_VIRT) { | ||
| 1260 | DRCMRRXSS2DR = DRCMR_MAPVLD | ||
| 1261 | | drv_data->rx_channel; | ||
| 1262 | DRCMRTXSS2DR = DRCMR_MAPVLD | ||
| 1263 | | drv_data->tx_channel; | ||
| 1264 | } else if (drv_data->ioaddr == SSP3_VIRT) { | ||
| 1265 | DRCMRRXSS3DR = DRCMR_MAPVLD | ||
| 1266 | | drv_data->rx_channel; | ||
| 1267 | DRCMRTXSS3DR = DRCMR_MAPVLD | ||
| 1268 | | drv_data->tx_channel; | ||
| 1269 | } else { | ||
| 1270 | dev_err(dev, "bad SSP type\n"); | ||
| 1271 | goto out_error_dma_alloc; | ||
| 1272 | } | ||
| 1273 | } | ||
| 1274 | |||
| 1275 | /* Enable SOC clock */ | ||
| 1276 | pxa_set_cken(platform_info->clock_enable, 1); | ||
| 1277 | |||
| 1278 | /* Load default SSP configuration */ | ||
| 1279 | write_SSCR0(0, drv_data->ioaddr); | ||
| 1280 | write_SSCR1(SSCR1_RxTresh(4) | SSCR1_TxTresh(12), drv_data->ioaddr); | ||
| 1281 | write_SSCR0(SSCR0_SerClkDiv(2) | ||
| 1282 | | SSCR0_Motorola | ||
| 1283 | | SSCR0_DataSize(8), | ||
| 1284 | drv_data->ioaddr); | ||
| 1285 | if (drv_data->ssp_type != PXA25x_SSP) | ||
| 1286 | write_SSTO(0, drv_data->ioaddr); | ||
| 1287 | write_SSPSP(0, drv_data->ioaddr); | ||
| 1288 | |||
| 1289 | /* Initial and start queue */ | ||
| 1290 | status = init_queue(drv_data); | ||
| 1291 | if (status != 0) { | ||
| 1292 | dev_err(&pdev->dev, "problem initializing queue\n"); | ||
| 1293 | goto out_error_clock_enabled; | ||
| 1294 | } | ||
| 1295 | status = start_queue(drv_data); | ||
| 1296 | if (status != 0) { | ||
| 1297 | dev_err(&pdev->dev, "problem starting queue\n"); | ||
| 1298 | goto out_error_clock_enabled; | ||
| 1299 | } | ||
| 1300 | |||
| 1301 | /* Register with the SPI framework */ | ||
| 1302 | platform_set_drvdata(pdev, drv_data); | ||
| 1303 | status = spi_register_master(master); | ||
| 1304 | if (status != 0) { | ||
| 1305 | dev_err(&pdev->dev, "problem registering spi master\n"); | ||
| 1306 | goto out_error_queue_alloc; | ||
| 1307 | } | ||
| 1308 | |||
| 1309 | return status; | ||
| 1310 | |||
| 1311 | out_error_queue_alloc: | ||
| 1312 | destroy_queue(drv_data); | ||
| 1313 | |||
| 1314 | out_error_clock_enabled: | ||
| 1315 | pxa_set_cken(platform_info->clock_enable, 0); | ||
| 1316 | |||
| 1317 | out_error_dma_alloc: | ||
| 1318 | if (drv_data->tx_channel != -1) | ||
| 1319 | pxa_free_dma(drv_data->tx_channel); | ||
| 1320 | if (drv_data->rx_channel != -1) | ||
| 1321 | pxa_free_dma(drv_data->rx_channel); | ||
| 1322 | |||
| 1323 | out_error_irq_alloc: | ||
| 1324 | free_irq(irq, drv_data); | ||
| 1325 | |||
| 1326 | out_error_master_alloc: | ||
| 1327 | spi_master_put(master); | ||
| 1328 | return status; | ||
| 1329 | } | ||
| 1330 | |||
| 1331 | static int pxa2xx_spi_remove(struct platform_device *pdev) | ||
| 1332 | { | ||
| 1333 | struct driver_data *drv_data = platform_get_drvdata(pdev); | ||
| 1334 | int irq; | ||
| 1335 | int status = 0; | ||
| 1336 | |||
| 1337 | if (!drv_data) | ||
| 1338 | return 0; | ||
| 1339 | |||
| 1340 | /* Remove the queue */ | ||
| 1341 | status = destroy_queue(drv_data); | ||
| 1342 | if (status != 0) | ||
| 1343 | return status; | ||
| 1344 | |||
| 1345 | /* Disable the SSP at the peripheral and SOC level */ | ||
| 1346 | write_SSCR0(0, drv_data->ioaddr); | ||
| 1347 | pxa_set_cken(drv_data->master_info->clock_enable, 0); | ||
| 1348 | |||
| 1349 | /* Release DMA */ | ||
| 1350 | if (drv_data->master_info->enable_dma) { | ||
| 1351 | if (drv_data->ioaddr == SSP1_VIRT) { | ||
| 1352 | DRCMRRXSSDR = 0; | ||
| 1353 | DRCMRTXSSDR = 0; | ||
| 1354 | } else if (drv_data->ioaddr == SSP2_VIRT) { | ||
| 1355 | DRCMRRXSS2DR = 0; | ||
| 1356 | DRCMRTXSS2DR = 0; | ||
| 1357 | } else if (drv_data->ioaddr == SSP3_VIRT) { | ||
| 1358 | DRCMRRXSS3DR = 0; | ||
| 1359 | DRCMRTXSS3DR = 0; | ||
| 1360 | } | ||
| 1361 | pxa_free_dma(drv_data->tx_channel); | ||
| 1362 | pxa_free_dma(drv_data->rx_channel); | ||
| 1363 | } | ||
| 1364 | |||
| 1365 | /* Release IRQ */ | ||
| 1366 | irq = platform_get_irq(pdev, 0); | ||
| 1367 | if (irq >= 0) | ||
| 1368 | free_irq(irq, drv_data); | ||
| 1369 | |||
| 1370 | /* Disconnect from the SPI framework */ | ||
| 1371 | spi_unregister_master(drv_data->master); | ||
| 1372 | |||
| 1373 | /* Prevent double remove */ | ||
| 1374 | platform_set_drvdata(pdev, NULL); | ||
| 1375 | |||
| 1376 | return 0; | ||
| 1377 | } | ||
| 1378 | |||
| 1379 | static void pxa2xx_spi_shutdown(struct platform_device *pdev) | ||
| 1380 | { | ||
| 1381 | int status = 0; | ||
| 1382 | |||
| 1383 | if ((status = pxa2xx_spi_remove(pdev)) != 0) | ||
| 1384 | dev_err(&pdev->dev, "shutdown failed with %d\n", status); | ||
| 1385 | } | ||
| 1386 | |||
| 1387 | #ifdef CONFIG_PM | ||
| 1388 | static int suspend_devices(struct device *dev, void *pm_message) | ||
| 1389 | { | ||
| 1390 | pm_message_t *state = pm_message; | ||
| 1391 | |||
| 1392 | if (dev->power.power_state.event != state->event) { | ||
| 1393 | dev_warn(dev, "pm state does not match request\n"); | ||
| 1394 | return -1; | ||
| 1395 | } | ||
| 1396 | |||
| 1397 | return 0; | ||
| 1398 | } | ||
| 1399 | |||
| 1400 | static int pxa2xx_spi_suspend(struct platform_device *pdev, pm_message_t state) | ||
| 1401 | { | ||
| 1402 | struct driver_data *drv_data = platform_get_drvdata(pdev); | ||
| 1403 | int status = 0; | ||
| 1404 | |||
| 1405 | /* Check all childern for current power state */ | ||
| 1406 | if (device_for_each_child(&pdev->dev, &state, suspend_devices) != 0) { | ||
| 1407 | dev_warn(&pdev->dev, "suspend aborted\n"); | ||
| 1408 | return -1; | ||
| 1409 | } | ||
| 1410 | |||
| 1411 | status = stop_queue(drv_data); | ||
| 1412 | if (status != 0) | ||
| 1413 | return status; | ||
| 1414 | write_SSCR0(0, drv_data->ioaddr); | ||
| 1415 | pxa_set_cken(drv_data->master_info->clock_enable, 0); | ||
| 1416 | |||
| 1417 | return 0; | ||
| 1418 | } | ||
| 1419 | |||
| 1420 | static int pxa2xx_spi_resume(struct platform_device *pdev) | ||
| 1421 | { | ||
| 1422 | struct driver_data *drv_data = platform_get_drvdata(pdev); | ||
| 1423 | int status = 0; | ||
| 1424 | |||
| 1425 | /* Enable the SSP clock */ | ||
| 1426 | pxa_set_cken(drv_data->master_info->clock_enable, 1); | ||
| 1427 | |||
| 1428 | /* Start the queue running */ | ||
| 1429 | status = start_queue(drv_data); | ||
| 1430 | if (status != 0) { | ||
| 1431 | dev_err(&pdev->dev, "problem starting queue (%d)\n", status); | ||
| 1432 | return status; | ||
| 1433 | } | ||
| 1434 | |||
| 1435 | return 0; | ||
| 1436 | } | ||
| 1437 | #else | ||
| 1438 | #define pxa2xx_spi_suspend NULL | ||
| 1439 | #define pxa2xx_spi_resume NULL | ||
| 1440 | #endif /* CONFIG_PM */ | ||
| 1441 | |||
| 1442 | static struct platform_driver driver = { | ||
| 1443 | .driver = { | ||
| 1444 | .name = "pxa2xx-spi", | ||
| 1445 | .bus = &platform_bus_type, | ||
| 1446 | .owner = THIS_MODULE, | ||
| 1447 | }, | ||
| 1448 | .probe = pxa2xx_spi_probe, | ||
| 1449 | .remove = __devexit_p(pxa2xx_spi_remove), | ||
| 1450 | .shutdown = pxa2xx_spi_shutdown, | ||
| 1451 | .suspend = pxa2xx_spi_suspend, | ||
| 1452 | .resume = pxa2xx_spi_resume, | ||
| 1453 | }; | ||
| 1454 | |||
| 1455 | static int __init pxa2xx_spi_init(void) | ||
| 1456 | { | ||
| 1457 | platform_driver_register(&driver); | ||
| 1458 | |||
| 1459 | return 0; | ||
| 1460 | } | ||
| 1461 | module_init(pxa2xx_spi_init); | ||
| 1462 | |||
| 1463 | static void __exit pxa2xx_spi_exit(void) | ||
| 1464 | { | ||
| 1465 | platform_driver_unregister(&driver); | ||
| 1466 | } | ||
| 1467 | module_exit(pxa2xx_spi_exit); | ||
| diff --git a/drivers/spi/spi.c b/drivers/spi/spi.c index 94f5e8ed83a7..7a3f733051e9 100644 --- a/drivers/spi/spi.c +++ b/drivers/spi/spi.c | |||
| @@ -395,7 +395,7 @@ EXPORT_SYMBOL_GPL(spi_alloc_master); | |||
| 395 | int __init_or_module | 395 | int __init_or_module | 
| 396 | spi_register_master(struct spi_master *master) | 396 | spi_register_master(struct spi_master *master) | 
| 397 | { | 397 | { | 
| 398 | static atomic_t dyn_bus_id = ATOMIC_INIT(0); | 398 | static atomic_t dyn_bus_id = ATOMIC_INIT((1<<16) - 1); | 
| 399 | struct device *dev = master->cdev.dev; | 399 | struct device *dev = master->cdev.dev; | 
| 400 | int status = -ENODEV; | 400 | int status = -ENODEV; | 
| 401 | int dynamic = 0; | 401 | int dynamic = 0; | 
| @@ -404,7 +404,7 @@ spi_register_master(struct spi_master *master) | |||
| 404 | return -ENODEV; | 404 | return -ENODEV; | 
| 405 | 405 | ||
| 406 | /* convention: dynamically assigned bus IDs count down from the max */ | 406 | /* convention: dynamically assigned bus IDs count down from the max */ | 
| 407 | if (master->bus_num == 0) { | 407 | if (master->bus_num < 0) { | 
| 408 | master->bus_num = atomic_dec_return(&dyn_bus_id); | 408 | master->bus_num = atomic_dec_return(&dyn_bus_id); | 
| 409 | dynamic = 1; | 409 | dynamic = 1; | 
| 410 | } | 410 | } | 
| @@ -522,7 +522,8 @@ int spi_sync(struct spi_device *spi, struct spi_message *message) | |||
| 522 | } | 522 | } | 
| 523 | EXPORT_SYMBOL_GPL(spi_sync); | 523 | EXPORT_SYMBOL_GPL(spi_sync); | 
| 524 | 524 | ||
| 525 | #define SPI_BUFSIZ (SMP_CACHE_BYTES) | 525 | /* portable code must never pass more than 32 bytes */ | 
| 526 | #define SPI_BUFSIZ max(32,SMP_CACHE_BYTES) | ||
| 526 | 527 | ||
| 527 | static u8 *buf; | 528 | static u8 *buf; | 
| 528 | 529 | ||
| diff --git a/drivers/spi/spi_bitbang.c b/drivers/spi/spi_bitbang.c index f037e5593269..dd2f950b21a7 100644 --- a/drivers/spi/spi_bitbang.c +++ b/drivers/spi/spi_bitbang.c | |||
| @@ -138,6 +138,45 @@ static unsigned bitbang_txrx_32( | |||
| 138 | return t->len - count; | 138 | return t->len - count; | 
| 139 | } | 139 | } | 
| 140 | 140 | ||
| 141 | int spi_bitbang_setup_transfer(struct spi_device *spi, struct spi_transfer *t) | ||
| 142 | { | ||
| 143 | struct spi_bitbang_cs *cs = spi->controller_state; | ||
| 144 | u8 bits_per_word; | ||
| 145 | u32 hz; | ||
| 146 | |||
| 147 | if (t) { | ||
| 148 | bits_per_word = t->bits_per_word; | ||
| 149 | hz = t->speed_hz; | ||
| 150 | } else { | ||
| 151 | bits_per_word = 0; | ||
| 152 | hz = 0; | ||
| 153 | } | ||
| 154 | |||
| 155 | /* spi_transfer level calls that work per-word */ | ||
| 156 | if (!bits_per_word) | ||
| 157 | bits_per_word = spi->bits_per_word; | ||
| 158 | if (bits_per_word <= 8) | ||
| 159 | cs->txrx_bufs = bitbang_txrx_8; | ||
| 160 | else if (bits_per_word <= 16) | ||
| 161 | cs->txrx_bufs = bitbang_txrx_16; | ||
| 162 | else if (bits_per_word <= 32) | ||
| 163 | cs->txrx_bufs = bitbang_txrx_32; | ||
| 164 | else | ||
| 165 | return -EINVAL; | ||
| 166 | |||
| 167 | /* nsecs = (clock period)/2 */ | ||
| 168 | if (!hz) | ||
| 169 | hz = spi->max_speed_hz; | ||
| 170 | if (hz) { | ||
| 171 | cs->nsecs = (1000000000/2) / hz; | ||
| 172 | if (cs->nsecs > (MAX_UDELAY_MS * 1000 * 1000)) | ||
| 173 | return -EINVAL; | ||
| 174 | } | ||
| 175 | |||
| 176 | return 0; | ||
| 177 | } | ||
| 178 | EXPORT_SYMBOL_GPL(spi_bitbang_setup_transfer); | ||
| 179 | |||
| 141 | /** | 180 | /** | 
| 142 | * spi_bitbang_setup - default setup for per-word I/O loops | 181 | * spi_bitbang_setup - default setup for per-word I/O loops | 
| 143 | */ | 182 | */ | 
| @@ -145,8 +184,16 @@ int spi_bitbang_setup(struct spi_device *spi) | |||
| 145 | { | 184 | { | 
| 146 | struct spi_bitbang_cs *cs = spi->controller_state; | 185 | struct spi_bitbang_cs *cs = spi->controller_state; | 
| 147 | struct spi_bitbang *bitbang; | 186 | struct spi_bitbang *bitbang; | 
| 187 | int retval; | ||
| 148 | 188 | ||
| 149 | if (!spi->max_speed_hz) | 189 | bitbang = spi_master_get_devdata(spi->master); | 
| 190 | |||
| 191 | /* REVISIT: some systems will want to support devices using lsb-first | ||
| 192 | * bit encodings on the wire. In pure software that would be trivial, | ||
| 193 | * just bitbang_txrx_le_cphaX() routines shifting the other way, and | ||
| 194 | * some hardware controllers also have this support. | ||
| 195 | */ | ||
| 196 | if ((spi->mode & SPI_LSB_FIRST) != 0) | ||
| 150 | return -EINVAL; | 197 | return -EINVAL; | 
| 151 | 198 | ||
| 152 | if (!cs) { | 199 | if (!cs) { | 
| @@ -155,32 +202,20 @@ int spi_bitbang_setup(struct spi_device *spi) | |||
| 155 | return -ENOMEM; | 202 | return -ENOMEM; | 
| 156 | spi->controller_state = cs; | 203 | spi->controller_state = cs; | 
| 157 | } | 204 | } | 
| 158 | bitbang = spi_master_get_devdata(spi->master); | ||
| 159 | 205 | ||
| 160 | if (!spi->bits_per_word) | 206 | if (!spi->bits_per_word) | 
| 161 | spi->bits_per_word = 8; | 207 | spi->bits_per_word = 8; | 
| 162 | 208 | ||
| 163 | /* spi_transfer level calls that work per-word */ | ||
| 164 | if (spi->bits_per_word <= 8) | ||
| 165 | cs->txrx_bufs = bitbang_txrx_8; | ||
| 166 | else if (spi->bits_per_word <= 16) | ||
| 167 | cs->txrx_bufs = bitbang_txrx_16; | ||
| 168 | else if (spi->bits_per_word <= 32) | ||
| 169 | cs->txrx_bufs = bitbang_txrx_32; | ||
| 170 | else | ||
| 171 | return -EINVAL; | ||
| 172 | |||
| 173 | /* per-word shift register access, in hardware or bitbanging */ | 209 | /* per-word shift register access, in hardware or bitbanging */ | 
| 174 | cs->txrx_word = bitbang->txrx_word[spi->mode & (SPI_CPOL|SPI_CPHA)]; | 210 | cs->txrx_word = bitbang->txrx_word[spi->mode & (SPI_CPOL|SPI_CPHA)]; | 
| 175 | if (!cs->txrx_word) | 211 | if (!cs->txrx_word) | 
| 176 | return -EINVAL; | 212 | return -EINVAL; | 
| 177 | 213 | ||
| 178 | /* nsecs = (clock period)/2 */ | 214 | retval = spi_bitbang_setup_transfer(spi, NULL); | 
| 179 | cs->nsecs = (1000000000/2) / (spi->max_speed_hz); | 215 | if (retval < 0) | 
| 180 | if (cs->nsecs > MAX_UDELAY_MS * 1000) | 216 | return retval; | 
| 181 | return -EINVAL; | ||
| 182 | 217 | ||
| 183 | dev_dbg(&spi->dev, "%s, mode %d, %u bits/w, %u nsec\n", | 218 | dev_dbg(&spi->dev, "%s, mode %d, %u bits/w, %u nsec/bit\n", | 
| 184 | __FUNCTION__, spi->mode & (SPI_CPOL | SPI_CPHA), | 219 | __FUNCTION__, spi->mode & (SPI_CPOL | SPI_CPHA), | 
| 185 | spi->bits_per_word, 2 * cs->nsecs); | 220 | spi->bits_per_word, 2 * cs->nsecs); | 
| 186 | 221 | ||
| @@ -246,6 +281,8 @@ static void bitbang_work(void *_bitbang) | |||
| 246 | unsigned tmp; | 281 | unsigned tmp; | 
| 247 | unsigned cs_change; | 282 | unsigned cs_change; | 
| 248 | int status; | 283 | int status; | 
| 284 | int (*setup_transfer)(struct spi_device *, | ||
| 285 | struct spi_transfer *); | ||
| 249 | 286 | ||
| 250 | m = container_of(bitbang->queue.next, struct spi_message, | 287 | m = container_of(bitbang->queue.next, struct spi_message, | 
| 251 | queue); | 288 | queue); | 
| @@ -262,6 +299,7 @@ static void bitbang_work(void *_bitbang) | |||
| 262 | tmp = 0; | 299 | tmp = 0; | 
| 263 | cs_change = 1; | 300 | cs_change = 1; | 
| 264 | status = 0; | 301 | status = 0; | 
| 302 | setup_transfer = NULL; | ||
| 265 | 303 | ||
| 266 | list_for_each_entry (t, &m->transfers, transfer_list) { | 304 | list_for_each_entry (t, &m->transfers, transfer_list) { | 
| 267 | if (bitbang->shutdown) { | 305 | if (bitbang->shutdown) { | 
| @@ -269,6 +307,20 @@ static void bitbang_work(void *_bitbang) | |||
| 269 | break; | 307 | break; | 
| 270 | } | 308 | } | 
| 271 | 309 | ||
| 310 | /* override or restore speed and wordsize */ | ||
| 311 | if (t->speed_hz || t->bits_per_word) { | ||
| 312 | setup_transfer = bitbang->setup_transfer; | ||
| 313 | if (!setup_transfer) { | ||
| 314 | status = -ENOPROTOOPT; | ||
| 315 | break; | ||
| 316 | } | ||
| 317 | } | ||
| 318 | if (setup_transfer) { | ||
| 319 | status = setup_transfer(spi, t); | ||
| 320 | if (status < 0) | ||
| 321 | break; | ||
| 322 | } | ||
| 323 | |||
| 272 | /* set up default clock polarity, and activate chip; | 324 | /* set up default clock polarity, and activate chip; | 
| 273 | * this implicitly updates clock and spi modes as | 325 | * this implicitly updates clock and spi modes as | 
| 274 | * previously recorded for this device via setup(). | 326 | * previously recorded for this device via setup(). | 
| @@ -325,6 +377,10 @@ static void bitbang_work(void *_bitbang) | |||
| 325 | m->status = status; | 377 | m->status = status; | 
| 326 | m->complete(m->context); | 378 | m->complete(m->context); | 
| 327 | 379 | ||
| 380 | /* restore speed and wordsize */ | ||
| 381 | if (setup_transfer) | ||
| 382 | setup_transfer(spi, NULL); | ||
| 383 | |||
| 328 | /* normally deactivate chipselect ... unless no error and | 384 | /* normally deactivate chipselect ... unless no error and | 
| 329 | * cs_change has hinted that the next message will probably | 385 | * cs_change has hinted that the next message will probably | 
| 330 | * be for this chip too. | 386 | * be for this chip too. | 
| @@ -348,6 +404,7 @@ int spi_bitbang_transfer(struct spi_device *spi, struct spi_message *m) | |||
| 348 | { | 404 | { | 
| 349 | struct spi_bitbang *bitbang; | 405 | struct spi_bitbang *bitbang; | 
| 350 | unsigned long flags; | 406 | unsigned long flags; | 
| 407 | int status = 0; | ||
| 351 | 408 | ||
| 352 | m->actual_length = 0; | 409 | m->actual_length = 0; | 
| 353 | m->status = -EINPROGRESS; | 410 | m->status = -EINPROGRESS; | 
| @@ -357,11 +414,15 @@ int spi_bitbang_transfer(struct spi_device *spi, struct spi_message *m) | |||
| 357 | return -ESHUTDOWN; | 414 | return -ESHUTDOWN; | 
| 358 | 415 | ||
| 359 | spin_lock_irqsave(&bitbang->lock, flags); | 416 | spin_lock_irqsave(&bitbang->lock, flags); | 
| 360 | list_add_tail(&m->queue, &bitbang->queue); | 417 | if (!spi->max_speed_hz) | 
| 361 | queue_work(bitbang->workqueue, &bitbang->work); | 418 | status = -ENETDOWN; | 
| 419 | else { | ||
| 420 | list_add_tail(&m->queue, &bitbang->queue); | ||
| 421 | queue_work(bitbang->workqueue, &bitbang->work); | ||
| 422 | } | ||
| 362 | spin_unlock_irqrestore(&bitbang->lock, flags); | 423 | spin_unlock_irqrestore(&bitbang->lock, flags); | 
| 363 | 424 | ||
| 364 | return 0; | 425 | return status; | 
| 365 | } | 426 | } | 
| 366 | EXPORT_SYMBOL_GPL(spi_bitbang_transfer); | 427 | EXPORT_SYMBOL_GPL(spi_bitbang_transfer); | 
| 367 | 428 | ||
| @@ -406,6 +467,9 @@ int spi_bitbang_start(struct spi_bitbang *bitbang) | |||
| 406 | bitbang->use_dma = 0; | 467 | bitbang->use_dma = 0; | 
| 407 | bitbang->txrx_bufs = spi_bitbang_bufs; | 468 | bitbang->txrx_bufs = spi_bitbang_bufs; | 
| 408 | if (!bitbang->master->setup) { | 469 | if (!bitbang->master->setup) { | 
| 470 | if (!bitbang->setup_transfer) | ||
| 471 | bitbang->setup_transfer = | ||
| 472 | spi_bitbang_setup_transfer; | ||
| 409 | bitbang->master->setup = spi_bitbang_setup; | 473 | bitbang->master->setup = spi_bitbang_setup; | 
| 410 | bitbang->master->cleanup = spi_bitbang_cleanup; | 474 | bitbang->master->cleanup = spi_bitbang_cleanup; | 
| 411 | } | 475 | } | 
| diff --git a/drivers/video/backlight/backlight.c b/drivers/video/backlight/backlight.c index 334b1db1bd7c..27597c576eff 100644 --- a/drivers/video/backlight/backlight.c +++ b/drivers/video/backlight/backlight.c | |||
| @@ -29,12 +29,15 @@ static ssize_t backlight_show_power(struct class_device *cdev, char *buf) | |||
| 29 | 29 | ||
| 30 | static ssize_t backlight_store_power(struct class_device *cdev, const char *buf, size_t count) | 30 | static ssize_t backlight_store_power(struct class_device *cdev, const char *buf, size_t count) | 
| 31 | { | 31 | { | 
| 32 | int rc = -ENXIO, power; | 32 | int rc = -ENXIO; | 
| 33 | char *endp; | 33 | char *endp; | 
| 34 | struct backlight_device *bd = to_backlight_device(cdev); | 34 | struct backlight_device *bd = to_backlight_device(cdev); | 
| 35 | int power = simple_strtoul(buf, &endp, 0); | ||
| 36 | size_t size = endp - buf; | ||
| 35 | 37 | ||
| 36 | power = simple_strtoul(buf, &endp, 0); | 38 | if (*endp && isspace(*endp)) | 
| 37 | if (*endp && !isspace(*endp)) | 39 | size++; | 
| 40 | if (size != count) | ||
| 38 | return -EINVAL; | 41 | return -EINVAL; | 
| 39 | 42 | ||
| 40 | down(&bd->sem); | 43 | down(&bd->sem); | 
| @@ -65,12 +68,15 @@ static ssize_t backlight_show_brightness(struct class_device *cdev, char *buf) | |||
| 65 | 68 | ||
| 66 | static ssize_t backlight_store_brightness(struct class_device *cdev, const char *buf, size_t count) | 69 | static ssize_t backlight_store_brightness(struct class_device *cdev, const char *buf, size_t count) | 
| 67 | { | 70 | { | 
| 68 | int rc = -ENXIO, brightness; | 71 | int rc = -ENXIO; | 
| 69 | char *endp; | 72 | char *endp; | 
| 70 | struct backlight_device *bd = to_backlight_device(cdev); | 73 | struct backlight_device *bd = to_backlight_device(cdev); | 
| 74 | int brightness = simple_strtoul(buf, &endp, 0); | ||
| 75 | size_t size = endp - buf; | ||
| 71 | 76 | ||
| 72 | brightness = simple_strtoul(buf, &endp, 0); | 77 | if (*endp && isspace(*endp)) | 
| 73 | if (*endp && !isspace(*endp)) | 78 | size++; | 
| 79 | if (size != count) | ||
| 74 | return -EINVAL; | 80 | return -EINVAL; | 
| 75 | 81 | ||
| 76 | down(&bd->sem); | 82 | down(&bd->sem); | 
| diff --git a/drivers/video/backlight/lcd.c b/drivers/video/backlight/lcd.c index 86908a60c630..bc8ab005a3fb 100644 --- a/drivers/video/backlight/lcd.c +++ b/drivers/video/backlight/lcd.c | |||
| @@ -31,12 +31,15 @@ static ssize_t lcd_show_power(struct class_device *cdev, char *buf) | |||
| 31 | 31 | ||
| 32 | static ssize_t lcd_store_power(struct class_device *cdev, const char *buf, size_t count) | 32 | static ssize_t lcd_store_power(struct class_device *cdev, const char *buf, size_t count) | 
| 33 | { | 33 | { | 
| 34 | int rc, power; | 34 | int rc = -ENXIO; | 
| 35 | char *endp; | 35 | char *endp; | 
| 36 | struct lcd_device *ld = to_lcd_device(cdev); | 36 | struct lcd_device *ld = to_lcd_device(cdev); | 
| 37 | int power = simple_strtoul(buf, &endp, 0); | ||
| 38 | size_t size = endp - buf; | ||
| 37 | 39 | ||
| 38 | power = simple_strtoul(buf, &endp, 0); | 40 | if (*endp && isspace(*endp)) | 
| 39 | if (*endp && !isspace(*endp)) | 41 | size++; | 
| 42 | if (size != count) | ||
| 40 | return -EINVAL; | 43 | return -EINVAL; | 
| 41 | 44 | ||
| 42 | down(&ld->sem); | 45 | down(&ld->sem); | 
| @@ -44,8 +47,7 @@ static ssize_t lcd_store_power(struct class_device *cdev, const char *buf, size_ | |||
| 44 | pr_debug("lcd: set power to %d\n", power); | 47 | pr_debug("lcd: set power to %d\n", power); | 
| 45 | ld->props->set_power(ld, power); | 48 | ld->props->set_power(ld, power); | 
| 46 | rc = count; | 49 | rc = count; | 
| 47 | } else | 50 | } | 
| 48 | rc = -ENXIO; | ||
| 49 | up(&ld->sem); | 51 | up(&ld->sem); | 
| 50 | 52 | ||
| 51 | return rc; | 53 | return rc; | 
| @@ -53,14 +55,12 @@ static ssize_t lcd_store_power(struct class_device *cdev, const char *buf, size_ | |||
| 53 | 55 | ||
| 54 | static ssize_t lcd_show_contrast(struct class_device *cdev, char *buf) | 56 | static ssize_t lcd_show_contrast(struct class_device *cdev, char *buf) | 
| 55 | { | 57 | { | 
| 56 | int rc; | 58 | int rc = -ENXIO; | 
| 57 | struct lcd_device *ld = to_lcd_device(cdev); | 59 | struct lcd_device *ld = to_lcd_device(cdev); | 
| 58 | 60 | ||
| 59 | down(&ld->sem); | 61 | down(&ld->sem); | 
| 60 | if (likely(ld->props && ld->props->get_contrast)) | 62 | if (likely(ld->props && ld->props->get_contrast)) | 
| 61 | rc = sprintf(buf, "%d\n", ld->props->get_contrast(ld)); | 63 | rc = sprintf(buf, "%d\n", ld->props->get_contrast(ld)); | 
| 62 | else | ||
| 63 | rc = -ENXIO; | ||
| 64 | up(&ld->sem); | 64 | up(&ld->sem); | 
| 65 | 65 | ||
| 66 | return rc; | 66 | return rc; | 
| @@ -68,12 +68,15 @@ static ssize_t lcd_show_contrast(struct class_device *cdev, char *buf) | |||
| 68 | 68 | ||
| 69 | static ssize_t lcd_store_contrast(struct class_device *cdev, const char *buf, size_t count) | 69 | static ssize_t lcd_store_contrast(struct class_device *cdev, const char *buf, size_t count) | 
| 70 | { | 70 | { | 
| 71 | int rc, contrast; | 71 | int rc = -ENXIO; | 
| 72 | char *endp; | 72 | char *endp; | 
| 73 | struct lcd_device *ld = to_lcd_device(cdev); | 73 | struct lcd_device *ld = to_lcd_device(cdev); | 
| 74 | int contrast = simple_strtoul(buf, &endp, 0); | ||
| 75 | size_t size = endp - buf; | ||
| 74 | 76 | ||
| 75 | contrast = simple_strtoul(buf, &endp, 0); | 77 | if (*endp && isspace(*endp)) | 
| 76 | if (*endp && !isspace(*endp)) | 78 | size++; | 
| 79 | if (size != count) | ||
| 77 | return -EINVAL; | 80 | return -EINVAL; | 
| 78 | 81 | ||
| 79 | down(&ld->sem); | 82 | down(&ld->sem); | 
| @@ -81,8 +84,7 @@ static ssize_t lcd_store_contrast(struct class_device *cdev, const char *buf, si | |||
| 81 | pr_debug("lcd: set contrast to %d\n", contrast); | 84 | pr_debug("lcd: set contrast to %d\n", contrast); | 
| 82 | ld->props->set_contrast(ld, contrast); | 85 | ld->props->set_contrast(ld, contrast); | 
| 83 | rc = count; | 86 | rc = count; | 
| 84 | } else | 87 | } | 
| 85 | rc = -ENXIO; | ||
| 86 | up(&ld->sem); | 88 | up(&ld->sem); | 
| 87 | 89 | ||
| 88 | return rc; | 90 | return rc; | 
| @@ -90,14 +92,12 @@ static ssize_t lcd_store_contrast(struct class_device *cdev, const char *buf, si | |||
| 90 | 92 | ||
| 91 | static ssize_t lcd_show_max_contrast(struct class_device *cdev, char *buf) | 93 | static ssize_t lcd_show_max_contrast(struct class_device *cdev, char *buf) | 
| 92 | { | 94 | { | 
| 93 | int rc; | 95 | int rc = -ENXIO; | 
| 94 | struct lcd_device *ld = to_lcd_device(cdev); | 96 | struct lcd_device *ld = to_lcd_device(cdev); | 
| 95 | 97 | ||
| 96 | down(&ld->sem); | 98 | down(&ld->sem); | 
| 97 | if (likely(ld->props)) | 99 | if (likely(ld->props)) | 
| 98 | rc = sprintf(buf, "%d\n", ld->props->max_contrast); | 100 | rc = sprintf(buf, "%d\n", ld->props->max_contrast); | 
| 99 | else | ||
| 100 | rc = -ENXIO; | ||
| 101 | up(&ld->sem); | 101 | up(&ld->sem); | 
| 102 | 102 | ||
| 103 | return rc; | 103 | return rc; | 
| diff --git a/fs/9p/fcall.c b/fs/9p/fcall.c index 71742ba150c4..6f2617820a4e 100644 --- a/fs/9p/fcall.c +++ b/fs/9p/fcall.c | |||
| @@ -98,23 +98,20 @@ v9fs_t_attach(struct v9fs_session_info *v9ses, char *uname, char *aname, | |||
| 98 | static void v9fs_t_clunk_cb(void *a, struct v9fs_fcall *tc, | 98 | static void v9fs_t_clunk_cb(void *a, struct v9fs_fcall *tc, | 
| 99 | struct v9fs_fcall *rc, int err) | 99 | struct v9fs_fcall *rc, int err) | 
| 100 | { | 100 | { | 
| 101 | int fid; | 101 | int fid, id; | 
| 102 | struct v9fs_session_info *v9ses; | 102 | struct v9fs_session_info *v9ses; | 
| 103 | 103 | ||
| 104 | if (err) | 104 | id = 0; | 
| 105 | return; | ||
| 106 | |||
| 107 | fid = tc->params.tclunk.fid; | 105 | fid = tc->params.tclunk.fid; | 
| 108 | kfree(tc); | 106 | if (rc) | 
| 109 | 107 | id = rc->id; | |
| 110 | if (!rc) | ||
| 111 | return; | ||
| 112 | |||
| 113 | v9ses = a; | ||
| 114 | if (rc->id == RCLUNK) | ||
| 115 | v9fs_put_idpool(fid, &v9ses->fidpool); | ||
| 116 | 108 | ||
| 109 | kfree(tc); | ||
| 117 | kfree(rc); | 110 | kfree(rc); | 
| 111 | if (id == RCLUNK) { | ||
| 112 | v9ses = a; | ||
| 113 | v9fs_put_idpool(fid, &v9ses->fidpool); | ||
| 114 | } | ||
| 118 | } | 115 | } | 
| 119 | 116 | ||
| 120 | /** | 117 | /** | 
| diff --git a/fs/9p/mux.c b/fs/9p/mux.c index 3e5b124a7212..f4407eb276c7 100644 --- a/fs/9p/mux.c +++ b/fs/9p/mux.c | |||
| @@ -50,15 +50,23 @@ enum { | |||
| 50 | Wpending = 8, /* can write */ | 50 | Wpending = 8, /* can write */ | 
| 51 | }; | 51 | }; | 
| 52 | 52 | ||
| 53 | enum { | ||
| 54 | None, | ||
| 55 | Flushing, | ||
| 56 | Flushed, | ||
| 57 | }; | ||
| 58 | |||
| 53 | struct v9fs_mux_poll_task; | 59 | struct v9fs_mux_poll_task; | 
| 54 | 60 | ||
| 55 | struct v9fs_req { | 61 | struct v9fs_req { | 
| 62 | spinlock_t lock; | ||
| 56 | int tag; | 63 | int tag; | 
| 57 | struct v9fs_fcall *tcall; | 64 | struct v9fs_fcall *tcall; | 
| 58 | struct v9fs_fcall *rcall; | 65 | struct v9fs_fcall *rcall; | 
| 59 | int err; | 66 | int err; | 
| 60 | v9fs_mux_req_callback cb; | 67 | v9fs_mux_req_callback cb; | 
| 61 | void *cba; | 68 | void *cba; | 
| 69 | int flush; | ||
| 62 | struct list_head req_list; | 70 | struct list_head req_list; | 
| 63 | }; | 71 | }; | 
| 64 | 72 | ||
| @@ -96,8 +104,8 @@ struct v9fs_mux_poll_task { | |||
| 96 | 104 | ||
| 97 | struct v9fs_mux_rpc { | 105 | struct v9fs_mux_rpc { | 
| 98 | struct v9fs_mux_data *m; | 106 | struct v9fs_mux_data *m; | 
| 99 | struct v9fs_req *req; | ||
| 100 | int err; | 107 | int err; | 
| 108 | struct v9fs_fcall *tcall; | ||
| 101 | struct v9fs_fcall *rcall; | 109 | struct v9fs_fcall *rcall; | 
| 102 | wait_queue_head_t wqueue; | 110 | wait_queue_head_t wqueue; | 
| 103 | }; | 111 | }; | 
| @@ -524,10 +532,9 @@ again: | |||
| 524 | 532 | ||
| 525 | static void process_request(struct v9fs_mux_data *m, struct v9fs_req *req) | 533 | static void process_request(struct v9fs_mux_data *m, struct v9fs_req *req) | 
| 526 | { | 534 | { | 
| 527 | int ecode, tag; | 535 | int ecode; | 
| 528 | struct v9fs_str *ename; | 536 | struct v9fs_str *ename; | 
| 529 | 537 | ||
| 530 | tag = req->tag; | ||
| 531 | if (!req->err && req->rcall->id == RERROR) { | 538 | if (!req->err && req->rcall->id == RERROR) { | 
| 532 | ecode = req->rcall->params.rerror.errno; | 539 | ecode = req->rcall->params.rerror.errno; | 
| 533 | ename = &req->rcall->params.rerror.error; | 540 | ename = &req->rcall->params.rerror.error; | 
| @@ -553,23 +560,6 @@ static void process_request(struct v9fs_mux_data *m, struct v9fs_req *req) | |||
| 553 | if (!req->err) | 560 | if (!req->err) | 
| 554 | req->err = -EIO; | 561 | req->err = -EIO; | 
| 555 | } | 562 | } | 
| 556 | |||
| 557 | if (req->err == ERREQFLUSH) | ||
| 558 | return; | ||
| 559 | |||
| 560 | if (req->cb) { | ||
| 561 | dprintk(DEBUG_MUX, "calling callback tcall %p rcall %p\n", | ||
| 562 | req->tcall, req->rcall); | ||
| 563 | |||
| 564 | (*req->cb) (req->cba, req->tcall, req->rcall, req->err); | ||
| 565 | req->cb = NULL; | ||
| 566 | } else | ||
| 567 | kfree(req->rcall); | ||
| 568 | |||
| 569 | v9fs_mux_put_tag(m, tag); | ||
| 570 | |||
| 571 | wake_up(&m->equeue); | ||
| 572 | kfree(req); | ||
| 573 | } | 563 | } | 
| 574 | 564 | ||
| 575 | /** | 565 | /** | 
| @@ -669,17 +659,26 @@ static void v9fs_read_work(void *a) | |||
| 669 | list_for_each_entry_safe(rreq, rptr, &m->req_list, req_list) { | 659 | list_for_each_entry_safe(rreq, rptr, &m->req_list, req_list) { | 
| 670 | if (rreq->tag == rcall->tag) { | 660 | if (rreq->tag == rcall->tag) { | 
| 671 | req = rreq; | 661 | req = rreq; | 
| 672 | req->rcall = rcall; | 662 | if (req->flush != Flushing) | 
| 673 | list_del(&req->req_list); | 663 | list_del(&req->req_list); | 
| 674 | spin_unlock(&m->lock); | ||
| 675 | process_request(m, req); | ||
| 676 | break; | 664 | break; | 
| 677 | } | 665 | } | 
| 678 | |||
| 679 | } | 666 | } | 
| 667 | spin_unlock(&m->lock); | ||
| 680 | 668 | ||
| 681 | if (!req) { | 669 | if (req) { | 
| 682 | spin_unlock(&m->lock); | 670 | req->rcall = rcall; | 
| 671 | process_request(m, req); | ||
| 672 | |||
| 673 | if (req->flush != Flushing) { | ||
| 674 | if (req->cb) | ||
| 675 | (*req->cb) (req, req->cba); | ||
| 676 | else | ||
| 677 | kfree(req->rcall); | ||
| 678 | |||
| 679 | wake_up(&m->equeue); | ||
| 680 | } | ||
| 681 | } else { | ||
| 683 | if (err >= 0 && rcall->id != RFLUSH) | 682 | if (err >= 0 && rcall->id != RFLUSH) | 
| 684 | dprintk(DEBUG_ERROR, | 683 | dprintk(DEBUG_ERROR, | 
| 685 | "unexpected response mux %p id %d tag %d\n", | 684 | "unexpected response mux %p id %d tag %d\n", | 
| @@ -746,7 +745,6 @@ static struct v9fs_req *v9fs_send_request(struct v9fs_mux_data *m, | |||
| 746 | return ERR_PTR(-ENOMEM); | 745 | return ERR_PTR(-ENOMEM); | 
| 747 | 746 | ||
| 748 | v9fs_set_tag(tc, n); | 747 | v9fs_set_tag(tc, n); | 
| 749 | |||
| 750 | if ((v9fs_debug_level&DEBUG_FCALL) == DEBUG_FCALL) { | 748 | if ((v9fs_debug_level&DEBUG_FCALL) == DEBUG_FCALL) { | 
| 751 | char buf[150]; | 749 | char buf[150]; | 
| 752 | 750 | ||
| @@ -754,12 +752,14 @@ static struct v9fs_req *v9fs_send_request(struct v9fs_mux_data *m, | |||
| 754 | printk(KERN_NOTICE "<<< %p %s\n", m, buf); | 752 | printk(KERN_NOTICE "<<< %p %s\n", m, buf); | 
| 755 | } | 753 | } | 
| 756 | 754 | ||
| 755 | spin_lock_init(&req->lock); | ||
| 757 | req->tag = n; | 756 | req->tag = n; | 
| 758 | req->tcall = tc; | 757 | req->tcall = tc; | 
| 759 | req->rcall = NULL; | 758 | req->rcall = NULL; | 
| 760 | req->err = 0; | 759 | req->err = 0; | 
| 761 | req->cb = cb; | 760 | req->cb = cb; | 
| 762 | req->cba = cba; | 761 | req->cba = cba; | 
| 762 | req->flush = None; | ||
| 763 | 763 | ||
| 764 | spin_lock(&m->lock); | 764 | spin_lock(&m->lock); | 
| 765 | list_add_tail(&req->req_list, &m->unsent_req_list); | 765 | list_add_tail(&req->req_list, &m->unsent_req_list); | 
| @@ -776,72 +776,108 @@ static struct v9fs_req *v9fs_send_request(struct v9fs_mux_data *m, | |||
| 776 | return req; | 776 | return req; | 
| 777 | } | 777 | } | 
| 778 | 778 | ||
| 779 | static void v9fs_mux_flush_cb(void *a, struct v9fs_fcall *tc, | 779 | static void v9fs_mux_free_request(struct v9fs_mux_data *m, struct v9fs_req *req) | 
| 780 | struct v9fs_fcall *rc, int err) | 780 | { | 
| 781 | v9fs_mux_put_tag(m, req->tag); | ||
| 782 | kfree(req); | ||
| 783 | } | ||
| 784 | |||
| 785 | static void v9fs_mux_flush_cb(struct v9fs_req *freq, void *a) | ||
| 781 | { | 786 | { | 
| 782 | v9fs_mux_req_callback cb; | 787 | v9fs_mux_req_callback cb; | 
| 783 | int tag; | 788 | int tag; | 
| 784 | struct v9fs_mux_data *m; | 789 | struct v9fs_mux_data *m; | 
| 785 | struct v9fs_req *req, *rptr; | 790 | struct v9fs_req *req, *rreq, *rptr; | 
| 786 | 791 | ||
| 787 | m = a; | 792 | m = a; | 
| 788 | dprintk(DEBUG_MUX, "mux %p tc %p rc %p err %d oldtag %d\n", m, tc, | 793 | dprintk(DEBUG_MUX, "mux %p tc %p rc %p err %d oldtag %d\n", m, | 
| 789 | rc, err, tc->params.tflush.oldtag); | 794 | freq->tcall, freq->rcall, freq->err, | 
| 795 | freq->tcall->params.tflush.oldtag); | ||
| 790 | 796 | ||
| 791 | spin_lock(&m->lock); | 797 | spin_lock(&m->lock); | 
| 792 | cb = NULL; | 798 | cb = NULL; | 
| 793 | tag = tc->params.tflush.oldtag; | 799 | tag = freq->tcall->params.tflush.oldtag; | 
| 794 | list_for_each_entry_safe(req, rptr, &m->req_list, req_list) { | 800 | req = NULL; | 
| 795 | if (req->tag == tag) { | 801 | list_for_each_entry_safe(rreq, rptr, &m->req_list, req_list) { | 
| 802 | if (rreq->tag == tag) { | ||
| 803 | req = rreq; | ||
| 796 | list_del(&req->req_list); | 804 | list_del(&req->req_list); | 
| 797 | if (req->cb) { | ||
| 798 | cb = req->cb; | ||
| 799 | req->cb = NULL; | ||
| 800 | spin_unlock(&m->lock); | ||
| 801 | (*cb) (req->cba, req->tcall, req->rcall, | ||
| 802 | req->err); | ||
| 803 | } | ||
| 804 | kfree(req); | ||
| 805 | wake_up(&m->equeue); | ||
| 806 | break; | 805 | break; | 
| 807 | } | 806 | } | 
| 808 | } | 807 | } | 
| 808 | spin_unlock(&m->lock); | ||
| 809 | 809 | ||
| 810 | if (!cb) | 810 | if (req) { | 
| 811 | spin_unlock(&m->lock); | 811 | spin_lock(&req->lock); | 
| 812 | req->flush = Flushed; | ||
| 813 | spin_unlock(&req->lock); | ||
| 814 | |||
| 815 | if (req->cb) | ||
| 816 | (*req->cb) (req, req->cba); | ||
| 817 | else | ||
| 818 | kfree(req->rcall); | ||
| 819 | |||
| 820 | wake_up(&m->equeue); | ||
| 821 | } | ||
| 812 | 822 | ||
| 813 | v9fs_mux_put_tag(m, tag); | 823 | kfree(freq->tcall); | 
| 814 | kfree(tc); | 824 | kfree(freq->rcall); | 
| 815 | kfree(rc); | 825 | v9fs_mux_free_request(m, freq); | 
| 816 | } | 826 | } | 
| 817 | 827 | ||
| 818 | static void | 828 | static int | 
| 819 | v9fs_mux_flush_request(struct v9fs_mux_data *m, struct v9fs_req *req) | 829 | v9fs_mux_flush_request(struct v9fs_mux_data *m, struct v9fs_req *req) | 
| 820 | { | 830 | { | 
| 821 | struct v9fs_fcall *fc; | 831 | struct v9fs_fcall *fc; | 
| 832 | struct v9fs_req *rreq, *rptr; | ||
| 822 | 833 | ||
| 823 | dprintk(DEBUG_MUX, "mux %p req %p tag %d\n", m, req, req->tag); | 834 | dprintk(DEBUG_MUX, "mux %p req %p tag %d\n", m, req, req->tag); | 
| 824 | 835 | ||
| 836 | /* if a response was received for a request, do nothing */ | ||
| 837 | spin_lock(&req->lock); | ||
| 838 | if (req->rcall || req->err) { | ||
| 839 | spin_unlock(&req->lock); | ||
| 840 | dprintk(DEBUG_MUX, "mux %p req %p response already received\n", m, req); | ||
| 841 | return 0; | ||
| 842 | } | ||
| 843 | |||
| 844 | req->flush = Flushing; | ||
| 845 | spin_unlock(&req->lock); | ||
| 846 | |||
| 847 | spin_lock(&m->lock); | ||
| 848 | /* if the request is not sent yet, just remove it from the list */ | ||
| 849 | list_for_each_entry_safe(rreq, rptr, &m->unsent_req_list, req_list) { | ||
| 850 | if (rreq->tag == req->tag) { | ||
| 851 | dprintk(DEBUG_MUX, "mux %p req %p request is not sent yet\n", m, req); | ||
| 852 | list_del(&rreq->req_list); | ||
| 853 | req->flush = Flushed; | ||
| 854 | spin_unlock(&m->lock); | ||
| 855 | if (req->cb) | ||
| 856 | (*req->cb) (req, req->cba); | ||
| 857 | return 0; | ||
| 858 | } | ||
| 859 | } | ||
| 860 | spin_unlock(&m->lock); | ||
| 861 | |||
| 862 | clear_thread_flag(TIF_SIGPENDING); | ||
| 825 | fc = v9fs_create_tflush(req->tag); | 863 | fc = v9fs_create_tflush(req->tag); | 
| 826 | v9fs_send_request(m, fc, v9fs_mux_flush_cb, m); | 864 | v9fs_send_request(m, fc, v9fs_mux_flush_cb, m); | 
| 865 | return 1; | ||
| 827 | } | 866 | } | 
| 828 | 867 | ||
| 829 | static void | 868 | static void | 
| 830 | v9fs_mux_rpc_cb(void *a, struct v9fs_fcall *tc, struct v9fs_fcall *rc, int err) | 869 | v9fs_mux_rpc_cb(struct v9fs_req *req, void *a) | 
| 831 | { | 870 | { | 
| 832 | struct v9fs_mux_rpc *r; | 871 | struct v9fs_mux_rpc *r; | 
| 833 | 872 | ||
| 834 | if (err == ERREQFLUSH) { | 873 | dprintk(DEBUG_MUX, "req %p r %p\n", req, a); | 
| 835 | kfree(rc); | ||
| 836 | dprintk(DEBUG_MUX, "err req flush\n"); | ||
| 837 | return; | ||
| 838 | } | ||
| 839 | |||
| 840 | r = a; | 874 | r = a; | 
| 841 | dprintk(DEBUG_MUX, "mux %p req %p tc %p rc %p err %d\n", r->m, r->req, | 875 | r->rcall = req->rcall; | 
| 842 | tc, rc, err); | 876 | r->err = req->err; | 
| 843 | r->rcall = rc; | 877 | |
| 844 | r->err = err; | 878 | if (req->flush!=None && !req->err) | 
| 879 | r->err = -ERESTARTSYS; | ||
| 880 | |||
| 845 | wake_up(&r->wqueue); | 881 | wake_up(&r->wqueue); | 
| 846 | } | 882 | } | 
| 847 | 883 | ||
| @@ -856,12 +892,13 @@ int | |||
| 856 | v9fs_mux_rpc(struct v9fs_mux_data *m, struct v9fs_fcall *tc, | 892 | v9fs_mux_rpc(struct v9fs_mux_data *m, struct v9fs_fcall *tc, | 
| 857 | struct v9fs_fcall **rc) | 893 | struct v9fs_fcall **rc) | 
| 858 | { | 894 | { | 
| 859 | int err; | 895 | int err, sigpending; | 
| 860 | unsigned long flags; | 896 | unsigned long flags; | 
| 861 | struct v9fs_req *req; | 897 | struct v9fs_req *req; | 
| 862 | struct v9fs_mux_rpc r; | 898 | struct v9fs_mux_rpc r; | 
| 863 | 899 | ||
| 864 | r.err = 0; | 900 | r.err = 0; | 
| 901 | r.tcall = tc; | ||
| 865 | r.rcall = NULL; | 902 | r.rcall = NULL; | 
| 866 | r.m = m; | 903 | r.m = m; | 
| 867 | init_waitqueue_head(&r.wqueue); | 904 | init_waitqueue_head(&r.wqueue); | 
| @@ -869,48 +906,50 @@ v9fs_mux_rpc(struct v9fs_mux_data *m, struct v9fs_fcall *tc, | |||
| 869 | if (rc) | 906 | if (rc) | 
| 870 | *rc = NULL; | 907 | *rc = NULL; | 
| 871 | 908 | ||
| 909 | sigpending = 0; | ||
| 910 | if (signal_pending(current)) { | ||
| 911 | sigpending = 1; | ||
| 912 | clear_thread_flag(TIF_SIGPENDING); | ||
| 913 | } | ||
| 914 | |||
| 872 | req = v9fs_send_request(m, tc, v9fs_mux_rpc_cb, &r); | 915 | req = v9fs_send_request(m, tc, v9fs_mux_rpc_cb, &r); | 
| 873 | if (IS_ERR(req)) { | 916 | if (IS_ERR(req)) { | 
| 874 | err = PTR_ERR(req); | 917 | err = PTR_ERR(req); | 
| 875 | dprintk(DEBUG_MUX, "error %d\n", err); | 918 | dprintk(DEBUG_MUX, "error %d\n", err); | 
| 876 | return PTR_ERR(req); | 919 | return err; | 
| 877 | } | 920 | } | 
| 878 | 921 | ||
| 879 | r.req = req; | ||
| 880 | dprintk(DEBUG_MUX, "mux %p tc %p tag %d rpc %p req %p\n", m, tc, | ||
| 881 | req->tag, &r, req); | ||
| 882 | err = wait_event_interruptible(r.wqueue, r.rcall != NULL || r.err < 0); | 922 | err = wait_event_interruptible(r.wqueue, r.rcall != NULL || r.err < 0); | 
| 883 | if (r.err < 0) | 923 | if (r.err < 0) | 
| 884 | err = r.err; | 924 | err = r.err; | 
| 885 | 925 | ||
| 886 | if (err == -ERESTARTSYS && m->trans->status == Connected && m->err == 0) { | 926 | if (err == -ERESTARTSYS && m->trans->status == Connected && m->err == 0) { | 
| 887 | spin_lock(&m->lock); | 927 | if (v9fs_mux_flush_request(m, req)) { | 
| 888 | req->tcall = NULL; | 928 | /* wait until we get response of the flush message */ | 
| 889 | req->err = ERREQFLUSH; | 929 | do { | 
| 890 | spin_unlock(&m->lock); | 930 | clear_thread_flag(TIF_SIGPENDING); | 
| 931 | err = wait_event_interruptible(r.wqueue, | ||
| 932 | r.rcall || r.err); | ||
| 933 | } while (!r.rcall && !r.err && err==-ERESTARTSYS && | ||
| 934 | m->trans->status==Connected && !m->err); | ||
| 935 | } | ||
| 936 | sigpending = 1; | ||
| 937 | } | ||
| 891 | 938 | ||
| 892 | clear_thread_flag(TIF_SIGPENDING); | 939 | if (sigpending) { | 
| 893 | v9fs_mux_flush_request(m, req); | ||
| 894 | spin_lock_irqsave(¤t->sighand->siglock, flags); | 940 | spin_lock_irqsave(¤t->sighand->siglock, flags); | 
| 895 | recalc_sigpending(); | 941 | recalc_sigpending(); | 
| 896 | spin_unlock_irqrestore(¤t->sighand->siglock, flags); | 942 | spin_unlock_irqrestore(¤t->sighand->siglock, flags); | 
| 897 | } | 943 | } | 
| 898 | 944 | ||
| 899 | if (!err) { | 945 | if (rc) | 
| 900 | if (r.rcall) | 946 | *rc = r.rcall; | 
| 901 | dprintk(DEBUG_MUX, "got response id %d tag %d\n", | 947 | else | 
| 902 | r.rcall->id, r.rcall->tag); | ||
| 903 | |||
| 904 | if (rc) | ||
| 905 | *rc = r.rcall; | ||
| 906 | else | ||
| 907 | kfree(r.rcall); | ||
| 908 | } else { | ||
| 909 | kfree(r.rcall); | 948 | kfree(r.rcall); | 
| 910 | dprintk(DEBUG_MUX, "got error %d\n", err); | 949 | |
| 911 | if (err > 0) | 950 | v9fs_mux_free_request(m, req); | 
| 912 | err = -EIO; | 951 | if (err > 0) | 
| 913 | } | 952 | err = -EIO; | 
| 914 | 953 | ||
| 915 | return err; | 954 | return err; | 
| 916 | } | 955 | } | 
| @@ -951,12 +990,15 @@ void v9fs_mux_cancel(struct v9fs_mux_data *m, int err) | |||
| 951 | struct v9fs_req *req, *rtmp; | 990 | struct v9fs_req *req, *rtmp; | 
| 952 | LIST_HEAD(cancel_list); | 991 | LIST_HEAD(cancel_list); | 
| 953 | 992 | ||
| 954 | dprintk(DEBUG_MUX, "mux %p err %d\n", m, err); | 993 | dprintk(DEBUG_ERROR, "mux %p err %d\n", m, err); | 
| 955 | m->err = err; | 994 | m->err = err; | 
| 956 | spin_lock(&m->lock); | 995 | spin_lock(&m->lock); | 
| 957 | list_for_each_entry_safe(req, rtmp, &m->req_list, req_list) { | 996 | list_for_each_entry_safe(req, rtmp, &m->req_list, req_list) { | 
| 958 | list_move(&req->req_list, &cancel_list); | 997 | list_move(&req->req_list, &cancel_list); | 
| 959 | } | 998 | } | 
| 999 | list_for_each_entry_safe(req, rtmp, &m->unsent_req_list, req_list) { | ||
| 1000 | list_move(&req->req_list, &cancel_list); | ||
| 1001 | } | ||
| 960 | spin_unlock(&m->lock); | 1002 | spin_unlock(&m->lock); | 
| 961 | 1003 | ||
| 962 | list_for_each_entry_safe(req, rtmp, &cancel_list, req_list) { | 1004 | list_for_each_entry_safe(req, rtmp, &cancel_list, req_list) { | 
| @@ -965,11 +1007,9 @@ void v9fs_mux_cancel(struct v9fs_mux_data *m, int err) | |||
| 965 | req->err = err; | 1007 | req->err = err; | 
| 966 | 1008 | ||
| 967 | if (req->cb) | 1009 | if (req->cb) | 
| 968 | (*req->cb) (req->cba, req->tcall, req->rcall, req->err); | 1010 | (*req->cb) (req, req->cba); | 
| 969 | else | 1011 | else | 
| 970 | kfree(req->rcall); | 1012 | kfree(req->rcall); | 
| 971 | |||
| 972 | kfree(req); | ||
| 973 | } | 1013 | } | 
| 974 | 1014 | ||
| 975 | wake_up(&m->equeue); | 1015 | wake_up(&m->equeue); | 
| diff --git a/fs/9p/mux.h b/fs/9p/mux.h index e90bfd32ea42..fb10c50186a1 100644 --- a/fs/9p/mux.h +++ b/fs/9p/mux.h | |||
| @@ -24,6 +24,7 @@ | |||
| 24 | */ | 24 | */ | 
| 25 | 25 | ||
| 26 | struct v9fs_mux_data; | 26 | struct v9fs_mux_data; | 
| 27 | struct v9fs_req; | ||
| 27 | 28 | ||
| 28 | /** | 29 | /** | 
| 29 | * v9fs_mux_req_callback - callback function that is called when the | 30 | * v9fs_mux_req_callback - callback function that is called when the | 
| @@ -36,8 +37,7 @@ struct v9fs_mux_data; | |||
| 36 | * @rc - response call | 37 | * @rc - response call | 
| 37 | * @err - error code (non-zero if error occured) | 38 | * @err - error code (non-zero if error occured) | 
| 38 | */ | 39 | */ | 
| 39 | typedef void (*v9fs_mux_req_callback)(void *a, struct v9fs_fcall *tc, | 40 | typedef void (*v9fs_mux_req_callback)(struct v9fs_req *req, void *a); | 
| 40 | struct v9fs_fcall *rc, int err); | ||
| 41 | 41 | ||
| 42 | int v9fs_mux_global_init(void); | 42 | int v9fs_mux_global_init(void); | 
| 43 | void v9fs_mux_global_exit(void); | 43 | void v9fs_mux_global_exit(void); | 
| diff --git a/fs/9p/vfs_file.c b/fs/9p/vfs_file.c index 083dcfcd158e..1a8e46084f0e 100644 --- a/fs/9p/vfs_file.c +++ b/fs/9p/vfs_file.c | |||
| @@ -72,11 +72,17 @@ int v9fs_file_open(struct inode *inode, struct file *file) | |||
| 72 | return -ENOSPC; | 72 | return -ENOSPC; | 
| 73 | } | 73 | } | 
| 74 | 74 | ||
| 75 | err = v9fs_t_walk(v9ses, vfid->fid, fid, NULL, NULL); | 75 | err = v9fs_t_walk(v9ses, vfid->fid, fid, NULL, &fcall); | 
| 76 | if (err < 0) { | 76 | if (err < 0) { | 
| 77 | dprintk(DEBUG_ERROR, "rewalk didn't work\n"); | 77 | dprintk(DEBUG_ERROR, "rewalk didn't work\n"); | 
| 78 | goto put_fid; | 78 | if (fcall && fcall->id == RWALK) | 
| 79 | goto clunk_fid; | ||
| 80 | else { | ||
| 81 | v9fs_put_idpool(fid, &v9ses->fidpool); | ||
| 82 | goto free_fcall; | ||
| 83 | } | ||
| 79 | } | 84 | } | 
| 85 | kfree(fcall); | ||
| 80 | 86 | ||
| 81 | /* TODO: do special things for O_EXCL, O_NOFOLLOW, O_SYNC */ | 87 | /* TODO: do special things for O_EXCL, O_NOFOLLOW, O_SYNC */ | 
| 82 | /* translate open mode appropriately */ | 88 | /* translate open mode appropriately */ | 
| @@ -109,8 +115,7 @@ int v9fs_file_open(struct inode *inode, struct file *file) | |||
| 109 | clunk_fid: | 115 | clunk_fid: | 
| 110 | v9fs_t_clunk(v9ses, fid); | 116 | v9fs_t_clunk(v9ses, fid); | 
| 111 | 117 | ||
| 112 | put_fid: | 118 | free_fcall: | 
| 113 | v9fs_put_idpool(fid, &v9ses->fidpool); | ||
| 114 | kfree(fcall); | 119 | kfree(fcall); | 
| 115 | 120 | ||
| 116 | return err; | 121 | return err; | 
| diff --git a/fs/9p/vfs_inode.c b/fs/9p/vfs_inode.c index 133db366d306..2cb87ba4b1c1 100644 --- a/fs/9p/vfs_inode.c +++ b/fs/9p/vfs_inode.c | |||
| @@ -270,7 +270,10 @@ v9fs_create(struct v9fs_session_info *v9ses, u32 pfid, char *name, u32 perm, | |||
| 270 | err = v9fs_t_walk(v9ses, pfid, fid, NULL, &fcall); | 270 | err = v9fs_t_walk(v9ses, pfid, fid, NULL, &fcall); | 
| 271 | if (err < 0) { | 271 | if (err < 0) { | 
| 272 | PRINT_FCALL_ERROR("clone error", fcall); | 272 | PRINT_FCALL_ERROR("clone error", fcall); | 
| 273 | goto put_fid; | 273 | if (fcall && fcall->id == RWALK) | 
| 274 | goto clunk_fid; | ||
| 275 | else | ||
| 276 | goto put_fid; | ||
| 274 | } | 277 | } | 
| 275 | kfree(fcall); | 278 | kfree(fcall); | 
| 276 | 279 | ||
| @@ -322,6 +325,9 @@ v9fs_clone_walk(struct v9fs_session_info *v9ses, u32 fid, struct dentry *dentry) | |||
| 322 | &fcall); | 325 | &fcall); | 
| 323 | 326 | ||
| 324 | if (err < 0) { | 327 | if (err < 0) { | 
| 328 | if (fcall && fcall->id == RWALK) | ||
| 329 | goto clunk_fid; | ||
| 330 | |||
| 325 | PRINT_FCALL_ERROR("walk error", fcall); | 331 | PRINT_FCALL_ERROR("walk error", fcall); | 
| 326 | v9fs_put_idpool(nfid, &v9ses->fidpool); | 332 | v9fs_put_idpool(nfid, &v9ses->fidpool); | 
| 327 | goto error; | 333 | goto error; | 
| @@ -640,19 +646,26 @@ static struct dentry *v9fs_vfs_lookup(struct inode *dir, struct dentry *dentry, | |||
| 640 | } | 646 | } | 
| 641 | 647 | ||
| 642 | result = v9fs_t_walk(v9ses, dirfidnum, newfid, | 648 | result = v9fs_t_walk(v9ses, dirfidnum, newfid, | 
| 643 | (char *)dentry->d_name.name, NULL); | 649 | (char *)dentry->d_name.name, &fcall); | 
| 650 | |||
| 644 | if (result < 0) { | 651 | if (result < 0) { | 
| 645 | v9fs_put_idpool(newfid, &v9ses->fidpool); | 652 | if (fcall && fcall->id == RWALK) | 
| 653 | v9fs_t_clunk(v9ses, newfid); | ||
| 654 | else | ||
| 655 | v9fs_put_idpool(newfid, &v9ses->fidpool); | ||
| 656 | |||
| 646 | if (result == -ENOENT) { | 657 | if (result == -ENOENT) { | 
| 647 | d_add(dentry, NULL); | 658 | d_add(dentry, NULL); | 
| 648 | dprintk(DEBUG_VFS, | 659 | dprintk(DEBUG_VFS, | 
| 649 | "Return negative dentry %p count %d\n", | 660 | "Return negative dentry %p count %d\n", | 
| 650 | dentry, atomic_read(&dentry->d_count)); | 661 | dentry, atomic_read(&dentry->d_count)); | 
| 662 | kfree(fcall); | ||
| 651 | return NULL; | 663 | return NULL; | 
| 652 | } | 664 | } | 
| 653 | dprintk(DEBUG_ERROR, "walk error:%d\n", result); | 665 | dprintk(DEBUG_ERROR, "walk error:%d\n", result); | 
| 654 | goto FreeFcall; | 666 | goto FreeFcall; | 
| 655 | } | 667 | } | 
| 668 | kfree(fcall); | ||
| 656 | 669 | ||
| 657 | result = v9fs_t_stat(v9ses, newfid, &fcall); | 670 | result = v9fs_t_stat(v9ses, newfid, &fcall); | 
| 658 | if (result < 0) { | 671 | if (result < 0) { | 
| diff --git a/fs/Makefile b/fs/Makefile index 83bf478e786b..078d3d1191a5 100644 --- a/fs/Makefile +++ b/fs/Makefile | |||
| @@ -45,6 +45,7 @@ obj-$(CONFIG_DNOTIFY) += dnotify.o | |||
| 45 | obj-$(CONFIG_PROC_FS) += proc/ | 45 | obj-$(CONFIG_PROC_FS) += proc/ | 
| 46 | obj-y += partitions/ | 46 | obj-y += partitions/ | 
| 47 | obj-$(CONFIG_SYSFS) += sysfs/ | 47 | obj-$(CONFIG_SYSFS) += sysfs/ | 
| 48 | obj-$(CONFIG_CONFIGFS_FS) += configfs/ | ||
| 48 | obj-y += devpts/ | 49 | obj-y += devpts/ | 
| 49 | 50 | ||
| 50 | obj-$(CONFIG_PROFILING) += dcookies.o | 51 | obj-$(CONFIG_PROFILING) += dcookies.o | 
| @@ -100,5 +101,4 @@ obj-$(CONFIG_BEFS_FS) += befs/ | |||
| 100 | obj-$(CONFIG_HOSTFS) += hostfs/ | 101 | obj-$(CONFIG_HOSTFS) += hostfs/ | 
| 101 | obj-$(CONFIG_HPPFS) += hppfs/ | 102 | obj-$(CONFIG_HPPFS) += hppfs/ | 
| 102 | obj-$(CONFIG_DEBUG_FS) += debugfs/ | 103 | obj-$(CONFIG_DEBUG_FS) += debugfs/ | 
| 103 | obj-$(CONFIG_CONFIGFS_FS) += configfs/ | ||
| 104 | obj-$(CONFIG_OCFS2_FS) += ocfs2/ | 104 | obj-$(CONFIG_OCFS2_FS) += ocfs2/ | 
| diff --git a/fs/autofs4/autofs_i.h b/fs/autofs4/autofs_i.h index 57c4903614e5..d6603d02304c 100644 --- a/fs/autofs4/autofs_i.h +++ b/fs/autofs4/autofs_i.h | |||
| @@ -74,8 +74,8 @@ struct autofs_wait_queue { | |||
| 74 | struct autofs_wait_queue *next; | 74 | struct autofs_wait_queue *next; | 
| 75 | autofs_wqt_t wait_queue_token; | 75 | autofs_wqt_t wait_queue_token; | 
| 76 | /* We use the following to see what we are waiting for */ | 76 | /* We use the following to see what we are waiting for */ | 
| 77 | int hash; | 77 | unsigned int hash; | 
| 78 | int len; | 78 | unsigned int len; | 
| 79 | char *name; | 79 | char *name; | 
| 80 | u32 dev; | 80 | u32 dev; | 
| 81 | u64 ino; | 81 | u64 ino; | 
| @@ -85,7 +85,6 @@ struct autofs_wait_queue { | |||
| 85 | pid_t tgid; | 85 | pid_t tgid; | 
| 86 | /* This is for status reporting upon return */ | 86 | /* This is for status reporting upon return */ | 
| 87 | int status; | 87 | int status; | 
| 88 | atomic_t notify; | ||
| 89 | atomic_t wait_ctr; | 88 | atomic_t wait_ctr; | 
| 90 | }; | 89 | }; | 
| 91 | 90 | ||
| diff --git a/fs/autofs4/root.c b/fs/autofs4/root.c index 84e030c8ddd0..5100f984783f 100644 --- a/fs/autofs4/root.c +++ b/fs/autofs4/root.c | |||
| @@ -327,6 +327,7 @@ static int try_to_fill_dentry(struct dentry *dentry, int flags) | |||
| 327 | static void *autofs4_follow_link(struct dentry *dentry, struct nameidata *nd) | 327 | static void *autofs4_follow_link(struct dentry *dentry, struct nameidata *nd) | 
| 328 | { | 328 | { | 
| 329 | struct autofs_sb_info *sbi = autofs4_sbi(dentry->d_sb); | 329 | struct autofs_sb_info *sbi = autofs4_sbi(dentry->d_sb); | 
| 330 | struct autofs_info *ino = autofs4_dentry_ino(dentry); | ||
| 330 | int oz_mode = autofs4_oz_mode(sbi); | 331 | int oz_mode = autofs4_oz_mode(sbi); | 
| 331 | unsigned int lookup_type; | 332 | unsigned int lookup_type; | 
| 332 | int status; | 333 | int status; | 
| @@ -340,13 +341,8 @@ static void *autofs4_follow_link(struct dentry *dentry, struct nameidata *nd) | |||
| 340 | if (oz_mode || !lookup_type) | 341 | if (oz_mode || !lookup_type) | 
| 341 | goto done; | 342 | goto done; | 
| 342 | 343 | ||
| 343 | /* | 344 | /* If an expire request is pending wait for it. */ | 
| 344 | * If a request is pending wait for it. | 345 | if (ino && (ino->flags & AUTOFS_INF_EXPIRING)) { | 
| 345 | * If it's a mount then it won't be expired till at least | ||
| 346 | * a liitle later and if it's an expire then we might need | ||
| 347 | * to mount it again. | ||
| 348 | */ | ||
| 349 | if (autofs4_ispending(dentry)) { | ||
| 350 | DPRINTK("waiting for active request %p name=%.*s", | 346 | DPRINTK("waiting for active request %p name=%.*s", | 
| 351 | dentry, dentry->d_name.len, dentry->d_name.name); | 347 | dentry, dentry->d_name.len, dentry->d_name.name); | 
| 352 | 348 | ||
| diff --git a/fs/autofs4/waitq.c b/fs/autofs4/waitq.c index 142ab6aa2aa1..ce103e7b0bc3 100644 --- a/fs/autofs4/waitq.c +++ b/fs/autofs4/waitq.c | |||
| @@ -189,14 +189,30 @@ static int autofs4_getpath(struct autofs_sb_info *sbi, | |||
| 189 | return len; | 189 | return len; | 
| 190 | } | 190 | } | 
| 191 | 191 | ||
| 192 | static struct autofs_wait_queue * | ||
| 193 | autofs4_find_wait(struct autofs_sb_info *sbi, | ||
| 194 | char *name, unsigned int hash, unsigned int len) | ||
| 195 | { | ||
| 196 | struct autofs_wait_queue *wq; | ||
| 197 | |||
| 198 | for (wq = sbi->queues; wq; wq = wq->next) { | ||
| 199 | if (wq->hash == hash && | ||
| 200 | wq->len == len && | ||
| 201 | wq->name && !memcmp(wq->name, name, len)) | ||
| 202 | break; | ||
| 203 | } | ||
| 204 | return wq; | ||
| 205 | } | ||
| 206 | |||
| 192 | int autofs4_wait(struct autofs_sb_info *sbi, struct dentry *dentry, | 207 | int autofs4_wait(struct autofs_sb_info *sbi, struct dentry *dentry, | 
| 193 | enum autofs_notify notify) | 208 | enum autofs_notify notify) | 
| 194 | { | 209 | { | 
| 210 | struct autofs_info *ino; | ||
| 195 | struct autofs_wait_queue *wq; | 211 | struct autofs_wait_queue *wq; | 
| 196 | char *name; | 212 | char *name; | 
| 197 | unsigned int len = 0; | 213 | unsigned int len = 0; | 
| 198 | unsigned int hash = 0; | 214 | unsigned int hash = 0; | 
| 199 | int status; | 215 | int status, type; | 
| 200 | 216 | ||
| 201 | /* In catatonic mode, we don't wait for nobody */ | 217 | /* In catatonic mode, we don't wait for nobody */ | 
| 202 | if (sbi->catatonic) | 218 | if (sbi->catatonic) | 
| @@ -223,21 +239,41 @@ int autofs4_wait(struct autofs_sb_info *sbi, struct dentry *dentry, | |||
| 223 | return -EINTR; | 239 | return -EINTR; | 
| 224 | } | 240 | } | 
| 225 | 241 | ||
| 226 | for (wq = sbi->queues ; wq ; wq = wq->next) { | 242 | wq = autofs4_find_wait(sbi, name, hash, len); | 
| 227 | if (wq->hash == dentry->d_name.hash && | 243 | ino = autofs4_dentry_ino(dentry); | 
| 228 | wq->len == len && | 244 | if (!wq && ino && notify == NFY_NONE) { | 
| 229 | wq->name && !memcmp(wq->name, name, len)) | 245 | /* | 
| 230 | break; | 246 | * Either we've betean the pending expire to post it's | 
| 231 | } | 247 | * wait or it finished while we waited on the mutex. | 
| 248 | * So we need to wait till either, the wait appears | ||
| 249 | * or the expire finishes. | ||
| 250 | */ | ||
| 251 | |||
| 252 | while (ino->flags & AUTOFS_INF_EXPIRING) { | ||
| 253 | mutex_unlock(&sbi->wq_mutex); | ||
| 254 | schedule_timeout_interruptible(HZ/10); | ||
| 255 | if (mutex_lock_interruptible(&sbi->wq_mutex)) { | ||
| 256 | kfree(name); | ||
| 257 | return -EINTR; | ||
| 258 | } | ||
| 259 | wq = autofs4_find_wait(sbi, name, hash, len); | ||
| 260 | if (wq) | ||
| 261 | break; | ||
| 262 | } | ||
| 232 | 263 | ||
| 233 | if (!wq) { | 264 | /* | 
| 234 | /* Can't wait for an expire if there's no mount */ | 265 | * Not ideal but the status has already gone. Of the two | 
| 235 | if (notify == NFY_NONE && !d_mountpoint(dentry)) { | 266 | * cases where we wait on NFY_NONE neither depend on the | 
| 267 | * return status of the wait. | ||
| 268 | */ | ||
| 269 | if (!wq) { | ||
| 236 | kfree(name); | 270 | kfree(name); | 
| 237 | mutex_unlock(&sbi->wq_mutex); | 271 | mutex_unlock(&sbi->wq_mutex); | 
| 238 | return -ENOENT; | 272 | return 0; | 
| 239 | } | 273 | } | 
| 274 | } | ||
| 240 | 275 | ||
| 276 | if (!wq) { | ||
| 241 | /* Create a new wait queue */ | 277 | /* Create a new wait queue */ | 
| 242 | wq = kmalloc(sizeof(struct autofs_wait_queue),GFP_KERNEL); | 278 | wq = kmalloc(sizeof(struct autofs_wait_queue),GFP_KERNEL); | 
| 243 | if (!wq) { | 279 | if (!wq) { | 
| @@ -263,20 +299,7 @@ int autofs4_wait(struct autofs_sb_info *sbi, struct dentry *dentry, | |||
| 263 | wq->tgid = current->tgid; | 299 | wq->tgid = current->tgid; | 
| 264 | wq->status = -EINTR; /* Status return if interrupted */ | 300 | wq->status = -EINTR; /* Status return if interrupted */ | 
| 265 | atomic_set(&wq->wait_ctr, 2); | 301 | atomic_set(&wq->wait_ctr, 2); | 
| 266 | atomic_set(&wq->notify, 1); | ||
| 267 | mutex_unlock(&sbi->wq_mutex); | ||
| 268 | } else { | ||
| 269 | atomic_inc(&wq->wait_ctr); | ||
| 270 | mutex_unlock(&sbi->wq_mutex); | 302 | mutex_unlock(&sbi->wq_mutex); | 
| 271 | kfree(name); | ||
| 272 | DPRINTK("existing wait id = 0x%08lx, name = %.*s, nfy=%d", | ||
| 273 | (unsigned long) wq->wait_queue_token, wq->len, wq->name, notify); | ||
| 274 | } | ||
| 275 | |||
| 276 | if (notify != NFY_NONE && atomic_read(&wq->notify)) { | ||
| 277 | int type; | ||
| 278 | |||
| 279 | atomic_dec(&wq->notify); | ||
| 280 | 303 | ||
| 281 | if (sbi->version < 5) { | 304 | if (sbi->version < 5) { | 
| 282 | if (notify == NFY_MOUNT) | 305 | if (notify == NFY_MOUNT) | 
| @@ -299,6 +322,12 @@ int autofs4_wait(struct autofs_sb_info *sbi, struct dentry *dentry, | |||
| 299 | 322 | ||
| 300 | /* autofs4_notify_daemon() may block */ | 323 | /* autofs4_notify_daemon() may block */ | 
| 301 | autofs4_notify_daemon(sbi, wq, type); | 324 | autofs4_notify_daemon(sbi, wq, type); | 
| 325 | } else { | ||
| 326 | atomic_inc(&wq->wait_ctr); | ||
| 327 | mutex_unlock(&sbi->wq_mutex); | ||
| 328 | kfree(name); | ||
| 329 | DPRINTK("existing wait id = 0x%08lx, name = %.*s, nfy=%d", | ||
| 330 | (unsigned long) wq->wait_queue_token, wq->len, wq->name, notify); | ||
| 302 | } | 331 | } | 
| 303 | 332 | ||
| 304 | /* wq->name is NULL if and only if the lock is already released */ | 333 | /* wq->name is NULL if and only if the lock is already released */ | 
| diff --git a/fs/compat.c b/fs/compat.c index 970888aad843..01f39f87f372 100644 --- a/fs/compat.c +++ b/fs/compat.c | |||
| @@ -1913,7 +1913,7 @@ asmlinkage long compat_sys_ppoll(struct pollfd __user *ufds, | |||
| 1913 | } | 1913 | } | 
| 1914 | 1914 | ||
| 1915 | if (sigmask) { | 1915 | if (sigmask) { | 
| 1916 | if (sigsetsize |= sizeof(compat_sigset_t)) | 1916 | if (sigsetsize != sizeof(compat_sigset_t)) | 
| 1917 | return -EINVAL; | 1917 | return -EINVAL; | 
| 1918 | if (copy_from_user(&ss32, sigmask, sizeof(ss32))) | 1918 | if (copy_from_user(&ss32, sigmask, sizeof(ss32))) | 
| 1919 | return -EFAULT; | 1919 | return -EFAULT; | 
| diff --git a/fs/configfs/dir.c b/fs/configfs/dir.c index 5638c8f9362f..5f952187fc53 100644 --- a/fs/configfs/dir.c +++ b/fs/configfs/dir.c | |||
| @@ -505,13 +505,15 @@ static int populate_groups(struct config_group *group) | |||
| 505 | int i; | 505 | int i; | 
| 506 | 506 | ||
| 507 | if (group->default_groups) { | 507 | if (group->default_groups) { | 
| 508 | /* FYI, we're faking mkdir here | 508 | /* | 
| 509 | * FYI, we're faking mkdir here | ||
| 509 | * I'm not sure we need this semaphore, as we're called | 510 | * I'm not sure we need this semaphore, as we're called | 
| 510 | * from our parent's mkdir. That holds our parent's | 511 | * from our parent's mkdir. That holds our parent's | 
| 511 | * i_mutex, so afaik lookup cannot continue through our | 512 | * i_mutex, so afaik lookup cannot continue through our | 
| 512 | * parent to find us, let alone mess with our tree. | 513 | * parent to find us, let alone mess with our tree. | 
| 513 | * That said, taking our i_mutex is closer to mkdir | 514 | * That said, taking our i_mutex is closer to mkdir | 
| 514 | * emulation, and shouldn't hurt. */ | 515 | * emulation, and shouldn't hurt. | 
| 516 | */ | ||
| 515 | mutex_lock(&dentry->d_inode->i_mutex); | 517 | mutex_lock(&dentry->d_inode->i_mutex); | 
| 516 | 518 | ||
| 517 | for (i = 0; group->default_groups[i]; i++) { | 519 | for (i = 0; group->default_groups[i]; i++) { | 
| @@ -546,20 +548,34 @@ static void unlink_obj(struct config_item *item) | |||
| 546 | 548 | ||
| 547 | item->ci_group = NULL; | 549 | item->ci_group = NULL; | 
| 548 | item->ci_parent = NULL; | 550 | item->ci_parent = NULL; | 
| 551 | |||
| 552 | /* Drop the reference for ci_entry */ | ||
| 549 | config_item_put(item); | 553 | config_item_put(item); | 
| 550 | 554 | ||
| 555 | /* Drop the reference for ci_parent */ | ||
| 551 | config_group_put(group); | 556 | config_group_put(group); | 
| 552 | } | 557 | } | 
| 553 | } | 558 | } | 
| 554 | 559 | ||
| 555 | static void link_obj(struct config_item *parent_item, struct config_item *item) | 560 | static void link_obj(struct config_item *parent_item, struct config_item *item) | 
| 556 | { | 561 | { | 
| 557 | /* Parent seems redundant with group, but it makes certain | 562 | /* | 
| 558 | * traversals much nicer. */ | 563 | * Parent seems redundant with group, but it makes certain | 
| 564 | * traversals much nicer. | ||
| 565 | */ | ||
| 559 | item->ci_parent = parent_item; | 566 | item->ci_parent = parent_item; | 
| 567 | |||
| 568 | /* | ||
| 569 | * We hold a reference on the parent for the child's ci_parent | ||
| 570 | * link. | ||
| 571 | */ | ||
| 560 | item->ci_group = config_group_get(to_config_group(parent_item)); | 572 | item->ci_group = config_group_get(to_config_group(parent_item)); | 
| 561 | list_add_tail(&item->ci_entry, &item->ci_group->cg_children); | 573 | list_add_tail(&item->ci_entry, &item->ci_group->cg_children); | 
| 562 | 574 | ||
| 575 | /* | ||
| 576 | * We hold a reference on the child for ci_entry on the parent's | ||
| 577 | * cg_children | ||
| 578 | */ | ||
| 563 | config_item_get(item); | 579 | config_item_get(item); | 
| 564 | } | 580 | } | 
| 565 | 581 | ||
| @@ -684,6 +700,10 @@ static void client_drop_item(struct config_item *parent_item, | |||
| 684 | type = parent_item->ci_type; | 700 | type = parent_item->ci_type; | 
| 685 | BUG_ON(!type); | 701 | BUG_ON(!type); | 
| 686 | 702 | ||
| 703 | /* | ||
| 704 | * If ->drop_item() exists, it is responsible for the | ||
| 705 | * config_item_put(). | ||
| 706 | */ | ||
| 687 | if (type->ct_group_ops && type->ct_group_ops->drop_item) | 707 | if (type->ct_group_ops && type->ct_group_ops->drop_item) | 
| 688 | type->ct_group_ops->drop_item(to_config_group(parent_item), | 708 | type->ct_group_ops->drop_item(to_config_group(parent_item), | 
| 689 | item); | 709 | item); | 
| @@ -694,23 +714,28 @@ static void client_drop_item(struct config_item *parent_item, | |||
| 694 | 714 | ||
| 695 | static int configfs_mkdir(struct inode *dir, struct dentry *dentry, int mode) | 715 | static int configfs_mkdir(struct inode *dir, struct dentry *dentry, int mode) | 
| 696 | { | 716 | { | 
| 697 | int ret; | 717 | int ret, module_got = 0; | 
| 698 | struct config_group *group; | 718 | struct config_group *group; | 
| 699 | struct config_item *item; | 719 | struct config_item *item; | 
| 700 | struct config_item *parent_item; | 720 | struct config_item *parent_item; | 
| 701 | struct configfs_subsystem *subsys; | 721 | struct configfs_subsystem *subsys; | 
| 702 | struct configfs_dirent *sd; | 722 | struct configfs_dirent *sd; | 
| 703 | struct config_item_type *type; | 723 | struct config_item_type *type; | 
| 704 | struct module *owner; | 724 | struct module *owner = NULL; | 
| 705 | char *name; | 725 | char *name; | 
| 706 | 726 | ||
| 707 | if (dentry->d_parent == configfs_sb->s_root) | 727 | if (dentry->d_parent == configfs_sb->s_root) { | 
| 708 | return -EPERM; | 728 | ret = -EPERM; | 
| 729 | goto out; | ||
| 730 | } | ||
| 709 | 731 | ||
| 710 | sd = dentry->d_parent->d_fsdata; | 732 | sd = dentry->d_parent->d_fsdata; | 
| 711 | if (!(sd->s_type & CONFIGFS_USET_DIR)) | 733 | if (!(sd->s_type & CONFIGFS_USET_DIR)) { | 
| 712 | return -EPERM; | 734 | ret = -EPERM; | 
| 735 | goto out; | ||
| 736 | } | ||
| 713 | 737 | ||
| 738 | /* Get a working ref for the duration of this function */ | ||
| 714 | parent_item = configfs_get_config_item(dentry->d_parent); | 739 | parent_item = configfs_get_config_item(dentry->d_parent); | 
| 715 | type = parent_item->ci_type; | 740 | type = parent_item->ci_type; | 
| 716 | subsys = to_config_group(parent_item)->cg_subsys; | 741 | subsys = to_config_group(parent_item)->cg_subsys; | 
| @@ -719,15 +744,16 @@ static int configfs_mkdir(struct inode *dir, struct dentry *dentry, int mode) | |||
| 719 | if (!type || !type->ct_group_ops || | 744 | if (!type || !type->ct_group_ops || | 
| 720 | (!type->ct_group_ops->make_group && | 745 | (!type->ct_group_ops->make_group && | 
| 721 | !type->ct_group_ops->make_item)) { | 746 | !type->ct_group_ops->make_item)) { | 
| 722 | config_item_put(parent_item); | 747 | ret = -EPERM; /* Lack-of-mkdir returns -EPERM */ | 
| 723 | return -EPERM; /* What lack-of-mkdir returns */ | 748 | goto out_put; | 
| 724 | } | 749 | } | 
| 725 | 750 | ||
| 726 | name = kmalloc(dentry->d_name.len + 1, GFP_KERNEL); | 751 | name = kmalloc(dentry->d_name.len + 1, GFP_KERNEL); | 
| 727 | if (!name) { | 752 | if (!name) { | 
| 728 | config_item_put(parent_item); | 753 | ret = -ENOMEM; | 
| 729 | return -ENOMEM; | 754 | goto out_put; | 
| 730 | } | 755 | } | 
| 756 | |||
| 731 | snprintf(name, dentry->d_name.len + 1, "%s", dentry->d_name.name); | 757 | snprintf(name, dentry->d_name.len + 1, "%s", dentry->d_name.name); | 
| 732 | 758 | ||
| 733 | down(&subsys->su_sem); | 759 | down(&subsys->su_sem); | 
| @@ -748,40 +774,67 @@ static int configfs_mkdir(struct inode *dir, struct dentry *dentry, int mode) | |||
| 748 | 774 | ||
| 749 | kfree(name); | 775 | kfree(name); | 
| 750 | if (!item) { | 776 | if (!item) { | 
| 751 | config_item_put(parent_item); | 777 | /* | 
| 752 | return -ENOMEM; | 778 | * If item == NULL, then link_obj() was never called. | 
| 779 | * There are no extra references to clean up. | ||
| 780 | */ | ||
| 781 | ret = -ENOMEM; | ||
| 782 | goto out_put; | ||
| 753 | } | 783 | } | 
| 754 | 784 | ||
| 755 | ret = -EINVAL; | 785 | /* | 
| 786 | * link_obj() has been called (via link_group() for groups). | ||
| 787 | * From here on out, errors must clean that up. | ||
| 788 | */ | ||
| 789 | |||
| 756 | type = item->ci_type; | 790 | type = item->ci_type; | 
| 757 | if (type) { | 791 | if (!type) { | 
| 758 | owner = type->ct_owner; | 792 | ret = -EINVAL; | 
| 759 | if (try_module_get(owner)) { | 793 | goto out_unlink; | 
| 760 | if (group) { | 794 | } | 
| 761 | ret = configfs_attach_group(parent_item, | ||
| 762 | item, | ||
| 763 | dentry); | ||
| 764 | } else { | ||
| 765 | ret = configfs_attach_item(parent_item, | ||
| 766 | item, | ||
| 767 | dentry); | ||
| 768 | } | ||
| 769 | 795 | ||
| 770 | if (ret) { | 796 | owner = type->ct_owner; | 
| 771 | down(&subsys->su_sem); | 797 | if (!try_module_get(owner)) { | 
| 772 | if (group) | 798 | ret = -EINVAL; | 
| 773 | unlink_group(group); | 799 | goto out_unlink; | 
| 774 | else | 800 | } | 
| 775 | unlink_obj(item); | ||
| 776 | client_drop_item(parent_item, item); | ||
| 777 | up(&subsys->su_sem); | ||
| 778 | 801 | ||
| 779 | config_item_put(parent_item); | 802 | /* | 
| 780 | module_put(owner); | 803 | * I hate doing it this way, but if there is | 
| 781 | } | 804 | * an error, module_put() probably should | 
| 782 | } | 805 | * happen after any cleanup. | 
| 806 | */ | ||
| 807 | module_got = 1; | ||
| 808 | |||
| 809 | if (group) | ||
| 810 | ret = configfs_attach_group(parent_item, item, dentry); | ||
| 811 | else | ||
| 812 | ret = configfs_attach_item(parent_item, item, dentry); | ||
| 813 | |||
| 814 | out_unlink: | ||
| 815 | if (ret) { | ||
| 816 | /* Tear down everything we built up */ | ||
| 817 | down(&subsys->su_sem); | ||
| 818 | if (group) | ||
| 819 | unlink_group(group); | ||
| 820 | else | ||
| 821 | unlink_obj(item); | ||
| 822 | client_drop_item(parent_item, item); | ||
| 823 | up(&subsys->su_sem); | ||
| 824 | |||
| 825 | if (module_got) | ||
| 826 | module_put(owner); | ||
| 783 | } | 827 | } | 
| 784 | 828 | ||
| 829 | out_put: | ||
| 830 | /* | ||
| 831 | * link_obj()/link_group() took a reference from child->parent, | ||
| 832 | * so the parent is safely pinned. We can drop our working | ||
| 833 | * reference. | ||
| 834 | */ | ||
| 835 | config_item_put(parent_item); | ||
| 836 | |||
| 837 | out: | ||
| 785 | return ret; | 838 | return ret; | 
| 786 | } | 839 | } | 
| 787 | 840 | ||
| @@ -801,6 +854,7 @@ static int configfs_rmdir(struct inode *dir, struct dentry *dentry) | |||
| 801 | if (sd->s_type & CONFIGFS_USET_DEFAULT) | 854 | if (sd->s_type & CONFIGFS_USET_DEFAULT) | 
| 802 | return -EPERM; | 855 | return -EPERM; | 
| 803 | 856 | ||
| 857 | /* Get a working ref until we have the child */ | ||
| 804 | parent_item = configfs_get_config_item(dentry->d_parent); | 858 | parent_item = configfs_get_config_item(dentry->d_parent); | 
| 805 | subsys = to_config_group(parent_item)->cg_subsys; | 859 | subsys = to_config_group(parent_item)->cg_subsys; | 
| 806 | BUG_ON(!subsys); | 860 | BUG_ON(!subsys); | 
| @@ -817,6 +871,7 @@ static int configfs_rmdir(struct inode *dir, struct dentry *dentry) | |||
| 817 | return ret; | 871 | return ret; | 
| 818 | } | 872 | } | 
| 819 | 873 | ||
| 874 | /* Get a working ref for the duration of this function */ | ||
| 820 | item = configfs_get_config_item(dentry); | 875 | item = configfs_get_config_item(dentry); | 
| 821 | 876 | ||
| 822 | /* Drop reference from above, item already holds one. */ | 877 | /* Drop reference from above, item already holds one. */ | 
| diff --git a/fs/jffs2/nodelist.c b/fs/jffs2/nodelist.c index d4d0c41490cd..1d46677afd17 100644 --- a/fs/jffs2/nodelist.c +++ b/fs/jffs2/nodelist.c | |||
| @@ -438,7 +438,8 @@ static int check_node_data(struct jffs2_sb_info *c, struct jffs2_tmp_dnode_info | |||
| 438 | if (c->mtd->point) { | 438 | if (c->mtd->point) { | 
| 439 | err = c->mtd->point(c->mtd, ofs, len, &retlen, &buffer); | 439 | err = c->mtd->point(c->mtd, ofs, len, &retlen, &buffer); | 
| 440 | if (!err && retlen < tn->csize) { | 440 | if (!err && retlen < tn->csize) { | 
| 441 | JFFS2_WARNING("MTD point returned len too short: %u instead of %u.\n", retlen, tn->csize); | 441 | JFFS2_WARNING("MTD point returned len too short: %zu " | 
| 442 | "instead of %u.\n", retlen, tn->csize); | ||
| 442 | c->mtd->unpoint(c->mtd, buffer, ofs, len); | 443 | c->mtd->unpoint(c->mtd, buffer, ofs, len); | 
| 443 | } else if (err) | 444 | } else if (err) | 
| 444 | JFFS2_WARNING("MTD point failed: error code %d.\n", err); | 445 | JFFS2_WARNING("MTD point failed: error code %d.\n", err); | 
| @@ -461,7 +462,8 @@ static int check_node_data(struct jffs2_sb_info *c, struct jffs2_tmp_dnode_info | |||
| 461 | } | 462 | } | 
| 462 | 463 | ||
| 463 | if (retlen != len) { | 464 | if (retlen != len) { | 
| 464 | JFFS2_ERROR("short read at %#08x: %d instead of %d.\n", ofs, retlen, len); | 465 | JFFS2_ERROR("short read at %#08x: %zd instead of %d.\n", | 
| 466 | ofs, retlen, len); | ||
| 465 | err = -EIO; | 467 | err = -EIO; | 
| 466 | goto free_out; | 468 | goto free_out; | 
| 467 | } | 469 | } | 
| diff --git a/fs/namespace.c b/fs/namespace.c index 2c5f1f80bdc2..bf478addb852 100644 --- a/fs/namespace.c +++ b/fs/namespace.c | |||
| @@ -899,13 +899,11 @@ static int do_change_type(struct nameidata *nd, int flag) | |||
| 899 | /* | 899 | /* | 
| 900 | * do loopback mount. | 900 | * do loopback mount. | 
| 901 | */ | 901 | */ | 
| 902 | static int do_loopback(struct nameidata *nd, char *old_name, unsigned long flags, int mnt_flags) | 902 | static int do_loopback(struct nameidata *nd, char *old_name, int recurse) | 
| 903 | { | 903 | { | 
| 904 | struct nameidata old_nd; | 904 | struct nameidata old_nd; | 
| 905 | struct vfsmount *mnt = NULL; | 905 | struct vfsmount *mnt = NULL; | 
| 906 | int recurse = flags & MS_REC; | ||
| 907 | int err = mount_is_safe(nd); | 906 | int err = mount_is_safe(nd); | 
| 908 | |||
| 909 | if (err) | 907 | if (err) | 
| 910 | return err; | 908 | return err; | 
| 911 | if (!old_name || !*old_name) | 909 | if (!old_name || !*old_name) | 
| @@ -939,7 +937,6 @@ static int do_loopback(struct nameidata *nd, char *old_name, unsigned long flags | |||
| 939 | spin_unlock(&vfsmount_lock); | 937 | spin_unlock(&vfsmount_lock); | 
| 940 | release_mounts(&umount_list); | 938 | release_mounts(&umount_list); | 
| 941 | } | 939 | } | 
| 942 | mnt->mnt_flags = mnt_flags; | ||
| 943 | 940 | ||
| 944 | out: | 941 | out: | 
| 945 | up_write(&namespace_sem); | 942 | up_write(&namespace_sem); | 
| @@ -1353,7 +1350,7 @@ long do_mount(char *dev_name, char *dir_name, char *type_page, | |||
| 1353 | retval = do_remount(&nd, flags & ~MS_REMOUNT, mnt_flags, | 1350 | retval = do_remount(&nd, flags & ~MS_REMOUNT, mnt_flags, | 
| 1354 | data_page); | 1351 | data_page); | 
| 1355 | else if (flags & MS_BIND) | 1352 | else if (flags & MS_BIND) | 
| 1356 | retval = do_loopback(&nd, dev_name, flags, mnt_flags); | 1353 | retval = do_loopback(&nd, dev_name, flags & MS_REC); | 
| 1357 | else if (flags & (MS_SHARED | MS_PRIVATE | MS_SLAVE | MS_UNBINDABLE)) | 1354 | else if (flags & (MS_SHARED | MS_PRIVATE | MS_SLAVE | MS_UNBINDABLE)) | 
| 1358 | retval = do_change_type(&nd, flags); | 1355 | retval = do_change_type(&nd, flags); | 
| 1359 | else if (flags & MS_MOVE) | 1356 | else if (flags & MS_MOVE) | 
| diff --git a/fs/ocfs2/aops.c b/fs/ocfs2/aops.c index 0d858d0b25be..47152bf9a7f2 100644 --- a/fs/ocfs2/aops.c +++ b/fs/ocfs2/aops.c | |||
| @@ -276,13 +276,29 @@ static int ocfs2_writepage(struct page *page, struct writeback_control *wbc) | |||
| 276 | return ret; | 276 | return ret; | 
| 277 | } | 277 | } | 
| 278 | 278 | ||
| 279 | /* This can also be called from ocfs2_write_zero_page() which has done | ||
| 280 | * it's own cluster locking. */ | ||
| 281 | int ocfs2_prepare_write_nolock(struct inode *inode, struct page *page, | ||
| 282 | unsigned from, unsigned to) | ||
| 283 | { | ||
| 284 | int ret; | ||
| 285 | |||
| 286 | down_read(&OCFS2_I(inode)->ip_alloc_sem); | ||
| 287 | |||
| 288 | ret = block_prepare_write(page, from, to, ocfs2_get_block); | ||
| 289 | |||
| 290 | up_read(&OCFS2_I(inode)->ip_alloc_sem); | ||
| 291 | |||
| 292 | return ret; | ||
| 293 | } | ||
| 294 | |||
| 279 | /* | 295 | /* | 
| 280 | * ocfs2_prepare_write() can be an outer-most ocfs2 call when it is called | 296 | * ocfs2_prepare_write() can be an outer-most ocfs2 call when it is called | 
| 281 | * from loopback. It must be able to perform its own locking around | 297 | * from loopback. It must be able to perform its own locking around | 
| 282 | * ocfs2_get_block(). | 298 | * ocfs2_get_block(). | 
| 283 | */ | 299 | */ | 
| 284 | int ocfs2_prepare_write(struct file *file, struct page *page, | 300 | static int ocfs2_prepare_write(struct file *file, struct page *page, | 
| 285 | unsigned from, unsigned to) | 301 | unsigned from, unsigned to) | 
| 286 | { | 302 | { | 
| 287 | struct inode *inode = page->mapping->host; | 303 | struct inode *inode = page->mapping->host; | 
| 288 | int ret; | 304 | int ret; | 
| @@ -295,11 +311,7 @@ int ocfs2_prepare_write(struct file *file, struct page *page, | |||
| 295 | goto out; | 311 | goto out; | 
| 296 | } | 312 | } | 
| 297 | 313 | ||
| 298 | down_read(&OCFS2_I(inode)->ip_alloc_sem); | 314 | ret = ocfs2_prepare_write_nolock(inode, page, from, to); | 
| 299 | |||
| 300 | ret = block_prepare_write(page, from, to, ocfs2_get_block); | ||
| 301 | |||
| 302 | up_read(&OCFS2_I(inode)->ip_alloc_sem); | ||
| 303 | 315 | ||
| 304 | ocfs2_meta_unlock(inode, 0); | 316 | ocfs2_meta_unlock(inode, 0); | 
| 305 | out: | 317 | out: | 
| @@ -625,11 +637,31 @@ static ssize_t ocfs2_direct_IO(int rw, | |||
| 625 | int ret; | 637 | int ret; | 
| 626 | 638 | ||
| 627 | mlog_entry_void(); | 639 | mlog_entry_void(); | 
| 640 | |||
| 641 | /* | ||
| 642 | * We get PR data locks even for O_DIRECT. This allows | ||
| 643 | * concurrent O_DIRECT I/O but doesn't let O_DIRECT with | ||
| 644 | * extending and buffered zeroing writes race. If they did | ||
| 645 | * race then the buffered zeroing could be written back after | ||
| 646 | * the O_DIRECT I/O. It's one thing to tell people not to mix | ||
| 647 | * buffered and O_DIRECT writes, but expecting them to | ||
| 648 | * understand that file extension is also an implicit buffered | ||
| 649 | * write is too much. By getting the PR we force writeback of | ||
| 650 | * the buffered zeroing before proceeding. | ||
| 651 | */ | ||
| 652 | ret = ocfs2_data_lock(inode, 0); | ||
| 653 | if (ret < 0) { | ||
| 654 | mlog_errno(ret); | ||
| 655 | goto out; | ||
| 656 | } | ||
| 657 | ocfs2_data_unlock(inode, 0); | ||
| 658 | |||
| 628 | ret = blockdev_direct_IO_no_locking(rw, iocb, inode, | 659 | ret = blockdev_direct_IO_no_locking(rw, iocb, inode, | 
| 629 | inode->i_sb->s_bdev, iov, offset, | 660 | inode->i_sb->s_bdev, iov, offset, | 
| 630 | nr_segs, | 661 | nr_segs, | 
| 631 | ocfs2_direct_IO_get_blocks, | 662 | ocfs2_direct_IO_get_blocks, | 
| 632 | ocfs2_dio_end_io); | 663 | ocfs2_dio_end_io); | 
| 664 | out: | ||
| 633 | mlog_exit(ret); | 665 | mlog_exit(ret); | 
| 634 | return ret; | 666 | return ret; | 
| 635 | } | 667 | } | 
| diff --git a/fs/ocfs2/aops.h b/fs/ocfs2/aops.h index d40456d509a0..e88c3f0b8fa9 100644 --- a/fs/ocfs2/aops.h +++ b/fs/ocfs2/aops.h | |||
| @@ -22,8 +22,8 @@ | |||
| 22 | #ifndef OCFS2_AOPS_H | 22 | #ifndef OCFS2_AOPS_H | 
| 23 | #define OCFS2_AOPS_H | 23 | #define OCFS2_AOPS_H | 
| 24 | 24 | ||
| 25 | int ocfs2_prepare_write(struct file *file, struct page *page, | 25 | int ocfs2_prepare_write_nolock(struct inode *inode, struct page *page, | 
| 26 | unsigned from, unsigned to); | 26 | unsigned from, unsigned to); | 
| 27 | 27 | ||
| 28 | struct ocfs2_journal_handle *ocfs2_start_walk_page_trans(struct inode *inode, | 28 | struct ocfs2_journal_handle *ocfs2_start_walk_page_trans(struct inode *inode, | 
| 29 | struct page *page, | 29 | struct page *page, | 
| diff --git a/fs/ocfs2/extent_map.c b/fs/ocfs2/extent_map.c index 4601fc256f11..1a5c69071df6 100644 --- a/fs/ocfs2/extent_map.c +++ b/fs/ocfs2/extent_map.c | |||
| @@ -569,7 +569,7 @@ static int ocfs2_extent_map_insert(struct inode *inode, | |||
| 569 | 569 | ||
| 570 | ret = -ENOMEM; | 570 | ret = -ENOMEM; | 
| 571 | ctxt.new_ent = kmem_cache_alloc(ocfs2_em_ent_cachep, | 571 | ctxt.new_ent = kmem_cache_alloc(ocfs2_em_ent_cachep, | 
| 572 | GFP_KERNEL); | 572 | GFP_NOFS); | 
| 573 | if (!ctxt.new_ent) { | 573 | if (!ctxt.new_ent) { | 
| 574 | mlog_errno(ret); | 574 | mlog_errno(ret); | 
| 575 | return ret; | 575 | return ret; | 
| @@ -583,14 +583,14 @@ static int ocfs2_extent_map_insert(struct inode *inode, | |||
| 583 | if (ctxt.need_left && !ctxt.left_ent) { | 583 | if (ctxt.need_left && !ctxt.left_ent) { | 
| 584 | ctxt.left_ent = | 584 | ctxt.left_ent = | 
| 585 | kmem_cache_alloc(ocfs2_em_ent_cachep, | 585 | kmem_cache_alloc(ocfs2_em_ent_cachep, | 
| 586 | GFP_KERNEL); | 586 | GFP_NOFS); | 
| 587 | if (!ctxt.left_ent) | 587 | if (!ctxt.left_ent) | 
| 588 | break; | 588 | break; | 
| 589 | } | 589 | } | 
| 590 | if (ctxt.need_right && !ctxt.right_ent) { | 590 | if (ctxt.need_right && !ctxt.right_ent) { | 
| 591 | ctxt.right_ent = | 591 | ctxt.right_ent = | 
| 592 | kmem_cache_alloc(ocfs2_em_ent_cachep, | 592 | kmem_cache_alloc(ocfs2_em_ent_cachep, | 
| 593 | GFP_KERNEL); | 593 | GFP_NOFS); | 
| 594 | if (!ctxt.right_ent) | 594 | if (!ctxt.right_ent) | 
| 595 | break; | 595 | break; | 
| 596 | } | 596 | } | 
| diff --git a/fs/ocfs2/file.c b/fs/ocfs2/file.c index 581eb451a41a..a9559c874530 100644 --- a/fs/ocfs2/file.c +++ b/fs/ocfs2/file.c | |||
| @@ -613,7 +613,8 @@ leave: | |||
| 613 | 613 | ||
| 614 | /* Some parts of this taken from generic_cont_expand, which turned out | 614 | /* Some parts of this taken from generic_cont_expand, which turned out | 
| 615 | * to be too fragile to do exactly what we need without us having to | 615 | * to be too fragile to do exactly what we need without us having to | 
| 616 | * worry about recursive locking in ->commit_write(). */ | 616 | * worry about recursive locking in ->prepare_write() and | 
| 617 | * ->commit_write(). */ | ||
| 617 | static int ocfs2_write_zero_page(struct inode *inode, | 618 | static int ocfs2_write_zero_page(struct inode *inode, | 
| 618 | u64 size) | 619 | u64 size) | 
| 619 | { | 620 | { | 
| @@ -641,7 +642,7 @@ static int ocfs2_write_zero_page(struct inode *inode, | |||
| 641 | goto out; | 642 | goto out; | 
| 642 | } | 643 | } | 
| 643 | 644 | ||
| 644 | ret = ocfs2_prepare_write(NULL, page, offset, offset); | 645 | ret = ocfs2_prepare_write_nolock(inode, page, offset, offset); | 
| 645 | if (ret < 0) { | 646 | if (ret < 0) { | 
| 646 | mlog_errno(ret); | 647 | mlog_errno(ret); | 
| 647 | goto out_unlock; | 648 | goto out_unlock; | 
| @@ -695,13 +696,26 @@ out: | |||
| 695 | return ret; | 696 | return ret; | 
| 696 | } | 697 | } | 
| 697 | 698 | ||
| 699 | /* | ||
| 700 | * A tail_to_skip value > 0 indicates that we're being called from | ||
| 701 | * ocfs2_file_aio_write(). This has the following implications: | ||
| 702 | * | ||
| 703 | * - we don't want to update i_size | ||
| 704 | * - di_bh will be NULL, which is fine because it's only used in the | ||
| 705 | * case where we want to update i_size. | ||
| 706 | * - ocfs2_zero_extend() will then only be filling the hole created | ||
| 707 | * between i_size and the start of the write. | ||
| 708 | */ | ||
| 698 | static int ocfs2_extend_file(struct inode *inode, | 709 | static int ocfs2_extend_file(struct inode *inode, | 
| 699 | struct buffer_head *di_bh, | 710 | struct buffer_head *di_bh, | 
| 700 | u64 new_i_size) | 711 | u64 new_i_size, | 
| 712 | size_t tail_to_skip) | ||
| 701 | { | 713 | { | 
| 702 | int ret = 0; | 714 | int ret = 0; | 
| 703 | u32 clusters_to_add; | 715 | u32 clusters_to_add; | 
| 704 | 716 | ||
| 717 | BUG_ON(!tail_to_skip && !di_bh); | ||
| 718 | |||
| 705 | /* setattr sometimes calls us like this. */ | 719 | /* setattr sometimes calls us like this. */ | 
| 706 | if (new_i_size == 0) | 720 | if (new_i_size == 0) | 
| 707 | goto out; | 721 | goto out; | 
| @@ -714,27 +728,44 @@ static int ocfs2_extend_file(struct inode *inode, | |||
| 714 | OCFS2_I(inode)->ip_clusters; | 728 | OCFS2_I(inode)->ip_clusters; | 
| 715 | 729 | ||
| 716 | if (clusters_to_add) { | 730 | if (clusters_to_add) { | 
| 717 | ret = ocfs2_extend_allocation(inode, clusters_to_add); | 731 | /* | 
| 732 | * protect the pages that ocfs2_zero_extend is going to | ||
| 733 | * be pulling into the page cache.. we do this before the | ||
| 734 | * metadata extend so that we don't get into the situation | ||
| 735 | * where we've extended the metadata but can't get the data | ||
| 736 | * lock to zero. | ||
| 737 | */ | ||
| 738 | ret = ocfs2_data_lock(inode, 1); | ||
| 718 | if (ret < 0) { | 739 | if (ret < 0) { | 
| 719 | mlog_errno(ret); | 740 | mlog_errno(ret); | 
| 720 | goto out; | 741 | goto out; | 
| 721 | } | 742 | } | 
| 722 | 743 | ||
| 723 | ret = ocfs2_zero_extend(inode, new_i_size); | 744 | ret = ocfs2_extend_allocation(inode, clusters_to_add); | 
| 724 | if (ret < 0) { | 745 | if (ret < 0) { | 
| 725 | mlog_errno(ret); | 746 | mlog_errno(ret); | 
| 726 | goto out; | 747 | goto out_unlock; | 
| 727 | } | 748 | } | 
| 728 | } | ||
| 729 | 749 | ||
| 730 | /* No allocation required, we just use this helper to | 750 | ret = ocfs2_zero_extend(inode, (u64)new_i_size - tail_to_skip); | 
| 731 | * do a trivial update of i_size. */ | 751 | if (ret < 0) { | 
| 732 | ret = ocfs2_simple_size_update(inode, di_bh, new_i_size); | 752 | mlog_errno(ret); | 
| 733 | if (ret < 0) { | 753 | goto out_unlock; | 
| 734 | mlog_errno(ret); | 754 | } | 
| 735 | goto out; | 755 | } | 
| 756 | |||
| 757 | if (!tail_to_skip) { | ||
| 758 | /* We're being called from ocfs2_setattr() which wants | ||
| 759 | * us to update i_size */ | ||
| 760 | ret = ocfs2_simple_size_update(inode, di_bh, new_i_size); | ||
| 761 | if (ret < 0) | ||
| 762 | mlog_errno(ret); | ||
| 736 | } | 763 | } | 
| 737 | 764 | ||
| 765 | out_unlock: | ||
| 766 | if (clusters_to_add) /* this is the only case in which we lock */ | ||
| 767 | ocfs2_data_unlock(inode, 1); | ||
| 768 | |||
| 738 | out: | 769 | out: | 
| 739 | return ret; | 770 | return ret; | 
| 740 | } | 771 | } | 
| @@ -793,7 +824,7 @@ int ocfs2_setattr(struct dentry *dentry, struct iattr *attr) | |||
| 793 | if (i_size_read(inode) > attr->ia_size) | 824 | if (i_size_read(inode) > attr->ia_size) | 
| 794 | status = ocfs2_truncate_file(inode, bh, attr->ia_size); | 825 | status = ocfs2_truncate_file(inode, bh, attr->ia_size); | 
| 795 | else | 826 | else | 
| 796 | status = ocfs2_extend_file(inode, bh, attr->ia_size); | 827 | status = ocfs2_extend_file(inode, bh, attr->ia_size, 0); | 
| 797 | if (status < 0) { | 828 | if (status < 0) { | 
| 798 | if (status != -ENOSPC) | 829 | if (status != -ENOSPC) | 
| 799 | mlog_errno(status); | 830 | mlog_errno(status); | 
| @@ -1049,21 +1080,12 @@ static ssize_t ocfs2_file_aio_write(struct kiocb *iocb, | |||
| 1049 | if (!clusters) | 1080 | if (!clusters) | 
| 1050 | break; | 1081 | break; | 
| 1051 | 1082 | ||
| 1052 | ret = ocfs2_extend_allocation(inode, clusters); | 1083 | ret = ocfs2_extend_file(inode, NULL, newsize, count); | 
| 1053 | if (ret < 0) { | 1084 | if (ret < 0) { | 
| 1054 | if (ret != -ENOSPC) | 1085 | if (ret != -ENOSPC) | 
| 1055 | mlog_errno(ret); | 1086 | mlog_errno(ret); | 
| 1056 | goto out; | 1087 | goto out; | 
| 1057 | } | 1088 | } | 
| 1058 | |||
| 1059 | /* Fill any holes which would've been created by this | ||
| 1060 | * write. If we're O_APPEND, this will wind up | ||
| 1061 | * (correctly) being a noop. */ | ||
| 1062 | ret = ocfs2_zero_extend(inode, (u64) newsize - count); | ||
| 1063 | if (ret < 0) { | ||
| 1064 | mlog_errno(ret); | ||
| 1065 | goto out; | ||
| 1066 | } | ||
| 1067 | break; | 1089 | break; | 
| 1068 | } | 1090 | } | 
| 1069 | 1091 | ||
| @@ -1146,6 +1168,22 @@ static ssize_t ocfs2_file_aio_read(struct kiocb *iocb, | |||
| 1146 | ocfs2_iocb_set_rw_locked(iocb); | 1168 | ocfs2_iocb_set_rw_locked(iocb); | 
| 1147 | } | 1169 | } | 
| 1148 | 1170 | ||
| 1171 | /* | ||
| 1172 | * We're fine letting folks race truncates and extending | ||
| 1173 | * writes with read across the cluster, just like they can | ||
| 1174 | * locally. Hence no rw_lock during read. | ||
| 1175 | * | ||
| 1176 | * Take and drop the meta data lock to update inode fields | ||
| 1177 | * like i_size. This allows the checks down below | ||
| 1178 | * generic_file_aio_read() a chance of actually working. | ||
| 1179 | */ | ||
| 1180 | ret = ocfs2_meta_lock(inode, NULL, NULL, 0); | ||
| 1181 | if (ret < 0) { | ||
| 1182 | mlog_errno(ret); | ||
| 1183 | goto bail; | ||
| 1184 | } | ||
| 1185 | ocfs2_meta_unlock(inode, 0); | ||
| 1186 | |||
| 1149 | ret = generic_file_aio_read(iocb, buf, count, iocb->ki_pos); | 1187 | ret = generic_file_aio_read(iocb, buf, count, iocb->ki_pos); | 
| 1150 | if (ret == -EINVAL) | 1188 | if (ret == -EINVAL) | 
| 1151 | mlog(ML_ERROR, "generic_file_aio_read returned -EINVAL\n"); | 1189 | mlog(ML_ERROR, "generic_file_aio_read returned -EINVAL\n"); | 
| diff --git a/fs/ocfs2/journal.c b/fs/ocfs2/journal.c index 6a610ae53583..eebc3cfa6be8 100644 --- a/fs/ocfs2/journal.c +++ b/fs/ocfs2/journal.c | |||
| @@ -117,7 +117,7 @@ struct ocfs2_journal_handle *ocfs2_alloc_handle(struct ocfs2_super *osb) | |||
| 117 | { | 117 | { | 
| 118 | struct ocfs2_journal_handle *retval = NULL; | 118 | struct ocfs2_journal_handle *retval = NULL; | 
| 119 | 119 | ||
| 120 | retval = kcalloc(1, sizeof(*retval), GFP_KERNEL); | 120 | retval = kcalloc(1, sizeof(*retval), GFP_NOFS); | 
| 121 | if (!retval) { | 121 | if (!retval) { | 
| 122 | mlog(ML_ERROR, "Failed to allocate memory for journal " | 122 | mlog(ML_ERROR, "Failed to allocate memory for journal " | 
| 123 | "handle!\n"); | 123 | "handle!\n"); | 
| @@ -870,9 +870,11 @@ static int ocfs2_force_read_journal(struct inode *inode) | |||
| 870 | if (p_blocks > CONCURRENT_JOURNAL_FILL) | 870 | if (p_blocks > CONCURRENT_JOURNAL_FILL) | 
| 871 | p_blocks = CONCURRENT_JOURNAL_FILL; | 871 | p_blocks = CONCURRENT_JOURNAL_FILL; | 
| 872 | 872 | ||
| 873 | /* We are reading journal data which should not | ||
| 874 | * be put in the uptodate cache */ | ||
| 873 | status = ocfs2_read_blocks(OCFS2_SB(inode->i_sb), | 875 | status = ocfs2_read_blocks(OCFS2_SB(inode->i_sb), | 
| 874 | p_blkno, p_blocks, bhs, 0, | 876 | p_blkno, p_blocks, bhs, 0, | 
| 875 | inode); | 877 | NULL); | 
| 876 | if (status < 0) { | 878 | if (status < 0) { | 
| 877 | mlog_errno(status); | 879 | mlog_errno(status); | 
| 878 | goto bail; | 880 | goto bail; | 
| @@ -982,7 +984,7 @@ static void ocfs2_queue_recovery_completion(struct ocfs2_journal *journal, | |||
| 982 | { | 984 | { | 
| 983 | struct ocfs2_la_recovery_item *item; | 985 | struct ocfs2_la_recovery_item *item; | 
| 984 | 986 | ||
| 985 | item = kmalloc(sizeof(struct ocfs2_la_recovery_item), GFP_KERNEL); | 987 | item = kmalloc(sizeof(struct ocfs2_la_recovery_item), GFP_NOFS); | 
| 986 | if (!item) { | 988 | if (!item) { | 
| 987 | /* Though we wish to avoid it, we are in fact safe in | 989 | /* Though we wish to avoid it, we are in fact safe in | 
| 988 | * skipping local alloc cleanup as fsck.ocfs2 is more | 990 | * skipping local alloc cleanup as fsck.ocfs2 is more | 
| diff --git a/fs/ocfs2/uptodate.c b/fs/ocfs2/uptodate.c index 04a684dfdd96..b8a00a793326 100644 --- a/fs/ocfs2/uptodate.c +++ b/fs/ocfs2/uptodate.c | |||
| @@ -337,7 +337,7 @@ static void __ocfs2_set_buffer_uptodate(struct ocfs2_inode_info *oi, | |||
| 337 | (unsigned long long)oi->ip_blkno, | 337 | (unsigned long long)oi->ip_blkno, | 
| 338 | (unsigned long long)block, expand_tree); | 338 | (unsigned long long)block, expand_tree); | 
| 339 | 339 | ||
| 340 | new = kmem_cache_alloc(ocfs2_uptodate_cachep, GFP_KERNEL); | 340 | new = kmem_cache_alloc(ocfs2_uptodate_cachep, GFP_NOFS); | 
| 341 | if (!new) { | 341 | if (!new) { | 
| 342 | mlog_errno(-ENOMEM); | 342 | mlog_errno(-ENOMEM); | 
| 343 | return; | 343 | return; | 
| @@ -349,7 +349,7 @@ static void __ocfs2_set_buffer_uptodate(struct ocfs2_inode_info *oi, | |||
| 349 | * has no way of tracking that. */ | 349 | * has no way of tracking that. */ | 
| 350 | for(i = 0; i < OCFS2_INODE_MAX_CACHE_ARRAY; i++) { | 350 | for(i = 0; i < OCFS2_INODE_MAX_CACHE_ARRAY; i++) { | 
| 351 | tree[i] = kmem_cache_alloc(ocfs2_uptodate_cachep, | 351 | tree[i] = kmem_cache_alloc(ocfs2_uptodate_cachep, | 
| 352 | GFP_KERNEL); | 352 | GFP_NOFS); | 
| 353 | if (!tree[i]) { | 353 | if (!tree[i]) { | 
| 354 | mlog_errno(-ENOMEM); | 354 | mlog_errno(-ENOMEM); | 
| 355 | goto out_free; | 355 | goto out_free; | 
| diff --git a/fs/ocfs2/vote.c b/fs/ocfs2/vote.c index 53049a204197..ee42765a8553 100644 --- a/fs/ocfs2/vote.c +++ b/fs/ocfs2/vote.c | |||
| @@ -586,7 +586,7 @@ static struct ocfs2_net_wait_ctxt *ocfs2_new_net_wait_ctxt(unsigned int response | |||
| 586 | { | 586 | { | 
| 587 | struct ocfs2_net_wait_ctxt *w; | 587 | struct ocfs2_net_wait_ctxt *w; | 
| 588 | 588 | ||
| 589 | w = kcalloc(1, sizeof(*w), GFP_KERNEL); | 589 | w = kcalloc(1, sizeof(*w), GFP_NOFS); | 
| 590 | if (!w) { | 590 | if (!w) { | 
| 591 | mlog_errno(-ENOMEM); | 591 | mlog_errno(-ENOMEM); | 
| 592 | goto bail; | 592 | goto bail; | 
| @@ -749,7 +749,7 @@ static struct ocfs2_vote_msg * ocfs2_new_vote_request(struct ocfs2_super *osb, | |||
| 749 | 749 | ||
| 750 | BUG_ON(!ocfs2_is_valid_vote_request(type)); | 750 | BUG_ON(!ocfs2_is_valid_vote_request(type)); | 
| 751 | 751 | ||
| 752 | request = kcalloc(1, sizeof(*request), GFP_KERNEL); | 752 | request = kcalloc(1, sizeof(*request), GFP_NOFS); | 
| 753 | if (!request) { | 753 | if (!request) { | 
| 754 | mlog_errno(-ENOMEM); | 754 | mlog_errno(-ENOMEM); | 
| 755 | } else { | 755 | } else { | 
| @@ -1129,7 +1129,7 @@ static int ocfs2_handle_vote_message(struct o2net_msg *msg, | |||
| 1129 | struct ocfs2_super *osb = data; | 1129 | struct ocfs2_super *osb = data; | 
| 1130 | struct ocfs2_vote_work *work; | 1130 | struct ocfs2_vote_work *work; | 
| 1131 | 1131 | ||
| 1132 | work = kmalloc(sizeof(struct ocfs2_vote_work), GFP_KERNEL); | 1132 | work = kmalloc(sizeof(struct ocfs2_vote_work), GFP_NOFS); | 
| 1133 | if (!work) { | 1133 | if (!work) { | 
| 1134 | status = -ENOMEM; | 1134 | status = -ENOMEM; | 
| 1135 | mlog_errno(status); | 1135 | mlog_errno(status); | 
| @@ -1124,7 +1124,6 @@ asmlinkage long sys_openat(int dfd, const char __user *filename, int flags, | |||
| 1124 | prevent_tail_call(ret); | 1124 | prevent_tail_call(ret); | 
| 1125 | return ret; | 1125 | return ret; | 
| 1126 | } | 1126 | } | 
| 1127 | EXPORT_SYMBOL_GPL(sys_openat); | ||
| 1128 | 1127 | ||
| 1129 | #ifndef __alpha__ | 1128 | #ifndef __alpha__ | 
| 1130 | 1129 | ||
| diff --git a/fs/smbfs/dir.c b/fs/smbfs/dir.c index 34c7a11d91f0..70d9c5a37f5a 100644 --- a/fs/smbfs/dir.c +++ b/fs/smbfs/dir.c | |||
| @@ -434,6 +434,11 @@ smb_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd) | |||
| 434 | if (dentry->d_name.len > SMB_MAXNAMELEN) | 434 | if (dentry->d_name.len > SMB_MAXNAMELEN) | 
| 435 | goto out; | 435 | goto out; | 
| 436 | 436 | ||
| 437 | /* Do not allow lookup of names with backslashes in */ | ||
| 438 | error = -EINVAL; | ||
| 439 | if (memchr(dentry->d_name.name, '\\', dentry->d_name.len)) | ||
| 440 | goto out; | ||
| 441 | |||
| 437 | lock_kernel(); | 442 | lock_kernel(); | 
| 438 | error = smb_proc_getattr(dentry, &finfo); | 443 | error = smb_proc_getattr(dentry, &finfo); | 
| 439 | #ifdef SMBFS_PARANOIA | 444 | #ifdef SMBFS_PARANOIA | 
| diff --git a/fs/smbfs/request.c b/fs/smbfs/request.c index c71c375863cc..c71dd2760d32 100644 --- a/fs/smbfs/request.c +++ b/fs/smbfs/request.c | |||
| @@ -339,9 +339,11 @@ int smb_add_request(struct smb_request *req) | |||
| 339 | /* | 339 | /* | 
| 340 | * On timeout or on interrupt we want to try and remove the | 340 | * On timeout or on interrupt we want to try and remove the | 
| 341 | * request from the recvq/xmitq. | 341 | * request from the recvq/xmitq. | 
| 342 | * First check if the request is still part of a queue. (May | ||
| 343 | * have been removed by some error condition) | ||
| 342 | */ | 344 | */ | 
| 343 | smb_lock_server(server); | 345 | smb_lock_server(server); | 
| 344 | if (!(req->rq_flags & SMB_REQ_RECEIVED)) { | 346 | if (!list_empty(&req->rq_queue)) { | 
| 345 | list_del_init(&req->rq_queue); | 347 | list_del_init(&req->rq_queue); | 
| 346 | smb_rput(req); | 348 | smb_rput(req); | 
| 347 | } | 349 | } | 
| diff --git a/include/asm-arm/arch-pxa/pxa2xx_spi.h b/include/asm-arm/arch-pxa/pxa2xx_spi.h new file mode 100644 index 000000000000..1e70908b816f --- /dev/null +++ b/include/asm-arm/arch-pxa/pxa2xx_spi.h | |||
| @@ -0,0 +1,68 @@ | |||
| 1 | /* | ||
| 2 | * Copyright (C) 2005 Stephen Street / StreetFire Sound Labs | ||
| 3 | * | ||
| 4 | * This program is free software; you can redistribute it and/or modify | ||
| 5 | * it under the terms of the GNU General Public License as published by | ||
| 6 | * the Free Software Foundation; either version 2 of the License, or | ||
| 7 | * (at your option) any later version. | ||
| 8 | * | ||
| 9 | * This program is distributed in the hope that it will be useful, | ||
| 10 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 11 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 12 | * GNU General Public License for more details. | ||
| 13 | * | ||
| 14 | * You should have received a copy of the GNU General Public License | ||
| 15 | * along with this program; if not, write to the Free Software | ||
| 16 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | ||
| 17 | */ | ||
| 18 | |||
| 19 | #ifndef PXA2XX_SPI_H_ | ||
| 20 | #define PXA2XX_SPI_H_ | ||
| 21 | |||
| 22 | #define PXA2XX_CS_ASSERT (0x01) | ||
| 23 | #define PXA2XX_CS_DEASSERT (0x02) | ||
| 24 | |||
| 25 | #if defined(CONFIG_PXA25x) | ||
| 26 | #define CLOCK_SPEED_HZ 3686400 | ||
| 27 | #define SSP1_SerClkDiv(x) (((CLOCK_SPEED_HZ/2/(x+1))<<8)&0x0000ff00) | ||
| 28 | #define SSP2_SerClkDiv(x) (((CLOCK_SPEED_HZ/(x+1))<<8)&0x000fff00) | ||
| 29 | #define SSP3_SerClkDiv(x) (((CLOCK_SPEED_HZ/(x+1))<<8)&0x000fff00) | ||
| 30 | #elif defined(CONFIG_PXA27x) | ||
| 31 | #define CLOCK_SPEED_HZ 13000000 | ||
| 32 | #define SSP1_SerClkDiv(x) (((CLOCK_SPEED_HZ/(x+1))<<8)&0x000fff00) | ||
| 33 | #define SSP2_SerClkDiv(x) (((CLOCK_SPEED_HZ/(x+1))<<8)&0x000fff00) | ||
| 34 | #define SSP3_SerClkDiv(x) (((CLOCK_SPEED_HZ/(x+1))<<8)&0x000fff00) | ||
| 35 | #endif | ||
| 36 | |||
| 37 | #define SSP1_VIRT ((void *)(io_p2v(__PREG(SSCR0_P(1))))) | ||
| 38 | #define SSP2_VIRT ((void *)(io_p2v(__PREG(SSCR0_P(2))))) | ||
| 39 | #define SSP3_VIRT ((void *)(io_p2v(__PREG(SSCR0_P(3))))) | ||
| 40 | |||
| 41 | enum pxa_ssp_type { | ||
| 42 | SSP_UNDEFINED = 0, | ||
| 43 | PXA25x_SSP, /* pxa 210, 250, 255, 26x */ | ||
| 44 | PXA25x_NSSP, /* pxa 255, 26x (including ASSP) */ | ||
| 45 | PXA27x_SSP, | ||
| 46 | }; | ||
| 47 | |||
| 48 | /* device.platform_data for SSP controller devices */ | ||
| 49 | struct pxa2xx_spi_master { | ||
| 50 | enum pxa_ssp_type ssp_type; | ||
| 51 | u32 clock_enable; | ||
| 52 | u16 num_chipselect; | ||
| 53 | u8 enable_dma; | ||
| 54 | }; | ||
| 55 | |||
| 56 | /* spi_board_info.controller_data for SPI slave devices, | ||
| 57 | * copied to spi_device.platform_data ... mostly for dma tuning | ||
| 58 | */ | ||
| 59 | struct pxa2xx_spi_chip { | ||
| 60 | u8 tx_threshold; | ||
| 61 | u8 rx_threshold; | ||
| 62 | u8 dma_burst_size; | ||
| 63 | u32 timeout_microsecs; | ||
| 64 | u8 enable_loopback; | ||
| 65 | void (*cs_control)(u32 command); | ||
| 66 | }; | ||
| 67 | |||
| 68 | #endif /*PXA2XX_SPI_H_*/ | ||
| diff --git a/include/asm-arm/procinfo.h b/include/asm-arm/procinfo.h index a9c75b2c314f..842526055225 100644 --- a/include/asm-arm/procinfo.h +++ b/include/asm-arm/procinfo.h | |||
| @@ -45,8 +45,6 @@ extern unsigned int elf_hwcap; | |||
| 45 | 45 | ||
| 46 | #endif /* __ASSEMBLY__ */ | 46 | #endif /* __ASSEMBLY__ */ | 
| 47 | 47 | ||
| 48 | #define PROC_INFO_SZ 48 | ||
| 49 | |||
| 50 | #define HWCAP_SWP 1 | 48 | #define HWCAP_SWP 1 | 
| 51 | #define HWCAP_HALF 2 | 49 | #define HWCAP_HALF 2 | 
| 52 | #define HWCAP_THUMB 4 | 50 | #define HWCAP_THUMB 4 | 
| diff --git a/include/asm-arm/spinlock.h b/include/asm-arm/spinlock.h index 43ad4e55878c..406ca97a8ab2 100644 --- a/include/asm-arm/spinlock.h +++ b/include/asm-arm/spinlock.h | |||
| @@ -142,6 +142,9 @@ static inline void __raw_write_unlock(raw_rwlock_t *rw) | |||
| 142 | : "cc"); | 142 | : "cc"); | 
| 143 | } | 143 | } | 
| 144 | 144 | ||
| 145 | /* write_can_lock - would write_trylock() succeed? */ | ||
| 146 | #define __raw_write_can_lock(x) ((x)->lock == 0x80000000) | ||
| 147 | |||
| 145 | /* | 148 | /* | 
| 146 | * Read locks are a bit more hairy: | 149 | * Read locks are a bit more hairy: | 
| 147 | * - Exclusively load the lock value. | 150 | * - Exclusively load the lock value. | 
| @@ -198,4 +201,7 @@ static inline void __raw_read_unlock(raw_rwlock_t *rw) | |||
| 198 | 201 | ||
| 199 | #define __raw_read_trylock(lock) generic__raw_read_trylock(lock) | 202 | #define __raw_read_trylock(lock) generic__raw_read_trylock(lock) | 
| 200 | 203 | ||
| 204 | /* read_can_lock - would read_trylock() succeed? */ | ||
| 205 | #define __raw_read_can_lock(x) ((x)->lock < 0x80000000) | ||
| 206 | |||
| 201 | #endif /* __ASM_SPINLOCK_H */ | 207 | #endif /* __ASM_SPINLOCK_H */ | 
| diff --git a/include/asm-s390/unistd.h b/include/asm-s390/unistd.h index 657d582e8149..41c2792ff6b0 100644 --- a/include/asm-s390/unistd.h +++ b/include/asm-s390/unistd.h | |||
| @@ -296,8 +296,14 @@ | |||
| 296 | #define __NR_pselect6 301 | 296 | #define __NR_pselect6 301 | 
| 297 | #define __NR_ppoll 302 | 297 | #define __NR_ppoll 302 | 
| 298 | #define __NR_unshare 303 | 298 | #define __NR_unshare 303 | 
| 299 | #define __NR_set_robust_list 304 | ||
| 300 | #define __NR_get_robust_list 305 | ||
| 301 | #define __NR_splice 306 | ||
| 302 | #define __NR_sync_file_range 307 | ||
| 303 | #define __NR_tee 308 | ||
| 304 | #define __NR_vmsplice 309 | ||
| 299 | 305 | ||
| 300 | #define NR_syscalls 304 | 306 | #define NR_syscalls 310 | 
| 301 | 307 | ||
| 302 | /* | 308 | /* | 
| 303 | * There are some system calls that are not present on 64 bit, some | 309 | * There are some system calls that are not present on 64 bit, some | 
| diff --git a/include/linux/kernel.h b/include/linux/kernel.h index e1bd0842f6a1..f4fc576ed4c4 100644 --- a/include/linux/kernel.h +++ b/include/linux/kernel.h | |||
| @@ -124,6 +124,7 @@ extern int get_option(char **str, int *pint); | |||
| 124 | extern char *get_options(const char *str, int nints, int *ints); | 124 | extern char *get_options(const char *str, int nints, int *ints); | 
| 125 | extern unsigned long long memparse(char *ptr, char **retptr); | 125 | extern unsigned long long memparse(char *ptr, char **retptr); | 
| 126 | 126 | ||
| 127 | extern int core_kernel_text(unsigned long addr); | ||
| 127 | extern int __kernel_text_address(unsigned long addr); | 128 | extern int __kernel_text_address(unsigned long addr); | 
| 128 | extern int kernel_text_address(unsigned long addr); | 129 | extern int kernel_text_address(unsigned long addr); | 
| 129 | extern int session_of_pgrp(int pgrp); | 130 | extern int session_of_pgrp(int pgrp); | 
| diff --git a/include/linux/mmc/mmc.h b/include/linux/mmc/mmc.h index bdc556d88498..03a14a30c46a 100644 --- a/include/linux/mmc/mmc.h +++ b/include/linux/mmc/mmc.h | |||
| @@ -69,6 +69,7 @@ struct mmc_data { | |||
| 69 | unsigned int timeout_ns; /* data timeout (in ns, max 80ms) */ | 69 | unsigned int timeout_ns; /* data timeout (in ns, max 80ms) */ | 
| 70 | unsigned int timeout_clks; /* data timeout (in clocks) */ | 70 | unsigned int timeout_clks; /* data timeout (in clocks) */ | 
| 71 | unsigned int blksz_bits; /* data block size */ | 71 | unsigned int blksz_bits; /* data block size */ | 
| 72 | unsigned int blksz; /* data block size */ | ||
| 72 | unsigned int blocks; /* number of blocks */ | 73 | unsigned int blocks; /* number of blocks */ | 
| 73 | unsigned int error; /* data error */ | 74 | unsigned int error; /* data error */ | 
| 74 | unsigned int flags; | 75 | unsigned int flags; | 
| diff --git a/include/linux/rcupdate.h b/include/linux/rcupdate.h index 5673008b61e1..970284f571a6 100644 --- a/include/linux/rcupdate.h +++ b/include/linux/rcupdate.h | |||
| @@ -132,6 +132,7 @@ static inline void rcu_bh_qsctr_inc(int cpu) | |||
| 132 | } | 132 | } | 
| 133 | 133 | ||
| 134 | extern int rcu_pending(int cpu); | 134 | extern int rcu_pending(int cpu); | 
| 135 | extern int rcu_needs_cpu(int cpu); | ||
| 135 | 136 | ||
| 136 | /** | 137 | /** | 
| 137 | * rcu_read_lock - mark the beginning of an RCU read-side critical section. | 138 | * rcu_read_lock - mark the beginning of an RCU read-side critical section. | 
| diff --git a/include/linux/slab.h b/include/linux/slab.h index 3af03b19c983..2d985d59c7b8 100644 --- a/include/linux/slab.h +++ b/include/linux/slab.h | |||
| @@ -150,6 +150,7 @@ static inline void *kcalloc(size_t n, size_t size, gfp_t flags) | |||
| 150 | 150 | ||
| 151 | extern void kfree(const void *); | 151 | extern void kfree(const void *); | 
| 152 | extern unsigned int ksize(const void *); | 152 | extern unsigned int ksize(const void *); | 
| 153 | extern int slab_is_available(void); | ||
| 153 | 154 | ||
| 154 | #ifdef CONFIG_NUMA | 155 | #ifdef CONFIG_NUMA | 
| 155 | extern void *kmem_cache_alloc_node(kmem_cache_t *, gfp_t flags, int node); | 156 | extern void *kmem_cache_alloc_node(kmem_cache_t *, gfp_t flags, int node); | 
| diff --git a/include/linux/spi/spi.h b/include/linux/spi/spi.h index b05f1463a267..e928c0dcc297 100644 --- a/include/linux/spi/spi.h +++ b/include/linux/spi/spi.h | |||
| @@ -31,18 +31,23 @@ extern struct bus_type spi_bus_type; | |||
| 31 | * @master: SPI controller used with the device. | 31 | * @master: SPI controller used with the device. | 
| 32 | * @max_speed_hz: Maximum clock rate to be used with this chip | 32 | * @max_speed_hz: Maximum clock rate to be used with this chip | 
| 33 | * (on this board); may be changed by the device's driver. | 33 | * (on this board); may be changed by the device's driver. | 
| 34 | * The spi_transfer.speed_hz can override this for each transfer. | ||
| 34 | * @chip-select: Chipselect, distinguishing chips handled by "master". | 35 | * @chip-select: Chipselect, distinguishing chips handled by "master". | 
| 35 | * @mode: The spi mode defines how data is clocked out and in. | 36 | * @mode: The spi mode defines how data is clocked out and in. | 
| 36 | * This may be changed by the device's driver. | 37 | * This may be changed by the device's driver. | 
| 38 | * The "active low" default for chipselect mode can be overridden, | ||
| 39 | * as can the "MSB first" default for each word in a transfer. | ||
| 37 | * @bits_per_word: Data transfers involve one or more words; word sizes | 40 | * @bits_per_word: Data transfers involve one or more words; word sizes | 
| 38 | * like eight or 12 bits are common. In-memory wordsizes are | 41 | * like eight or 12 bits are common. In-memory wordsizes are | 
| 39 | * powers of two bytes (e.g. 20 bit samples use 32 bits). | 42 | * powers of two bytes (e.g. 20 bit samples use 32 bits). | 
| 40 | * This may be changed by the device's driver. | 43 | * This may be changed by the device's driver, or left at the | 
| 44 | * default (0) indicating protocol words are eight bit bytes. | ||
| 45 | * The spi_transfer.bits_per_word can override this for each transfer. | ||
| 41 | * @irq: Negative, or the number passed to request_irq() to receive | 46 | * @irq: Negative, or the number passed to request_irq() to receive | 
| 42 | * interrupts from this device. | 47 | * interrupts from this device. | 
| 43 | * @controller_state: Controller's runtime state | 48 | * @controller_state: Controller's runtime state | 
| 44 | * @controller_data: Board-specific definitions for controller, such as | 49 | * @controller_data: Board-specific definitions for controller, such as | 
| 45 | * FIFO initialization parameters; from board_info.controller_data | 50 | * FIFO initialization parameters; from board_info.controller_data | 
| 46 | * | 51 | * | 
| 47 | * An spi_device is used to interchange data between an SPI slave | 52 | * An spi_device is used to interchange data between an SPI slave | 
| 48 | * (usually a discrete chip) and CPU memory. | 53 | * (usually a discrete chip) and CPU memory. | 
| @@ -65,6 +70,7 @@ struct spi_device { | |||
| 65 | #define SPI_MODE_2 (SPI_CPOL|0) | 70 | #define SPI_MODE_2 (SPI_CPOL|0) | 
| 66 | #define SPI_MODE_3 (SPI_CPOL|SPI_CPHA) | 71 | #define SPI_MODE_3 (SPI_CPOL|SPI_CPHA) | 
| 67 | #define SPI_CS_HIGH 0x04 /* chipselect active high? */ | 72 | #define SPI_CS_HIGH 0x04 /* chipselect active high? */ | 
| 73 | #define SPI_LSB_FIRST 0x08 /* per-word bits-on-wire */ | ||
| 68 | u8 bits_per_word; | 74 | u8 bits_per_word; | 
| 69 | int irq; | 75 | int irq; | 
| 70 | void *controller_state; | 76 | void *controller_state; | 
| @@ -73,7 +79,6 @@ struct spi_device { | |||
| 73 | 79 | ||
| 74 | // likely need more hooks for more protocol options affecting how | 80 | // likely need more hooks for more protocol options affecting how | 
| 75 | // the controller talks to each chip, like: | 81 | // the controller talks to each chip, like: | 
| 76 | // - bit order (default is wordwise msb-first) | ||
| 77 | // - memory packing (12 bit samples into low bits, others zeroed) | 82 | // - memory packing (12 bit samples into low bits, others zeroed) | 
| 78 | // - priority | 83 | // - priority | 
| 79 | // - drop chipselect after each word | 84 | // - drop chipselect after each word | 
| @@ -143,13 +148,13 @@ static inline void spi_unregister_driver(struct spi_driver *sdrv) | |||
| 143 | * struct spi_master - interface to SPI master controller | 148 | * struct spi_master - interface to SPI master controller | 
| 144 | * @cdev: class interface to this driver | 149 | * @cdev: class interface to this driver | 
| 145 | * @bus_num: board-specific (and often SOC-specific) identifier for a | 150 | * @bus_num: board-specific (and often SOC-specific) identifier for a | 
| 146 | * given SPI controller. | 151 | * given SPI controller. | 
| 147 | * @num_chipselect: chipselects are used to distinguish individual | 152 | * @num_chipselect: chipselects are used to distinguish individual | 
| 148 | * SPI slaves, and are numbered from zero to num_chipselects. | 153 | * SPI slaves, and are numbered from zero to num_chipselects. | 
| 149 | * each slave has a chipselect signal, but it's common that not | 154 | * each slave has a chipselect signal, but it's common that not | 
| 150 | * every chipselect is connected to a slave. | 155 | * every chipselect is connected to a slave. | 
| 151 | * @setup: updates the device mode and clocking records used by a | 156 | * @setup: updates the device mode and clocking records used by a | 
| 152 | * device's SPI controller; protocol code may call this. | 157 | * device's SPI controller; protocol code may call this. | 
| 153 | * @transfer: adds a message to the controller's transfer queue. | 158 | * @transfer: adds a message to the controller's transfer queue. | 
| 154 | * @cleanup: frees controller-specific state | 159 | * @cleanup: frees controller-specific state | 
| 155 | * | 160 | * | 
| @@ -167,13 +172,13 @@ static inline void spi_unregister_driver(struct spi_driver *sdrv) | |||
| 167 | struct spi_master { | 172 | struct spi_master { | 
| 168 | struct class_device cdev; | 173 | struct class_device cdev; | 
| 169 | 174 | ||
| 170 | /* other than zero (== assign one dynamically), bus_num is fully | 175 | /* other than negative (== assign one dynamically), bus_num is fully | 
| 171 | * board-specific. usually that simplifies to being SOC-specific. | 176 | * board-specific. usually that simplifies to being SOC-specific. | 
| 172 | * example: one SOC has three SPI controllers, numbered 1..3, | 177 | * example: one SOC has three SPI controllers, numbered 0..2, | 
| 173 | * and one board's schematics might show it using SPI-2. software | 178 | * and one board's schematics might show it using SPI-2. software | 
| 174 | * would normally use bus_num=2 for that controller. | 179 | * would normally use bus_num=2 for that controller. | 
| 175 | */ | 180 | */ | 
| 176 | u16 bus_num; | 181 | s16 bus_num; | 
| 177 | 182 | ||
| 178 | /* chipselects will be integral to many controllers; some others | 183 | /* chipselects will be integral to many controllers; some others | 
| 179 | * might use board-specific GPIOs. | 184 | * might use board-specific GPIOs. | 
| @@ -268,10 +273,14 @@ extern struct spi_master *spi_busnum_to_master(u16 busnum); | |||
| 268 | * @tx_dma: DMA address of tx_buf, if spi_message.is_dma_mapped | 273 | * @tx_dma: DMA address of tx_buf, if spi_message.is_dma_mapped | 
| 269 | * @rx_dma: DMA address of rx_buf, if spi_message.is_dma_mapped | 274 | * @rx_dma: DMA address of rx_buf, if spi_message.is_dma_mapped | 
| 270 | * @len: size of rx and tx buffers (in bytes) | 275 | * @len: size of rx and tx buffers (in bytes) | 
| 276 | * @speed_hz: Select a speed other then the device default for this | ||
| 277 | * transfer. If 0 the default (from spi_device) is used. | ||
| 278 | * @bits_per_word: select a bits_per_word other then the device default | ||
| 279 | * for this transfer. If 0 the default (from spi_device) is used. | ||
| 271 | * @cs_change: affects chipselect after this transfer completes | 280 | * @cs_change: affects chipselect after this transfer completes | 
| 272 | * @delay_usecs: microseconds to delay after this transfer before | 281 | * @delay_usecs: microseconds to delay after this transfer before | 
| 273 | * (optionally) changing the chipselect status, then starting | 282 | * (optionally) changing the chipselect status, then starting | 
| 274 | * the next transfer or completing this spi_message. | 283 | * the next transfer or completing this spi_message. | 
| 275 | * @transfer_list: transfers are sequenced through spi_message.transfers | 284 | * @transfer_list: transfers are sequenced through spi_message.transfers | 
| 276 | * | 285 | * | 
| 277 | * SPI transfers always write the same number of bytes as they read. | 286 | * SPI transfers always write the same number of bytes as they read. | 
| @@ -322,7 +331,9 @@ struct spi_transfer { | |||
| 322 | dma_addr_t rx_dma; | 331 | dma_addr_t rx_dma; | 
| 323 | 332 | ||
| 324 | unsigned cs_change:1; | 333 | unsigned cs_change:1; | 
| 334 | u8 bits_per_word; | ||
| 325 | u16 delay_usecs; | 335 | u16 delay_usecs; | 
| 336 | u32 speed_hz; | ||
| 326 | 337 | ||
| 327 | struct list_head transfer_list; | 338 | struct list_head transfer_list; | 
| 328 | }; | 339 | }; | 
| @@ -356,7 +367,7 @@ struct spi_transfer { | |||
| 356 | * and its transfers, ignore them until its completion callback. | 367 | * and its transfers, ignore them until its completion callback. | 
| 357 | */ | 368 | */ | 
| 358 | struct spi_message { | 369 | struct spi_message { | 
| 359 | struct list_head transfers; | 370 | struct list_head transfers; | 
| 360 | 371 | ||
| 361 | struct spi_device *spi; | 372 | struct spi_device *spi; | 
| 362 | 373 | ||
| @@ -374,7 +385,7 @@ struct spi_message { | |||
| 374 | */ | 385 | */ | 
| 375 | 386 | ||
| 376 | /* completion is reported through a callback */ | 387 | /* completion is reported through a callback */ | 
| 377 | void (*complete)(void *context); | 388 | void (*complete)(void *context); | 
| 378 | void *context; | 389 | void *context; | 
| 379 | unsigned actual_length; | 390 | unsigned actual_length; | 
| 380 | int status; | 391 | int status; | 
| diff --git a/include/linux/spi/spi_bitbang.h b/include/linux/spi/spi_bitbang.h index c961fe9bf3eb..16ce178f54d7 100644 --- a/include/linux/spi/spi_bitbang.h +++ b/include/linux/spi/spi_bitbang.h | |||
| @@ -30,6 +30,12 @@ struct spi_bitbang { | |||
| 30 | 30 | ||
| 31 | struct spi_master *master; | 31 | struct spi_master *master; | 
| 32 | 32 | ||
| 33 | /* setup_transfer() changes clock and/or wordsize to match settings | ||
| 34 | * for this transfer; zeroes restore defaults from spi_device. | ||
| 35 | */ | ||
| 36 | int (*setup_transfer)(struct spi_device *spi, | ||
| 37 | struct spi_transfer *t); | ||
| 38 | |||
| 33 | void (*chipselect)(struct spi_device *spi, int is_on); | 39 | void (*chipselect)(struct spi_device *spi, int is_on); | 
| 34 | #define BITBANG_CS_ACTIVE 1 /* normally nCS, active low */ | 40 | #define BITBANG_CS_ACTIVE 1 /* normally nCS, active low */ | 
| 35 | #define BITBANG_CS_INACTIVE 0 | 41 | #define BITBANG_CS_INACTIVE 0 | 
| @@ -51,6 +57,8 @@ struct spi_bitbang { | |||
| 51 | extern int spi_bitbang_setup(struct spi_device *spi); | 57 | extern int spi_bitbang_setup(struct spi_device *spi); | 
| 52 | extern void spi_bitbang_cleanup(const struct spi_device *spi); | 58 | extern void spi_bitbang_cleanup(const struct spi_device *spi); | 
| 53 | extern int spi_bitbang_transfer(struct spi_device *spi, struct spi_message *m); | 59 | extern int spi_bitbang_transfer(struct spi_device *spi, struct spi_message *m); | 
| 60 | extern int spi_bitbang_setup_transfer(struct spi_device *spi, | ||
| 61 | struct spi_transfer *t); | ||
| 54 | 62 | ||
| 55 | /* start or stop queue processing */ | 63 | /* start or stop queue processing */ | 
| 56 | extern int spi_bitbang_start(struct spi_bitbang *spi); | 64 | extern int spi_bitbang_start(struct spi_bitbang *spi); | 
| diff --git a/include/linux/swap.h b/include/linux/swap.h index 5b1fdf1cff4f..f03c24719302 100644 --- a/include/linux/swap.h +++ b/include/linux/swap.h | |||
| @@ -296,7 +296,7 @@ static inline void disable_swap_token(void) | |||
| 296 | #define read_swap_cache_async(swp,vma,addr) NULL | 296 | #define read_swap_cache_async(swp,vma,addr) NULL | 
| 297 | #define lookup_swap_cache(swp) NULL | 297 | #define lookup_swap_cache(swp) NULL | 
| 298 | #define valid_swaphandles(swp, off) 0 | 298 | #define valid_swaphandles(swp, off) 0 | 
| 299 | #define can_share_swap_page(p) 0 | 299 | #define can_share_swap_page(p) (page_mapcount(p) == 1) | 
| 300 | #define move_to_swap_cache(p, swp) 1 | 300 | #define move_to_swap_cache(p, swp) 1 | 
| 301 | #define move_from_swap_cache(p, i, m) 1 | 301 | #define move_from_swap_cache(p, i, m) 1 | 
| 302 | #define __delete_from_swap_cache(p) /*NOTHING*/ | 302 | #define __delete_from_swap_cache(p) /*NOTHING*/ | 
| diff --git a/include/net/sctp/command.h b/include/net/sctp/command.h index 34a1a09e5aef..807d6f1ef4b5 100644 --- a/include/net/sctp/command.h +++ b/include/net/sctp/command.h | |||
| @@ -99,6 +99,7 @@ typedef enum { | |||
| 99 | SCTP_CMD_DEL_NON_PRIMARY, /* Removes non-primary peer transports. */ | 99 | SCTP_CMD_DEL_NON_PRIMARY, /* Removes non-primary peer transports. */ | 
| 100 | SCTP_CMD_T3_RTX_TIMERS_STOP, /* Stops T3-rtx pending timers */ | 100 | SCTP_CMD_T3_RTX_TIMERS_STOP, /* Stops T3-rtx pending timers */ | 
| 101 | SCTP_CMD_FORCE_PRIM_RETRAN, /* Forces retrans. over primary path. */ | 101 | SCTP_CMD_FORCE_PRIM_RETRAN, /* Forces retrans. over primary path. */ | 
| 102 | SCTP_CMD_SET_SK_ERR, /* Set sk_err */ | ||
| 102 | SCTP_CMD_LAST | 103 | SCTP_CMD_LAST | 
| 103 | } sctp_verb_t; | 104 | } sctp_verb_t; | 
| 104 | 105 | ||
| diff --git a/include/net/sctp/sctp.h b/include/net/sctp/sctp.h index e673b2c984e9..aa6033ca7cd8 100644 --- a/include/net/sctp/sctp.h +++ b/include/net/sctp/sctp.h | |||
| @@ -461,12 +461,12 @@ static inline int sctp_frag_point(const struct sctp_sock *sp, int pmtu) | |||
| 461 | * there is room for a param header too. | 461 | * there is room for a param header too. | 
| 462 | */ | 462 | */ | 
| 463 | #define sctp_walk_params(pos, chunk, member)\ | 463 | #define sctp_walk_params(pos, chunk, member)\ | 
| 464 | _sctp_walk_params((pos), (chunk), WORD_ROUND(ntohs((chunk)->chunk_hdr.length)), member) | 464 | _sctp_walk_params((pos), (chunk), ntohs((chunk)->chunk_hdr.length), member) | 
| 465 | 465 | ||
| 466 | #define _sctp_walk_params(pos, chunk, end, member)\ | 466 | #define _sctp_walk_params(pos, chunk, end, member)\ | 
| 467 | for (pos.v = chunk->member;\ | 467 | for (pos.v = chunk->member;\ | 
| 468 | pos.v <= (void *)chunk + end - sizeof(sctp_paramhdr_t) &&\ | 468 | pos.v <= (void *)chunk + end - sizeof(sctp_paramhdr_t) &&\ | 
| 469 | pos.v <= (void *)chunk + end - WORD_ROUND(ntohs(pos.p->length)) &&\ | 469 | pos.v <= (void *)chunk + end - ntohs(pos.p->length) &&\ | 
| 470 | ntohs(pos.p->length) >= sizeof(sctp_paramhdr_t);\ | 470 | ntohs(pos.p->length) >= sizeof(sctp_paramhdr_t);\ | 
| 471 | pos.v += WORD_ROUND(ntohs(pos.p->length))) | 471 | pos.v += WORD_ROUND(ntohs(pos.p->length))) | 
| 472 | 472 | ||
| @@ -477,7 +477,7 @@ _sctp_walk_errors((err), (chunk_hdr), ntohs((chunk_hdr)->length)) | |||
| 477 | for (err = (sctp_errhdr_t *)((void *)chunk_hdr + \ | 477 | for (err = (sctp_errhdr_t *)((void *)chunk_hdr + \ | 
| 478 | sizeof(sctp_chunkhdr_t));\ | 478 | sizeof(sctp_chunkhdr_t));\ | 
| 479 | (void *)err <= (void *)chunk_hdr + end - sizeof(sctp_errhdr_t) &&\ | 479 | (void *)err <= (void *)chunk_hdr + end - sizeof(sctp_errhdr_t) &&\ | 
| 480 | (void *)err <= (void *)chunk_hdr + end - WORD_ROUND(ntohs(err->length)) &&\ | 480 | (void *)err <= (void *)chunk_hdr + end - ntohs(err->length) &&\ | 
| 481 | ntohs(err->length) >= sizeof(sctp_errhdr_t); \ | 481 | ntohs(err->length) >= sizeof(sctp_errhdr_t); \ | 
| 482 | err = (sctp_errhdr_t *)((void *)err + WORD_ROUND(ntohs(err->length)))) | 482 | err = (sctp_errhdr_t *)((void *)err + WORD_ROUND(ntohs(err->length)))) | 
| 483 | 483 | ||
| diff --git a/init/do_mounts.c b/init/do_mounts.c index adb7cad3e6ee..f4b7b9d278cd 100644 --- a/init/do_mounts.c +++ b/init/do_mounts.c | |||
| @@ -310,6 +310,11 @@ retry: | |||
| 310 | 310 | ||
| 311 | panic("VFS: Unable to mount root fs on %s", b); | 311 | panic("VFS: Unable to mount root fs on %s", b); | 
| 312 | } | 312 | } | 
| 313 | |||
| 314 | printk("No filesystem could mount root, tried: "); | ||
| 315 | for (p = fs_names; *p; p += strlen(p)+1) | ||
| 316 | printk(" %s", p); | ||
| 317 | printk("\n"); | ||
| 313 | panic("VFS: Unable to mount root fs on %s", __bdevname(ROOT_DEV, b)); | 318 | panic("VFS: Unable to mount root fs on %s", __bdevname(ROOT_DEV, b)); | 
| 314 | out: | 319 | out: | 
| 315 | putname(fs_names); | 320 | putname(fs_names); | 
| diff --git a/init/initramfs.c b/init/initramfs.c index 679d870d991b..f81cfa40a719 100644 --- a/init/initramfs.c +++ b/init/initramfs.c | |||
| @@ -26,10 +26,12 @@ static void __init free(void *where) | |||
| 26 | 26 | ||
| 27 | /* link hash */ | 27 | /* link hash */ | 
| 28 | 28 | ||
| 29 | #define N_ALIGN(len) ((((len) + 1) & ~3) + 2) | ||
| 30 | |||
| 29 | static __initdata struct hash { | 31 | static __initdata struct hash { | 
| 30 | int ino, minor, major; | 32 | int ino, minor, major; | 
| 31 | struct hash *next; | 33 | struct hash *next; | 
| 32 | char *name; | 34 | char name[N_ALIGN(PATH_MAX)]; | 
| 33 | } *head[32]; | 35 | } *head[32]; | 
| 34 | 36 | ||
| 35 | static inline int hash(int major, int minor, int ino) | 37 | static inline int hash(int major, int minor, int ino) | 
| @@ -57,7 +59,7 @@ static char __init *find_link(int major, int minor, int ino, char *name) | |||
| 57 | q->ino = ino; | 59 | q->ino = ino; | 
| 58 | q->minor = minor; | 60 | q->minor = minor; | 
| 59 | q->major = major; | 61 | q->major = major; | 
| 60 | q->name = name; | 62 | strcpy(q->name, name); | 
| 61 | q->next = NULL; | 63 | q->next = NULL; | 
| 62 | *p = q; | 64 | *p = q; | 
| 63 | return NULL; | 65 | return NULL; | 
| @@ -133,8 +135,6 @@ static inline void eat(unsigned n) | |||
| 133 | count -= n; | 135 | count -= n; | 
| 134 | } | 136 | } | 
| 135 | 137 | ||
| 136 | #define N_ALIGN(len) ((((len) + 1) & ~3) + 2) | ||
| 137 | |||
| 138 | static __initdata char *collected; | 138 | static __initdata char *collected; | 
| 139 | static __initdata int remains; | 139 | static __initdata int remains; | 
| 140 | static __initdata char *collect; | 140 | static __initdata char *collect; | 
| diff --git a/kernel/extable.c b/kernel/extable.c index 7501b531ceed..7fe262855317 100644 --- a/kernel/extable.c +++ b/kernel/extable.c | |||
| @@ -40,7 +40,7 @@ const struct exception_table_entry *search_exception_tables(unsigned long addr) | |||
| 40 | return e; | 40 | return e; | 
| 41 | } | 41 | } | 
| 42 | 42 | ||
| 43 | static int core_kernel_text(unsigned long addr) | 43 | int core_kernel_text(unsigned long addr) | 
| 44 | { | 44 | { | 
| 45 | if (addr >= (unsigned long)_stext && | 45 | if (addr >= (unsigned long)_stext && | 
| 46 | addr <= (unsigned long)_etext) | 46 | addr <= (unsigned long)_etext) | 
| diff --git a/kernel/module.c b/kernel/module.c index d24deb0dbbc9..bbe04862e1b0 100644 --- a/kernel/module.c +++ b/kernel/module.c | |||
| @@ -705,14 +705,14 @@ EXPORT_SYMBOL(__symbol_put); | |||
| 705 | 705 | ||
| 706 | void symbol_put_addr(void *addr) | 706 | void symbol_put_addr(void *addr) | 
| 707 | { | 707 | { | 
| 708 | unsigned long flags; | 708 | struct module *modaddr; | 
| 709 | 709 | ||
| 710 | spin_lock_irqsave(&modlist_lock, flags); | 710 | if (core_kernel_text((unsigned long)addr)) | 
| 711 | if (!kernel_text_address((unsigned long)addr)) | 711 | return; | 
| 712 | BUG(); | ||
| 713 | 712 | ||
| 714 | module_put(module_text_address((unsigned long)addr)); | 713 | if (!(modaddr = module_text_address((unsigned long)addr))) | 
| 715 | spin_unlock_irqrestore(&modlist_lock, flags); | 714 | BUG(); | 
| 715 | module_put(modaddr); | ||
| 716 | } | 716 | } | 
| 717 | EXPORT_SYMBOL_GPL(symbol_put_addr); | 717 | EXPORT_SYMBOL_GPL(symbol_put_addr); | 
| 718 | 718 | ||
| diff --git a/kernel/rcupdate.c b/kernel/rcupdate.c index 6d32ff26f948..2058f88c7bbb 100644 --- a/kernel/rcupdate.c +++ b/kernel/rcupdate.c | |||
| @@ -479,12 +479,31 @@ static int __rcu_pending(struct rcu_ctrlblk *rcp, struct rcu_data *rdp) | |||
| 479 | return 0; | 479 | return 0; | 
| 480 | } | 480 | } | 
| 481 | 481 | ||
| 482 | /* | ||
| 483 | * Check to see if there is any immediate RCU-related work to be done | ||
| 484 | * by the current CPU, returning 1 if so. This function is part of the | ||
| 485 | * RCU implementation; it is -not- an exported member of the RCU API. | ||
| 486 | */ | ||
| 482 | int rcu_pending(int cpu) | 487 | int rcu_pending(int cpu) | 
| 483 | { | 488 | { | 
| 484 | return __rcu_pending(&rcu_ctrlblk, &per_cpu(rcu_data, cpu)) || | 489 | return __rcu_pending(&rcu_ctrlblk, &per_cpu(rcu_data, cpu)) || | 
| 485 | __rcu_pending(&rcu_bh_ctrlblk, &per_cpu(rcu_bh_data, cpu)); | 490 | __rcu_pending(&rcu_bh_ctrlblk, &per_cpu(rcu_bh_data, cpu)); | 
| 486 | } | 491 | } | 
| 487 | 492 | ||
| 493 | /* | ||
| 494 | * Check to see if any future RCU-related work will need to be done | ||
| 495 | * by the current CPU, even if none need be done immediately, returning | ||
| 496 | * 1 if so. This function is part of the RCU implementation; it is -not- | ||
| 497 | * an exported member of the RCU API. | ||
| 498 | */ | ||
| 499 | int rcu_needs_cpu(int cpu) | ||
| 500 | { | ||
| 501 | struct rcu_data *rdp = &per_cpu(rcu_data, cpu); | ||
| 502 | struct rcu_data *rdp_bh = &per_cpu(rcu_bh_data, cpu); | ||
| 503 | |||
| 504 | return (!!rdp->curlist || !!rdp_bh->curlist || rcu_pending(cpu)); | ||
| 505 | } | ||
| 506 | |||
| 488 | void rcu_check_callbacks(int cpu, int user) | 507 | void rcu_check_callbacks(int cpu, int user) | 
| 489 | { | 508 | { | 
| 490 | if (user || | 509 | if (user || | 
| diff --git a/mm/page_alloc.c b/mm/page_alloc.c index ea77c999047e..813b4ec1298a 100644 --- a/mm/page_alloc.c +++ b/mm/page_alloc.c | |||
| @@ -39,6 +39,7 @@ | |||
| 39 | #include <linux/mempolicy.h> | 39 | #include <linux/mempolicy.h> | 
| 40 | 40 | ||
| 41 | #include <asm/tlbflush.h> | 41 | #include <asm/tlbflush.h> | 
| 42 | #include <asm/div64.h> | ||
| 42 | #include "internal.h" | 43 | #include "internal.h" | 
| 43 | 44 | ||
| 44 | /* | 45 | /* | 
| @@ -2566,9 +2567,11 @@ void setup_per_zone_pages_min(void) | |||
| 2566 | } | 2567 | } | 
| 2567 | 2568 | ||
| 2568 | for_each_zone(zone) { | 2569 | for_each_zone(zone) { | 
| 2569 | unsigned long tmp; | 2570 | u64 tmp; | 
| 2571 | |||
| 2570 | spin_lock_irqsave(&zone->lru_lock, flags); | 2572 | spin_lock_irqsave(&zone->lru_lock, flags); | 
| 2571 | tmp = (pages_min * zone->present_pages) / lowmem_pages; | 2573 | tmp = (u64)pages_min * zone->present_pages; | 
| 2574 | do_div(tmp, lowmem_pages); | ||
| 2572 | if (is_highmem(zone)) { | 2575 | if (is_highmem(zone)) { | 
| 2573 | /* | 2576 | /* | 
| 2574 | * __GFP_HIGH and PF_MEMALLOC allocations usually don't | 2577 | * __GFP_HIGH and PF_MEMALLOC allocations usually don't | 
| @@ -2595,8 +2598,8 @@ void setup_per_zone_pages_min(void) | |||
| 2595 | zone->pages_min = tmp; | 2598 | zone->pages_min = tmp; | 
| 2596 | } | 2599 | } | 
| 2597 | 2600 | ||
| 2598 | zone->pages_low = zone->pages_min + tmp / 4; | 2601 | zone->pages_low = zone->pages_min + (tmp >> 2); | 
| 2599 | zone->pages_high = zone->pages_min + tmp / 2; | 2602 | zone->pages_high = zone->pages_min + (tmp >> 1); | 
| 2600 | spin_unlock_irqrestore(&zone->lru_lock, flags); | 2603 | spin_unlock_irqrestore(&zone->lru_lock, flags); | 
| 2601 | } | 2604 | } | 
| 2602 | 2605 | ||
| @@ -700,6 +700,14 @@ static enum { | |||
| 700 | FULL | 700 | FULL | 
| 701 | } g_cpucache_up; | 701 | } g_cpucache_up; | 
| 702 | 702 | ||
| 703 | /* | ||
| 704 | * used by boot code to determine if it can use slab based allocator | ||
| 705 | */ | ||
| 706 | int slab_is_available(void) | ||
| 707 | { | ||
| 708 | return g_cpucache_up == FULL; | ||
| 709 | } | ||
| 710 | |||
| 703 | static DEFINE_PER_CPU(struct work_struct, reap_work); | 711 | static DEFINE_PER_CPU(struct work_struct, reap_work); | 
| 704 | 712 | ||
| 705 | static void free_block(struct kmem_cache *cachep, void **objpp, int len, | 713 | static void free_block(struct kmem_cache *cachep, void **objpp, int len, | 
| @@ -2192,11 +2200,14 @@ static void drain_cpu_caches(struct kmem_cache *cachep) | |||
| 2192 | check_irq_on(); | 2200 | check_irq_on(); | 
| 2193 | for_each_online_node(node) { | 2201 | for_each_online_node(node) { | 
| 2194 | l3 = cachep->nodelists[node]; | 2202 | l3 = cachep->nodelists[node]; | 
| 2195 | if (l3) { | 2203 | if (l3 && l3->alien) | 
| 2204 | drain_alien_cache(cachep, l3->alien); | ||
| 2205 | } | ||
| 2206 | |||
| 2207 | for_each_online_node(node) { | ||
| 2208 | l3 = cachep->nodelists[node]; | ||
| 2209 | if (l3) | ||
| 2196 | drain_array(cachep, l3, l3->shared, 1, node); | 2210 | drain_array(cachep, l3, l3->shared, 1, node); | 
| 2197 | if (l3->alien) | ||
| 2198 | drain_alien_cache(cachep, l3->alien); | ||
| 2199 | } | ||
| 2200 | } | 2211 | } | 
| 2201 | } | 2212 | } | 
| 2202 | 2213 | ||
| diff --git a/mm/sparse.c b/mm/sparse.c index d7c32de99ee8..c5e89eb9ac8f 100644 --- a/mm/sparse.c +++ b/mm/sparse.c | |||
| @@ -32,7 +32,7 @@ static struct mem_section *sparse_index_alloc(int nid) | |||
| 32 | unsigned long array_size = SECTIONS_PER_ROOT * | 32 | unsigned long array_size = SECTIONS_PER_ROOT * | 
| 33 | sizeof(struct mem_section); | 33 | sizeof(struct mem_section); | 
| 34 | 34 | ||
| 35 | if (system_state == SYSTEM_RUNNING) | 35 | if (slab_is_available()) | 
| 36 | section = kmalloc_node(array_size, GFP_KERNEL, nid); | 36 | section = kmalloc_node(array_size, GFP_KERNEL, nid); | 
| 37 | else | 37 | else | 
| 38 | section = alloc_bootmem_node(NODE_DATA(nid), array_size); | 38 | section = alloc_bootmem_node(NODE_DATA(nid), array_size); | 
| diff --git a/net/802/tr.c b/net/802/tr.c index afd8385c0c9c..e9dc803f2fe0 100644 --- a/net/802/tr.c +++ b/net/802/tr.c | |||
| @@ -643,6 +643,5 @@ static int __init rif_init(void) | |||
| 643 | 643 | ||
| 644 | module_init(rif_init); | 644 | module_init(rif_init); | 
| 645 | 645 | ||
| 646 | EXPORT_SYMBOL(tr_source_route); | ||
| 647 | EXPORT_SYMBOL(tr_type_trans); | 646 | EXPORT_SYMBOL(tr_type_trans); | 
| 648 | EXPORT_SYMBOL(alloc_trdev); | 647 | EXPORT_SYMBOL(alloc_trdev); | 
| diff --git a/net/bridge/netfilter/ebt_log.c b/net/bridge/netfilter/ebt_log.c index d159c92cca84..466ed3440b74 100644 --- a/net/bridge/netfilter/ebt_log.c +++ b/net/bridge/netfilter/ebt_log.c | |||
| @@ -168,7 +168,7 @@ static void ebt_log(const struct sk_buff *skb, unsigned int hooknr, | |||
| 168 | 168 | ||
| 169 | if (info->bitmask & EBT_LOG_NFLOG) | 169 | if (info->bitmask & EBT_LOG_NFLOG) | 
| 170 | nf_log_packet(PF_BRIDGE, hooknr, skb, in, out, &li, | 170 | nf_log_packet(PF_BRIDGE, hooknr, skb, in, out, &li, | 
| 171 | info->prefix); | 171 | "%s", info->prefix); | 
| 172 | else | 172 | else | 
| 173 | ebt_log_packet(PF_BRIDGE, hooknr, skb, in, out, &li, | 173 | ebt_log_packet(PF_BRIDGE, hooknr, skb, in, out, &li, | 
| 174 | info->prefix); | 174 | info->prefix); | 
| diff --git a/net/ipv4/netfilter/arp_tables.c b/net/ipv4/netfilter/arp_tables.c index c2d92f99a2b8..d0d19192026d 100644 --- a/net/ipv4/netfilter/arp_tables.c +++ b/net/ipv4/netfilter/arp_tables.c | |||
| @@ -948,7 +948,7 @@ static int do_add_counters(void __user *user, unsigned int len) | |||
| 948 | 948 | ||
| 949 | write_lock_bh(&t->lock); | 949 | write_lock_bh(&t->lock); | 
| 950 | private = t->private; | 950 | private = t->private; | 
| 951 | if (private->number != paddc->num_counters) { | 951 | if (private->number != tmp.num_counters) { | 
| 952 | ret = -EINVAL; | 952 | ret = -EINVAL; | 
| 953 | goto unlock_up_free; | 953 | goto unlock_up_free; | 
| 954 | } | 954 | } | 
| diff --git a/net/ipv4/netfilter/ip_nat_proto_gre.c b/net/ipv4/netfilter/ip_nat_proto_gre.c index 6c4899d8046a..96ceabaec402 100644 --- a/net/ipv4/netfilter/ip_nat_proto_gre.c +++ b/net/ipv4/netfilter/ip_nat_proto_gre.c | |||
| @@ -49,15 +49,15 @@ gre_in_range(const struct ip_conntrack_tuple *tuple, | |||
| 49 | const union ip_conntrack_manip_proto *min, | 49 | const union ip_conntrack_manip_proto *min, | 
| 50 | const union ip_conntrack_manip_proto *max) | 50 | const union ip_conntrack_manip_proto *max) | 
| 51 | { | 51 | { | 
| 52 | u_int32_t key; | 52 | __be16 key; | 
| 53 | 53 | ||
| 54 | if (maniptype == IP_NAT_MANIP_SRC) | 54 | if (maniptype == IP_NAT_MANIP_SRC) | 
| 55 | key = tuple->src.u.gre.key; | 55 | key = tuple->src.u.gre.key; | 
| 56 | else | 56 | else | 
| 57 | key = tuple->dst.u.gre.key; | 57 | key = tuple->dst.u.gre.key; | 
| 58 | 58 | ||
| 59 | return ntohl(key) >= ntohl(min->gre.key) | 59 | return ntohs(key) >= ntohs(min->gre.key) | 
| 60 | && ntohl(key) <= ntohl(max->gre.key); | 60 | && ntohs(key) <= ntohs(max->gre.key); | 
| 61 | } | 61 | } | 
| 62 | 62 | ||
| 63 | /* generate unique tuple ... */ | 63 | /* generate unique tuple ... */ | 
| @@ -81,14 +81,14 @@ gre_unique_tuple(struct ip_conntrack_tuple *tuple, | |||
| 81 | min = 1; | 81 | min = 1; | 
| 82 | range_size = 0xffff; | 82 | range_size = 0xffff; | 
| 83 | } else { | 83 | } else { | 
| 84 | min = ntohl(range->min.gre.key); | 84 | min = ntohs(range->min.gre.key); | 
| 85 | range_size = ntohl(range->max.gre.key) - min + 1; | 85 | range_size = ntohs(range->max.gre.key) - min + 1; | 
| 86 | } | 86 | } | 
| 87 | 87 | ||
| 88 | DEBUGP("min = %u, range_size = %u\n", min, range_size); | 88 | DEBUGP("min = %u, range_size = %u\n", min, range_size); | 
| 89 | 89 | ||
| 90 | for (i = 0; i < range_size; i++, key++) { | 90 | for (i = 0; i < range_size; i++, key++) { | 
| 91 | *keyptr = htonl(min + key % range_size); | 91 | *keyptr = htons(min + key % range_size); | 
| 92 | if (!ip_nat_used_tuple(tuple, conntrack)) | 92 | if (!ip_nat_used_tuple(tuple, conntrack)) | 
| 93 | return 1; | 93 | return 1; | 
| 94 | } | 94 | } | 
| diff --git a/net/ipv4/netfilter/ipt_LOG.c b/net/ipv4/netfilter/ipt_LOG.c index 39fd4c2a2386..b98f7b08b084 100644 --- a/net/ipv4/netfilter/ipt_LOG.c +++ b/net/ipv4/netfilter/ipt_LOG.c | |||
| @@ -428,7 +428,7 @@ ipt_log_target(struct sk_buff **pskb, | |||
| 428 | 428 | ||
| 429 | if (loginfo->logflags & IPT_LOG_NFLOG) | 429 | if (loginfo->logflags & IPT_LOG_NFLOG) | 
| 430 | nf_log_packet(PF_INET, hooknum, *pskb, in, out, &li, | 430 | nf_log_packet(PF_INET, hooknum, *pskb, in, out, &li, | 
| 431 | loginfo->prefix); | 431 | "%s", loginfo->prefix); | 
| 432 | else | 432 | else | 
| 433 | ipt_log_packet(PF_INET, hooknum, *pskb, in, out, &li, | 433 | ipt_log_packet(PF_INET, hooknum, *pskb, in, out, &li, | 
| 434 | loginfo->prefix); | 434 | loginfo->prefix); | 
| diff --git a/net/ipv4/netfilter/ipt_recent.c b/net/ipv4/netfilter/ipt_recent.c index 143843285702..b847ee409efb 100644 --- a/net/ipv4/netfilter/ipt_recent.c +++ b/net/ipv4/netfilter/ipt_recent.c | |||
| @@ -821,6 +821,7 @@ checkentry(const char *tablename, | |||
| 821 | /* Create our proc 'status' entry. */ | 821 | /* Create our proc 'status' entry. */ | 
| 822 | curr_table->status_proc = create_proc_entry(curr_table->name, ip_list_perms, proc_net_ipt_recent); | 822 | curr_table->status_proc = create_proc_entry(curr_table->name, ip_list_perms, proc_net_ipt_recent); | 
| 823 | if (!curr_table->status_proc) { | 823 | if (!curr_table->status_proc) { | 
| 824 | vfree(hold); | ||
| 824 | printk(KERN_INFO RECENT_NAME ": checkentry: unable to allocate for /proc entry.\n"); | 825 | printk(KERN_INFO RECENT_NAME ": checkentry: unable to allocate for /proc entry.\n"); | 
| 825 | /* Destroy the created table */ | 826 | /* Destroy the created table */ | 
| 826 | spin_lock_bh(&recent_lock); | 827 | spin_lock_bh(&recent_lock); | 
| @@ -845,7 +846,6 @@ checkentry(const char *tablename, | |||
| 845 | spin_unlock_bh(&recent_lock); | 846 | spin_unlock_bh(&recent_lock); | 
| 846 | vfree(curr_table->time_info); | 847 | vfree(curr_table->time_info); | 
| 847 | vfree(curr_table->hash_table); | 848 | vfree(curr_table->hash_table); | 
| 848 | vfree(hold); | ||
| 849 | vfree(curr_table->table); | 849 | vfree(curr_table->table); | 
| 850 | vfree(curr_table); | 850 | vfree(curr_table); | 
| 851 | return 0; | 851 | return 0; | 
| diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c index 9f0cca4c4fae..4a538bc1683d 100644 --- a/net/ipv4/tcp_input.c +++ b/net/ipv4/tcp_input.c | |||
| @@ -1662,6 +1662,8 @@ static void tcp_update_scoreboard(struct sock *sk, struct tcp_sock *tp) | |||
| 1662 | if (!(TCP_SKB_CB(skb)->sacked&TCPCB_TAGBITS)) { | 1662 | if (!(TCP_SKB_CB(skb)->sacked&TCPCB_TAGBITS)) { | 
| 1663 | TCP_SKB_CB(skb)->sacked |= TCPCB_LOST; | 1663 | TCP_SKB_CB(skb)->sacked |= TCPCB_LOST; | 
| 1664 | tp->lost_out += tcp_skb_pcount(skb); | 1664 | tp->lost_out += tcp_skb_pcount(skb); | 
| 1665 | if (IsReno(tp)) | ||
| 1666 | tcp_remove_reno_sacks(sk, tp, tcp_skb_pcount(skb) + 1); | ||
| 1665 | 1667 | ||
| 1666 | /* clear xmit_retrans hint */ | 1668 | /* clear xmit_retrans hint */ | 
| 1667 | if (tp->retransmit_skb_hint && | 1669 | if (tp->retransmit_skb_hint && | 
| diff --git a/net/ipv6/netfilter/ip6_tables.c b/net/ipv6/netfilter/ip6_tables.c index 0a673038344f..2e72f89a7019 100644 --- a/net/ipv6/netfilter/ip6_tables.c +++ b/net/ipv6/netfilter/ip6_tables.c | |||
| @@ -1103,7 +1103,7 @@ do_add_counters(void __user *user, unsigned int len) | |||
| 1103 | 1103 | ||
| 1104 | write_lock_bh(&t->lock); | 1104 | write_lock_bh(&t->lock); | 
| 1105 | private = t->private; | 1105 | private = t->private; | 
| 1106 | if (private->number != paddc->num_counters) { | 1106 | if (private->number != tmp.num_counters) { | 
| 1107 | ret = -EINVAL; | 1107 | ret = -EINVAL; | 
| 1108 | goto unlock_up_free; | 1108 | goto unlock_up_free; | 
| 1109 | } | 1109 | } | 
| diff --git a/net/ipv6/netfilter/ip6t_LOG.c b/net/ipv6/netfilter/ip6t_LOG.c index a96c0de14b00..73c6300109d6 100644 --- a/net/ipv6/netfilter/ip6t_LOG.c +++ b/net/ipv6/netfilter/ip6t_LOG.c | |||
| @@ -439,7 +439,7 @@ ip6t_log_target(struct sk_buff **pskb, | |||
| 439 | 439 | ||
| 440 | if (loginfo->logflags & IP6T_LOG_NFLOG) | 440 | if (loginfo->logflags & IP6T_LOG_NFLOG) | 
| 441 | nf_log_packet(PF_INET6, hooknum, *pskb, in, out, &li, | 441 | nf_log_packet(PF_INET6, hooknum, *pskb, in, out, &li, | 
| 442 | loginfo->prefix); | 442 | "%s", loginfo->prefix); | 
| 443 | else | 443 | else | 
| 444 | ip6t_log_packet(PF_INET6, hooknum, *pskb, in, out, &li, | 444 | ip6t_log_packet(PF_INET6, hooknum, *pskb, in, out, &li, | 
| 445 | loginfo->prefix); | 445 | loginfo->prefix); | 
| diff --git a/net/ipv6/netfilter/ip6t_eui64.c b/net/ipv6/netfilter/ip6t_eui64.c index 94dbdb8b458d..4f6b84c8f4ab 100644 --- a/net/ipv6/netfilter/ip6t_eui64.c +++ b/net/ipv6/netfilter/ip6t_eui64.c | |||
| @@ -40,7 +40,7 @@ match(const struct sk_buff *skb, | |||
| 40 | 40 | ||
| 41 | memset(eui64, 0, sizeof(eui64)); | 41 | memset(eui64, 0, sizeof(eui64)); | 
| 42 | 42 | ||
| 43 | if (eth_hdr(skb)->h_proto == ntohs(ETH_P_IPV6)) { | 43 | if (eth_hdr(skb)->h_proto == htons(ETH_P_IPV6)) { | 
| 44 | if (skb->nh.ipv6h->version == 0x6) { | 44 | if (skb->nh.ipv6h->version == 0x6) { | 
| 45 | memcpy(eui64, eth_hdr(skb)->h_source, 3); | 45 | memcpy(eui64, eth_hdr(skb)->h_source, 3); | 
| 46 | memcpy(eui64 + 5, eth_hdr(skb)->h_source + 3, 3); | 46 | memcpy(eui64 + 5, eth_hdr(skb)->h_source + 3, 3); | 
| diff --git a/net/ipx/af_ipx.c b/net/ipx/af_ipx.c index 2dbf134d5266..811d998725bc 100644 --- a/net/ipx/af_ipx.c +++ b/net/ipx/af_ipx.c | |||
| @@ -944,9 +944,9 @@ out: | |||
| 944 | return rc; | 944 | return rc; | 
| 945 | } | 945 | } | 
| 946 | 946 | ||
| 947 | static int ipx_map_frame_type(unsigned char type) | 947 | static __be16 ipx_map_frame_type(unsigned char type) | 
| 948 | { | 948 | { | 
| 949 | int rc = 0; | 949 | __be16 rc = 0; | 
| 950 | 950 | ||
| 951 | switch (type) { | 951 | switch (type) { | 
| 952 | case IPX_FRAME_ETHERII: rc = htons(ETH_P_IPX); break; | 952 | case IPX_FRAME_ETHERII: rc = htons(ETH_P_IPX); break; | 
| diff --git a/net/ipx/ipx_route.c b/net/ipx/ipx_route.c index 67774448efd9..a394c6fe19a2 100644 --- a/net/ipx/ipx_route.c +++ b/net/ipx/ipx_route.c | |||
| @@ -119,7 +119,7 @@ out: | |||
| 119 | return rc; | 119 | return rc; | 
| 120 | } | 120 | } | 
| 121 | 121 | ||
| 122 | static int ipxrtr_delete(long net) | 122 | static int ipxrtr_delete(__u32 net) | 
| 123 | { | 123 | { | 
| 124 | struct ipx_route *r, *tmp; | 124 | struct ipx_route *r, *tmp; | 
| 125 | int rc; | 125 | int rc; | 
| diff --git a/net/netfilter/nfnetlink_log.c b/net/netfilter/nfnetlink_log.c index c60273cad778..61cdda4e5d3b 100644 --- a/net/netfilter/nfnetlink_log.c +++ b/net/netfilter/nfnetlink_log.c | |||
| @@ -321,7 +321,7 @@ static int | |||
| 321 | nfulnl_set_flags(struct nfulnl_instance *inst, u_int16_t flags) | 321 | nfulnl_set_flags(struct nfulnl_instance *inst, u_int16_t flags) | 
| 322 | { | 322 | { | 
| 323 | spin_lock_bh(&inst->lock); | 323 | spin_lock_bh(&inst->lock); | 
| 324 | inst->flags = ntohs(flags); | 324 | inst->flags = flags; | 
| 325 | spin_unlock_bh(&inst->lock); | 325 | spin_unlock_bh(&inst->lock); | 
| 326 | 326 | ||
| 327 | return 0; | 327 | return 0; | 
| @@ -902,7 +902,7 @@ nfulnl_recv_config(struct sock *ctnl, struct sk_buff *skb, | |||
| 902 | if (nfula[NFULA_CFG_FLAGS-1]) { | 902 | if (nfula[NFULA_CFG_FLAGS-1]) { | 
| 903 | u_int16_t flags = | 903 | u_int16_t flags = | 
| 904 | *(u_int16_t *)NFA_DATA(nfula[NFULA_CFG_FLAGS-1]); | 904 | *(u_int16_t *)NFA_DATA(nfula[NFULA_CFG_FLAGS-1]); | 
| 905 | nfulnl_set_flags(inst, ntohl(flags)); | 905 | nfulnl_set_flags(inst, ntohs(flags)); | 
| 906 | } | 906 | } | 
| 907 | 907 | ||
| 908 | out_put: | 908 | out_put: | 
| diff --git a/net/sched/sch_generic.c b/net/sched/sch_generic.c index 31eb83717c26..138ea92ed268 100644 --- a/net/sched/sch_generic.c +++ b/net/sched/sch_generic.c | |||
| @@ -193,8 +193,10 @@ static void dev_watchdog(unsigned long arg) | |||
| 193 | netif_running(dev) && | 193 | netif_running(dev) && | 
| 194 | netif_carrier_ok(dev)) { | 194 | netif_carrier_ok(dev)) { | 
| 195 | if (netif_queue_stopped(dev) && | 195 | if (netif_queue_stopped(dev) && | 
| 196 | (jiffies - dev->trans_start) > dev->watchdog_timeo) { | 196 | time_after(jiffies, dev->trans_start + dev->watchdog_timeo)) { | 
| 197 | printk(KERN_INFO "NETDEV WATCHDOG: %s: transmit timed out\n", dev->name); | 197 | |
| 198 | printk(KERN_INFO "NETDEV WATCHDOG: %s: transmit timed out\n", | ||
| 199 | dev->name); | ||
| 198 | dev->tx_timeout(dev); | 200 | dev->tx_timeout(dev); | 
| 199 | } | 201 | } | 
| 200 | if (!mod_timer(&dev->watchdog_timer, jiffies + dev->watchdog_timeo)) | 202 | if (!mod_timer(&dev->watchdog_timer, jiffies + dev->watchdog_timeo)) | 
| diff --git a/net/sctp/input.c b/net/sctp/input.c index d117ebc75cf8..1662f9cc869e 100644 --- a/net/sctp/input.c +++ b/net/sctp/input.c | |||
| @@ -73,6 +73,8 @@ static struct sctp_association *__sctp_lookup_association( | |||
| 73 | const union sctp_addr *peer, | 73 | const union sctp_addr *peer, | 
| 74 | struct sctp_transport **pt); | 74 | struct sctp_transport **pt); | 
| 75 | 75 | ||
| 76 | static void sctp_add_backlog(struct sock *sk, struct sk_buff *skb); | ||
| 77 | |||
| 76 | 78 | ||
| 77 | /* Calculate the SCTP checksum of an SCTP packet. */ | 79 | /* Calculate the SCTP checksum of an SCTP packet. */ | 
| 78 | static inline int sctp_rcv_checksum(struct sk_buff *skb) | 80 | static inline int sctp_rcv_checksum(struct sk_buff *skb) | 
| @@ -186,7 +188,6 @@ int sctp_rcv(struct sk_buff *skb) | |||
| 186 | */ | 188 | */ | 
| 187 | if (sk->sk_bound_dev_if && (sk->sk_bound_dev_if != af->skb_iif(skb))) | 189 | if (sk->sk_bound_dev_if && (sk->sk_bound_dev_if != af->skb_iif(skb))) | 
| 188 | { | 190 | { | 
| 189 | sock_put(sk); | ||
| 190 | if (asoc) { | 191 | if (asoc) { | 
| 191 | sctp_association_put(asoc); | 192 | sctp_association_put(asoc); | 
| 192 | asoc = NULL; | 193 | asoc = NULL; | 
| @@ -197,7 +198,6 @@ int sctp_rcv(struct sk_buff *skb) | |||
| 197 | sk = sctp_get_ctl_sock(); | 198 | sk = sctp_get_ctl_sock(); | 
| 198 | ep = sctp_sk(sk)->ep; | 199 | ep = sctp_sk(sk)->ep; | 
| 199 | sctp_endpoint_hold(ep); | 200 | sctp_endpoint_hold(ep); | 
| 200 | sock_hold(sk); | ||
| 201 | rcvr = &ep->base; | 201 | rcvr = &ep->base; | 
| 202 | } | 202 | } | 
| 203 | 203 | ||
| @@ -253,25 +253,18 @@ int sctp_rcv(struct sk_buff *skb) | |||
| 253 | */ | 253 | */ | 
| 254 | sctp_bh_lock_sock(sk); | 254 | sctp_bh_lock_sock(sk); | 
| 255 | 255 | ||
| 256 | /* It is possible that the association could have moved to a different | ||
| 257 | * socket if it is peeled off. If so, update the sk. | ||
| 258 | */ | ||
| 259 | if (sk != rcvr->sk) { | ||
| 260 | sctp_bh_lock_sock(rcvr->sk); | ||
| 261 | sctp_bh_unlock_sock(sk); | ||
| 262 | sk = rcvr->sk; | ||
| 263 | } | ||
| 264 | |||
| 265 | if (sock_owned_by_user(sk)) | 256 | if (sock_owned_by_user(sk)) | 
| 266 | sk_add_backlog(sk, skb); | 257 | sctp_add_backlog(sk, skb); | 
| 267 | else | 258 | else | 
| 268 | sctp_backlog_rcv(sk, skb); | 259 | sctp_inq_push(&chunk->rcvr->inqueue, chunk); | 
| 269 | 260 | ||
| 270 | /* Release the sock and the sock ref we took in the lookup calls. | ||
| 271 | * The asoc/ep ref will be released in sctp_backlog_rcv. | ||
| 272 | */ | ||
| 273 | sctp_bh_unlock_sock(sk); | 261 | sctp_bh_unlock_sock(sk); | 
| 274 | sock_put(sk); | 262 | |
| 263 | /* Release the asoc/ep ref we took in the lookup calls. */ | ||
| 264 | if (asoc) | ||
| 265 | sctp_association_put(asoc); | ||
| 266 | else | ||
| 267 | sctp_endpoint_put(ep); | ||
| 275 | 268 | ||
| 276 | return 0; | 269 | return 0; | 
| 277 | 270 | ||
| @@ -280,8 +273,7 @@ discard_it: | |||
| 280 | return 0; | 273 | return 0; | 
| 281 | 274 | ||
| 282 | discard_release: | 275 | discard_release: | 
| 283 | /* Release any structures we may be holding. */ | 276 | /* Release the asoc/ep ref we took in the lookup calls. */ | 
| 284 | sock_put(sk); | ||
| 285 | if (asoc) | 277 | if (asoc) | 
| 286 | sctp_association_put(asoc); | 278 | sctp_association_put(asoc); | 
| 287 | else | 279 | else | 
| @@ -290,56 +282,87 @@ discard_release: | |||
| 290 | goto discard_it; | 282 | goto discard_it; | 
| 291 | } | 283 | } | 
| 292 | 284 | ||
| 293 | /* Handle second half of inbound skb processing. If the sock was busy, | 285 | /* Process the backlog queue of the socket. Every skb on | 
| 294 | * we may have need to delay processing until later when the sock is | 286 | * the backlog holds a ref on an association or endpoint. | 
| 295 | * released (on the backlog). If not busy, we call this routine | 287 | * We hold this ref throughout the state machine to make | 
| 296 | * directly from the bottom half. | 288 | * sure that the structure we need is still around. | 
| 297 | */ | 289 | */ | 
| 298 | int sctp_backlog_rcv(struct sock *sk, struct sk_buff *skb) | 290 | int sctp_backlog_rcv(struct sock *sk, struct sk_buff *skb) | 
| 299 | { | 291 | { | 
| 300 | struct sctp_chunk *chunk = SCTP_INPUT_CB(skb)->chunk; | 292 | struct sctp_chunk *chunk = SCTP_INPUT_CB(skb)->chunk; | 
| 301 | struct sctp_inq *inqueue = NULL; | 293 | struct sctp_inq *inqueue = &chunk->rcvr->inqueue; | 
| 302 | struct sctp_ep_common *rcvr = NULL; | 294 | struct sctp_ep_common *rcvr = NULL; | 
| 295 | int backloged = 0; | ||
| 303 | 296 | ||
| 304 | rcvr = chunk->rcvr; | 297 | rcvr = chunk->rcvr; | 
| 305 | 298 | ||
| 306 | BUG_TRAP(rcvr->sk == sk); | 299 | /* If the rcvr is dead then the association or endpoint | 
| 307 | 300 | * has been deleted and we can safely drop the chunk | |
| 308 | if (rcvr->dead) { | 301 | * and refs that we are holding. | 
| 309 | sctp_chunk_free(chunk); | 302 | */ | 
| 310 | } else { | 303 | if (rcvr->dead) { | 
| 311 | inqueue = &chunk->rcvr->inqueue; | 304 | sctp_chunk_free(chunk); | 
| 312 | sctp_inq_push(inqueue, chunk); | 305 | goto done; | 
| 313 | } | 306 | } | 
| 314 | 307 | ||
| 315 | /* Release the asoc/ep ref we took in the lookup calls in sctp_rcv. */ | 308 | if (unlikely(rcvr->sk != sk)) { | 
| 316 | if (SCTP_EP_TYPE_ASSOCIATION == rcvr->type) | 309 | /* In this case, the association moved from one socket to | 
| 317 | sctp_association_put(sctp_assoc(rcvr)); | 310 | * another. We are currently sitting on the backlog of the | 
| 318 | else | 311 | * old socket, so we need to move. | 
| 319 | sctp_endpoint_put(sctp_ep(rcvr)); | 312 | * However, since we are here in the process context we | 
| 320 | 313 | * need to take make sure that the user doesn't own | |
| 314 | * the new socket when we process the packet. | ||
| 315 | * If the new socket is user-owned, queue the chunk to the | ||
| 316 | * backlog of the new socket without dropping any refs. | ||
| 317 | * Otherwise, we can safely push the chunk on the inqueue. | ||
| 318 | */ | ||
| 319 | |||
| 320 | sk = rcvr->sk; | ||
| 321 | sctp_bh_lock_sock(sk); | ||
| 322 | |||
| 323 | if (sock_owned_by_user(sk)) { | ||
| 324 | sk_add_backlog(sk, skb); | ||
| 325 | backloged = 1; | ||
| 326 | } else | ||
| 327 | sctp_inq_push(inqueue, chunk); | ||
| 328 | |||
| 329 | sctp_bh_unlock_sock(sk); | ||
| 330 | |||
| 331 | /* If the chunk was backloged again, don't drop refs */ | ||
| 332 | if (backloged) | ||
| 333 | return 0; | ||
| 334 | } else { | ||
| 335 | sctp_inq_push(inqueue, chunk); | ||
| 336 | } | ||
| 337 | |||
| 338 | done: | ||
| 339 | /* Release the refs we took in sctp_add_backlog */ | ||
| 340 | if (SCTP_EP_TYPE_ASSOCIATION == rcvr->type) | ||
| 341 | sctp_association_put(sctp_assoc(rcvr)); | ||
| 342 | else if (SCTP_EP_TYPE_SOCKET == rcvr->type) | ||
| 343 | sctp_endpoint_put(sctp_ep(rcvr)); | ||
| 344 | else | ||
| 345 | BUG(); | ||
| 346 | |||
| 321 | return 0; | 347 | return 0; | 
| 322 | } | 348 | } | 
| 323 | 349 | ||
| 324 | void sctp_backlog_migrate(struct sctp_association *assoc, | 350 | static void sctp_add_backlog(struct sock *sk, struct sk_buff *skb) | 
| 325 | struct sock *oldsk, struct sock *newsk) | ||
| 326 | { | 351 | { | 
| 327 | struct sk_buff *skb; | 352 | struct sctp_chunk *chunk = SCTP_INPUT_CB(skb)->chunk; | 
| 328 | struct sctp_chunk *chunk; | 353 | struct sctp_ep_common *rcvr = chunk->rcvr; | 
| 329 | 354 | ||
| 330 | skb = oldsk->sk_backlog.head; | 355 | /* Hold the assoc/ep while hanging on the backlog queue. | 
| 331 | oldsk->sk_backlog.head = oldsk->sk_backlog.tail = NULL; | 356 | * This way, we know structures we need will not disappear from us | 
| 332 | while (skb != NULL) { | 357 | */ | 
| 333 | struct sk_buff *next = skb->next; | 358 | if (SCTP_EP_TYPE_ASSOCIATION == rcvr->type) | 
| 334 | 359 | sctp_association_hold(sctp_assoc(rcvr)); | |
| 335 | chunk = SCTP_INPUT_CB(skb)->chunk; | 360 | else if (SCTP_EP_TYPE_SOCKET == rcvr->type) | 
| 336 | skb->next = NULL; | 361 | sctp_endpoint_hold(sctp_ep(rcvr)); | 
| 337 | if (&assoc->base == chunk->rcvr) | 362 | else | 
| 338 | sk_add_backlog(newsk, skb); | 363 | BUG(); | 
| 339 | else | 364 | |
| 340 | sk_add_backlog(oldsk, skb); | 365 | sk_add_backlog(sk, skb); | 
| 341 | skb = next; | ||
| 342 | } | ||
| 343 | } | 366 | } | 
| 344 | 367 | ||
| 345 | /* Handle icmp frag needed error. */ | 368 | /* Handle icmp frag needed error. */ | 
| @@ -412,7 +435,7 @@ struct sock *sctp_err_lookup(int family, struct sk_buff *skb, | |||
| 412 | union sctp_addr daddr; | 435 | union sctp_addr daddr; | 
| 413 | struct sctp_af *af; | 436 | struct sctp_af *af; | 
| 414 | struct sock *sk = NULL; | 437 | struct sock *sk = NULL; | 
| 415 | struct sctp_association *asoc = NULL; | 438 | struct sctp_association *asoc; | 
| 416 | struct sctp_transport *transport = NULL; | 439 | struct sctp_transport *transport = NULL; | 
| 417 | 440 | ||
| 418 | *app = NULL; *tpp = NULL; | 441 | *app = NULL; *tpp = NULL; | 
| @@ -453,7 +476,6 @@ struct sock *sctp_err_lookup(int family, struct sk_buff *skb, | |||
| 453 | return sk; | 476 | return sk; | 
| 454 | 477 | ||
| 455 | out: | 478 | out: | 
| 456 | sock_put(sk); | ||
| 457 | if (asoc) | 479 | if (asoc) | 
| 458 | sctp_association_put(asoc); | 480 | sctp_association_put(asoc); | 
| 459 | return NULL; | 481 | return NULL; | 
| @@ -463,7 +485,6 @@ out: | |||
| 463 | void sctp_err_finish(struct sock *sk, struct sctp_association *asoc) | 485 | void sctp_err_finish(struct sock *sk, struct sctp_association *asoc) | 
| 464 | { | 486 | { | 
| 465 | sctp_bh_unlock_sock(sk); | 487 | sctp_bh_unlock_sock(sk); | 
| 466 | sock_put(sk); | ||
| 467 | if (asoc) | 488 | if (asoc) | 
| 468 | sctp_association_put(asoc); | 489 | sctp_association_put(asoc); | 
| 469 | } | 490 | } | 
| @@ -490,7 +511,7 @@ void sctp_v4_err(struct sk_buff *skb, __u32 info) | |||
| 490 | int type = skb->h.icmph->type; | 511 | int type = skb->h.icmph->type; | 
| 491 | int code = skb->h.icmph->code; | 512 | int code = skb->h.icmph->code; | 
| 492 | struct sock *sk; | 513 | struct sock *sk; | 
| 493 | struct sctp_association *asoc; | 514 | struct sctp_association *asoc = NULL; | 
| 494 | struct sctp_transport *transport; | 515 | struct sctp_transport *transport; | 
| 495 | struct inet_sock *inet; | 516 | struct inet_sock *inet; | 
| 496 | char *saveip, *savesctp; | 517 | char *saveip, *savesctp; | 
| @@ -716,7 +737,6 @@ static struct sctp_endpoint *__sctp_rcv_lookup_endpoint(const union sctp_addr *l | |||
| 716 | 737 | ||
| 717 | hit: | 738 | hit: | 
| 718 | sctp_endpoint_hold(ep); | 739 | sctp_endpoint_hold(ep); | 
| 719 | sock_hold(epb->sk); | ||
| 720 | read_unlock(&head->lock); | 740 | read_unlock(&head->lock); | 
| 721 | return ep; | 741 | return ep; | 
| 722 | } | 742 | } | 
| @@ -818,7 +838,6 @@ static struct sctp_association *__sctp_lookup_association( | |||
| 818 | hit: | 838 | hit: | 
| 819 | *pt = transport; | 839 | *pt = transport; | 
| 820 | sctp_association_hold(asoc); | 840 | sctp_association_hold(asoc); | 
| 821 | sock_hold(epb->sk); | ||
| 822 | read_unlock(&head->lock); | 841 | read_unlock(&head->lock); | 
| 823 | return asoc; | 842 | return asoc; | 
| 824 | } | 843 | } | 
| @@ -846,7 +865,6 @@ int sctp_has_association(const union sctp_addr *laddr, | |||
| 846 | struct sctp_transport *transport; | 865 | struct sctp_transport *transport; | 
| 847 | 866 | ||
| 848 | if ((asoc = sctp_lookup_association(laddr, paddr, &transport))) { | 867 | if ((asoc = sctp_lookup_association(laddr, paddr, &transport))) { | 
| 849 | sock_put(asoc->base.sk); | ||
| 850 | sctp_association_put(asoc); | 868 | sctp_association_put(asoc); | 
| 851 | return 1; | 869 | return 1; | 
| 852 | } | 870 | } | 
| diff --git a/net/sctp/sm_sideeffect.c b/net/sctp/sm_sideeffect.c index 8d1dc24bab4c..c5beb2ad7ef7 100644 --- a/net/sctp/sm_sideeffect.c +++ b/net/sctp/sm_sideeffect.c | |||
| @@ -498,10 +498,6 @@ static void sctp_cmd_assoc_failed(sctp_cmd_seq_t *commands, | |||
| 498 | sctp_add_cmd_sf(commands, SCTP_CMD_NEW_STATE, | 498 | sctp_add_cmd_sf(commands, SCTP_CMD_NEW_STATE, | 
| 499 | SCTP_STATE(SCTP_STATE_CLOSED)); | 499 | SCTP_STATE(SCTP_STATE_CLOSED)); | 
| 500 | 500 | ||
| 501 | /* Set sk_err to ECONNRESET on a 1-1 style socket. */ | ||
| 502 | if (!sctp_style(asoc->base.sk, UDP)) | ||
| 503 | asoc->base.sk->sk_err = ECONNRESET; | ||
| 504 | |||
| 505 | /* SEND_FAILED sent later when cleaning up the association. */ | 501 | /* SEND_FAILED sent later when cleaning up the association. */ | 
| 506 | asoc->outqueue.error = error; | 502 | asoc->outqueue.error = error; | 
| 507 | sctp_add_cmd_sf(commands, SCTP_CMD_DELETE_TCB, SCTP_NULL()); | 503 | sctp_add_cmd_sf(commands, SCTP_CMD_DELETE_TCB, SCTP_NULL()); | 
| @@ -838,6 +834,15 @@ static void sctp_cmd_del_non_primary(struct sctp_association *asoc) | |||
| 838 | return; | 834 | return; | 
| 839 | } | 835 | } | 
| 840 | 836 | ||
| 837 | /* Helper function to set sk_err on a 1-1 style socket. */ | ||
| 838 | static void sctp_cmd_set_sk_err(struct sctp_association *asoc, int error) | ||
| 839 | { | ||
| 840 | struct sock *sk = asoc->base.sk; | ||
| 841 | |||
| 842 | if (!sctp_style(sk, UDP)) | ||
| 843 | sk->sk_err = error; | ||
| 844 | } | ||
| 845 | |||
| 841 | /* These three macros allow us to pull the debugging code out of the | 846 | /* These three macros allow us to pull the debugging code out of the | 
| 842 | * main flow of sctp_do_sm() to keep attention focused on the real | 847 | * main flow of sctp_do_sm() to keep attention focused on the real | 
| 843 | * functionality there. | 848 | * functionality there. | 
| @@ -1458,6 +1463,9 @@ static int sctp_cmd_interpreter(sctp_event_t event_type, | |||
| 1458 | local_cork = 0; | 1463 | local_cork = 0; | 
| 1459 | asoc->peer.retran_path = t; | 1464 | asoc->peer.retran_path = t; | 
| 1460 | break; | 1465 | break; | 
| 1466 | case SCTP_CMD_SET_SK_ERR: | ||
| 1467 | sctp_cmd_set_sk_err(asoc, cmd->obj.error); | ||
| 1468 | break; | ||
| 1461 | default: | 1469 | default: | 
| 1462 | printk(KERN_WARNING "Impossible command: %u, %p\n", | 1470 | printk(KERN_WARNING "Impossible command: %u, %p\n", | 
| 1463 | cmd->verb, cmd->obj.ptr); | 1471 | cmd->verb, cmd->obj.ptr); | 
| diff --git a/net/sctp/sm_statefuns.c b/net/sctp/sm_statefuns.c index 8cdba51ec076..8bc279219a72 100644 --- a/net/sctp/sm_statefuns.c +++ b/net/sctp/sm_statefuns.c | |||
| @@ -93,7 +93,7 @@ static sctp_disposition_t sctp_sf_shut_8_4_5(const struct sctp_endpoint *ep, | |||
| 93 | static struct sctp_sackhdr *sctp_sm_pull_sack(struct sctp_chunk *chunk); | 93 | static struct sctp_sackhdr *sctp_sm_pull_sack(struct sctp_chunk *chunk); | 
| 94 | 94 | ||
| 95 | static sctp_disposition_t sctp_stop_t1_and_abort(sctp_cmd_seq_t *commands, | 95 | static sctp_disposition_t sctp_stop_t1_and_abort(sctp_cmd_seq_t *commands, | 
| 96 | __u16 error, | 96 | __u16 error, int sk_err, | 
| 97 | const struct sctp_association *asoc, | 97 | const struct sctp_association *asoc, | 
| 98 | struct sctp_transport *transport); | 98 | struct sctp_transport *transport); | 
| 99 | 99 | ||
| @@ -448,7 +448,7 @@ sctp_disposition_t sctp_sf_do_5_1C_ack(const struct sctp_endpoint *ep, | |||
| 448 | __u32 init_tag; | 448 | __u32 init_tag; | 
| 449 | struct sctp_chunk *err_chunk; | 449 | struct sctp_chunk *err_chunk; | 
| 450 | struct sctp_packet *packet; | 450 | struct sctp_packet *packet; | 
| 451 | sctp_disposition_t ret; | 451 | __u16 error; | 
| 452 | 452 | ||
| 453 | if (!sctp_vtag_verify(chunk, asoc)) | 453 | if (!sctp_vtag_verify(chunk, asoc)) | 
| 454 | return sctp_sf_pdiscard(ep, asoc, type, arg, commands); | 454 | return sctp_sf_pdiscard(ep, asoc, type, arg, commands); | 
| @@ -480,11 +480,9 @@ sctp_disposition_t sctp_sf_do_5_1C_ack(const struct sctp_endpoint *ep, | |||
| 480 | goto nomem; | 480 | goto nomem; | 
| 481 | 481 | ||
| 482 | sctp_add_cmd_sf(commands, SCTP_CMD_REPLY, SCTP_CHUNK(reply)); | 482 | sctp_add_cmd_sf(commands, SCTP_CMD_REPLY, SCTP_CHUNK(reply)); | 
| 483 | sctp_add_cmd_sf(commands, SCTP_CMD_NEW_STATE, | 483 | return sctp_stop_t1_and_abort(commands, SCTP_ERROR_INV_PARAM, | 
| 484 | SCTP_STATE(SCTP_STATE_CLOSED)); | 484 | ECONNREFUSED, asoc, | 
| 485 | SCTP_INC_STATS(SCTP_MIB_ABORTEDS); | 485 | chunk->transport); | 
| 486 | sctp_add_cmd_sf(commands, SCTP_CMD_DELETE_TCB, SCTP_NULL()); | ||
| 487 | return SCTP_DISPOSITION_DELETE_TCB; | ||
| 488 | } | 486 | } | 
| 489 | 487 | ||
| 490 | /* Verify the INIT chunk before processing it. */ | 488 | /* Verify the INIT chunk before processing it. */ | 
| @@ -511,27 +509,16 @@ sctp_disposition_t sctp_sf_do_5_1C_ack(const struct sctp_endpoint *ep, | |||
| 511 | sctp_add_cmd_sf(commands, SCTP_CMD_SEND_PKT, | 509 | sctp_add_cmd_sf(commands, SCTP_CMD_SEND_PKT, | 
| 512 | SCTP_PACKET(packet)); | 510 | SCTP_PACKET(packet)); | 
| 513 | SCTP_INC_STATS(SCTP_MIB_OUTCTRLCHUNKS); | 511 | SCTP_INC_STATS(SCTP_MIB_OUTCTRLCHUNKS); | 
| 514 | sctp_add_cmd_sf(commands, SCTP_CMD_NEW_STATE, | 512 | error = SCTP_ERROR_INV_PARAM; | 
| 515 | SCTP_STATE(SCTP_STATE_CLOSED)); | ||
| 516 | sctp_add_cmd_sf(commands, SCTP_CMD_DELETE_TCB, | ||
| 517 | SCTP_NULL()); | ||
| 518 | return SCTP_DISPOSITION_CONSUME; | ||
| 519 | } else { | 513 | } else { | 
| 520 | sctp_add_cmd_sf(commands, SCTP_CMD_NEW_STATE, | 514 | error = SCTP_ERROR_NO_RESOURCE; | 
| 521 | SCTP_STATE(SCTP_STATE_CLOSED)); | ||
| 522 | sctp_add_cmd_sf(commands, SCTP_CMD_DELETE_TCB, | ||
| 523 | SCTP_NULL()); | ||
| 524 | return SCTP_DISPOSITION_NOMEM; | ||
| 525 | } | 515 | } | 
| 526 | } else { | 516 | } else { | 
| 527 | ret = sctp_sf_tabort_8_4_8(ep, asoc, type, arg, | 517 | sctp_sf_tabort_8_4_8(ep, asoc, type, arg, commands); | 
| 528 | commands); | 518 | error = SCTP_ERROR_INV_PARAM; | 
| 529 | sctp_add_cmd_sf(commands, SCTP_CMD_NEW_STATE, | ||
| 530 | SCTP_STATE(SCTP_STATE_CLOSED)); | ||
| 531 | sctp_add_cmd_sf(commands, SCTP_CMD_DELETE_TCB, | ||
| 532 | SCTP_NULL()); | ||
| 533 | return ret; | ||
| 534 | } | 519 | } | 
| 520 | return sctp_stop_t1_and_abort(commands, error, ECONNREFUSED, | ||
| 521 | asoc, chunk->transport); | ||
| 535 | } | 522 | } | 
| 536 | 523 | ||
| 537 | /* Tag the variable length parameters. Note that we never | 524 | /* Tag the variable length parameters. Note that we never | 
| @@ -886,6 +873,8 @@ sctp_disposition_t sctp_sf_sendbeat_8_3(const struct sctp_endpoint *ep, | |||
| 886 | struct sctp_transport *transport = (struct sctp_transport *) arg; | 873 | struct sctp_transport *transport = (struct sctp_transport *) arg; | 
| 887 | 874 | ||
| 888 | if (asoc->overall_error_count >= asoc->max_retrans) { | 875 | if (asoc->overall_error_count >= asoc->max_retrans) { | 
| 876 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 877 | SCTP_ERROR(ETIMEDOUT)); | ||
| 889 | /* CMD_ASSOC_FAILED calls CMD_DELETE_TCB. */ | 878 | /* CMD_ASSOC_FAILED calls CMD_DELETE_TCB. */ | 
| 890 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 879 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 
| 891 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 880 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 
| @@ -1030,6 +1019,12 @@ sctp_disposition_t sctp_sf_backbeat_8_3(const struct sctp_endpoint *ep, | |||
| 1030 | commands); | 1019 | commands); | 
| 1031 | 1020 | ||
| 1032 | hbinfo = (sctp_sender_hb_info_t *) chunk->skb->data; | 1021 | hbinfo = (sctp_sender_hb_info_t *) chunk->skb->data; | 
| 1022 | /* Make sure that the length of the parameter is what we expect */ | ||
| 1023 | if (ntohs(hbinfo->param_hdr.length) != | ||
| 1024 | sizeof(sctp_sender_hb_info_t)) { | ||
| 1025 | return SCTP_DISPOSITION_DISCARD; | ||
| 1026 | } | ||
| 1027 | |||
| 1033 | from_addr = hbinfo->daddr; | 1028 | from_addr = hbinfo->daddr; | 
| 1034 | link = sctp_assoc_lookup_paddr(asoc, &from_addr); | 1029 | link = sctp_assoc_lookup_paddr(asoc, &from_addr); | 
| 1035 | 1030 | ||
| @@ -2126,6 +2121,8 @@ static sctp_disposition_t sctp_sf_do_5_2_6_stale(const struct sctp_endpoint *ep, | |||
| 2126 | int attempts = asoc->init_err_counter + 1; | 2121 | int attempts = asoc->init_err_counter + 1; | 
| 2127 | 2122 | ||
| 2128 | if (attempts > asoc->max_init_attempts) { | 2123 | if (attempts > asoc->max_init_attempts) { | 
| 2124 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 2125 | SCTP_ERROR(ETIMEDOUT)); | ||
| 2129 | sctp_add_cmd_sf(commands, SCTP_CMD_INIT_FAILED, | 2126 | sctp_add_cmd_sf(commands, SCTP_CMD_INIT_FAILED, | 
| 2130 | SCTP_U32(SCTP_ERROR_STALE_COOKIE)); | 2127 | SCTP_U32(SCTP_ERROR_STALE_COOKIE)); | 
| 2131 | return SCTP_DISPOSITION_DELETE_TCB; | 2128 | return SCTP_DISPOSITION_DELETE_TCB; | 
| @@ -2262,6 +2259,7 @@ sctp_disposition_t sctp_sf_do_9_1_abort(const struct sctp_endpoint *ep, | |||
| 2262 | if (len >= sizeof(struct sctp_chunkhdr) + sizeof(struct sctp_errhdr)) | 2259 | if (len >= sizeof(struct sctp_chunkhdr) + sizeof(struct sctp_errhdr)) | 
| 2263 | error = ((sctp_errhdr_t *)chunk->skb->data)->cause; | 2260 | error = ((sctp_errhdr_t *)chunk->skb->data)->cause; | 
| 2264 | 2261 | ||
| 2262 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, SCTP_ERROR(ECONNRESET)); | ||
| 2265 | /* ASSOC_FAILED will DELETE_TCB. */ | 2263 | /* ASSOC_FAILED will DELETE_TCB. */ | 
| 2266 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, SCTP_U32(error)); | 2264 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, SCTP_U32(error)); | 
| 2267 | SCTP_INC_STATS(SCTP_MIB_ABORTEDS); | 2265 | SCTP_INC_STATS(SCTP_MIB_ABORTEDS); | 
| @@ -2306,7 +2304,8 @@ sctp_disposition_t sctp_sf_cookie_wait_abort(const struct sctp_endpoint *ep, | |||
| 2306 | if (len >= sizeof(struct sctp_chunkhdr) + sizeof(struct sctp_errhdr)) | 2304 | if (len >= sizeof(struct sctp_chunkhdr) + sizeof(struct sctp_errhdr)) | 
| 2307 | error = ((sctp_errhdr_t *)chunk->skb->data)->cause; | 2305 | error = ((sctp_errhdr_t *)chunk->skb->data)->cause; | 
| 2308 | 2306 | ||
| 2309 | return sctp_stop_t1_and_abort(commands, error, asoc, chunk->transport); | 2307 | return sctp_stop_t1_and_abort(commands, error, ECONNREFUSED, asoc, | 
| 2308 | chunk->transport); | ||
| 2310 | } | 2309 | } | 
| 2311 | 2310 | ||
| 2312 | /* | 2311 | /* | 
| @@ -2318,7 +2317,8 @@ sctp_disposition_t sctp_sf_cookie_wait_icmp_abort(const struct sctp_endpoint *ep | |||
| 2318 | void *arg, | 2317 | void *arg, | 
| 2319 | sctp_cmd_seq_t *commands) | 2318 | sctp_cmd_seq_t *commands) | 
| 2320 | { | 2319 | { | 
| 2321 | return sctp_stop_t1_and_abort(commands, SCTP_ERROR_NO_ERROR, asoc, | 2320 | return sctp_stop_t1_and_abort(commands, SCTP_ERROR_NO_ERROR, | 
| 2321 | ENOPROTOOPT, asoc, | ||
| 2322 | (struct sctp_transport *)arg); | 2322 | (struct sctp_transport *)arg); | 
| 2323 | } | 2323 | } | 
| 2324 | 2324 | ||
| @@ -2343,7 +2343,7 @@ sctp_disposition_t sctp_sf_cookie_echoed_abort(const struct sctp_endpoint *ep, | |||
| 2343 | * This is common code called by several sctp_sf_*_abort() functions above. | 2343 | * This is common code called by several sctp_sf_*_abort() functions above. | 
| 2344 | */ | 2344 | */ | 
| 2345 | static sctp_disposition_t sctp_stop_t1_and_abort(sctp_cmd_seq_t *commands, | 2345 | static sctp_disposition_t sctp_stop_t1_and_abort(sctp_cmd_seq_t *commands, | 
| 2346 | __u16 error, | 2346 | __u16 error, int sk_err, | 
| 2347 | const struct sctp_association *asoc, | 2347 | const struct sctp_association *asoc, | 
| 2348 | struct sctp_transport *transport) | 2348 | struct sctp_transport *transport) | 
| 2349 | { | 2349 | { | 
| @@ -2353,6 +2353,7 @@ static sctp_disposition_t sctp_stop_t1_and_abort(sctp_cmd_seq_t *commands, | |||
| 2353 | SCTP_INC_STATS(SCTP_MIB_ABORTEDS); | 2353 | SCTP_INC_STATS(SCTP_MIB_ABORTEDS); | 
| 2354 | sctp_add_cmd_sf(commands, SCTP_CMD_TIMER_STOP, | 2354 | sctp_add_cmd_sf(commands, SCTP_CMD_TIMER_STOP, | 
| 2355 | SCTP_TO(SCTP_EVENT_TIMEOUT_T1_INIT)); | 2355 | SCTP_TO(SCTP_EVENT_TIMEOUT_T1_INIT)); | 
| 2356 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, SCTP_ERROR(sk_err)); | ||
| 2356 | /* CMD_INIT_FAILED will DELETE_TCB. */ | 2357 | /* CMD_INIT_FAILED will DELETE_TCB. */ | 
| 2357 | sctp_add_cmd_sf(commands, SCTP_CMD_INIT_FAILED, | 2358 | sctp_add_cmd_sf(commands, SCTP_CMD_INIT_FAILED, | 
| 2358 | SCTP_U32(error)); | 2359 | SCTP_U32(error)); | 
| @@ -3336,6 +3337,8 @@ sctp_disposition_t sctp_sf_do_asconf_ack(const struct sctp_endpoint *ep, | |||
| 3336 | sctp_add_cmd_sf(commands, SCTP_CMD_TIMER_STOP, | 3337 | sctp_add_cmd_sf(commands, SCTP_CMD_TIMER_STOP, | 
| 3337 | SCTP_TO(SCTP_EVENT_TIMEOUT_T4_RTO)); | 3338 | SCTP_TO(SCTP_EVENT_TIMEOUT_T4_RTO)); | 
| 3338 | sctp_add_cmd_sf(commands, SCTP_CMD_DISCARD_PACKET,SCTP_NULL()); | 3339 | sctp_add_cmd_sf(commands, SCTP_CMD_DISCARD_PACKET,SCTP_NULL()); | 
| 3340 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 3341 | SCTP_ERROR(ECONNABORTED)); | ||
| 3339 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 3342 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 
| 3340 | SCTP_U32(SCTP_ERROR_ASCONF_ACK)); | 3343 | SCTP_U32(SCTP_ERROR_ASCONF_ACK)); | 
| 3341 | SCTP_INC_STATS(SCTP_MIB_ABORTEDS); | 3344 | SCTP_INC_STATS(SCTP_MIB_ABORTEDS); | 
| @@ -3362,6 +3365,8 @@ sctp_disposition_t sctp_sf_do_asconf_ack(const struct sctp_endpoint *ep, | |||
| 3362 | * processing the rest of the chunks in the packet. | 3365 | * processing the rest of the chunks in the packet. | 
| 3363 | */ | 3366 | */ | 
| 3364 | sctp_add_cmd_sf(commands, SCTP_CMD_DISCARD_PACKET,SCTP_NULL()); | 3367 | sctp_add_cmd_sf(commands, SCTP_CMD_DISCARD_PACKET,SCTP_NULL()); | 
| 3368 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 3369 | SCTP_ERROR(ECONNABORTED)); | ||
| 3365 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 3370 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 
| 3366 | SCTP_U32(SCTP_ERROR_ASCONF_ACK)); | 3371 | SCTP_U32(SCTP_ERROR_ASCONF_ACK)); | 
| 3367 | SCTP_INC_STATS(SCTP_MIB_ABORTEDS); | 3372 | SCTP_INC_STATS(SCTP_MIB_ABORTEDS); | 
| @@ -3714,9 +3719,13 @@ static sctp_disposition_t sctp_sf_violation_chunklen( | |||
| 3714 | if (asoc->state <= SCTP_STATE_COOKIE_ECHOED) { | 3719 | if (asoc->state <= SCTP_STATE_COOKIE_ECHOED) { | 
| 3715 | sctp_add_cmd_sf(commands, SCTP_CMD_TIMER_STOP, | 3720 | sctp_add_cmd_sf(commands, SCTP_CMD_TIMER_STOP, | 
| 3716 | SCTP_TO(SCTP_EVENT_TIMEOUT_T1_INIT)); | 3721 | SCTP_TO(SCTP_EVENT_TIMEOUT_T1_INIT)); | 
| 3722 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 3723 | SCTP_ERROR(ECONNREFUSED)); | ||
| 3717 | sctp_add_cmd_sf(commands, SCTP_CMD_INIT_FAILED, | 3724 | sctp_add_cmd_sf(commands, SCTP_CMD_INIT_FAILED, | 
| 3718 | SCTP_U32(SCTP_ERROR_PROTO_VIOLATION)); | 3725 | SCTP_U32(SCTP_ERROR_PROTO_VIOLATION)); | 
| 3719 | } else { | 3726 | } else { | 
| 3727 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 3728 | SCTP_ERROR(ECONNABORTED)); | ||
| 3720 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 3729 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 
| 3721 | SCTP_U32(SCTP_ERROR_PROTO_VIOLATION)); | 3730 | SCTP_U32(SCTP_ERROR_PROTO_VIOLATION)); | 
| 3722 | SCTP_DEC_STATS(SCTP_MIB_CURRESTAB); | 3731 | SCTP_DEC_STATS(SCTP_MIB_CURRESTAB); | 
| @@ -4034,6 +4043,8 @@ sctp_disposition_t sctp_sf_do_9_1_prm_abort( | |||
| 4034 | * TCB. This is a departure from our typical NOMEM handling. | 4043 | * TCB. This is a departure from our typical NOMEM handling. | 
| 4035 | */ | 4044 | */ | 
| 4036 | 4045 | ||
| 4046 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 4047 | SCTP_ERROR(ECONNABORTED)); | ||
| 4037 | /* Delete the established association. */ | 4048 | /* Delete the established association. */ | 
| 4038 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 4049 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 
| 4039 | SCTP_U32(SCTP_ERROR_USER_ABORT)); | 4050 | SCTP_U32(SCTP_ERROR_USER_ABORT)); | 
| @@ -4175,6 +4186,8 @@ sctp_disposition_t sctp_sf_cookie_wait_prm_abort( | |||
| 4175 | * TCB. This is a departure from our typical NOMEM handling. | 4186 | * TCB. This is a departure from our typical NOMEM handling. | 
| 4176 | */ | 4187 | */ | 
| 4177 | 4188 | ||
| 4189 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 4190 | SCTP_ERROR(ECONNREFUSED)); | ||
| 4178 | /* Delete the established association. */ | 4191 | /* Delete the established association. */ | 
| 4179 | sctp_add_cmd_sf(commands, SCTP_CMD_INIT_FAILED, | 4192 | sctp_add_cmd_sf(commands, SCTP_CMD_INIT_FAILED, | 
| 4180 | SCTP_U32(SCTP_ERROR_USER_ABORT)); | 4193 | SCTP_U32(SCTP_ERROR_USER_ABORT)); | 
| @@ -4543,6 +4556,8 @@ sctp_disposition_t sctp_sf_do_6_3_3_rtx(const struct sctp_endpoint *ep, | |||
| 4543 | struct sctp_transport *transport = arg; | 4556 | struct sctp_transport *transport = arg; | 
| 4544 | 4557 | ||
| 4545 | if (asoc->overall_error_count >= asoc->max_retrans) { | 4558 | if (asoc->overall_error_count >= asoc->max_retrans) { | 
| 4559 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 4560 | SCTP_ERROR(ETIMEDOUT)); | ||
| 4546 | /* CMD_ASSOC_FAILED calls CMD_DELETE_TCB. */ | 4561 | /* CMD_ASSOC_FAILED calls CMD_DELETE_TCB. */ | 
| 4547 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 4562 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 
| 4548 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 4563 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 
| @@ -4662,6 +4677,8 @@ sctp_disposition_t sctp_sf_t1_init_timer_expire(const struct sctp_endpoint *ep, | |||
| 4662 | SCTP_DEBUG_PRINTK("Giving up on INIT, attempts: %d" | 4677 | SCTP_DEBUG_PRINTK("Giving up on INIT, attempts: %d" | 
| 4663 | " max_init_attempts: %d\n", | 4678 | " max_init_attempts: %d\n", | 
| 4664 | attempts, asoc->max_init_attempts); | 4679 | attempts, asoc->max_init_attempts); | 
| 4680 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 4681 | SCTP_ERROR(ETIMEDOUT)); | ||
| 4665 | sctp_add_cmd_sf(commands, SCTP_CMD_INIT_FAILED, | 4682 | sctp_add_cmd_sf(commands, SCTP_CMD_INIT_FAILED, | 
| 4666 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 4683 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 
| 4667 | return SCTP_DISPOSITION_DELETE_TCB; | 4684 | return SCTP_DISPOSITION_DELETE_TCB; | 
| @@ -4711,6 +4728,8 @@ sctp_disposition_t sctp_sf_t1_cookie_timer_expire(const struct sctp_endpoint *ep | |||
| 4711 | 4728 | ||
| 4712 | sctp_add_cmd_sf(commands, SCTP_CMD_REPLY, SCTP_CHUNK(repl)); | 4729 | sctp_add_cmd_sf(commands, SCTP_CMD_REPLY, SCTP_CHUNK(repl)); | 
| 4713 | } else { | 4730 | } else { | 
| 4731 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 4732 | SCTP_ERROR(ETIMEDOUT)); | ||
| 4714 | sctp_add_cmd_sf(commands, SCTP_CMD_INIT_FAILED, | 4733 | sctp_add_cmd_sf(commands, SCTP_CMD_INIT_FAILED, | 
| 4715 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 4734 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 
| 4716 | return SCTP_DISPOSITION_DELETE_TCB; | 4735 | return SCTP_DISPOSITION_DELETE_TCB; | 
| @@ -4742,6 +4761,8 @@ sctp_disposition_t sctp_sf_t2_timer_expire(const struct sctp_endpoint *ep, | |||
| 4742 | 4761 | ||
| 4743 | SCTP_DEBUG_PRINTK("Timer T2 expired.\n"); | 4762 | SCTP_DEBUG_PRINTK("Timer T2 expired.\n"); | 
| 4744 | if (asoc->overall_error_count >= asoc->max_retrans) { | 4763 | if (asoc->overall_error_count >= asoc->max_retrans) { | 
| 4764 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 4765 | SCTP_ERROR(ETIMEDOUT)); | ||
| 4745 | /* Note: CMD_ASSOC_FAILED calls CMD_DELETE_TCB. */ | 4766 | /* Note: CMD_ASSOC_FAILED calls CMD_DELETE_TCB. */ | 
| 4746 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 4767 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 
| 4747 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 4768 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 
| @@ -4817,6 +4838,8 @@ sctp_disposition_t sctp_sf_t4_timer_expire( | |||
| 4817 | if (asoc->overall_error_count >= asoc->max_retrans) { | 4838 | if (asoc->overall_error_count >= asoc->max_retrans) { | 
| 4818 | sctp_add_cmd_sf(commands, SCTP_CMD_TIMER_STOP, | 4839 | sctp_add_cmd_sf(commands, SCTP_CMD_TIMER_STOP, | 
| 4819 | SCTP_TO(SCTP_EVENT_TIMEOUT_T4_RTO)); | 4840 | SCTP_TO(SCTP_EVENT_TIMEOUT_T4_RTO)); | 
| 4841 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 4842 | SCTP_ERROR(ETIMEDOUT)); | ||
| 4820 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 4843 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 
| 4821 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 4844 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 
| 4822 | SCTP_INC_STATS(SCTP_MIB_ABORTEDS); | 4845 | SCTP_INC_STATS(SCTP_MIB_ABORTEDS); | 
| @@ -4870,6 +4893,8 @@ sctp_disposition_t sctp_sf_t5_timer_expire(const struct sctp_endpoint *ep, | |||
| 4870 | goto nomem; | 4893 | goto nomem; | 
| 4871 | 4894 | ||
| 4872 | sctp_add_cmd_sf(commands, SCTP_CMD_REPLY, SCTP_CHUNK(reply)); | 4895 | sctp_add_cmd_sf(commands, SCTP_CMD_REPLY, SCTP_CHUNK(reply)); | 
| 4896 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 4897 | SCTP_ERROR(ETIMEDOUT)); | ||
| 4873 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 4898 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 
| 4874 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 4899 | SCTP_U32(SCTP_ERROR_NO_ERROR)); | 
| 4875 | 4900 | ||
| @@ -5309,6 +5334,8 @@ static int sctp_eat_data(const struct sctp_association *asoc, | |||
| 5309 | * processing the rest of the chunks in the packet. | 5334 | * processing the rest of the chunks in the packet. | 
| 5310 | */ | 5335 | */ | 
| 5311 | sctp_add_cmd_sf(commands, SCTP_CMD_DISCARD_PACKET,SCTP_NULL()); | 5336 | sctp_add_cmd_sf(commands, SCTP_CMD_DISCARD_PACKET,SCTP_NULL()); | 
| 5337 | sctp_add_cmd_sf(commands, SCTP_CMD_SET_SK_ERR, | ||
| 5338 | SCTP_ERROR(ECONNABORTED)); | ||
| 5312 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 5339 | sctp_add_cmd_sf(commands, SCTP_CMD_ASSOC_FAILED, | 
| 5313 | SCTP_U32(SCTP_ERROR_NO_DATA)); | 5340 | SCTP_U32(SCTP_ERROR_NO_DATA)); | 
| 5314 | SCTP_INC_STATS(SCTP_MIB_ABORTEDS); | 5341 | SCTP_INC_STATS(SCTP_MIB_ABORTEDS); | 
| diff --git a/net/sctp/socket.c b/net/sctp/socket.c index b6e4b89539b3..174d4d35e951 100644 --- a/net/sctp/socket.c +++ b/net/sctp/socket.c | |||
| @@ -1057,6 +1057,7 @@ static int __sctp_connect(struct sock* sk, | |||
| 1057 | inet_sk(sk)->dport = htons(asoc->peer.port); | 1057 | inet_sk(sk)->dport = htons(asoc->peer.port); | 
| 1058 | af = sctp_get_af_specific(to.sa.sa_family); | 1058 | af = sctp_get_af_specific(to.sa.sa_family); | 
| 1059 | af->to_sk_daddr(&to, sk); | 1059 | af->to_sk_daddr(&to, sk); | 
| 1060 | sk->sk_err = 0; | ||
| 1060 | 1061 | ||
| 1061 | timeo = sock_sndtimeo(sk, sk->sk_socket->file->f_flags & O_NONBLOCK); | 1062 | timeo = sock_sndtimeo(sk, sk->sk_socket->file->f_flags & O_NONBLOCK); | 
| 1062 | err = sctp_wait_for_connect(asoc, &timeo); | 1063 | err = sctp_wait_for_connect(asoc, &timeo); | 
| @@ -1228,7 +1229,7 @@ SCTP_STATIC void sctp_close(struct sock *sk, long timeout) | |||
| 1228 | 1229 | ||
| 1229 | ep = sctp_sk(sk)->ep; | 1230 | ep = sctp_sk(sk)->ep; | 
| 1230 | 1231 | ||
| 1231 | /* Walk all associations on a socket, not on an endpoint. */ | 1232 | /* Walk all associations on an endpoint. */ | 
| 1232 | list_for_each_safe(pos, temp, &ep->asocs) { | 1233 | list_for_each_safe(pos, temp, &ep->asocs) { | 
| 1233 | asoc = list_entry(pos, struct sctp_association, asocs); | 1234 | asoc = list_entry(pos, struct sctp_association, asocs); | 
| 1234 | 1235 | ||
| @@ -1241,13 +1242,13 @@ SCTP_STATIC void sctp_close(struct sock *sk, long timeout) | |||
| 1241 | if (sctp_state(asoc, CLOSED)) { | 1242 | if (sctp_state(asoc, CLOSED)) { | 
| 1242 | sctp_unhash_established(asoc); | 1243 | sctp_unhash_established(asoc); | 
| 1243 | sctp_association_free(asoc); | 1244 | sctp_association_free(asoc); | 
| 1245 | continue; | ||
| 1246 | } | ||
| 1247 | } | ||
| 1244 | 1248 | ||
| 1245 | } else if (sock_flag(sk, SOCK_LINGER) && | 1249 | if (sock_flag(sk, SOCK_LINGER) && !sk->sk_lingertime) | 
| 1246 | !sk->sk_lingertime) | 1250 | sctp_primitive_ABORT(asoc, NULL); | 
| 1247 | sctp_primitive_ABORT(asoc, NULL); | 1251 | else | 
| 1248 | else | ||
| 1249 | sctp_primitive_SHUTDOWN(asoc, NULL); | ||
| 1250 | } else | ||
| 1251 | sctp_primitive_SHUTDOWN(asoc, NULL); | 1252 | sctp_primitive_SHUTDOWN(asoc, NULL); | 
| 1252 | } | 1253 | } | 
| 1253 | 1254 | ||
| @@ -5317,6 +5318,7 @@ static int sctp_wait_for_sndbuf(struct sctp_association *asoc, long *timeo_p, | |||
| 5317 | */ | 5318 | */ | 
| 5318 | sctp_release_sock(sk); | 5319 | sctp_release_sock(sk); | 
| 5319 | current_timeo = schedule_timeout(current_timeo); | 5320 | current_timeo = schedule_timeout(current_timeo); | 
| 5321 | BUG_ON(sk != asoc->base.sk); | ||
| 5320 | sctp_lock_sock(sk); | 5322 | sctp_lock_sock(sk); | 
| 5321 | 5323 | ||
| 5322 | *timeo_p = current_timeo; | 5324 | *timeo_p = current_timeo; | 
| @@ -5604,12 +5606,14 @@ static void sctp_sock_migrate(struct sock *oldsk, struct sock *newsk, | |||
| 5604 | */ | 5606 | */ | 
| 5605 | newsp->type = type; | 5607 | newsp->type = type; | 
| 5606 | 5608 | ||
| 5607 | spin_lock_bh(&oldsk->sk_lock.slock); | 5609 | /* Mark the new socket "in-use" by the user so that any packets | 
| 5608 | /* Migrate the backlog from oldsk to newsk. */ | 5610 | * that may arrive on the association after we've moved it are | 
| 5609 | sctp_backlog_migrate(assoc, oldsk, newsk); | 5611 | * queued to the backlog. This prevents a potential race between | 
| 5610 | /* Migrate the association to the new socket. */ | 5612 | * backlog processing on the old socket and new-packet processing | 
| 5613 | * on the new socket. | ||
| 5614 | */ | ||
| 5615 | sctp_lock_sock(newsk); | ||
| 5611 | sctp_assoc_migrate(assoc, newsk); | 5616 | sctp_assoc_migrate(assoc, newsk); | 
| 5612 | spin_unlock_bh(&oldsk->sk_lock.slock); | ||
| 5613 | 5617 | ||
| 5614 | /* If the association on the newsk is already closed before accept() | 5618 | /* If the association on the newsk is already closed before accept() | 
| 5615 | * is called, set RCV_SHUTDOWN flag. | 5619 | * is called, set RCV_SHUTDOWN flag. | 
| @@ -5618,6 +5622,7 @@ static void sctp_sock_migrate(struct sock *oldsk, struct sock *newsk, | |||
| 5618 | newsk->sk_shutdown |= RCV_SHUTDOWN; | 5622 | newsk->sk_shutdown |= RCV_SHUTDOWN; | 
| 5619 | 5623 | ||
| 5620 | newsk->sk_state = SCTP_SS_ESTABLISHED; | 5624 | newsk->sk_state = SCTP_SS_ESTABLISHED; | 
| 5625 | sctp_release_sock(newsk); | ||
| 5621 | } | 5626 | } | 
| 5622 | 5627 | ||
| 5623 | /* This proto struct describes the ULP interface for SCTP. */ | 5628 | /* This proto struct describes the ULP interface for SCTP. */ | 
| diff --git a/security/selinux/ss/services.c b/security/selinux/ss/services.c index 7177e98df7f3..c284dbb8b8c0 100644 --- a/security/selinux/ss/services.c +++ b/security/selinux/ss/services.c | |||
| @@ -594,6 +594,10 @@ int security_sid_to_context(u32 sid, char **scontext, u32 *scontext_len) | |||
| 594 | 594 | ||
| 595 | *scontext_len = strlen(initial_sid_to_string[sid]) + 1; | 595 | *scontext_len = strlen(initial_sid_to_string[sid]) + 1; | 
| 596 | scontextp = kmalloc(*scontext_len,GFP_ATOMIC); | 596 | scontextp = kmalloc(*scontext_len,GFP_ATOMIC); | 
| 597 | if (!scontextp) { | ||
| 598 | rc = -ENOMEM; | ||
| 599 | goto out; | ||
| 600 | } | ||
| 597 | strcpy(scontextp, initial_sid_to_string[sid]); | 601 | strcpy(scontextp, initial_sid_to_string[sid]); | 
| 598 | *scontext = scontextp; | 602 | *scontext = scontextp; | 
| 599 | goto out; | 603 | goto out; | 
