diff options
author | Imre Kaloz <kaloz@openwrt.org> | 2008-01-28 23:44:06 +0000 |
---|---|---|
committer | Imre Kaloz <kaloz@openwrt.org> | 2008-01-28 23:44:06 +0000 |
commit | 8e05a28c505bf746bb781a93030f7b02956a72c8 (patch) | |
tree | 9951518c6a8954950cbadcebc5ca03033b73128c /target/linux/generic-2.6 | |
parent | c579f6b689d658854a62cf2ef47de846fb715257 (diff) | |
download | upstream-8e05a28c505bf746bb781a93030f7b02956a72c8.tar.gz upstream-8e05a28c505bf746bb781a93030f7b02956a72c8.tar.bz2 upstream-8e05a28c505bf746bb781a93030f7b02956a72c8.zip |
add upstream git patch for arch/powerpc
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@10300 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/generic-2.6')
-rw-r--r-- | target/linux/generic-2.6/patches-2.6.24/700-powerpc_git.patch | 71515 |
1 files changed, 71515 insertions, 0 deletions
diff --git a/target/linux/generic-2.6/patches-2.6.24/700-powerpc_git.patch b/target/linux/generic-2.6/patches-2.6.24/700-powerpc_git.patch new file mode 100644 index 0000000000..75c8c2edc3 --- /dev/null +++ b/target/linux/generic-2.6/patches-2.6.24/700-powerpc_git.patch @@ -0,0 +1,71515 @@ +diff -x .git -x .gitignore -Nur linux-2.6.24/Documentation/kernel-parameters.txt powerpc.git/Documentation/kernel-parameters.txt +--- linux-2.6.24/Documentation/kernel-parameters.txt 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/Documentation/kernel-parameters.txt 2008-01-28 20:25:33.000000000 +0100 +@@ -686,6 +686,7 @@ + See Documentation/isdn/README.HiSax. + + hugepages= [HW,X86-32,IA-64] Maximal number of HugeTLB pages. ++ hugepagesz= [HW,IA-64,PPC] The size of the HugeTLB pages. + + i8042.direct [HW] Put keyboard port into non-translated mode + i8042.dumbkbd [HW] Pretend that controller can only read data from +diff -x .git -x .gitignore -Nur linux-2.6.24/Documentation/powerpc/00-INDEX powerpc.git/Documentation/powerpc/00-INDEX +--- linux-2.6.24/Documentation/powerpc/00-INDEX 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/Documentation/powerpc/00-INDEX 2008-01-28 20:25:33.000000000 +0100 +@@ -28,3 +28,6 @@ + - info on sound support under Linux/PPC + zImage_layout.txt + - info on the kernel images for Linux/PPC ++qe_firmware.txt ++ - describes the layout of firmware binaries for the Freescale QUICC ++ Engine and the code that parses and uploads the microcode therein. +diff -x .git -x .gitignore -Nur linux-2.6.24/Documentation/powerpc/booting-without-of.txt powerpc.git/Documentation/powerpc/booting-without-of.txt +--- linux-2.6.24/Documentation/powerpc/booting-without-of.txt 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/Documentation/powerpc/booting-without-of.txt 2008-01-28 20:25:33.000000000 +0100 +@@ -52,7 +52,11 @@ + i) Freescale QUICC Engine module (QE) + j) CFI or JEDEC memory-mapped NOR flash + k) Global Utilities Block +- l) Xilinx IP cores ++ l) Freescale Communications Processor Module ++ m) Chipselect/Local Bus ++ n) 4xx/Axon EMAC ethernet nodes ++ o) Xilinx IP cores ++ p) Freescale Synchronous Serial Interface + + VII - Specifying interrupt information for devices + 1) interrupts property +@@ -671,10 +675,10 @@ + + In general, the format of an address for a device is defined by the + parent bus type, based on the #address-cells and #size-cells +-property. In the absence of such a property, the parent's parent +-values are used, etc... The kernel requires the root node to have +-those properties defining addresses format for devices directly mapped +-on the processor bus. ++properties. Note that the parent's parent definitions of #address-cells ++and #size-cells are not inhereted so every node with children must specify ++them. The kernel requires the root node to have those properties defining ++addresses format for devices directly mapped on the processor bus. + + Those 2 properties define 'cells' for representing an address and a + size. A "cell" is a 32-bit number. For example, if both contain 2 +@@ -711,13 +715,14 @@ + like address space bits, you'll have to add a bus translator to the + prom_parse.c file of the recent kernels for your bus type. + +-The "reg" property only defines addresses and sizes (if #size-cells +-is non-0) within a given bus. In order to translate addresses upward ++The "reg" property only defines addresses and sizes (if #size-cells is ++non-0) within a given bus. In order to translate addresses upward + (that is into parent bus addresses, and possibly into CPU physical + addresses), all busses must contain a "ranges" property. If the + "ranges" property is missing at a given level, it's assumed that +-translation isn't possible. The format of the "ranges" property for a +-bus is a list of: ++translation isn't possible, i.e., the registers are not visible on the ++parent bus. The format of the "ranges" property for a bus is a list ++of: + + bus address, parent bus address, size + +@@ -735,6 +740,10 @@ + 1/1 format, unless the processor supports physical addresses greater + than 32-bits, in which case a 2/1 format is recommended. + ++Alternatively, the "ranges" property may be empty, indicating that the ++registers are visible on the parent bus using an identity mapping ++translation. In other words, the parent bus address space is the same ++as the child bus address space. + + 2) Note about "compatible" properties + ------------------------------------- +@@ -1218,16 +1227,14 @@ + + Required properties: + - reg : Offset and length of the register set for the device +- - device_type : Should be "mdio" + - compatible : Should define the compatible device type for the +- mdio. Currently, this is most likely to be "gianfar" ++ mdio. Currently, this is most likely to be "fsl,gianfar-mdio" + + Example: + + mdio@24520 { + reg = <24520 20>; +- device_type = "mdio"; +- compatible = "gianfar"; ++ compatible = "fsl,gianfar-mdio"; + + ethernet-phy@0 { + ...... +@@ -1254,6 +1261,10 @@ + services interrupts for this device. + - phy-handle : The phandle for the PHY connected to this ethernet + controller. ++ - fixed-link : <a b c d e> where a is emulated phy id - choose any, ++ but unique to the all specified fixed-links, b is duplex - 0 half, ++ 1 full, c is link speed - d#10/d#100/d#1000, d is pause - 0 no ++ pause, 1 pause, e is asym_pause - 0 no asym_pause, 1 asym_pause. + + Recommended properties: + +@@ -1408,7 +1419,6 @@ + + Example multi port host USB controller device node : + usb@22000 { +- device_type = "usb"; + compatible = "fsl-usb2-mph"; + reg = <22000 1000>; + #address-cells = <1>; +@@ -1422,7 +1432,6 @@ + + Example dual role USB controller device node : + usb@23000 { +- device_type = "usb"; + compatible = "fsl-usb2-dr"; + reg = <23000 1000>; + #address-cells = <1>; +@@ -1586,7 +1595,6 @@ + iii) USB (Universal Serial Bus Controller) + + Required properties: +- - device_type : should be "usb". + - compatible : could be "qe_udc" or "fhci-hcd". + - mode : the could be "host" or "slave". + - reg : Offset and length of the register set for the device +@@ -1600,7 +1608,6 @@ + + Example(slave): + usb@6c0 { +- device_type = "usb"; + compatible = "qe_udc"; + reg = <6c0 40>; + interrupts = <8b 0>; +@@ -1613,7 +1620,7 @@ + + Required properties: + - device_type : should be "network", "hldc", "uart", "transparent" +- "bisync" or "atm". ++ "bisync", "atm", or "serial". + - compatible : could be "ucc_geth" or "fsl_atm" and so on. + - model : should be "UCC". + - device-id : the ucc number(1-8), corresponding to UCCx in UM. +@@ -1626,6 +1633,26 @@ + - interrupt-parent : the phandle for the interrupt controller that + services interrupts for this device. + - pio-handle : The phandle for the Parallel I/O port configuration. ++ - port-number : for UART drivers, the port number to use, between 0 and 3. ++ This usually corresponds to the /dev/ttyQE device, e.g. <0> = /dev/ttyQE0. ++ The port number is added to the minor number of the device. Unlike the ++ CPM UART driver, the port-number is required for the QE UART driver. ++ - soft-uart : for UART drivers, if specified this means the QE UART device ++ driver should use "Soft-UART" mode, which is needed on some SOCs that have ++ broken UART hardware. Soft-UART is provided via a microcode upload. ++ - rx-clock-name: the UCC receive clock source ++ "none": clock source is disabled ++ "brg1" through "brg16": clock source is BRG1-BRG16, respectively ++ "clk1" through "clk24": clock source is CLK1-CLK24, respectively ++ - tx-clock-name: the UCC transmit clock source ++ "none": clock source is disabled ++ "brg1" through "brg16": clock source is BRG1-BRG16, respectively ++ "clk1" through "clk24": clock source is CLK1-CLK24, respectively ++ The following two properties are deprecated. rx-clock has been replaced ++ with rx-clock-name, and tx-clock has been replaced with tx-clock-name. ++ Drivers that currently use the deprecated properties should continue to ++ do so, in order to support older device trees, but they should be updated ++ to check for the new properties first. + - rx-clock : represents the UCC receive clock source. + 0x00 : clock source is disabled; + 0x1~0x10 : clock source is BRG1~BRG16 respectively; +@@ -1772,6 +1799,32 @@ + }; + }; + ++ viii) Uploaded QE firmware ++ ++ If a new firwmare has been uploaded to the QE (usually by the ++ boot loader), then a 'firmware' child node should be added to the QE ++ node. This node provides information on the uploaded firmware that ++ device drivers may need. ++ ++ Required properties: ++ - id: The string name of the firmware. This is taken from the 'id' ++ member of the qe_firmware structure of the uploaded firmware. ++ Device drivers can search this string to determine if the ++ firmware they want is already present. ++ - extended-modes: The Extended Modes bitfield, taken from the ++ firmware binary. It is a 64-bit number represented ++ as an array of two 32-bit numbers. ++ - virtual-traps: The virtual traps, taken from the firmware binary. ++ It is an array of 8 32-bit numbers. ++ ++ Example: ++ ++ firmware { ++ id = "Soft-UART"; ++ extended-modes = <0 0>; ++ virtual-traps = <0 0 0 0 0 0 0 0>; ++ } ++ + j) CFI or JEDEC memory-mapped NOR flash + + Flash chips (Memory Technology Devices) are often used for solid state +@@ -2075,8 +2128,7 @@ + + Example: + localbus@f0010100 { +- compatible = "fsl,mpc8272ads-localbus", +- "fsl,mpc8272-localbus", ++ compatible = "fsl,mpc8272-localbus", + "fsl,pq2-localbus"; + #address-cells = <2>; + #size-cells = <1>; +@@ -2254,7 +2306,7 @@ + available. + For Axon: 0x0000012a + +- l) Xilinx IP cores ++ o) Xilinx IP cores + + The Xilinx EDK toolchain ships with a set of IP cores (devices) for use + in Xilinx Spartan and Virtex FPGAs. The devices cover the whole range +@@ -2276,7 +2328,7 @@ + properties of the device node. In general, device nodes for IP-cores + will take the following form: + +- (name)@(base-address) { ++ (name): (generic-name)@(base-address) { + compatible = "xlnx,(ip-core-name)-(HW_VER)" + [, (list of compatible devices), ...]; + reg = <(baseaddr) (size)>; +@@ -2286,6 +2338,9 @@ + xlnx,(parameter2) = <(int-value)>; + }; + ++ (generic-name): an open firmware-style name that describes the ++ generic class of device. Preferably, this is one word, such ++ as 'serial' or 'ethernet'. + (ip-core-name): the name of the ip block (given after the BEGIN + directive in system.mhs). Should be in lowercase + and all underscores '_' converted to dashes '-'. +@@ -2294,9 +2349,9 @@ + dropped from the parameter name, the name is converted + to lowercase and all underscore '_' characters are + converted to dashes '-'. +- (baseaddr): the C_BASEADDR parameter. ++ (baseaddr): the baseaddr parameter value (often named C_BASEADDR). + (HW_VER): from the HW_VER parameter. +- (size): equals C_HIGHADDR - C_BASEADDR + 1 ++ (size): the address range size (often C_HIGHADDR - C_BASEADDR + 1). + + Typically, the compatible list will include the exact IP core version + followed by an older IP core version which implements the same +@@ -2326,11 +2381,11 @@ + + becomes the following device tree node: + +- opb-uartlite-0@ec100000 { ++ opb_uartlite_0: serial@ec100000 { + device_type = "serial"; + compatible = "xlnx,opb-uartlite-1.00.b"; + reg = <ec100000 10000>; +- interrupt-parent = <&opb-intc>; ++ interrupt-parent = <&opb_intc_0>; + interrupts = <1 0>; // got this from the opb_intc parameters + current-speed = <d#115200>; // standard serial device prop + clock-frequency = <d#50000000>; // standard serial device prop +@@ -2339,16 +2394,19 @@ + xlnx,use-parity = <0>; + }; + +- Some IP cores actually implement 2 or more logical devices. In this case, +- the device should still describe the whole IP core with a single node +- and add a child node for each logical device. The ranges property can +- be used to translate from parent IP-core to the registers of each device. +- (Note: this makes the assumption that both logical devices have the same +- bus binding. If this is not true, then separate nodes should be used for +- each logical device). The 'cell-index' property can be used to enumerate +- logical devices within an IP core. For example, the following is the +- system.mhs entry for the dual ps2 controller found on the ml403 reference +- design. ++ Some IP cores actually implement 2 or more logical devices. In ++ this case, the device should still describe the whole IP core with ++ a single node and add a child node for each logical device. The ++ ranges property can be used to translate from parent IP-core to the ++ registers of each device. In addition, the parent node should be ++ compatible with the bus type 'xlnx,compound', and should contain ++ #address-cells and #size-cells, as with any other bus. (Note: this ++ makes the assumption that both logical devices have the same bus ++ binding. If this is not true, then separate nodes should be used ++ for each logical device). The 'cell-index' property can be used to ++ enumerate logical devices within an IP core. For example, the ++ following is the system.mhs entry for the dual ps2 controller found ++ on the ml403 reference design. + + BEGIN opb_ps2_dual_ref + PARAMETER INSTANCE = opb_ps2_dual_ref_0 +@@ -2370,21 +2428,24 @@ + + It would result in the following device tree nodes: + +- opb_ps2_dual_ref_0@a9000000 { ++ opb_ps2_dual_ref_0: opb-ps2-dual-ref@a9000000 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ compatible = "xlnx,compound"; + ranges = <0 a9000000 2000>; + // If this device had extra parameters, then they would + // go here. + ps2@0 { + compatible = "xlnx,opb-ps2-dual-ref-1.00.a"; + reg = <0 40>; +- interrupt-parent = <&opb-intc>; ++ interrupt-parent = <&opb_intc_0>; + interrupts = <3 0>; + cell-index = <0>; + }; + ps2@1000 { + compatible = "xlnx,opb-ps2-dual-ref-1.00.a"; + reg = <1000 40>; +- interrupt-parent = <&opb-intc>; ++ interrupt-parent = <&opb_intc_0>; + interrupts = <3 0>; + cell-index = <0>; + }; +@@ -2447,17 +2508,18 @@ + + Gives this device tree (some properties removed for clarity): + +- plb-v34-0 { ++ plb@0 { + #address-cells = <1>; + #size-cells = <1>; ++ compatible = "xlnx,plb-v34-1.02.a"; + device_type = "ibm,plb"; + ranges; // 1:1 translation + +- plb-bram-if-cntrl-0@ffff0000 { ++ plb_bram_if_cntrl_0: bram@ffff0000 { + reg = <ffff0000 10000>; + } + +- opb-v20-0 { ++ opb@20000000 { + #address-cells = <1>; + #size-cells = <1>; + ranges = <20000000 20000000 20000000 +@@ -2465,11 +2527,11 @@ + 80000000 80000000 40000000 + c0000000 c0000000 20000000>; + +- opb-uart16550-0@a0000000 { ++ opb_uart16550_0: serial@a0000000 { + reg = <a00000000 2000>; + }; + +- opb-intc-0@d1000fc0 { ++ opb_intc_0: interrupt-controller@d1000fc0 { + reg = <d1000fc0 20>; + }; + }; +@@ -2514,6 +2576,46 @@ + Requred properties: + - current-speed : Baud rate of uartlite + ++ p) Freescale Synchronous Serial Interface ++ ++ The SSI is a serial device that communicates with audio codecs. It can ++ be programmed in AC97, I2S, left-justified, or right-justified modes. ++ ++ Required properties: ++ - compatible : compatible list, containing "fsl,ssi" ++ - cell-index : the SSI, <0> = SSI1, <1> = SSI2, and so on ++ - reg : offset and length of the register set for the device ++ - interrupts : <a b> where a is the interrupt number and b is a ++ field that represents an encoding of the sense and ++ level information for the interrupt. This should be ++ encoded based on the information in section 2) ++ depending on the type of interrupt controller you ++ have. ++ - interrupt-parent : the phandle for the interrupt controller that ++ services interrupts for this device. ++ - fsl,mode : the operating mode for the SSI interface ++ "i2s-slave" - I2S mode, SSI is clock slave ++ "i2s-master" - I2S mode, SSI is clock master ++ "lj-slave" - left-justified mode, SSI is clock slave ++ "lj-master" - l.j. mode, SSI is clock master ++ "rj-slave" - right-justified mode, SSI is clock slave ++ "rj-master" - r.j., SSI is clock master ++ "ac97-slave" - AC97 mode, SSI is clock slave ++ "ac97-master" - AC97 mode, SSI is clock master ++ ++ Optional properties: ++ - codec-handle : phandle to a 'codec' node that defines an audio ++ codec connected to this SSI. This node is typically ++ a child of an I2C or other control node. ++ ++ Child 'codec' node required properties: ++ - compatible : compatible list, contains the name of the codec ++ ++ Child 'codec' node optional properties: ++ - clock-frequency : The frequency of the input clock, which typically ++ comes from an on-board dedicated oscillator. ++ ++ + More devices will be defined as this spec matures. + + VII - Specifying interrupt information for devices +diff -x .git -x .gitignore -Nur linux-2.6.24/Documentation/powerpc/qe_firmware.txt powerpc.git/Documentation/powerpc/qe_firmware.txt +--- linux-2.6.24/Documentation/powerpc/qe_firmware.txt 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/Documentation/powerpc/qe_firmware.txt 2008-01-28 20:25:33.000000000 +0100 +@@ -0,0 +1,295 @@ ++ Freescale QUICC Engine Firmware Uploading ++ ----------------------------------------- ++ ++(c) 2007 Timur Tabi <timur at freescale.com>, ++ Freescale Semiconductor ++ ++Table of Contents ++================= ++ ++ I - Software License for Firmware ++ ++ II - Microcode Availability ++ ++ III - Description and Terminology ++ ++ IV - Microcode Programming Details ++ ++ V - Firmware Structure Layout ++ ++ VI - Sample Code for Creating Firmware Files ++ ++Revision Information ++==================== ++ ++November 30, 2007: Rev 1.0 - Initial version ++ ++I - Software License for Firmware ++================================= ++ ++Each firmware file comes with its own software license. For information on ++the particular license, please see the license text that is distributed with ++the firmware. ++ ++II - Microcode Availability ++=========================== ++ ++Firmware files are distributed through various channels. Some are available on ++http://opensource.freescale.com. For other firmware files, please contact ++your Freescale representative or your operating system vendor. ++ ++III - Description and Terminology ++================================ ++ ++In this document, the term 'microcode' refers to the sequence of 32-bit ++integers that compose the actual QE microcode. ++ ++The term 'firmware' refers to a binary blob that contains the microcode as ++well as other data that ++ ++ 1) describes the microcode's purpose ++ 2) describes how and where to upload the microcode ++ 3) specifies the values of various registers ++ 4) includes additional data for use by specific device drivers ++ ++Firmware files are binary files that contain only a firmware. ++ ++IV - Microcode Programming Details ++=================================== ++ ++The QE architecture allows for only one microcode present in I-RAM for each ++RISC processor. To replace any current microcode, a full QE reset (which ++disables the microcode) must be performed first. ++ ++QE microcode is uploaded using the following procedure: ++ ++1) The microcode is placed into I-RAM at a specific location, using the ++ IRAM.IADD and IRAM.IDATA registers. ++ ++2) The CERCR.CIR bit is set to 0 or 1, depending on whether the firmware ++ needs split I-RAM. Split I-RAM is only meaningful for SOCs that have ++ QEs with multiple RISC processors, such as the 8360. Splitting the I-RAM ++ allows each processor to run a different microcode, effectively creating an ++ asymmetric multiprocessing (AMP) system. ++ ++3) The TIBCR trap registers are loaded with the addresses of the trap handlers ++ in the microcode. ++ ++4) The RSP.ECCR register is programmed with the value provided. ++ ++5) If necessary, device drivers that need the virtual traps and extended mode ++ data will use them. ++ ++Virtual Microcode Traps ++ ++These virtual traps are conditional branches in the microcode. These are ++"soft" provisional introduced in the ROMcode in order to enable higher ++flexibility and save h/w traps If new features are activated or an issue is ++being fixed in the RAM package utilizing they should be activated. This data ++structure signals the microcode which of these virtual traps is active. ++ ++This structure contains 6 words that the application should copy to some ++specific been defined. This table describes the structure. ++ ++ --------------------------------------------------------------- ++ | Offset in | | Destination Offset | Size of | ++ | array | Protocol | within PRAM | Operand | ++ --------------------------------------------------------------| ++ | 0 | Ethernet | 0xF8 | 4 bytes | ++ | | interworking | | | ++ --------------------------------------------------------------- ++ | 4 | ATM | 0xF8 | 4 bytes | ++ | | interworking | | | ++ --------------------------------------------------------------- ++ | 8 | PPP | 0xF8 | 4 bytes | ++ | | interworking | | | ++ --------------------------------------------------------------- ++ | 12 | Ethernet RX | 0x22 | 1 byte | ++ | | Distributor Page | | | ++ --------------------------------------------------------------- ++ | 16 | ATM Globtal | 0x28 | 1 byte | ++ | | Params Table | | | ++ --------------------------------------------------------------- ++ | 20 | Insert Frame | 0xF8 | 4 bytes | ++ --------------------------------------------------------------- ++ ++ ++Extended Modes ++ ++This is a double word bit array (64 bits) that defines special functionality ++which has an impact on the softwarew drivers. Each bit has its own impact ++and has special instructions for the s/w associated with it. This structure is ++described in this table: ++ ++ ----------------------------------------------------------------------- ++ | Bit # | Name | Description | ++ ----------------------------------------------------------------------- ++ | 0 | General | Indicates that prior to each host command | ++ | | push command | given by the application, the software must | ++ | | | assert a special host command (push command)| ++ | | | CECDR = 0x00800000. | ++ | | | CECR = 0x01c1000f. | ++ ----------------------------------------------------------------------- ++ | 1 | UCC ATM | Indicates that after issuing ATM RX INIT | ++ | | RX INIT | command, the host must issue another special| ++ | | push command | command (push command) and immediately | ++ | | | following that re-issue the ATM RX INIT | ++ | | | command. (This makes the sequence of | ++ | | | initializing the ATM receiver a sequence of | ++ | | | three host commands) | ++ | | | CECDR = 0x00800000. | ++ | | | CECR = 0x01c1000f. | ++ ----------------------------------------------------------------------- ++ | 2 | Add/remove | Indicates that following the specific host | ++ | | command | command: "Add/Remove entry in Hash Lookup | ++ | | validation | Table" used in Interworking setup, the user | ++ | | | must issue another command. | ++ | | | CECDR = 0xce000003. | ++ | | | CECR = 0x01c10f58. | ++ ----------------------------------------------------------------------- ++ | 3 | General push | Indicates that the s/w has to initialize | ++ | | command | some pointers in the Ethernet thread pages | ++ | | | which are used when Header Compression is | ++ | | | activated. The full details of these | ++ | | | pointers is located in the software drivers.| ++ ----------------------------------------------------------------------- ++ | 4 | General push | Indicates that after issuing Ethernet TX | ++ | | command | INIT command, user must issue this command | ++ | | | for each SNUM of Ethernet TX thread. | ++ | | | CECDR = 0x00800003. | ++ | | | CECR = 0x7'b{0}, 8'b{Enet TX thread SNUM}, | ++ | | | 1'b{1}, 12'b{0}, 4'b{1} | ++ ----------------------------------------------------------------------- ++ | 5 - 31 | N/A | Reserved, set to zero. | ++ ----------------------------------------------------------------------- ++ ++V - Firmware Structure Layout ++============================== ++ ++QE microcode from Freescale is typically provided as a header file. This ++header file contains macros that define the microcode binary itself as well as ++some other data used in uploading that microcode. The format of these files ++do not lend themselves to simple inclusion into other code. Hence, ++the need for a more portable format. This section defines that format. ++ ++Instead of distributing a header file, the microcode and related data are ++embedded into a binary blob. This blob is passed to the qe_upload_firmware() ++function, which parses the blob and performs everything necessary to upload ++the microcode. ++ ++All integers are big-endian. See the comments for function ++qe_upload_firmware() for up-to-date implementation information. ++ ++This structure supports versioning, where the version of the structure is ++embedded into the structure itself. To ensure forward and backwards ++compatibility, all versions of the structure must use the same 'qe_header' ++structure at the beginning. ++ ++'header' (type: struct qe_header): ++ The 'length' field is the size, in bytes, of the entire structure, ++ including all the microcode embedded in it, as well as the CRC (if ++ present). ++ ++ The 'magic' field is an array of three bytes that contains the letters ++ 'Q', 'E', and 'F'. This is an identifier that indicates that this ++ structure is a QE Firmware structure. ++ ++ The 'version' field is a single byte that indicates the version of this ++ structure. If the layout of the structure should ever need to be ++ changed to add support for additional types of microcode, then the ++ version number should also be changed. ++ ++The 'id' field is a null-terminated string(suitable for printing) that ++identifies the firmware. ++ ++The 'count' field indicates the number of 'microcode' structures. There ++must be one and only one 'microcode' structure for each RISC processor. ++Therefore, this field also represents the number of RISC processors for this ++SOC. ++ ++The 'soc' structure contains the SOC numbers and revisions used to match ++the microcode to the SOC itself. Normally, the microcode loader should ++check the data in this structure with the SOC number and revisions, and ++only upload the microcode if there's a match. However, this check is not ++made on all platforms. ++ ++Although it is not recommended, you can specify '0' in the soc.model ++field to skip matching SOCs altogether. ++ ++The 'model' field is a 16-bit number that matches the actual SOC. The ++'major' and 'minor' fields are the major and minor revision numbrs, ++respectively, of the SOC. ++ ++For example, to match the 8323, revision 1.0: ++ soc.model = 8323 ++ soc.major = 1 ++ soc.minor = 0 ++ ++'padding' is neccessary for structure alignment. This field ensures that the ++'extended_modes' field is aligned on a 64-bit boundary. ++ ++'extended_modes' is a bitfield that defines special functionality which has an ++impact on the device drivers. Each bit has its own impact and has special ++instructions for the driver associated with it. This field is stored in ++the QE library and available to any driver that calles qe_get_firmware_info(). ++ ++'vtraps' is an array of 8 words that contain virtual trap values for each ++virtual traps. As with 'extended_modes', this field is stored in the QE ++library and available to any driver that calles qe_get_firmware_info(). ++ ++'microcode' (type: struct qe_microcode): ++ For each RISC processor there is one 'microcode' structure. The first ++ 'microcode' structure is for the first RISC, and so on. ++ ++ The 'id' field is a null-terminated string suitable for printing that ++ identifies this particular microcode. ++ ++ 'traps' is an array of 16 words that contain hardware trap values ++ for each of the 16 traps. If trap[i] is 0, then this particular ++ trap is to be ignored (i.e. not written to TIBCR[i]). The entire value ++ is written as-is to the TIBCR[i] register, so be sure to set the EN ++ and T_IBP bits if necessary. ++ ++ 'eccr' is the value to program into the ECCR register. ++ ++ 'iram_offset' is the offset into IRAM to start writing the ++ microcode. ++ ++ 'count' is the number of 32-bit words in the microcode. ++ ++ 'code_offset' is the offset, in bytes, from the beginning of this ++ structure where the microcode itself can be found. The first ++ microcode binary should be located immediately after the 'microcode' ++ array. ++ ++ 'major', 'minor', and 'revision' are the major, minor, and revision ++ version numbers, respectively, of the microcode. If all values are 0, ++ then these fields are ignored. ++ ++ 'reserved' is necessary for structure alignment. Since 'microcode' ++ is an array, the 64-bit 'extended_modes' field needs to be aligned ++ on a 64-bit boundary, and this can only happen if the size of ++ 'microcode' is a multiple of 8 bytes. To ensure that, we add ++ 'reserved'. ++ ++After the last microcode is a 32-bit CRC. It can be calculated using ++this algorithm: ++ ++u32 crc32(const u8 *p, unsigned int len) ++{ ++ unsigned int i; ++ u32 crc = 0; ++ ++ while (len--) { ++ crc ^= *p++; ++ for (i = 0; i < 8; i++) ++ crc = (crc >> 1) ^ ((crc & 1) ? 0xedb88320 : 0); ++ } ++ return crc; ++} ++ ++VI - Sample Code for Creating Firmware Files ++============================================ ++ ++A Python program that creates firmware binaries from the header files normally ++distributed by Freescale can be found on http://opensource.freescale.com. +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/Kconfig powerpc.git/arch/powerpc/Kconfig +--- linux-2.6.24/arch/powerpc/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/Kconfig 2008-01-28 21:37:04.000000000 +0100 +@@ -140,6 +140,9 @@ + Used to allow a board to specify it wants a uImage built by default + default n + ++config REDBOOT ++ bool ++ + config PPC64_SWSUSP + bool + depends on PPC64 && (BROKEN || (PPC_PMAC64 && EXPERIMENTAL)) +@@ -160,11 +163,13 @@ + + config PPC_OF_PLATFORM_PCI + bool ++ depends on PCI + depends on PPC64 # not supported on 32 bits yet + default n + + source "init/Kconfig" + ++source "arch/powerpc/sysdev/Kconfig" + source "arch/powerpc/platforms/Kconfig" + + menu "Kernel options" +@@ -417,7 +422,7 @@ + + config ISA_DMA_API + bool +- default y ++ default !PPC_ISERIES || PCI + + menu "Bus options" + +@@ -467,7 +472,7 @@ + config PCI + bool "PCI support" if 40x || CPM2 || PPC_83xx || PPC_85xx || PPC_86xx \ + || PPC_MPC52xx || (EMBEDDED && (PPC_PSERIES || PPC_ISERIES)) \ +- || PPC_PS3 ++ || PPC_PS3 || 44x + default y if !40x && !CPM2 && !8xx && !PPC_83xx \ + && !PPC_85xx && !PPC_86xx + default PCI_PERMEDIA if !4xx && !CPM2 && !8xx +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/Kconfig.debug powerpc.git/arch/powerpc/Kconfig.debug +--- linux-2.6.24/arch/powerpc/Kconfig.debug 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/Kconfig.debug 2008-01-28 20:25:49.000000000 +0100 +@@ -151,6 +151,13 @@ + + config PPC_EARLY_DEBUG + bool "Early debugging (dangerous)" ++ help ++ Say Y to enable some early debugging facilities that may be available ++ for your processor/board combination. Those facilities are hacks ++ intended to debug problems early during boot, this should not be ++ enabled in a production kernel. ++ Note that enabling this will also cause the kernel default log level ++ to be pushed to max automatically very early during boot + + choice + prompt "Early debugging console" +@@ -218,7 +225,16 @@ + depends on 44x + help + Select this to enable early debugging for IBM 44x chips via the +- inbuilt serial port. ++ inbuilt serial port. If you enable this, ensure you set ++ PPC_EARLY_DEBUG_44x_PHYSLOW below to suit your target board. ++ ++config PPC_EARLY_DEBUG_40x ++ bool "Early serial debugging for IBM/AMCC 40x CPUs" ++ depends on 40x ++ help ++ Select this to enable early debugging for IBM 40x chips via the ++ inbuilt serial port. This works on chips with a 16550 compatible ++ UART. Xilinx chips with uartlite cannot use this option. + + config PPC_EARLY_DEBUG_CPM + bool "Early serial debugging for Freescale CPM-based serial ports" +@@ -235,12 +251,20 @@ + hex "Low 32 bits of early debug UART physical address" + depends on PPC_EARLY_DEBUG_44x + default "0x40000200" ++ help ++ You probably want 0x40000200 for ebony boards and ++ 0x40000300 for taishan + + config PPC_EARLY_DEBUG_44x_PHYSHIGH + hex "EPRN of early debug UART physical address" + depends on PPC_EARLY_DEBUG_44x + default "0x1" + ++config PPC_EARLY_DEBUG_40x_PHYSADDR ++ hex "Early debug UART physical address" ++ depends on PPC_EARLY_DEBUG_40x ++ default "0xef600300" ++ + config PPC_EARLY_DEBUG_CPM_ADDR + hex "CPM UART early debug transmit descriptor address" + depends on PPC_EARLY_DEBUG_CPM +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/Makefile powerpc.git/arch/powerpc/Makefile +--- linux-2.6.24/arch/powerpc/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -167,6 +167,9 @@ + $(BOOT_TARGETS): vmlinux + $(Q)$(MAKE) ARCH=ppc64 $(build)=$(boot) $(patsubst %,$(boot)/%,$@) + ++bootwrapper_install: ++ $(Q)$(MAKE) ARCH=ppc64 $(build)=$(boot) $(patsubst %,$(boot)/%,$@) ++ + define archhelp + @echo '* zImage - Compressed kernel image (arch/$(ARCH)/boot/zImage.*)' + @echo ' install - Install kernel using' +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/4xx.c powerpc.git/arch/powerpc/boot/4xx.c +--- linux-2.6.24/arch/powerpc/boot/4xx.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/4xx.c 2008-01-28 20:25:49.000000000 +0100 +@@ -22,16 +22,14 @@ + #include "dcr.h" + + /* Read the 4xx SDRAM controller to get size of system memory. */ +-void ibm4xx_fixup_memsize(void) ++void ibm4xx_sdram_fixup_memsize(void) + { + int i; + unsigned long memsize, bank_config; + + memsize = 0; + for (i = 0; i < ARRAY_SIZE(sdram_bxcr); i++) { +- mtdcr(DCRN_SDRAM0_CFGADDR, sdram_bxcr[i]); +- bank_config = mfdcr(DCRN_SDRAM0_CFGDATA); +- ++ bank_config = SDRAM0_READ(sdram_bxcr[i]); + if (bank_config & SDRAM_CONFIG_BANK_ENABLE) + memsize += SDRAM_CONFIG_BANK_SIZE(bank_config); + } +@@ -39,6 +37,69 @@ + dt_fixup_memory(0, memsize); + } + ++/* Read the 440SPe MQ controller to get size of system memory. */ ++#define DCRN_MQ0_B0BAS 0x40 ++#define DCRN_MQ0_B1BAS 0x41 ++#define DCRN_MQ0_B2BAS 0x42 ++#define DCRN_MQ0_B3BAS 0x43 ++ ++static u64 ibm440spe_decode_bas(u32 bas) ++{ ++ u64 base = ((u64)(bas & 0xFFE00000u)) << 2; ++ ++ /* open coded because I'm paranoid about invalid values */ ++ switch ((bas >> 4) & 0xFFF) { ++ case 0: ++ return 0; ++ case 0xffc: ++ return base + 0x000800000ull; ++ case 0xff8: ++ return base + 0x001000000ull; ++ case 0xff0: ++ return base + 0x002000000ull; ++ case 0xfe0: ++ return base + 0x004000000ull; ++ case 0xfc0: ++ return base + 0x008000000ull; ++ case 0xf80: ++ return base + 0x010000000ull; ++ case 0xf00: ++ return base + 0x020000000ull; ++ case 0xe00: ++ return base + 0x040000000ull; ++ case 0xc00: ++ return base + 0x080000000ull; ++ case 0x800: ++ return base + 0x100000000ull; ++ } ++ printf("Memory BAS value 0x%08x unsupported !\n", bas); ++ return 0; ++} ++ ++void ibm440spe_fixup_memsize(void) ++{ ++ u64 banktop, memsize = 0; ++ ++ /* Ultimately, we should directly construct the memory node ++ * so we are able to handle holes in the memory address space ++ */ ++ banktop = ibm440spe_decode_bas(mfdcr(DCRN_MQ0_B0BAS)); ++ if (banktop > memsize) ++ memsize = banktop; ++ banktop = ibm440spe_decode_bas(mfdcr(DCRN_MQ0_B1BAS)); ++ if (banktop > memsize) ++ memsize = banktop; ++ banktop = ibm440spe_decode_bas(mfdcr(DCRN_MQ0_B2BAS)); ++ if (banktop > memsize) ++ memsize = banktop; ++ banktop = ibm440spe_decode_bas(mfdcr(DCRN_MQ0_B3BAS)); ++ if (banktop > memsize) ++ memsize = banktop; ++ ++ dt_fixup_memory(0, memsize); ++} ++ ++ + /* 4xx DDR1/2 Denali memory controller support */ + /* DDR0 registers */ + #define DDR0_02 2 +@@ -77,19 +138,13 @@ + + #define DDR_GET_VAL(val, mask, shift) (((val) >> (shift)) & (mask)) + +-static inline u32 mfdcr_sdram0(u32 reg) +-{ +- mtdcr(DCRN_SDRAM0_CFGADDR, reg); +- return mfdcr(DCRN_SDRAM0_CFGDATA); +-} +- + void ibm4xx_denali_fixup_memsize(void) + { + u32 val, max_cs, max_col, max_row; + u32 cs, col, row, bank, dpath; + unsigned long memsize; + +- val = mfdcr_sdram0(DDR0_02); ++ val = SDRAM0_READ(DDR0_02); + if (!DDR_GET_VAL(val, DDR_START, DDR_START_SHIFT)) + fatal("DDR controller is not initialized\n"); + +@@ -99,12 +154,12 @@ + max_row = DDR_GET_VAL(val, DDR_MAX_ROW_REG, DDR_MAX_ROW_REG_SHIFT); + + /* get CS value */ +- val = mfdcr_sdram0(DDR0_10); ++ val = SDRAM0_READ(DDR0_10); + + val = DDR_GET_VAL(val, DDR_CS_MAP, DDR_CS_MAP_SHIFT); + cs = 0; + while (val) { +- if (val && 0x1) ++ if (val & 0x1) + cs++; + val = val >> 1; + } +@@ -115,15 +170,15 @@ + fatal("DDR wrong CS configuration\n"); + + /* get data path bytes */ +- val = mfdcr_sdram0(DDR0_14); ++ val = SDRAM0_READ(DDR0_14); + + if (DDR_GET_VAL(val, DDR_REDUC, DDR_REDUC_SHIFT)) + dpath = 8; /* 64 bits */ + else + dpath = 4; /* 32 bits */ + +- /* get adress pins (rows) */ +- val = mfdcr_sdram0(DDR0_42); ++ /* get address pins (rows) */ ++ val = SDRAM0_READ(DDR0_42); + + row = DDR_GET_VAL(val, DDR_APIN, DDR_APIN_SHIFT); + if (row > max_row) +@@ -131,7 +186,7 @@ + row = max_row - row; + + /* get collomn size and banks */ +- val = mfdcr_sdram0(DDR0_43); ++ val = SDRAM0_READ(DDR0_43); + + col = DDR_GET_VAL(val, DDR_COL_SZ, DDR_COL_SZ_SHIFT); + if (col > max_col) +@@ -179,13 +234,17 @@ + #define EMAC_RESET 0x20000000 + void ibm4xx_quiesce_eth(u32 *emac0, u32 *emac1) + { +- /* Quiesce the MAL and EMAC(s) since PIBS/OpenBIOS don't do this for us */ ++ /* Quiesce the MAL and EMAC(s) since PIBS/OpenBIOS don't ++ * do this for us ++ */ + if (emac0) + *emac0 = EMAC_RESET; + if (emac1) + *emac1 = EMAC_RESET; + + mtdcr(DCRN_MAL0_CFG, MAL_RESET); ++ while (mfdcr(DCRN_MAL0_CFG) & MAL_RESET) ++ ; /* loop until reset takes effect */ + } + + /* Read 4xx EBC bus bridge registers to get mappings of the peripheral +@@ -217,84 +276,335 @@ + setprop(devp, "ranges", ranges, (p - ranges) * sizeof(u32)); + } + +-#define SPRN_CCR1 0x378 +-void ibm440ep_fixup_clocks(unsigned int sysclk, unsigned int ser_clk) ++/* Calculate 440GP clocks */ ++void ibm440gp_fixup_clocks(unsigned int sys_clk, unsigned int ser_clk) + { +- u32 cpu, plb, opb, ebc, tb, uart0, m, vco; +- u32 reg; +- u32 fwdva, fwdvb, fbdv, lfbdv, opbdv0, perdv0, spcid0, prbdv0, tmp; +- +- mtdcr(DCRN_CPR0_ADDR, CPR0_PLLD0); +- reg = mfdcr(DCRN_CPR0_DATA); +- tmp = (reg & 0x000F0000) >> 16; +- fwdva = tmp ? tmp : 16; +- tmp = (reg & 0x00000700) >> 8; +- fwdvb = tmp ? tmp : 8; +- tmp = (reg & 0x1F000000) >> 24; +- fbdv = tmp ? tmp : 32; +- lfbdv = (reg & 0x0000007F); +- +- mtdcr(DCRN_CPR0_ADDR, CPR0_OPBD0); +- reg = mfdcr(DCRN_CPR0_DATA); +- tmp = (reg & 0x03000000) >> 24; +- opbdv0 = tmp ? tmp : 4; +- +- mtdcr(DCRN_CPR0_ADDR, CPR0_PERD0); +- reg = mfdcr(DCRN_CPR0_DATA); +- tmp = (reg & 0x07000000) >> 24; +- perdv0 = tmp ? tmp : 8; +- +- mtdcr(DCRN_CPR0_ADDR, CPR0_PRIMBD0); +- reg = mfdcr(DCRN_CPR0_DATA); +- tmp = (reg & 0x07000000) >> 24; +- prbdv0 = tmp ? tmp : 8; +- +- mtdcr(DCRN_CPR0_ADDR, CPR0_SCPID); +- reg = mfdcr(DCRN_CPR0_DATA); +- tmp = (reg & 0x03000000) >> 24; +- spcid0 = tmp ? tmp : 4; +- +- /* Calculate M */ +- mtdcr(DCRN_CPR0_ADDR, CPR0_PLLC0); +- reg = mfdcr(DCRN_CPR0_DATA); +- tmp = (reg & 0x03000000) >> 24; +- if (tmp == 0) { /* PLL output */ +- tmp = (reg & 0x20000000) >> 29; +- if (!tmp) /* PLLOUTA */ +- m = fbdv * lfbdv * fwdva; ++ u32 sys0 = mfdcr(DCRN_CPC0_SYS0); ++ u32 cr0 = mfdcr(DCRN_CPC0_CR0); ++ u32 cpu, plb, opb, ebc, tb, uart0, uart1, m; ++ u32 opdv = CPC0_SYS0_OPDV(sys0); ++ u32 epdv = CPC0_SYS0_EPDV(sys0); ++ ++ if (sys0 & CPC0_SYS0_BYPASS) { ++ /* Bypass system PLL */ ++ cpu = plb = sys_clk; ++ } else { ++ if (sys0 & CPC0_SYS0_EXTSL) ++ /* PerClk */ ++ m = CPC0_SYS0_FWDVB(sys0) * opdv * epdv; + else +- m = fbdv * lfbdv * fwdvb; ++ /* CPU clock */ ++ m = CPC0_SYS0_FBDV(sys0) * CPC0_SYS0_FWDVA(sys0); ++ cpu = sys_clk * m / CPC0_SYS0_FWDVA(sys0); ++ plb = sys_clk * m / CPC0_SYS0_FWDVB(sys0); + } +- else if (tmp == 1) /* CPU output */ +- m = fbdv * fwdva; ++ ++ opb = plb / opdv; ++ ebc = opb / epdv; ++ ++ /* FIXME: Check if this is for all 440GP, or just Ebony */ ++ if ((mfpvr() & 0xf0000fff) == 0x40000440) ++ /* Rev. B 440GP, use external system clock */ ++ tb = sys_clk; + else +- m = perdv0 * opbdv0 * fwdvb; ++ /* Rev. C 440GP, errata force us to use internal clock */ ++ tb = cpu; + +- vco = (m * sysclk) + (m >> 1); +- cpu = vco / fwdva; +- plb = vco / fwdvb / prbdv0; +- opb = plb / opbdv0; +- ebc = plb / perdv0; ++ if (cr0 & CPC0_CR0_U0EC) ++ /* External UART clock */ ++ uart0 = ser_clk; ++ else ++ /* Internal UART clock */ ++ uart0 = plb / CPC0_CR0_UDIV(cr0); + +- /* FIXME */ +- uart0 = ser_clk; ++ if (cr0 & CPC0_CR0_U1EC) ++ /* External UART clock */ ++ uart1 = ser_clk; ++ else ++ /* Internal UART clock */ ++ uart1 = plb / CPC0_CR0_UDIV(cr0); ++ ++ printf("PPC440GP: SysClk = %dMHz (%x)\n\r", ++ (sys_clk + 500000) / 1000000, sys_clk); ++ ++ dt_fixup_cpu_clocks(cpu, tb, 0); ++ ++ dt_fixup_clock("/plb", plb); ++ dt_fixup_clock("/plb/opb", opb); ++ dt_fixup_clock("/plb/opb/ebc", ebc); ++ dt_fixup_clock("/plb/opb/serial@40000200", uart0); ++ dt_fixup_clock("/plb/opb/serial@40000300", uart1); ++} ++ ++#define SPRN_CCR1 0x378 ++ ++static inline u32 __fix_zero(u32 v, u32 def) ++{ ++ return v ? v : def; ++} ++ ++static unsigned int __ibm440eplike_fixup_clocks(unsigned int sys_clk, ++ unsigned int tmr_clk, ++ int per_clk_from_opb) ++{ ++ /* PLL config */ ++ u32 pllc = CPR0_READ(DCRN_CPR0_PLLC); ++ u32 plld = CPR0_READ(DCRN_CPR0_PLLD); ++ ++ /* Dividers */ ++ u32 fbdv = __fix_zero((plld >> 24) & 0x1f, 32); ++ u32 fwdva = __fix_zero((plld >> 16) & 0xf, 16); ++ u32 fwdvb = __fix_zero((plld >> 8) & 7, 8); ++ u32 lfbdv = __fix_zero(plld & 0x3f, 64); ++ u32 pradv0 = __fix_zero((CPR0_READ(DCRN_CPR0_PRIMAD) >> 24) & 7, 8); ++ u32 prbdv0 = __fix_zero((CPR0_READ(DCRN_CPR0_PRIMBD) >> 24) & 7, 8); ++ u32 opbdv0 = __fix_zero((CPR0_READ(DCRN_CPR0_OPBD) >> 24) & 3, 4); ++ u32 perdv0 = __fix_zero((CPR0_READ(DCRN_CPR0_PERD) >> 24) & 3, 4); ++ ++ /* Input clocks for primary dividers */ ++ u32 clk_a, clk_b; ++ ++ /* Resulting clocks */ ++ u32 cpu, plb, opb, ebc, vco; ++ ++ /* Timebase */ ++ u32 ccr1, tb = tmr_clk; ++ ++ if (pllc & 0x40000000) { ++ u32 m; ++ ++ /* Feedback path */ ++ switch ((pllc >> 24) & 7) { ++ case 0: ++ /* PLLOUTx */ ++ m = ((pllc & 0x20000000) ? fwdvb : fwdva) * lfbdv; ++ break; ++ case 1: ++ /* CPU */ ++ m = fwdva * pradv0; ++ break; ++ case 5: ++ /* PERClk */ ++ m = fwdvb * prbdv0 * opbdv0 * perdv0; ++ break; ++ default: ++ printf("WARNING ! Invalid PLL feedback source !\n"); ++ goto bypass; ++ } ++ m *= fbdv; ++ vco = sys_clk * m; ++ clk_a = vco / fwdva; ++ clk_b = vco / fwdvb; ++ } else { ++bypass: ++ /* Bypass system PLL */ ++ vco = 0; ++ clk_a = clk_b = sys_clk; ++ } ++ ++ cpu = clk_a / pradv0; ++ plb = clk_b / prbdv0; ++ opb = plb / opbdv0; ++ ebc = (per_clk_from_opb ? opb : plb) / perdv0; + + /* Figure out timebase. Either CPU or default TmrClk */ +- asm volatile ( +- "mfspr %0,%1\n" +- : +- "=&r"(reg) : "i"(SPRN_CCR1)); +- if (reg & 0x0080) +- tb = 25000000; /* TmrClk is 25MHz */ +- else ++ ccr1 = mfspr(SPRN_CCR1); ++ ++ /* If passed a 0 tmr_clk, force CPU clock */ ++ if (tb == 0) { ++ ccr1 &= ~0x80u; ++ mtspr(SPRN_CCR1, ccr1); ++ } ++ if ((ccr1 & 0x0080) == 0) + tb = cpu; + + dt_fixup_cpu_clocks(cpu, tb, 0); + dt_fixup_clock("/plb", plb); + dt_fixup_clock("/plb/opb", opb); + dt_fixup_clock("/plb/opb/ebc", ebc); ++ ++ return plb; ++} ++ ++static void eplike_fixup_uart_clk(int index, const char *path, ++ unsigned int ser_clk, ++ unsigned int plb_clk) ++{ ++ unsigned int sdr; ++ unsigned int clock; ++ ++ switch (index) { ++ case 0: ++ sdr = SDR0_READ(DCRN_SDR0_UART0); ++ break; ++ case 1: ++ sdr = SDR0_READ(DCRN_SDR0_UART1); ++ break; ++ case 2: ++ sdr = SDR0_READ(DCRN_SDR0_UART2); ++ break; ++ case 3: ++ sdr = SDR0_READ(DCRN_SDR0_UART3); ++ break; ++ default: ++ return; ++ } ++ ++ if (sdr & 0x00800000u) ++ clock = ser_clk; ++ else ++ clock = plb_clk / __fix_zero(sdr & 0xff, 256); ++ ++ dt_fixup_clock(path, clock); ++} ++ ++void ibm440ep_fixup_clocks(unsigned int sys_clk, ++ unsigned int ser_clk, ++ unsigned int tmr_clk) ++{ ++ unsigned int plb_clk = __ibm440eplike_fixup_clocks(sys_clk, tmr_clk, 0); ++ ++ /* serial clocks beed fixup based on int/ext */ ++ eplike_fixup_uart_clk(0, "/plb/opb/serial@ef600300", ser_clk, plb_clk); ++ eplike_fixup_uart_clk(1, "/plb/opb/serial@ef600400", ser_clk, plb_clk); ++ eplike_fixup_uart_clk(2, "/plb/opb/serial@ef600500", ser_clk, plb_clk); ++ eplike_fixup_uart_clk(3, "/plb/opb/serial@ef600600", ser_clk, plb_clk); ++} ++ ++void ibm440gx_fixup_clocks(unsigned int sys_clk, ++ unsigned int ser_clk, ++ unsigned int tmr_clk) ++{ ++ unsigned int plb_clk = __ibm440eplike_fixup_clocks(sys_clk, tmr_clk, 1); ++ ++ /* serial clocks beed fixup based on int/ext */ ++ eplike_fixup_uart_clk(0, "/plb/opb/serial@40000200", ser_clk, plb_clk); ++ eplike_fixup_uart_clk(1, "/plb/opb/serial@40000300", ser_clk, plb_clk); ++} ++ ++void ibm440spe_fixup_clocks(unsigned int sys_clk, ++ unsigned int ser_clk, ++ unsigned int tmr_clk) ++{ ++ unsigned int plb_clk = __ibm440eplike_fixup_clocks(sys_clk, tmr_clk, 1); ++ ++ /* serial clocks beed fixup based on int/ext */ ++ eplike_fixup_uart_clk(0, "/plb/opb/serial@10000200", ser_clk, plb_clk); ++ eplike_fixup_uart_clk(1, "/plb/opb/serial@10000300", ser_clk, plb_clk); ++ eplike_fixup_uart_clk(2, "/plb/opb/serial@10000600", ser_clk, plb_clk); ++} ++ ++void ibm405gp_fixup_clocks(unsigned int sys_clk, unsigned int ser_clk) ++{ ++ u32 pllmr = mfdcr(DCRN_CPC0_PLLMR); ++ u32 cpc0_cr0 = mfdcr(DCRN_405_CPC0_CR0); ++ u32 cpc0_cr1 = mfdcr(DCRN_405_CPC0_CR1); ++ u32 psr = mfdcr(DCRN_405_CPC0_PSR); ++ u32 cpu, plb, opb, ebc, tb, uart0, uart1, m; ++ u32 fwdv, fwdvb, fbdv, cbdv, opdv, epdv, ppdv, udiv; ++ ++ fwdv = (8 - ((pllmr & 0xe0000000) >> 29)); ++ fbdv = (pllmr & 0x1e000000) >> 25; ++ if (fbdv == 0) ++ fbdv = 16; ++ cbdv = ((pllmr & 0x00060000) >> 17) + 1; /* CPU:PLB */ ++ opdv = ((pllmr & 0x00018000) >> 15) + 1; /* PLB:OPB */ ++ ppdv = ((pllmr & 0x00001800) >> 13) + 1; /* PLB:PCI */ ++ epdv = ((pllmr & 0x00001800) >> 11) + 2; /* PLB:EBC */ ++ udiv = ((cpc0_cr0 & 0x3e) >> 1) + 1; ++ ++ /* check for 405GPr */ ++ if ((mfpvr() & 0xfffffff0) == (0x50910951 & 0xfffffff0)) { ++ fwdvb = 8 - (pllmr & 0x00000007); ++ if (!(psr & 0x00001000)) /* PCI async mode enable == 0 */ ++ if (psr & 0x00000020) /* New mode enable */ ++ m = fwdvb * 2 * ppdv; ++ else ++ m = fwdvb * cbdv * ppdv; ++ else if (psr & 0x00000020) /* New mode enable */ ++ if (psr & 0x00000800) /* PerClk synch mode */ ++ m = fwdvb * 2 * epdv; ++ else ++ m = fbdv * fwdv; ++ else if (epdv == fbdv) ++ m = fbdv * cbdv * epdv; ++ else ++ m = fbdv * fwdvb * cbdv; ++ ++ cpu = sys_clk * m / fwdv; ++ plb = sys_clk * m / (fwdvb * cbdv); ++ } else { ++ m = fwdv * fbdv * cbdv; ++ cpu = sys_clk * m / fwdv; ++ plb = cpu / cbdv; ++ } ++ opb = plb / opdv; ++ ebc = plb / epdv; ++ ++ if (cpc0_cr0 & 0x80) ++ /* uart0 uses the external clock */ ++ uart0 = ser_clk; ++ else ++ uart0 = cpu / udiv; ++ ++ if (cpc0_cr0 & 0x40) ++ /* uart1 uses the external clock */ ++ uart1 = ser_clk; ++ else ++ uart1 = cpu / udiv; ++ ++ /* setup the timebase clock to tick at the cpu frequency */ ++ cpc0_cr1 = cpc0_cr1 & ~0x00800000; ++ mtdcr(DCRN_405_CPC0_CR1, cpc0_cr1); ++ tb = cpu; ++ ++ dt_fixup_cpu_clocks(cpu, tb, 0); ++ dt_fixup_clock("/plb", plb); ++ dt_fixup_clock("/plb/opb", opb); ++ dt_fixup_clock("/plb/ebc", ebc); ++ dt_fixup_clock("/plb/opb/serial@ef600300", uart0); ++ dt_fixup_clock("/plb/opb/serial@ef600400", uart1); ++} ++ ++ ++void ibm405ep_fixup_clocks(unsigned int sys_clk) ++{ ++ u32 pllmr0 = mfdcr(DCRN_CPC0_PLLMR0); ++ u32 pllmr1 = mfdcr(DCRN_CPC0_PLLMR1); ++ u32 cpc0_ucr = mfdcr(DCRN_CPC0_UCR); ++ u32 cpu, plb, opb, ebc, uart0, uart1; ++ u32 fwdva, fwdvb, fbdv, cbdv, opdv, epdv; ++ u32 pllmr0_ccdv, tb, m; ++ ++ fwdva = 8 - ((pllmr1 & 0x00070000) >> 16); ++ fwdvb = 8 - ((pllmr1 & 0x00007000) >> 12); ++ fbdv = (pllmr1 & 0x00f00000) >> 20; ++ if (fbdv == 0) ++ fbdv = 16; ++ ++ cbdv = ((pllmr0 & 0x00030000) >> 16) + 1; /* CPU:PLB */ ++ epdv = ((pllmr0 & 0x00000300) >> 8) + 2; /* PLB:EBC */ ++ opdv = ((pllmr0 & 0x00003000) >> 12) + 1; /* PLB:OPB */ ++ ++ m = fbdv * fwdvb; ++ ++ pllmr0_ccdv = ((pllmr0 & 0x00300000) >> 20) + 1; ++ if (pllmr1 & 0x80000000) ++ cpu = sys_clk * m / (fwdva * pllmr0_ccdv); ++ else ++ cpu = sys_clk / pllmr0_ccdv; ++ ++ plb = cpu / cbdv; ++ opb = plb / opdv; ++ ebc = plb / epdv; ++ tb = cpu; ++ uart0 = cpu / (cpc0_ucr & 0x0000007f); ++ uart1 = cpu / ((cpc0_ucr & 0x00007f00) >> 8); ++ ++ dt_fixup_cpu_clocks(cpu, tb, 0); ++ dt_fixup_clock("/plb", plb); ++ dt_fixup_clock("/plb/opb", opb); ++ dt_fixup_clock("/plb/ebc", ebc); + dt_fixup_clock("/plb/opb/serial@ef600300", uart0); +- dt_fixup_clock("/plb/opb/serial@ef600400", uart0); +- dt_fixup_clock("/plb/opb/serial@ef600500", uart0); +- dt_fixup_clock("/plb/opb/serial@ef600600", uart0); ++ dt_fixup_clock("/plb/opb/serial@ef600400", uart1); + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/4xx.h powerpc.git/arch/powerpc/boot/4xx.h +--- linux-2.6.24/arch/powerpc/boot/4xx.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/4xx.h 2008-01-28 20:25:49.000000000 +0100 +@@ -11,12 +11,22 @@ + #ifndef _POWERPC_BOOT_4XX_H_ + #define _POWERPC_BOOT_4XX_H_ + +-void ibm4xx_fixup_memsize(void); ++void ibm4xx_sdram_fixup_memsize(void); ++void ibm440spe_fixup_memsize(void); + void ibm4xx_denali_fixup_memsize(void); + void ibm44x_dbcr_reset(void); + void ibm40x_dbcr_reset(void); + void ibm4xx_quiesce_eth(u32 *emac0, u32 *emac1); + void ibm4xx_fixup_ebc_ranges(const char *ebc); +-void ibm440ep_fixup_clocks(unsigned int sysclk, unsigned int ser_clk); ++ ++void ibm405gp_fixup_clocks(unsigned int sys_clk, unsigned int ser_clk); ++void ibm405ep_fixup_clocks(unsigned int sys_clk); ++void ibm440gp_fixup_clocks(unsigned int sys_clk, unsigned int ser_clk); ++void ibm440ep_fixup_clocks(unsigned int sys_clk, unsigned int ser_clk, ++ unsigned int tmr_clk); ++void ibm440gx_fixup_clocks(unsigned int sys_clk, unsigned int ser_clk, ++ unsigned int tmr_clk); ++void ibm440spe_fixup_clocks(unsigned int sys_clk, unsigned int ser_clk, ++ unsigned int tmr_clk); + + #endif /* _POWERPC_BOOT_4XX_H_ */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/Makefile powerpc.git/arch/powerpc/boot/Makefile +--- linux-2.6.24/arch/powerpc/boot/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -33,12 +33,15 @@ + BOOTCFLAGS += -fno-stack-protector + endif + +-BOOTCFLAGS += -I$(obj) -I$(srctree)/$(obj) ++BOOTCFLAGS += -I$(obj) -I$(srctree)/$(obj) -I$(srctree)/$(src)/libfdt + + $(obj)/4xx.o: BOOTCFLAGS += -mcpu=440 + $(obj)/ebony.o: BOOTCFLAGS += -mcpu=440 ++$(obj)/cuboot-taishan.o: BOOTCFLAGS += -mcpu=440 ++$(obj)/cuboot-katmai.o: BOOTCFLAGS += -mcpu=440 + $(obj)/treeboot-walnut.o: BOOTCFLAGS += -mcpu=405 + ++ + zlib := inffast.c inflate.c inftrees.c + zlibheader := inffast.h inffixed.h inflate.h inftrees.h infutil.h + zliblinuxheader := zlib.h zconf.h zutil.h +@@ -46,17 +49,21 @@ + $(addprefix $(obj)/,$(zlib) gunzip_util.o main.o): \ + $(addprefix $(obj)/,$(zliblinuxheader)) $(addprefix $(obj)/,$(zlibheader)) + +-src-wlib := string.S crt0.S stdio.c main.c flatdevtree.c flatdevtree_misc.c \ ++src-libfdt := fdt.c fdt_ro.c fdt_wip.c fdt_sw.c fdt_rw.c fdt_strerror.c ++src-wlib := string.S crt0.S stdio.c main.c \ ++ $(addprefix libfdt/,$(src-libfdt)) libfdt-wrapper.c \ + ns16550.c serial.c simple_alloc.c div64.S util.S \ + gunzip_util.c elf_util.c $(zlib) devtree.c oflib.c ofconsole.c \ + 4xx.c ebony.c mv64x60.c mpsc.c mv64x60_i2c.c cuboot.c bamboo.c \ + cpm-serial.c stdlib.c mpc52xx-psc.c planetcore.c uartlite.c \ + fsl-soc.c mpc8xx.c pq2.c +-src-plat := of.c cuboot-52xx.c cuboot-83xx.c cuboot-85xx.c holly.c \ ++src-plat := of.c cuboot-52xx.c cuboot-824x.c cuboot-83xx.c cuboot-85xx.c holly.c \ + cuboot-ebony.c treeboot-ebony.c prpmc2800.c \ + ps3-head.S ps3-hvcall.S ps3.c treeboot-bamboo.c cuboot-8xx.c \ + cuboot-pq2.c cuboot-sequoia.c treeboot-walnut.c cuboot-bamboo.c \ +- fixed-head.S ep88xc.c cuboot-hpc2.c ++ fixed-head.S ep88xc.c cuboot-hpc2.c ep405.c cuboot-taishan.c \ ++ cuboot-katmai.c cuboot-rainier.c redboot-8xx.c ep8248e.c \ ++ cuboot-warp.c + src-boot := $(src-wlib) $(src-plat) empty.c + + src-boot := $(addprefix $(obj)/, $(src-boot)) +@@ -101,24 +108,61 @@ + cmd_bootar = $(CROSS32AR) -cr $@.$$$$ $(filter-out FORCE,$^); mv $@.$$$$ $@ + + $(patsubst %.c,%.o, $(filter %.c, $(src-boot))): %.o: %.c FORCE ++ $(Q)mkdir -p $(dir $@) + $(call if_changed_dep,bootcc) + $(patsubst %.S,%.o, $(filter %.S, $(src-boot))): %.o: %.S FORCE ++ $(Q)mkdir -p $(dir $@) + $(call if_changed_dep,bootas) + + $(obj)/wrapper.a: $(obj-wlib) FORCE + $(call if_changed,bootar) + +-hostprogs-y := addnote addRamDisk hack-coff mktree ++hostprogs-y := addnote addRamDisk hack-coff mktree dtc + + targets += $(patsubst $(obj)/%,%,$(obj-boot) wrapper.a) + extra-y := $(obj)/wrapper.a $(obj-plat) $(obj)/empty.o \ + $(obj)/zImage.lds $(obj)/zImage.coff.lds $(obj)/zImage.ps3.lds + + wrapper :=$(srctree)/$(src)/wrapper +-wrapperbits := $(extra-y) $(addprefix $(obj)/,addnote hack-coff mktree) \ ++wrapperbits := $(extra-y) $(addprefix $(obj)/,addnote hack-coff mktree dtc) \ + $(wrapper) FORCE + + ############# ++# Bits for building dtc ++# DTC_GENPARSER := 1 # Uncomment to rebuild flex/bison output ++ ++dtc-objs := dtc.o flattree.o fstree.o data.o livetree.o treesource.o srcpos.o checks.o ++dtc-objs += dtc-lexer.lex.o dtc-parser.tab.o ++dtc-objs := $(addprefix dtc-src/, $(dtc-objs)) ++ ++# prerequisites on generated files needs to be explicit ++$(obj)/dtc-src/dtc-parser.tab.o: $(obj)/dtc-src/dtc-parser.tab.c $(obj)/dtc-src/dtc-parser.tab.h ++$(obj)/dtc-src/dtc-lexer.lex.o: $(obj)/dtc-src/dtc-lexer.lex.c $(obj)/dtc-src/dtc-parser.tab.h ++ ++HOSTCFLAGS += -I$(src)/dtc-src/ -I$(src)/libfdt/ ++ ++targets += dtc-src/dtc-parser.tab.c ++targets += dtc-src/dtc-lexer.lex.c ++ ++ifdef DTC_GENPARSER ++BISON = bison ++FLEX = flex ++ ++quiet_cmd_bison = BISON $@ ++ cmd_bison = $(BISON) -o$@ -d $<; cp $@ $@_shipped ++quiet_cmd_flex = FLEX $@ ++ cmd_flex = $(FLEX) -o$@ $<; cp $@ $@_shipped ++ ++$(obj)/dtc-src/dtc-parser.tab.c: $(src)/dtc-src/dtc-parser.y FORCE ++ $(call if_changed,bison) ++ ++$(obj)/dtc-src/dtc-parser.tab.h: $(obj)/dtc-src/dtc-parser.tab.c ++ ++$(obj)/dtc-src/dtc-lexer.lex.c: $(src)/dtc-src/dtc-lexer.l FORCE ++ $(call if_changed,flex) ++endif ++ ++############# + # Bits for building various flavours of zImage + + ifneq ($(CROSS32_COMPILE),) +@@ -150,15 +194,26 @@ + ifneq ($(CONFIG_DEVICE_TREE),"") + image-$(CONFIG_PPC_8xx) += cuImage.8xx + image-$(CONFIG_PPC_EP88XC) += zImage.ep88xc ++image-$(CONFIG_EP405) += zImage.ep405 + image-$(CONFIG_8260) += cuImage.pq2 ++image-$(CONFIG_EP8248E) += zImage.ep8248e + image-$(CONFIG_PPC_MPC52xx) += cuImage.52xx ++image-$(CONFIG_STORCENTER) += cuImage.824x + image-$(CONFIG_PPC_83xx) += cuImage.83xx + image-$(CONFIG_PPC_85xx) += cuImage.85xx + image-$(CONFIG_MPC7448HPC2) += cuImage.hpc2 + image-$(CONFIG_EBONY) += treeImage.ebony cuImage.ebony + image-$(CONFIG_BAMBOO) += treeImage.bamboo cuImage.bamboo + image-$(CONFIG_SEQUOIA) += cuImage.sequoia ++image-$(CONFIG_RAINIER) += cuImage.rainier + image-$(CONFIG_WALNUT) += treeImage.walnut ++image-$(CONFIG_TAISHAN) += cuImage.taishan ++image-$(CONFIG_KATMAI) += cuImage.katmai ++image-$(CONFIG_WARP) += cuImage.warp ++endif ++ ++ifneq ($(CONFIG_REDBOOT),"") ++image-$(CONFIG_PPC_8xx) += zImage.redboot-8xx + endif + + # For 32-bit powermacs, build the COFF and miboot images +@@ -243,3 +298,51 @@ + clean-kernel += $(addsuffix .gz,$(clean-kernel)) + # If not absolute clean-files are relative to $(obj). + clean-files += $(addprefix $(objtree)/, $(clean-kernel)) ++ ++WRAPPER_OBJDIR := /usr/lib/kernel-wrapper ++WRAPPER_DTSDIR := /usr/lib/kernel-wrapper/dts ++WRAPPER_BINDIR := /usr/sbin ++INSTALL := install ++ ++extra-installed := $(patsubst $(obj)/%, $(DESTDIR)$(WRAPPER_OBJDIR)/%, $(extra-y)) ++hostprogs-installed := $(patsubst %, $(DESTDIR)$(WRAPPER_BINDIR)/%, $(hostprogs-y)) ++wrapper-installed := $(DESTDIR)$(WRAPPER_BINDIR)/wrapper ++dts-installed := $(patsubst $(obj)/dts/%, $(DESTDIR)$(WRAPPER_DTSDIR)/%, $(wildcard $(obj)/dts/*.dts)) ++ ++all-installed := $(extra-installed) $(hostprogs-installed) $(wrapper-installed) $(dts-installed) ++ ++quiet_cmd_mkdir = MKDIR $(patsubst $(INSTALL_HDR_PATH)/%,%,$@) ++ cmd_mkdir = mkdir -p $@ ++ ++quiet_cmd_install = INSTALL $(patsubst $(DESTDIR)$(WRAPPER_OBJDIR)/%,%,$@) ++ cmd_install = $(INSTALL) -m0644 $(patsubst $(DESTDIR)$(WRAPPER_OBJDIR)/%,$(obj)/%,$@) $@ ++ ++quiet_cmd_install_dts = INSTALL $(patsubst $(DESTDIR)$(WRAPPER_DTSDIR)/%,dts/%,$@) ++ cmd_install_dts = $(INSTALL) -m0644 $(patsubst $(DESTDIR)$(WRAPPER_DTSDIR)/%,$(srctree)/$(obj)/dts/%,$@) $@ ++ ++quiet_cmd_install_exe = INSTALL $(patsubst $(DESTDIR)$(WRAPPER_BINDIR)/%,%,$@) ++ cmd_install_exe = $(INSTALL) -m0755 $(patsubst $(DESTDIR)$(WRAPPER_BINDIR)/%,$(obj)/%,$@) $@ ++ ++quiet_cmd_install_wrapper = INSTALL $(patsubst $(DESTDIR)$(WRAPPER_BINDIR)/%,%,$@) ++ cmd_install_wrapper = $(INSTALL) -m0755 $(patsubst $(DESTDIR)$(WRAPPER_BINDIR)/%,$(srctree)/$(obj)/%,$@) $@ ;\ ++ sed -i $@ -e 's%^object=.*%object=$(WRAPPER_OBJDIR)%' \ ++ -e 's%^objbin=.*%objbin=$(WRAPPER_BINDIR)%' \ ++ ++ ++$(DESTDIR)$(WRAPPER_OBJDIR) $(DESTDIR)$(WRAPPER_DTSDIR) $(DESTDIR)$(WRAPPER_BINDIR): ++ $(call cmd,mkdir) ++ ++$(extra-installed) : $(DESTDIR)$(WRAPPER_OBJDIR)/% : $(obj)/% | $(DESTDIR)$(WRAPPER_OBJDIR) ++ $(call cmd,install) ++ ++$(hostprogs-installed) : $(DESTDIR)$(WRAPPER_BINDIR)/% : $(obj)/% | $(DESTDIR)$(WRAPPER_BINDIR) ++ $(call cmd,install_exe) ++ ++$(dts-installed) : $(DESTDIR)$(WRAPPER_DTSDIR)/% : $(srctree)/$(obj)/dts/% | $(DESTDIR)$(WRAPPER_DTSDIR) ++ $(call cmd,install_dts) ++ ++$(wrapper-installed): $(DESTDIR)$(WRAPPER_BINDIR) $(srctree)/$(obj)/wrapper | $(DESTDIR)$(WRAPPER_BINDIR) ++ $(call cmd,install_wrapper) ++ ++$(obj)/bootwrapper_install: $(all-installed) ++ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/bamboo.c powerpc.git/arch/powerpc/boot/bamboo.c +--- linux-2.6.24/arch/powerpc/boot/bamboo.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/bamboo.c 2008-01-28 20:25:49.000000000 +0100 +@@ -30,8 +30,8 @@ + { + unsigned long sysclk = 33333333; + +- ibm440ep_fixup_clocks(sysclk, 11059200); +- ibm4xx_fixup_memsize(); ++ ibm440ep_fixup_clocks(sysclk, 11059200, 25000000); ++ ibm4xx_sdram_fixup_memsize(); + ibm4xx_quiesce_eth((u32 *)0xef600e00, (u32 *)0xef600f00); + dt_fixup_mac_addresses(bamboo_mac0, bamboo_mac1); + } +@@ -42,6 +42,6 @@ + platform_ops.exit = ibm44x_dbcr_reset; + bamboo_mac0 = mac0; + bamboo_mac1 = mac1; +- ft_init(_dtb_start, 0, 32); ++ fdt_init(_dtb_start); + serial_console_init(); + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/cuboot-52xx.c powerpc.git/arch/powerpc/boot/cuboot-52xx.c +--- linux-2.6.24/arch/powerpc/boot/cuboot-52xx.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/cuboot-52xx.c 2008-01-28 20:25:49.000000000 +0100 +@@ -53,7 +53,7 @@ + unsigned long r6, unsigned long r7) + { + CUBOOT_INIT(); +- ft_init(_dtb_start, _dtb_end - _dtb_start, 32); ++ fdt_init(_dtb_start); + serial_console_init(); + platform_ops.fixups = platform_fixups; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/cuboot-824x.c powerpc.git/arch/powerpc/boot/cuboot-824x.c +--- linux-2.6.24/arch/powerpc/boot/cuboot-824x.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/cuboot-824x.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,53 @@ ++/* ++ * Old U-boot compatibility for 824x ++ * ++ * Copyright (c) 2007 Freescale Semiconductor, Inc. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 as published ++ * by the Free Software Foundation. ++ */ ++ ++#include "ops.h" ++#include "stdio.h" ++#include "cuboot.h" ++ ++#define TARGET_824x ++#include "ppcboot.h" ++ ++static bd_t bd; ++ ++ ++static void platform_fixups(void) ++{ ++ void *soc; ++ ++ dt_fixup_memory(bd.bi_memstart, bd.bi_memsize); ++ dt_fixup_mac_addresses(bd.bi_enetaddr); ++ dt_fixup_cpu_clocks(bd.bi_intfreq, bd.bi_busfreq / 4, bd.bi_busfreq); ++ ++ soc = find_node_by_devtype(NULL, "soc"); ++ if (soc) { ++ void *serial = NULL; ++ ++ setprop(soc, "bus-frequency", &bd.bi_busfreq, ++ sizeof(bd.bi_busfreq)); ++ ++ while ((serial = find_node_by_devtype(serial, "serial"))) { ++ if (get_parent(serial) != soc) ++ continue; ++ ++ setprop(serial, "clock-frequency", &bd.bi_busfreq, ++ sizeof(bd.bi_busfreq)); ++ } ++ } ++} ++ ++void platform_init(unsigned long r3, unsigned long r4, unsigned long r5, ++ unsigned long r6, unsigned long r7) ++{ ++ CUBOOT_INIT(); ++ fdt_init(_dtb_start); ++ serial_console_init(); ++ platform_ops.fixups = platform_fixups; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/cuboot-83xx.c powerpc.git/arch/powerpc/boot/cuboot-83xx.c +--- linux-2.6.24/arch/powerpc/boot/cuboot-83xx.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/cuboot-83xx.c 2008-01-28 20:25:49.000000000 +0100 +@@ -24,7 +24,8 @@ + void *soc; + + dt_fixup_memory(bd.bi_memstart, bd.bi_memsize); +- dt_fixup_mac_addresses(bd.bi_enetaddr, bd.bi_enet1addr); ++ dt_fixup_mac_address_by_alias("ethernet0", bd.bi_enetaddr); ++ dt_fixup_mac_address_by_alias("ethernet1", bd.bi_enet1addr); + dt_fixup_cpu_clocks(bd.bi_intfreq, bd.bi_busfreq / 4, bd.bi_busfreq); + + /* Unfortunately, the specific model number is encoded in the +@@ -52,7 +53,7 @@ + unsigned long r6, unsigned long r7) + { + CUBOOT_INIT(); +- ft_init(_dtb_start, _dtb_end - _dtb_start, 32); ++ fdt_init(_dtb_start); + serial_console_init(); + platform_ops.fixups = platform_fixups; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/cuboot-85xx.c powerpc.git/arch/powerpc/boot/cuboot-85xx.c +--- linux-2.6.24/arch/powerpc/boot/cuboot-85xx.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/cuboot-85xx.c 2008-01-28 20:25:49.000000000 +0100 +@@ -24,8 +24,9 @@ + void *soc; + + dt_fixup_memory(bd.bi_memstart, bd.bi_memsize); +- dt_fixup_mac_addresses(bd.bi_enetaddr, bd.bi_enet1addr, +- bd.bi_enet2addr); ++ dt_fixup_mac_address_by_alias("ethernet0", bd.bi_enetaddr); ++ dt_fixup_mac_address_by_alias("ethernet1", bd.bi_enet1addr); ++ dt_fixup_mac_address_by_alias("ethernet2", bd.bi_enet2addr); + dt_fixup_cpu_clocks(bd.bi_intfreq, bd.bi_busfreq / 8, bd.bi_busfreq); + + /* Unfortunately, the specific model number is encoded in the +@@ -53,7 +54,7 @@ + unsigned long r6, unsigned long r7) + { + CUBOOT_INIT(); +- ft_init(_dtb_start, _dtb_end - _dtb_start, 32); ++ fdt_init(_dtb_start); + serial_console_init(); + platform_ops.fixups = platform_fixups; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/cuboot-8xx.c powerpc.git/arch/powerpc/boot/cuboot-8xx.c +--- linux-2.6.24/arch/powerpc/boot/cuboot-8xx.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/cuboot-8xx.c 2008-01-28 20:25:49.000000000 +0100 +@@ -41,7 +41,7 @@ + unsigned long r6, unsigned long r7) + { + CUBOOT_INIT(); +- ft_init(_dtb_start, _dtb_end - _dtb_start, 32); ++ fdt_init(_dtb_start); + serial_console_init(); + platform_ops.fixups = platform_fixups; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/cuboot-hpc2.c powerpc.git/arch/powerpc/boot/cuboot-hpc2.c +--- linux-2.6.24/arch/powerpc/boot/cuboot-hpc2.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/cuboot-hpc2.c 2008-01-28 20:25:49.000000000 +0100 +@@ -42,7 +42,7 @@ + unsigned long r6, unsigned long r7) + { + CUBOOT_INIT(); +- ft_init(_dtb_start, _dtb_end - _dtb_start, 32); ++ fdt_init(_dtb_start); + serial_console_init(); + platform_ops.fixups = platform_fixups; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/cuboot-katmai.c powerpc.git/arch/powerpc/boot/cuboot-katmai.c +--- linux-2.6.24/arch/powerpc/boot/cuboot-katmai.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/cuboot-katmai.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,56 @@ ++/* ++ * Old U-boot compatibility for Katmai ++ * ++ * Author: Hugh Blemings <hugh@au.ibm.com> ++ * ++ * Copyright 2007 Hugh Blemings, IBM Corporation. ++ * Based on cuboot-ebony.c which is: ++ * Copyright 2007 David Gibson, IBM Corporation. ++ * Based on cuboot-83xx.c, which is: ++ * Copyright (c) 2007 Freescale Semiconductor, Inc. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 as published ++ * by the Free Software Foundation. ++ */ ++ ++#include "ops.h" ++#include "stdio.h" ++#include "reg.h" ++#include "dcr.h" ++#include "4xx.h" ++#include "44x.h" ++#include "cuboot.h" ++ ++#define TARGET_44x ++#include "ppcboot.h" ++ ++static bd_t bd; ++ ++BSS_STACK(4096); ++ ++static void katmai_fixups(void) ++{ ++ unsigned long sysclk = 33333000; ++ ++ /* 440SP Clock logic is all but identical to 440GX ++ * so we just use that code for now at least ++ */ ++ ibm440spe_fixup_clocks(sysclk, 6 * 1843200, 0); ++ ++ ibm440spe_fixup_memsize(); ++ ++ dt_fixup_mac_address(0, bd.bi_enetaddr); ++ ++ ibm4xx_fixup_ebc_ranges("/plb/opb/ebc"); ++} ++ ++void platform_init(unsigned long r3, unsigned long r4, unsigned long r5, ++ unsigned long r6, unsigned long r7) ++{ ++ CUBOOT_INIT(); ++ ++ platform_ops.fixups = katmai_fixups; ++ fdt_init(_dtb_start); ++ serial_console_init(); ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/cuboot-pq2.c powerpc.git/arch/powerpc/boot/cuboot-pq2.c +--- linux-2.6.24/arch/powerpc/boot/cuboot-pq2.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/cuboot-pq2.c 2008-01-28 20:25:49.000000000 +0100 +@@ -255,7 +255,7 @@ + unsigned long r6, unsigned long r7) + { + CUBOOT_INIT(); +- ft_init(_dtb_start, _dtb_end - _dtb_start, 32); ++ fdt_init(_dtb_start); + serial_console_init(); + platform_ops.fixups = pq2_platform_fixups; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/cuboot-rainier.c powerpc.git/arch/powerpc/boot/cuboot-rainier.c +--- linux-2.6.24/arch/powerpc/boot/cuboot-rainier.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/cuboot-rainier.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,56 @@ ++/* ++ * Old U-boot compatibility for Rainier ++ * ++ * Valentine Barshak <vbarshak@ru.mvista.com> ++ * Copyright 2007 MontaVista Software, Inc ++ * ++ * Based on Ebony code by David Gibson <david@gibson.dropbear.id.au> ++ * Copyright IBM Corporation, 2007 ++ * ++ * Based on Bamboo code by Josh Boyer <jwboyer@linux.vnet.ibm.com> ++ * Copyright IBM Corporation, 2007 ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License ++ * as published by the Free Software Foundation; version 2 of the License ++ */ ++ ++#include <stdarg.h> ++#include <stddef.h> ++#include "types.h" ++#include "elf.h" ++#include "string.h" ++#include "stdio.h" ++#include "page.h" ++#include "ops.h" ++#include "dcr.h" ++#include "4xx.h" ++#include "44x.h" ++#include "cuboot.h" ++ ++#define TARGET_4xx ++#define TARGET_44x ++#include "ppcboot.h" ++ ++static bd_t bd; ++ ++ ++static void rainier_fixups(void) ++{ ++ unsigned long sysclk = 33333333; ++ ++ ibm440ep_fixup_clocks(sysclk, 11059200, 50000000); ++ ibm4xx_fixup_ebc_ranges("/plb/opb/ebc"); ++ ibm4xx_denali_fixup_memsize(); ++ dt_fixup_mac_addresses(&bd.bi_enetaddr, &bd.bi_enet1addr); ++} ++ ++void platform_init(unsigned long r3, unsigned long r4, unsigned long r5, ++ unsigned long r6, unsigned long r7) ++{ ++ CUBOOT_INIT(); ++ platform_ops.fixups = rainier_fixups; ++ platform_ops.exit = ibm44x_dbcr_reset; ++ fdt_init(_dtb_start); ++ serial_console_init(); ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/cuboot-sequoia.c powerpc.git/arch/powerpc/boot/cuboot-sequoia.c +--- linux-2.6.24/arch/powerpc/boot/cuboot-sequoia.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/cuboot-sequoia.c 2008-01-28 20:25:49.000000000 +0100 +@@ -39,7 +39,7 @@ + { + unsigned long sysclk = 33333333; + +- ibm440ep_fixup_clocks(sysclk, 11059200); ++ ibm440ep_fixup_clocks(sysclk, 11059200, 50000000); + ibm4xx_fixup_ebc_ranges("/plb/opb/ebc"); + ibm4xx_denali_fixup_memsize(); + dt_fixup_mac_addresses(&bd.bi_enetaddr, &bd.bi_enet1addr); +@@ -51,6 +51,6 @@ + CUBOOT_INIT(); + platform_ops.fixups = sequoia_fixups; + platform_ops.exit = ibm44x_dbcr_reset; +- ft_init(_dtb_start, 0, 32); ++ fdt_init(_dtb_start); + serial_console_init(); + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/cuboot-taishan.c powerpc.git/arch/powerpc/boot/cuboot-taishan.c +--- linux-2.6.24/arch/powerpc/boot/cuboot-taishan.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/cuboot-taishan.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,54 @@ ++/* ++ * Old U-boot compatibility for Taishan ++ * ++ * Author: Hugh Blemings <hugh@au.ibm.com> ++ * ++ * Copyright 2007 Hugh Blemings, IBM Corporation. ++ * Based on cuboot-ebony.c which is: ++ * Copyright 2007 David Gibson, IBM Corporation. ++ * Based on cuboot-83xx.c, which is: ++ * Copyright (c) 2007 Freescale Semiconductor, Inc. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 as published ++ * by the Free Software Foundation. ++ */ ++ ++#include "ops.h" ++#include "stdio.h" ++#include "cuboot.h" ++#include "reg.h" ++#include "dcr.h" ++#include "4xx.h" ++ ++#define TARGET_44x ++#include "ppcboot.h" ++ ++static bd_t bd; ++ ++BSS_STACK(4096); ++ ++static void taishan_fixups(void) ++{ ++ /* FIXME: sysclk should be derived by reading the FPGA ++ registers */ ++ unsigned long sysclk = 33000000; ++ ++ ibm440gx_fixup_clocks(sysclk, 6 * 1843200, 25000000); ++ ++ ibm4xx_sdram_fixup_memsize(); ++ ++ dt_fixup_mac_addresses(bd.bi_enetaddr, bd.bi_enet1addr); ++ ++ ibm4xx_fixup_ebc_ranges("/plb/opb/ebc"); ++} ++ ++void platform_init(unsigned long r3, unsigned long r4, unsigned long r5, ++ unsigned long r6, unsigned long r7) ++{ ++ CUBOOT_INIT(); ++ ++ platform_ops.fixups = taishan_fixups; ++ fdt_init(_dtb_start); ++ serial_console_init(); ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/cuboot-warp.c powerpc.git/arch/powerpc/boot/cuboot-warp.c +--- linux-2.6.24/arch/powerpc/boot/cuboot-warp.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/cuboot-warp.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,39 @@ ++/* ++ * Copyright (c) 2008 PIKA Technologies ++ * Sean MacLennan <smaclennan@pikatech.com> ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 as published ++ * by the Free Software Foundation. ++ */ ++ ++#include "ops.h" ++#include "4xx.h" ++#include "cuboot.h" ++ ++#define TARGET_44x ++#include "ppcboot.h" ++ ++static bd_t bd; ++ ++static void warp_fixups(void) ++{ ++ unsigned long sysclk = 66000000; ++ ++ ibm440ep_fixup_clocks(sysclk, 11059200, 50000000); ++ ibm4xx_sdram_fixup_memsize(); ++ ibm4xx_fixup_ebc_ranges("/plb/opb/ebc"); ++ dt_fixup_mac_addresses(&bd.bi_enetaddr); ++} ++ ++ ++void platform_init(unsigned long r3, unsigned long r4, unsigned long r5, ++ unsigned long r6, unsigned long r7) ++{ ++ CUBOOT_INIT(); ++ ++ platform_ops.fixups = warp_fixups; ++ platform_ops.exit = ibm44x_dbcr_reset; ++ fdt_init(_dtb_start); ++ serial_console_init(); ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dcr.h powerpc.git/arch/powerpc/boot/dcr.h +--- linux-2.6.24/arch/powerpc/boot/dcr.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dcr.h 2008-01-28 20:25:49.000000000 +0100 +@@ -14,12 +14,20 @@ + #define DCRN_SDRAM0_CFGADDR 0x010 + #define DCRN_SDRAM0_CFGDATA 0x011 + ++#define SDRAM0_READ(offset) ({\ ++ mtdcr(DCRN_SDRAM0_CFGADDR, offset); \ ++ mfdcr(DCRN_SDRAM0_CFGDATA); }) ++#define SDRAM0_WRITE(offset, data) ({\ ++ mtdcr(DCRN_SDRAM0_CFGADDR, offset); \ ++ mtdcr(DCRN_SDRAM0_CFGDATA, data); }) ++ + #define SDRAM0_B0CR 0x40 + #define SDRAM0_B1CR 0x44 + #define SDRAM0_B2CR 0x48 + #define SDRAM0_B3CR 0x4c + +-static const unsigned long sdram_bxcr[] = { SDRAM0_B0CR, SDRAM0_B1CR, SDRAM0_B2CR, SDRAM0_B3CR }; ++static const unsigned long sdram_bxcr[] = { SDRAM0_B0CR, SDRAM0_B1CR, ++ SDRAM0_B2CR, SDRAM0_B3CR }; + + #define SDRAM_CONFIG_BANK_ENABLE 0x00000001 + #define SDRAM_CONFIG_SIZE_MASK 0x000e0000 +@@ -138,5 +146,54 @@ + #define DCRN_CPC0_PLLMR 0xb0 + #define DCRN_405_CPC0_CR0 0xb1 + #define DCRN_405_CPC0_CR1 0xb2 ++#define DCRN_405_CPC0_PSR 0xb4 ++ ++/* 405EP Clocking/Power Management/Chip Control regs */ ++#define DCRN_CPC0_PLLMR0 0xf0 ++#define DCRN_CPC0_PLLMR1 0xf4 ++#define DCRN_CPC0_UCR 0xf5 ++ ++/* 440GX Clock control etc */ ++ ++ ++#define DCRN_CPR0_CLKUPD 0x020 ++#define DCRN_CPR0_PLLC 0x040 ++#define DCRN_CPR0_PLLD 0x060 ++#define DCRN_CPR0_PRIMAD 0x080 ++#define DCRN_CPR0_PRIMBD 0x0a0 ++#define DCRN_CPR0_OPBD 0x0c0 ++#define DCRN_CPR0_PERD 0x0e0 ++#define DCRN_CPR0_MALD 0x100 ++ ++#define DCRN_SDR0_CONFIG_ADDR 0xe ++#define DCRN_SDR0_CONFIG_DATA 0xf ++ ++/* SDR read/write helper macros */ ++#define SDR0_READ(offset) ({\ ++ mtdcr(DCRN_SDR0_CONFIG_ADDR, offset); \ ++ mfdcr(DCRN_SDR0_CONFIG_DATA); }) ++#define SDR0_WRITE(offset, data) ({\ ++ mtdcr(DCRN_SDR0_CONFIG_ADDR, offset); \ ++ mtdcr(DCRN_SDR0_CONFIG_DATA, data); }) ++ ++#define DCRN_SDR0_UART0 0x0120 ++#define DCRN_SDR0_UART1 0x0121 ++#define DCRN_SDR0_UART2 0x0122 ++#define DCRN_SDR0_UART3 0x0123 ++ ++ ++/* CPRs read/write helper macros - based off include/asm-ppc/ibm44x.h */ ++ ++#define DCRN_CPR0_CFGADDR 0xc ++#define DCRN_CPR0_CFGDATA 0xd ++ ++#define CPR0_READ(offset) ({\ ++ mtdcr(DCRN_CPR0_CFGADDR, offset); \ ++ mfdcr(DCRN_CPR0_CFGDATA); }) ++#define CPR0_WRITE(offset, data) ({\ ++ mtdcr(DCRN_CPR0_CFGADDR, offset); \ ++ mtdcr(DCRN_CPR0_CFGDATA, data); }) ++ ++ + + #endif /* _PPC_BOOT_DCR_H_ */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/devtree.c powerpc.git/arch/powerpc/boot/devtree.c +--- linux-2.6.24/arch/powerpc/boot/devtree.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/devtree.c 2008-01-28 20:25:49.000000000 +0100 +@@ -88,6 +88,20 @@ + } + } + ++void dt_fixup_mac_address_by_alias(const char *alias, const u8 *addr) ++{ ++ void *devp = find_node_by_alias(alias); ++ ++ if (devp) { ++ printf("%s: local-mac-address <-" ++ " %02x:%02x:%02x:%02x:%02x:%02x\n\r", alias, ++ addr[0], addr[1], addr[2], ++ addr[3], addr[4], addr[5]); ++ ++ setprop(devp, "local-mac-address", addr, 6); ++ } ++} ++ + void dt_fixup_mac_address(u32 index, const u8 *addr) + { + void *devp = find_node_by_prop_value(NULL, "linux,network-index", +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/Makefile.dtc powerpc.git/arch/powerpc/boot/dtc-src/Makefile.dtc +--- linux-2.6.24/arch/powerpc/boot/dtc-src/Makefile.dtc 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/Makefile.dtc 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,25 @@ ++# Makefile.dtc ++# ++# This is not a complete Makefile of itself. Instead, it is designed to ++# be easily embeddable into other systems of Makefiles. ++# ++DTC_SRCS = dtc.c flattree.c fstree.c data.c livetree.c treesource.c srcpos.c \ ++ checks.c ++DTC_EXTRA = dtc.h srcpos.h ++DTC_LEXFILES = dtc-lexer.l ++DTC_BISONFILES = dtc-parser.y ++ ++DTC_LEX_SRCS = $(DTC_LEXFILES:%.l=%.lex.c) ++DTC_BISON_SRCS = $(DTC_BISONFILES:%.y=%.tab.c) ++DTC_BISON_INCLUDES = $(DTC_BISONFILES:%.y=%.tab.h) ++ ++DTC_GEN_SRCS = $(DTC_LEX_SRCS) $(DTC_BISON_SRCS) ++DTC_GEN_ALL = $(DTC_GEN_SRCS) $(DTC_BISON_INCLUDES) ++DTC_OBJS = $(DTC_SRCS:%.c=%.o) $(DTC_GEN_SRCS:%.c=%.o) ++ ++DTC_CLEANFILES = $(DTC_GEN_ALL) ++ ++# We assume the containing Makefile system can do auto-dependencies for most ++# things, but we supply the dependencies on generated header files explicitly ++ ++$(addprefix $(DTC_objdir)/,$(DTC_GEN_SRCS:%.c=%.o)): $(addprefix $(DTC_objdir)/,$(DTC_BISON_INCLUDES)) +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/checks.c powerpc.git/arch/powerpc/boot/dtc-src/checks.c +--- linux-2.6.24/arch/powerpc/boot/dtc-src/checks.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/checks.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,750 @@ ++/* ++ * (C) Copyright David Gibson <dwg@au1.ibm.com>, IBM Corporation. 2007. ++ * ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 ++ * USA ++ */ ++ ++#include "dtc.h" ++ ++#ifdef TRACE_CHECKS ++#define TRACE(c, ...) \ ++ do { \ ++ fprintf(stderr, "=== %s: ", (c)->name); \ ++ fprintf(stderr, __VA_ARGS__); \ ++ fprintf(stderr, "\n"); \ ++ } while (0) ++#else ++#define TRACE(c, fmt, ...) do { } while (0) ++#endif ++ ++enum checklevel { ++ IGNORE = 0, ++ WARN = 1, ++ ERROR = 2, ++}; ++ ++enum checkstatus { ++ UNCHECKED = 0, ++ PREREQ, ++ PASSED, ++ FAILED, ++}; ++ ++struct check; ++ ++typedef void (*tree_check_fn)(struct check *c, struct node *dt); ++typedef void (*node_check_fn)(struct check *c, struct node *dt, struct node *node); ++typedef void (*prop_check_fn)(struct check *c, struct node *dt, ++ struct node *node, struct property *prop); ++ ++struct check { ++ const char *name; ++ tree_check_fn tree_fn; ++ node_check_fn node_fn; ++ prop_check_fn prop_fn; ++ void *data; ++ enum checklevel level; ++ enum checkstatus status; ++ int inprogress; ++ int num_prereqs; ++ struct check **prereq; ++}; ++ ++#define CHECK(nm, tfn, nfn, pfn, d, lvl, ...) \ ++ static struct check *nm##_prereqs[] = { __VA_ARGS__ }; \ ++ static struct check nm = { \ ++ .name = #nm, \ ++ .tree_fn = (tfn), \ ++ .node_fn = (nfn), \ ++ .prop_fn = (pfn), \ ++ .data = (d), \ ++ .level = (lvl), \ ++ .status = UNCHECKED, \ ++ .num_prereqs = ARRAY_SIZE(nm##_prereqs), \ ++ .prereq = nm##_prereqs, \ ++ }; ++ ++#define TREE_CHECK(nm, d, lvl, ...) \ ++ CHECK(nm, check_##nm, NULL, NULL, d, lvl, __VA_ARGS__) ++#define NODE_CHECK(nm, d, lvl, ...) \ ++ CHECK(nm, NULL, check_##nm, NULL, d, lvl, __VA_ARGS__) ++#define PROP_CHECK(nm, d, lvl, ...) \ ++ CHECK(nm, NULL, NULL, check_##nm, d, lvl, __VA_ARGS__) ++#define BATCH_CHECK(nm, lvl, ...) \ ++ CHECK(nm, NULL, NULL, NULL, NULL, lvl, __VA_ARGS__) ++ ++#ifdef __GNUC__ ++static inline void check_msg(struct check *c, const char *fmt, ...) __attribute__((format (printf, 2, 3))); ++#endif ++static inline void check_msg(struct check *c, const char *fmt, ...) ++{ ++ va_list ap; ++ va_start(ap, fmt); ++ ++ if ((c->level < WARN) || (c->level <= quiet)) ++ return; /* Suppress message */ ++ ++ fprintf(stderr, "%s (%s): ", ++ (c->level == ERROR) ? "ERROR" : "Warning", c->name); ++ vfprintf(stderr, fmt, ap); ++ fprintf(stderr, "\n"); ++} ++ ++#define FAIL(c, ...) \ ++ do { \ ++ TRACE((c), "\t\tFAILED at %s:%d", __FILE__, __LINE__); \ ++ (c)->status = FAILED; \ ++ check_msg((c), __VA_ARGS__); \ ++ } while (0) ++ ++static void check_nodes_props(struct check *c, struct node *dt, struct node *node) ++{ ++ struct node *child; ++ struct property *prop; ++ ++ TRACE(c, "%s", node->fullpath); ++ if (c->node_fn) ++ c->node_fn(c, dt, node); ++ ++ if (c->prop_fn) ++ for_each_property(node, prop) { ++ TRACE(c, "%s\t'%s'", node->fullpath, prop->name); ++ c->prop_fn(c, dt, node, prop); ++ } ++ ++ for_each_child(node, child) ++ check_nodes_props(c, dt, child); ++} ++ ++static int run_check(struct check *c, struct node *dt) ++{ ++ int error = 0; ++ int i; ++ ++ assert(!c->inprogress); ++ ++ if (c->status != UNCHECKED) ++ goto out; ++ ++ c->inprogress = 1; ++ ++ for (i = 0; i < c->num_prereqs; i++) { ++ struct check *prq = c->prereq[i]; ++ error |= run_check(prq, dt); ++ if (prq->status != PASSED) { ++ c->status = PREREQ; ++ check_msg(c, "Failed prerequisite '%s'", ++ c->prereq[i]->name); ++ } ++ } ++ ++ if (c->status != UNCHECKED) ++ goto out; ++ ++ if (c->node_fn || c->prop_fn) ++ check_nodes_props(c, dt, dt); ++ ++ if (c->tree_fn) ++ c->tree_fn(c, dt); ++ if (c->status == UNCHECKED) ++ c->status = PASSED; ++ ++ TRACE(c, "\tCompleted, status %d", c->status); ++ ++out: ++ c->inprogress = 0; ++ if ((c->status != PASSED) && (c->level == ERROR)) ++ error = 1; ++ return error; ++} ++ ++/* ++ * Utility check functions ++ */ ++ ++static void check_is_string(struct check *c, struct node *root, ++ struct node *node) ++{ ++ struct property *prop; ++ char *propname = c->data; ++ ++ prop = get_property(node, propname); ++ if (!prop) ++ return; /* Not present, assumed ok */ ++ ++ if (!data_is_one_string(prop->val)) ++ FAIL(c, "\"%s\" property in %s is not a string", ++ propname, node->fullpath); ++} ++#define CHECK_IS_STRING(nm, propname, lvl) \ ++ CHECK(nm, NULL, check_is_string, NULL, (propname), (lvl)) ++ ++static void check_is_cell(struct check *c, struct node *root, ++ struct node *node) ++{ ++ struct property *prop; ++ char *propname = c->data; ++ ++ prop = get_property(node, propname); ++ if (!prop) ++ return; /* Not present, assumed ok */ ++ ++ if (prop->val.len != sizeof(cell_t)) ++ FAIL(c, "\"%s\" property in %s is not a single cell", ++ propname, node->fullpath); ++} ++#define CHECK_IS_CELL(nm, propname, lvl) \ ++ CHECK(nm, NULL, check_is_cell, NULL, (propname), (lvl)) ++ ++/* ++ * Structural check functions ++ */ ++ ++static void check_duplicate_node_names(struct check *c, struct node *dt, ++ struct node *node) ++{ ++ struct node *child, *child2; ++ ++ for_each_child(node, child) ++ for (child2 = child->next_sibling; ++ child2; ++ child2 = child2->next_sibling) ++ if (streq(child->name, child2->name)) ++ FAIL(c, "Duplicate node name %s", ++ child->fullpath); ++} ++NODE_CHECK(duplicate_node_names, NULL, ERROR); ++ ++static void check_duplicate_property_names(struct check *c, struct node *dt, ++ struct node *node) ++{ ++ struct property *prop, *prop2; ++ ++ for_each_property(node, prop) ++ for (prop2 = prop->next; prop2; prop2 = prop2->next) ++ if (streq(prop->name, prop2->name)) ++ FAIL(c, "Duplicate property name %s in %s", ++ prop->name, node->fullpath); ++} ++NODE_CHECK(duplicate_property_names, NULL, ERROR); ++ ++static void check_explicit_phandles(struct check *c, struct node *root, ++ struct node *node) ++{ ++ struct property *prop; ++ struct node *other; ++ cell_t phandle; ++ ++ prop = get_property(node, "linux,phandle"); ++ if (! prop) ++ return; /* No phandle, that's fine */ ++ ++ if (prop->val.len != sizeof(cell_t)) { ++ FAIL(c, "%s has bad length (%d) linux,phandle property", ++ node->fullpath, prop->val.len); ++ return; ++ } ++ ++ phandle = propval_cell(prop); ++ if ((phandle == 0) || (phandle == -1)) { ++ FAIL(c, "%s has invalid linux,phandle value 0x%x", ++ node->fullpath, phandle); ++ return; ++ } ++ ++ other = get_node_by_phandle(root, phandle); ++ if (other) { ++ FAIL(c, "%s has duplicated phandle 0x%x (seen before at %s)", ++ node->fullpath, phandle, other->fullpath); ++ return; ++ } ++ ++ node->phandle = phandle; ++} ++NODE_CHECK(explicit_phandles, NULL, ERROR); ++ ++static void check_name_properties(struct check *c, struct node *root, ++ struct node *node) ++{ ++ struct property *prop; ++ ++ prop = get_property(node, "name"); ++ if (!prop) ++ return; /* No name property, that's fine */ ++ ++ if ((prop->val.len != node->basenamelen+1) ++ || (memcmp(prop->val.val, node->name, node->basenamelen) != 0)) ++ FAIL(c, "\"name\" property in %s is incorrect (\"%s\" instead" ++ " of base node name)", node->fullpath, prop->val.val); ++} ++CHECK_IS_STRING(name_is_string, "name", ERROR); ++NODE_CHECK(name_properties, NULL, ERROR, &name_is_string); ++ ++/* ++ * Reference fixup functions ++ */ ++ ++static void fixup_phandle_references(struct check *c, struct node *dt, ++ struct node *node, struct property *prop) ++{ ++ struct marker *m = prop->val.markers; ++ struct node *refnode; ++ cell_t phandle; ++ ++ for_each_marker_of_type(m, REF_PHANDLE) { ++ assert(m->offset + sizeof(cell_t) <= prop->val.len); ++ ++ refnode = get_node_by_ref(dt, m->ref); ++ if (! refnode) { ++ FAIL(c, "Reference to non-existent node or label \"%s\"\n", ++ m->ref); ++ continue; ++ } ++ ++ phandle = get_node_phandle(dt, refnode); ++ *((cell_t *)(prop->val.val + m->offset)) = cpu_to_be32(phandle); ++ } ++} ++CHECK(phandle_references, NULL, NULL, fixup_phandle_references, NULL, ERROR, ++ &duplicate_node_names, &explicit_phandles); ++ ++static void fixup_path_references(struct check *c, struct node *dt, ++ struct node *node, struct property *prop) ++{ ++ struct marker *m = prop->val.markers; ++ struct node *refnode; ++ char *path; ++ ++ for_each_marker_of_type(m, REF_PATH) { ++ assert(m->offset <= prop->val.len); ++ ++ refnode = get_node_by_ref(dt, m->ref); ++ if (!refnode) { ++ FAIL(c, "Reference to non-existent node or label \"%s\"\n", ++ m->ref); ++ continue; ++ } ++ ++ path = refnode->fullpath; ++ prop->val = data_insert_at_marker(prop->val, m, path, ++ strlen(path) + 1); ++ } ++} ++CHECK(path_references, NULL, NULL, fixup_path_references, NULL, ERROR, ++ &duplicate_node_names); ++ ++/* ++ * Semantic checks ++ */ ++CHECK_IS_CELL(address_cells_is_cell, "#address-cells", WARN); ++CHECK_IS_CELL(size_cells_is_cell, "#size-cells", WARN); ++CHECK_IS_CELL(interrupt_cells_is_cell, "#interrupt-cells", WARN); ++ ++CHECK_IS_STRING(device_type_is_string, "device_type", WARN); ++CHECK_IS_STRING(model_is_string, "model", WARN); ++CHECK_IS_STRING(status_is_string, "status", WARN); ++ ++static void fixup_addr_size_cells(struct check *c, struct node *dt, ++ struct node *node) ++{ ++ struct property *prop; ++ ++ node->addr_cells = -1; ++ node->size_cells = -1; ++ ++ prop = get_property(node, "#address-cells"); ++ if (prop) ++ node->addr_cells = propval_cell(prop); ++ ++ prop = get_property(node, "#size-cells"); ++ if (prop) ++ node->size_cells = propval_cell(prop); ++} ++CHECK(addr_size_cells, NULL, fixup_addr_size_cells, NULL, NULL, WARN, ++ &address_cells_is_cell, &size_cells_is_cell); ++ ++#define node_addr_cells(n) \ ++ (((n)->addr_cells == -1) ? 2 : (n)->addr_cells) ++#define node_size_cells(n) \ ++ (((n)->size_cells == -1) ? 1 : (n)->size_cells) ++ ++static void check_reg_format(struct check *c, struct node *dt, ++ struct node *node) ++{ ++ struct property *prop; ++ int addr_cells, size_cells, entrylen; ++ ++ prop = get_property(node, "reg"); ++ if (!prop) ++ return; /* No "reg", that's fine */ ++ ++ if (!node->parent) { ++ FAIL(c, "Root node has a \"reg\" property"); ++ return; ++ } ++ ++ if (prop->val.len == 0) ++ FAIL(c, "\"reg\" property in %s is empty", node->fullpath); ++ ++ addr_cells = node_addr_cells(node->parent); ++ size_cells = node_size_cells(node->parent); ++ entrylen = (addr_cells + size_cells) * sizeof(cell_t); ++ ++ if ((prop->val.len % entrylen) != 0) ++ FAIL(c, "\"reg\" property in %s has invalid length (%d bytes) " ++ "(#address-cells == %d, #size-cells == %d)", ++ node->fullpath, prop->val.len, addr_cells, size_cells); ++} ++NODE_CHECK(reg_format, NULL, WARN, &addr_size_cells); ++ ++static void check_ranges_format(struct check *c, struct node *dt, ++ struct node *node) ++{ ++ struct property *prop; ++ int c_addr_cells, p_addr_cells, c_size_cells, p_size_cells, entrylen; ++ ++ prop = get_property(node, "ranges"); ++ if (!prop) ++ return; ++ ++ if (!node->parent) { ++ FAIL(c, "Root node has a \"ranges\" property"); ++ return; ++ } ++ ++ p_addr_cells = node_addr_cells(node->parent); ++ p_size_cells = node_size_cells(node->parent); ++ c_addr_cells = node_addr_cells(node); ++ c_size_cells = node_size_cells(node); ++ entrylen = (p_addr_cells + c_addr_cells + c_size_cells) * sizeof(cell_t); ++ ++ if (prop->val.len == 0) { ++ if (p_addr_cells != c_addr_cells) ++ FAIL(c, "%s has empty \"ranges\" property but its " ++ "#address-cells (%d) differs from %s (%d)", ++ node->fullpath, c_addr_cells, node->parent->fullpath, ++ p_addr_cells); ++ if (p_size_cells != c_size_cells) ++ FAIL(c, "%s has empty \"ranges\" property but its " ++ "#size-cells (%d) differs from %s (%d)", ++ node->fullpath, c_size_cells, node->parent->fullpath, ++ p_size_cells); ++ } else if ((prop->val.len % entrylen) != 0) { ++ FAIL(c, "\"ranges\" property in %s has invalid length (%d bytes) " ++ "(parent #address-cells == %d, child #address-cells == %d, " ++ "#size-cells == %d)", node->fullpath, prop->val.len, ++ p_addr_cells, c_addr_cells, c_size_cells); ++ } ++} ++NODE_CHECK(ranges_format, NULL, WARN, &addr_size_cells); ++ ++/* ++ * Style checks ++ */ ++static void check_avoid_default_addr_size(struct check *c, struct node *dt, ++ struct node *node) ++{ ++ struct property *reg, *ranges; ++ ++ if (!node->parent) ++ return; /* Ignore root node */ ++ ++ reg = get_property(node, "reg"); ++ ranges = get_property(node, "ranges"); ++ ++ if (!reg && !ranges) ++ return; ++ ++ if ((node->parent->addr_cells == -1)) ++ FAIL(c, "Relying on default #address-cells value for %s", ++ node->fullpath); ++ ++ if ((node->parent->size_cells == -1)) ++ FAIL(c, "Relying on default #size-cells value for %s", ++ node->fullpath); ++} ++NODE_CHECK(avoid_default_addr_size, NULL, WARN, &addr_size_cells); ++ ++static void check_obsolete_chosen_interrupt_controller(struct check *c, ++ struct node *dt) ++{ ++ struct node *chosen; ++ struct property *prop; ++ ++ chosen = get_node_by_path(dt, "/chosen"); ++ if (!chosen) ++ return; ++ ++ prop = get_property(chosen, "interrupt-controller"); ++ if (prop) ++ FAIL(c, "/chosen has obsolete \"interrupt-controller\" " ++ "property"); ++} ++TREE_CHECK(obsolete_chosen_interrupt_controller, NULL, WARN); ++ ++static struct check *check_table[] = { ++ &duplicate_node_names, &duplicate_property_names, ++ &name_is_string, &name_properties, ++ &explicit_phandles, ++ &phandle_references, &path_references, ++ ++ &address_cells_is_cell, &size_cells_is_cell, &interrupt_cells_is_cell, ++ &device_type_is_string, &model_is_string, &status_is_string, ++ ++ &addr_size_cells, ®_format, &ranges_format, ++ ++ &avoid_default_addr_size, ++ &obsolete_chosen_interrupt_controller, ++}; ++ ++int check_semantics(struct node *dt, int outversion, int boot_cpuid_phys); ++ ++void process_checks(int force, struct boot_info *bi, ++ int checkflag, int outversion, int boot_cpuid_phys) ++{ ++ struct node *dt = bi->dt; ++ int i; ++ int error = 0; ++ ++ for (i = 0; i < ARRAY_SIZE(check_table); i++) { ++ struct check *c = check_table[i]; ++ ++ if (c->level != IGNORE) ++ error = error || run_check(c, dt); ++ } ++ ++ if (error) { ++ if (!force) { ++ fprintf(stderr, "ERROR: Input tree has errors, aborting " ++ "(use -f to force output)\n"); ++ exit(2); ++ } else if (quiet < 3) { ++ fprintf(stderr, "Warning: Input tree has errors, " ++ "output forced\n"); ++ } ++ } ++ ++ if (checkflag) { ++ if (error) { ++ fprintf(stderr, "Warning: Skipping semantic checks due to structural errors\n"); ++ } else { ++ if (!check_semantics(bi->dt, outversion, ++ boot_cpuid_phys)) ++ fprintf(stderr, "Warning: Input tree has semantic errors\n"); ++ } ++ } ++} ++ ++/* ++ * Semantic check functions ++ */ ++ ++#define ERRMSG(...) if (quiet < 2) fprintf(stderr, "ERROR: " __VA_ARGS__) ++#define WARNMSG(...) if (quiet < 1) fprintf(stderr, "Warning: " __VA_ARGS__) ++ ++#define DO_ERR(...) do {ERRMSG(__VA_ARGS__); ok = 0; } while (0) ++ ++#define CHECK_HAVE(node, propname) \ ++ do { \ ++ if (! (prop = get_property((node), (propname)))) \ ++ DO_ERR("Missing \"%s\" property in %s\n", (propname), \ ++ (node)->fullpath); \ ++ } while (0); ++ ++#define CHECK_HAVE_WARN(node, propname) \ ++ do { \ ++ if (! (prop = get_property((node), (propname)))) \ ++ WARNMSG("%s has no \"%s\" property\n", \ ++ (node)->fullpath, (propname)); \ ++ } while (0) ++ ++#define CHECK_HAVE_STRING(node, propname) \ ++ do { \ ++ CHECK_HAVE((node), (propname)); \ ++ if (prop && !data_is_one_string(prop->val)) \ ++ DO_ERR("\"%s\" property in %s is not a string\n", \ ++ (propname), (node)->fullpath); \ ++ } while (0) ++ ++#define CHECK_HAVE_STREQ(node, propname, value) \ ++ do { \ ++ CHECK_HAVE_STRING((node), (propname)); \ ++ if (prop && !streq(prop->val.val, (value))) \ ++ DO_ERR("%s has wrong %s, %s (should be %s\n", \ ++ (node)->fullpath, (propname), \ ++ prop->val.val, (value)); \ ++ } while (0) ++ ++#define CHECK_HAVE_ONECELL(node, propname) \ ++ do { \ ++ CHECK_HAVE((node), (propname)); \ ++ if (prop && (prop->val.len != sizeof(cell_t))) \ ++ DO_ERR("\"%s\" property in %s has wrong size %d (should be 1 cell)\n", (propname), (node)->fullpath, prop->val.len); \ ++ } while (0) ++ ++#define CHECK_HAVE_WARN_ONECELL(node, propname) \ ++ do { \ ++ CHECK_HAVE_WARN((node), (propname)); \ ++ if (prop && (prop->val.len != sizeof(cell_t))) \ ++ DO_ERR("\"%s\" property in %s has wrong size %d (should be 1 cell)\n", (propname), (node)->fullpath, prop->val.len); \ ++ } while (0) ++ ++#define CHECK_HAVE_WARN_PHANDLE(xnode, propname, root) \ ++ do { \ ++ struct node *ref; \ ++ CHECK_HAVE_WARN_ONECELL((xnode), (propname)); \ ++ if (prop) {\ ++ cell_t phandle = propval_cell(prop); \ ++ if ((phandle == 0) || (phandle == -1)) { \ ++ DO_ERR("\"%s\" property in %s contains an invalid phandle %x\n", (propname), (xnode)->fullpath, phandle); \ ++ } else { \ ++ ref = get_node_by_phandle((root), propval_cell(prop)); \ ++ if (! ref) \ ++ DO_ERR("\"%s\" property in %s refers to non-existant phandle %x\n", (propname), (xnode)->fullpath, propval_cell(prop)); \ ++ } \ ++ } \ ++ } while (0) ++ ++#define CHECK_HAVE_WARN_STRING(node, propname) \ ++ do { \ ++ CHECK_HAVE_WARN((node), (propname)); \ ++ if (prop && !data_is_one_string(prop->val)) \ ++ DO_ERR("\"%s\" property in %s is not a string\n", \ ++ (propname), (node)->fullpath); \ ++ } while (0) ++ ++static int check_root(struct node *root) ++{ ++ struct property *prop; ++ int ok = 1; ++ ++ CHECK_HAVE_STRING(root, "model"); ++ CHECK_HAVE_WARN(root, "compatible"); ++ ++ return ok; ++} ++ ++static int check_cpus(struct node *root, int outversion, int boot_cpuid_phys) ++{ ++ struct node *cpus, *cpu; ++ struct property *prop; ++ struct node *bootcpu = NULL; ++ int ok = 1; ++ ++ cpus = get_subnode(root, "cpus"); ++ if (! cpus) { ++ ERRMSG("Missing /cpus node\n"); ++ return 0; ++ } ++ ++ if (cpus->addr_cells != 1) ++ DO_ERR("%s has bad #address-cells value %d (should be 1)\n", ++ cpus->fullpath, cpus->addr_cells); ++ if (cpus->size_cells != 0) ++ DO_ERR("%s has bad #size-cells value %d (should be 0)\n", ++ cpus->fullpath, cpus->size_cells); ++ ++ for_each_child(cpus, cpu) { ++ CHECK_HAVE_STREQ(cpu, "device_type", "cpu"); ++ ++ CHECK_HAVE_ONECELL(cpu, "reg"); ++ if (prop) { ++ cell_t unitnum; ++ char *eptr; ++ ++ unitnum = strtol(get_unitname(cpu), &eptr, 16); ++ if (*eptr) { ++ WARNMSG("%s has bad format unit name %s (should be CPU number\n", ++ cpu->fullpath, get_unitname(cpu)); ++ } else if (unitnum != propval_cell(prop)) { ++ WARNMSG("%s unit name \"%s\" does not match \"reg\" property <%x>\n", ++ cpu->fullpath, get_unitname(cpu), ++ propval_cell(prop)); ++ } ++ } ++ ++/* CHECK_HAVE_ONECELL(cpu, "d-cache-line-size"); */ ++/* CHECK_HAVE_ONECELL(cpu, "i-cache-line-size"); */ ++ CHECK_HAVE_ONECELL(cpu, "d-cache-size"); ++ CHECK_HAVE_ONECELL(cpu, "i-cache-size"); ++ ++ CHECK_HAVE_WARN_ONECELL(cpu, "clock-frequency"); ++ CHECK_HAVE_WARN_ONECELL(cpu, "timebase-frequency"); ++ ++ prop = get_property(cpu, "linux,boot-cpu"); ++ if (prop) { ++ if (prop->val.len) ++ WARNMSG("\"linux,boot-cpu\" property in %s is non-empty\n", ++ cpu->fullpath); ++ if (bootcpu) ++ DO_ERR("Multiple boot cpus (%s and %s)\n", ++ bootcpu->fullpath, cpu->fullpath); ++ else ++ bootcpu = cpu; ++ } ++ } ++ ++ if (outversion < 2) { ++ if (! bootcpu) ++ WARNMSG("No cpu has \"linux,boot-cpu\" property\n"); ++ } else { ++ if (bootcpu) ++ WARNMSG("\"linux,boot-cpu\" property is deprecated in blob version 2 or higher\n"); ++ if (boot_cpuid_phys == 0xfeedbeef) ++ WARNMSG("physical boot CPU not set. Use -b option to set\n"); ++ } ++ ++ return ok; ++} ++ ++static int check_memory(struct node *root) ++{ ++ struct node *mem; ++ struct property *prop; ++ int nnodes = 0; ++ int ok = 1; ++ ++ for_each_child(root, mem) { ++ if (! strneq(mem->name, "memory", mem->basenamelen)) ++ continue; ++ ++ nnodes++; ++ ++ CHECK_HAVE_STREQ(mem, "device_type", "memory"); ++ CHECK_HAVE(mem, "reg"); ++ } ++ ++ if (nnodes == 0) { ++ ERRMSG("No memory nodes\n"); ++ return 0; ++ } ++ ++ return ok; ++} ++ ++int check_semantics(struct node *dt, int outversion, int boot_cpuid_phys) ++{ ++ int ok = 1; ++ ++ ok = ok && check_root(dt); ++ ok = ok && check_cpus(dt, outversion, boot_cpuid_phys); ++ ok = ok && check_memory(dt); ++ if (! ok) ++ return 0; ++ ++ return 1; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/data.c powerpc.git/arch/powerpc/boot/dtc-src/data.c +--- linux-2.6.24/arch/powerpc/boot/dtc-src/data.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/data.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,321 @@ ++/* ++ * (C) Copyright David Gibson <dwg@au1.ibm.com>, IBM Corporation. 2005. ++ * ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 ++ * USA ++ */ ++ ++#include "dtc.h" ++ ++void data_free(struct data d) ++{ ++ struct marker *m, *nm; ++ ++ m = d.markers; ++ while (m) { ++ nm = m->next; ++ free(m->ref); ++ free(m); ++ m = nm; ++ } ++ ++ assert(!d.val || d.asize); ++ ++ if (d.val) ++ free(d.val); ++} ++ ++struct data data_grow_for(struct data d, int xlen) ++{ ++ struct data nd; ++ int newsize; ++ ++ /* we must start with an allocated datum */ ++ assert(!d.val || d.asize); ++ ++ if (xlen == 0) ++ return d; ++ ++ nd = d; ++ ++ newsize = xlen; ++ ++ while ((d.len + xlen) > newsize) ++ newsize *= 2; ++ ++ nd.asize = newsize; ++ nd.val = xrealloc(d.val, newsize); ++ ++ assert(nd.asize >= (d.len + xlen)); ++ ++ return nd; ++} ++ ++struct data data_copy_mem(const char *mem, int len) ++{ ++ struct data d; ++ ++ d = data_grow_for(empty_data, len); ++ ++ d.len = len; ++ memcpy(d.val, mem, len); ++ ++ return d; ++} ++ ++static char get_oct_char(const char *s, int *i) ++{ ++ char x[4]; ++ char *endx; ++ long val; ++ ++ x[3] = '\0'; ++ x[0] = s[(*i)]; ++ if (x[0]) { ++ x[1] = s[(*i)+1]; ++ if (x[1]) ++ x[2] = s[(*i)+2]; ++ } ++ ++ val = strtol(x, &endx, 8); ++ if ((endx - x) == 0) ++ fprintf(stderr, "Empty \\nnn escape\n"); ++ ++ (*i) += endx - x; ++ return val; ++} ++ ++static char get_hex_char(const char *s, int *i) ++{ ++ char x[3]; ++ char *endx; ++ long val; ++ ++ x[2] = '\0'; ++ x[0] = s[(*i)]; ++ if (x[0]) ++ x[1] = s[(*i)+1]; ++ ++ val = strtol(x, &endx, 16); ++ if ((endx - x) == 0) ++ fprintf(stderr, "Empty \\x escape\n"); ++ ++ (*i) += endx - x; ++ return val; ++} ++ ++struct data data_copy_escape_string(const char *s, int len) ++{ ++ int i = 0; ++ struct data d; ++ char *q; ++ ++ d = data_grow_for(empty_data, strlen(s)+1); ++ ++ q = d.val; ++ while (i < len) { ++ char c = s[i++]; ++ ++ if (c != '\\') { ++ q[d.len++] = c; ++ continue; ++ } ++ ++ c = s[i++]; ++ assert(c); ++ switch (c) { ++ case 'a': ++ q[d.len++] = '\a'; ++ break; ++ case 'b': ++ q[d.len++] = '\b'; ++ break; ++ case 't': ++ q[d.len++] = '\t'; ++ break; ++ case 'n': ++ q[d.len++] = '\n'; ++ break; ++ case 'v': ++ q[d.len++] = '\v'; ++ break; ++ case 'f': ++ q[d.len++] = '\f'; ++ break; ++ case 'r': ++ q[d.len++] = '\r'; ++ break; ++ case '0': ++ case '1': ++ case '2': ++ case '3': ++ case '4': ++ case '5': ++ case '6': ++ case '7': ++ i--; /* need to re-read the first digit as ++ * part of the octal value */ ++ q[d.len++] = get_oct_char(s, &i); ++ break; ++ case 'x': ++ q[d.len++] = get_hex_char(s, &i); ++ break; ++ default: ++ q[d.len++] = c; ++ } ++ } ++ ++ q[d.len++] = '\0'; ++ return d; ++} ++ ++struct data data_copy_file(FILE *f, size_t len) ++{ ++ struct data d; ++ ++ d = data_grow_for(empty_data, len); ++ ++ d.len = len; ++ fread(d.val, len, 1, f); ++ ++ return d; ++} ++ ++struct data data_append_data(struct data d, const void *p, int len) ++{ ++ d = data_grow_for(d, len); ++ memcpy(d.val + d.len, p, len); ++ d.len += len; ++ return d; ++} ++ ++struct data data_insert_at_marker(struct data d, struct marker *m, ++ const void *p, int len) ++{ ++ d = data_grow_for(d, len); ++ memmove(d.val + m->offset + len, d.val + m->offset, d.len - m->offset); ++ memcpy(d.val + m->offset, p, len); ++ d.len += len; ++ ++ /* Adjust all markers after the one we're inserting at */ ++ m = m->next; ++ for_each_marker(m) ++ m->offset += len; ++ return d; ++} ++ ++struct data data_append_markers(struct data d, struct marker *m) ++{ ++ struct marker **mp = &d.markers; ++ ++ /* Find the end of the markerlist */ ++ while (*mp) ++ mp = &((*mp)->next); ++ *mp = m; ++ return d; ++} ++ ++struct data data_merge(struct data d1, struct data d2) ++{ ++ struct data d; ++ struct marker *m2 = d2.markers; ++ ++ d = data_append_markers(data_append_data(d1, d2.val, d2.len), m2); ++ ++ /* Adjust for the length of d1 */ ++ for_each_marker(m2) ++ m2->offset += d1.len; ++ ++ d2.markers = NULL; /* So data_free() doesn't clobber them */ ++ data_free(d2); ++ ++ return d; ++} ++ ++struct data data_append_cell(struct data d, cell_t word) ++{ ++ cell_t beword = cpu_to_be32(word); ++ ++ return data_append_data(d, &beword, sizeof(beword)); ++} ++ ++struct data data_append_re(struct data d, const struct fdt_reserve_entry *re) ++{ ++ struct fdt_reserve_entry bere; ++ ++ bere.address = cpu_to_be64(re->address); ++ bere.size = cpu_to_be64(re->size); ++ ++ return data_append_data(d, &bere, sizeof(bere)); ++} ++ ++struct data data_append_addr(struct data d, u64 addr) ++{ ++ u64 beaddr = cpu_to_be64(addr); ++ ++ return data_append_data(d, &beaddr, sizeof(beaddr)); ++} ++ ++struct data data_append_byte(struct data d, uint8_t byte) ++{ ++ return data_append_data(d, &byte, 1); ++} ++ ++struct data data_append_zeroes(struct data d, int len) ++{ ++ d = data_grow_for(d, len); ++ ++ memset(d.val + d.len, 0, len); ++ d.len += len; ++ return d; ++} ++ ++struct data data_append_align(struct data d, int align) ++{ ++ int newlen = ALIGN(d.len, align); ++ return data_append_zeroes(d, newlen - d.len); ++} ++ ++struct data data_add_marker(struct data d, enum markertype type, char *ref) ++{ ++ struct marker *m; ++ ++ m = xmalloc(sizeof(*m)); ++ m->offset = d.len; ++ m->type = type; ++ m->ref = ref; ++ m->next = NULL; ++ ++ return data_append_markers(d, m); ++} ++ ++int data_is_one_string(struct data d) ++{ ++ int i; ++ int len = d.len; ++ ++ if (len == 0) ++ return 0; ++ ++ for (i = 0; i < len-1; i++) ++ if (d.val[i] == '\0') ++ return 0; ++ ++ if (d.val[len-1] != '\0') ++ return 0; ++ ++ return 1; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/dtc-lexer.l powerpc.git/arch/powerpc/boot/dtc-src/dtc-lexer.l +--- linux-2.6.24/arch/powerpc/boot/dtc-src/dtc-lexer.l 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/dtc-lexer.l 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,328 @@ ++/* ++ * (C) Copyright David Gibson <dwg@au1.ibm.com>, IBM Corporation. 2005. ++ * ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 ++ * USA ++ */ ++ ++%option noyywrap nounput yylineno ++ ++%x INCLUDE ++%x BYTESTRING ++%x PROPNODENAME ++%s V1 ++ ++PROPNODECHAR [a-zA-Z0-9,._+*#?@-] ++PATHCHAR ({PROPNODECHAR}|[/]) ++LABEL [a-zA-Z_][a-zA-Z0-9_]* ++ ++%{ ++#include "dtc.h" ++#include "srcpos.h" ++#include "dtc-parser.tab.h" ++ ++ ++/*#define LEXDEBUG 1*/ ++ ++#ifdef LEXDEBUG ++#define DPRINT(fmt, ...) fprintf(stderr, fmt, ##__VA_ARGS__) ++#else ++#define DPRINT(fmt, ...) do { } while (0) ++#endif ++ ++static int dts_version; /* = 0 */ ++ ++#define BEGIN_DEFAULT() if (dts_version == 0) { \ ++ DPRINT("<INITIAL>\n"); \ ++ BEGIN(INITIAL); \ ++ } else { \ ++ DPRINT("<V1>\n"); \ ++ BEGIN(V1); \ ++ } ++%} ++ ++%% ++<*>"/include/" BEGIN(INCLUDE); ++ ++<INCLUDE>\"[^"\n]*\" { ++ yytext[strlen(yytext) - 1] = 0; ++ if (!push_input_file(yytext + 1)) { ++ /* Some unrecoverable error.*/ ++ exit(1); ++ } ++ BEGIN_DEFAULT(); ++ } ++ ++ ++<*><<EOF>> { ++ if (!pop_input_file()) { ++ yyterminate(); ++ } ++ } ++ ++<*>\"([^\\"]|\\.)*\" { ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("String: %s\n", yytext); ++ yylval.data = data_copy_escape_string(yytext+1, ++ yyleng-2); ++ yylloc.first_line = yylineno; ++ return DT_STRING; ++ } ++ ++<*>"/dts-v1/" { ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Keyword: /dts-v1/\n"); ++ dts_version = 1; ++ BEGIN_DEFAULT(); ++ return DT_V1; ++ } ++ ++<*>"/memreserve/" { ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Keyword: /memreserve/\n"); ++ BEGIN_DEFAULT(); ++ return DT_MEMRESERVE; ++ } ++ ++<*>{LABEL}: { ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Label: %s\n", yytext); ++ yylval.labelref = strdup(yytext); ++ yylval.labelref[yyleng-1] = '\0'; ++ return DT_LABEL; ++ } ++ ++<INITIAL>[bodh]# { ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ if (*yytext == 'b') ++ yylval.cbase = 2; ++ else if (*yytext == 'o') ++ yylval.cbase = 8; ++ else if (*yytext == 'd') ++ yylval.cbase = 10; ++ else ++ yylval.cbase = 16; ++ DPRINT("Base: %d\n", yylval.cbase); ++ return DT_BASE; ++ } ++ ++<INITIAL>[0-9a-fA-F]+ { ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ yylval.literal = strdup(yytext); ++ DPRINT("Literal: '%s'\n", yylval.literal); ++ return DT_LEGACYLITERAL; ++ } ++ ++<V1>[0-9]+|0[xX][0-9a-fA-F]+ { ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ yylval.literal = strdup(yytext); ++ DPRINT("Literal: '%s'\n", yylval.literal); ++ return DT_LITERAL; ++ } ++ ++\&{LABEL} { /* label reference */ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Ref: %s\n", yytext+1); ++ yylval.labelref = strdup(yytext+1); ++ return DT_REF; ++ } ++ ++"&{/"{PATHCHAR}+\} { /* new-style path reference */ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ yytext[yyleng-1] = '\0'; ++ DPRINT("Ref: %s\n", yytext+2); ++ yylval.labelref = strdup(yytext+2); ++ return DT_REF; ++ } ++ ++<INITIAL>"&/"{PATHCHAR}+ { /* old-style path reference */ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Ref: %s\n", yytext+1); ++ yylval.labelref = strdup(yytext+1); ++ return DT_REF; ++ } ++ ++<BYTESTRING>[0-9a-fA-F]{2} { ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ yylval.byte = strtol(yytext, NULL, 16); ++ DPRINT("Byte: %02x\n", (int)yylval.byte); ++ return DT_BYTE; ++ } ++ ++<BYTESTRING>"]" { ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("/BYTESTRING\n"); ++ BEGIN_DEFAULT(); ++ return ']'; ++ } ++ ++<PROPNODENAME>{PROPNODECHAR}+ { ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("PropNodeName: %s\n", yytext); ++ yylval.propnodename = strdup(yytext); ++ BEGIN_DEFAULT(); ++ return DT_PROPNODENAME; ++ } ++ ++ ++<*>[[:space:]]+ /* eat whitespace */ ++ ++<*>"/*"([^*]|\*+[^*/])*\*+"/" { ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Comment: %s\n", yytext); ++ /* eat comments */ ++ } ++ ++<*>"//".*\n /* eat line comments */ ++ ++<*>. { ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Char: %c (\\x%02x)\n", yytext[0], ++ (unsigned)yytext[0]); ++ if (yytext[0] == '[') { ++ DPRINT("<BYTESTRING>\n"); ++ BEGIN(BYTESTRING); ++ } ++ if ((yytext[0] == '{') ++ || (yytext[0] == ';')) { ++ DPRINT("<PROPNODENAME>\n"); ++ BEGIN(PROPNODENAME); ++ } ++ return yytext[0]; ++ } ++ ++%% ++ ++ ++/* ++ * Stack of nested include file contexts. ++ */ ++ ++struct incl_file { ++ int filenum; ++ FILE *file; ++ YY_BUFFER_STATE yy_prev_buf; ++ int yy_prev_lineno; ++ struct incl_file *prev; ++}; ++ ++struct incl_file *incl_file_stack; ++ ++ ++/* ++ * Detect infinite include recursion. ++ */ ++#define MAX_INCLUDE_DEPTH (100) ++ ++static int incl_depth = 0; ++ ++ ++int push_input_file(const char *filename) ++{ ++ FILE *f; ++ struct incl_file *incl_file; ++ ++ if (!filename) { ++ yyerror("No include file name given."); ++ return 0; ++ } ++ ++ if (incl_depth++ >= MAX_INCLUDE_DEPTH) { ++ yyerror("Includes nested too deeply"); ++ return 0; ++ } ++ ++ f = dtc_open_file(filename); ++ ++ incl_file = malloc(sizeof(struct incl_file)); ++ if (!incl_file) { ++ yyerror("Can not allocate include file space."); ++ return 0; ++ } ++ ++ /* ++ * Save current context. ++ */ ++ incl_file->yy_prev_buf = YY_CURRENT_BUFFER; ++ incl_file->yy_prev_lineno = yylineno; ++ incl_file->filenum = srcpos_filenum; ++ incl_file->file = yyin; ++ incl_file->prev = incl_file_stack; ++ ++ incl_file_stack = incl_file; ++ ++ /* ++ * Establish new context. ++ */ ++ srcpos_filenum = lookup_file_name(filename, 0); ++ yylineno = 1; ++ yyin = f; ++ yy_switch_to_buffer(yy_create_buffer(yyin, YY_BUF_SIZE)); ++ ++ return 1; ++} ++ ++ ++int pop_input_file(void) ++{ ++ struct incl_file *incl_file; ++ ++ if (incl_file_stack == 0) ++ return 0; ++ ++ fclose(yyin); ++ ++ /* ++ * Pop. ++ */ ++ --incl_depth; ++ incl_file = incl_file_stack; ++ incl_file_stack = incl_file->prev; ++ ++ /* ++ * Recover old context. ++ */ ++ yy_delete_buffer(YY_CURRENT_BUFFER); ++ yy_switch_to_buffer(incl_file->yy_prev_buf); ++ yylineno = incl_file->yy_prev_lineno; ++ srcpos_filenum = incl_file->filenum; ++ yyin = incl_file->file; ++ ++ /* ++ * Free old state. ++ */ ++ free(incl_file); ++ ++ if (YY_CURRENT_BUFFER == 0) ++ return 0; ++ ++ return 1; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/dtc-lexer.lex.c_shipped powerpc.git/arch/powerpc/boot/dtc-src/dtc-lexer.lex.c_shipped +--- linux-2.6.24/arch/powerpc/boot/dtc-src/dtc-lexer.lex.c_shipped 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/dtc-lexer.lex.c_shipped 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,2174 @@ ++#line 2 "dtc-lexer.lex.c" ++ ++#line 4 "dtc-lexer.lex.c" ++ ++#define YY_INT_ALIGNED short int ++ ++/* A lexical scanner generated by flex */ ++ ++#define FLEX_SCANNER ++#define YY_FLEX_MAJOR_VERSION 2 ++#define YY_FLEX_MINOR_VERSION 5 ++#define YY_FLEX_SUBMINOR_VERSION 33 ++#if YY_FLEX_SUBMINOR_VERSION > 0 ++#define FLEX_BETA ++#endif ++ ++/* First, we deal with platform-specific or compiler-specific issues. */ ++ ++/* begin standard C headers. */ ++#include <stdio.h> ++#include <string.h> ++#include <errno.h> ++#include <stdlib.h> ++ ++/* end standard C headers. */ ++ ++/* flex integer type definitions */ ++ ++#ifndef FLEXINT_H ++#define FLEXINT_H ++ ++/* C99 systems have <inttypes.h>. Non-C99 systems may or may not. */ ++ ++#if __STDC_VERSION__ >= 199901L ++ ++/* C99 says to define __STDC_LIMIT_MACROS before including stdint.h, ++ * if you want the limit (max/min) macros for int types. ++ */ ++#ifndef __STDC_LIMIT_MACROS ++#define __STDC_LIMIT_MACROS 1 ++#endif ++ ++#include <inttypes.h> ++typedef int8_t flex_int8_t; ++typedef uint8_t flex_uint8_t; ++typedef int16_t flex_int16_t; ++typedef uint16_t flex_uint16_t; ++typedef int32_t flex_int32_t; ++typedef uint32_t flex_uint32_t; ++#else ++typedef signed char flex_int8_t; ++typedef short int flex_int16_t; ++typedef int flex_int32_t; ++typedef unsigned char flex_uint8_t; ++typedef unsigned short int flex_uint16_t; ++typedef unsigned int flex_uint32_t; ++#endif /* ! C99 */ ++ ++/* Limits of integral types. */ ++#ifndef INT8_MIN ++#define INT8_MIN (-128) ++#endif ++#ifndef INT16_MIN ++#define INT16_MIN (-32767-1) ++#endif ++#ifndef INT32_MIN ++#define INT32_MIN (-2147483647-1) ++#endif ++#ifndef INT8_MAX ++#define INT8_MAX (127) ++#endif ++#ifndef INT16_MAX ++#define INT16_MAX (32767) ++#endif ++#ifndef INT32_MAX ++#define INT32_MAX (2147483647) ++#endif ++#ifndef UINT8_MAX ++#define UINT8_MAX (255U) ++#endif ++#ifndef UINT16_MAX ++#define UINT16_MAX (65535U) ++#endif ++#ifndef UINT32_MAX ++#define UINT32_MAX (4294967295U) ++#endif ++ ++#endif /* ! FLEXINT_H */ ++ ++#ifdef __cplusplus ++ ++/* The "const" storage-class-modifier is valid. */ ++#define YY_USE_CONST ++ ++#else /* ! __cplusplus */ ++ ++#if __STDC__ ++ ++#define YY_USE_CONST ++ ++#endif /* __STDC__ */ ++#endif /* ! __cplusplus */ ++ ++#ifdef YY_USE_CONST ++#define yyconst const ++#else ++#define yyconst ++#endif ++ ++/* Returned upon end-of-file. */ ++#define YY_NULL 0 ++ ++/* Promotes a possibly negative, possibly signed char to an unsigned ++ * integer for use as an array index. If the signed char is negative, ++ * we want to instead treat it as an 8-bit unsigned char, hence the ++ * double cast. ++ */ ++#define YY_SC_TO_UI(c) ((unsigned int) (unsigned char) c) ++ ++/* Enter a start condition. This macro really ought to take a parameter, ++ * but we do it the disgusting crufty way forced on us by the ()-less ++ * definition of BEGIN. ++ */ ++#define BEGIN (yy_start) = 1 + 2 * ++ ++/* Translate the current start state into a value that can be later handed ++ * to BEGIN to return to the state. The YYSTATE alias is for lex ++ * compatibility. ++ */ ++#define YY_START (((yy_start) - 1) / 2) ++#define YYSTATE YY_START ++ ++/* Action number for EOF rule of a given start state. */ ++#define YY_STATE_EOF(state) (YY_END_OF_BUFFER + state + 1) ++ ++/* Special action meaning "start processing a new file". */ ++#define YY_NEW_FILE yyrestart(yyin ) ++ ++#define YY_END_OF_BUFFER_CHAR 0 ++ ++/* Size of default input buffer. */ ++#ifndef YY_BUF_SIZE ++#define YY_BUF_SIZE 16384 ++#endif ++ ++/* The state buf must be large enough to hold one state per character in the main buffer. ++ */ ++#define YY_STATE_BUF_SIZE ((YY_BUF_SIZE + 2) * sizeof(yy_state_type)) ++ ++#ifndef YY_TYPEDEF_YY_BUFFER_STATE ++#define YY_TYPEDEF_YY_BUFFER_STATE ++typedef struct yy_buffer_state *YY_BUFFER_STATE; ++#endif ++ ++extern int yyleng; ++ ++extern FILE *yyin, *yyout; ++ ++#define EOB_ACT_CONTINUE_SCAN 0 ++#define EOB_ACT_END_OF_FILE 1 ++#define EOB_ACT_LAST_MATCH 2 ++ ++ /* Note: We specifically omit the test for yy_rule_can_match_eol because it requires ++ * access to the local variable yy_act. Since yyless() is a macro, it would break ++ * existing scanners that call yyless() from OUTSIDE yylex. ++ * One obvious solution it to make yy_act a global. I tried that, and saw ++ * a 5% performance hit in a non-yylineno scanner, because yy_act is ++ * normally declared as a register variable-- so it is not worth it. ++ */ ++ #define YY_LESS_LINENO(n) \ ++ do { \ ++ int yyl;\ ++ for ( yyl = n; yyl < yyleng; ++yyl )\ ++ if ( yytext[yyl] == '\n' )\ ++ --yylineno;\ ++ }while(0) ++ ++/* Return all but the first "n" matched characters back to the input stream. */ ++#define yyless(n) \ ++ do \ ++ { \ ++ /* Undo effects of setting up yytext. */ \ ++ int yyless_macro_arg = (n); \ ++ YY_LESS_LINENO(yyless_macro_arg);\ ++ *yy_cp = (yy_hold_char); \ ++ YY_RESTORE_YY_MORE_OFFSET \ ++ (yy_c_buf_p) = yy_cp = yy_bp + yyless_macro_arg - YY_MORE_ADJ; \ ++ YY_DO_BEFORE_ACTION; /* set up yytext again */ \ ++ } \ ++ while ( 0 ) ++ ++#define unput(c) yyunput( c, (yytext_ptr) ) ++ ++/* The following is because we cannot portably get our hands on size_t ++ * (without autoconf's help, which isn't available because we want ++ * flex-generated scanners to compile on their own). ++ */ ++ ++#ifndef YY_TYPEDEF_YY_SIZE_T ++#define YY_TYPEDEF_YY_SIZE_T ++typedef unsigned int yy_size_t; ++#endif ++ ++#ifndef YY_STRUCT_YY_BUFFER_STATE ++#define YY_STRUCT_YY_BUFFER_STATE ++struct yy_buffer_state ++ { ++ FILE *yy_input_file; ++ ++ char *yy_ch_buf; /* input buffer */ ++ char *yy_buf_pos; /* current position in input buffer */ ++ ++ /* Size of input buffer in bytes, not including room for EOB ++ * characters. ++ */ ++ yy_size_t yy_buf_size; ++ ++ /* Number of characters read into yy_ch_buf, not including EOB ++ * characters. ++ */ ++ int yy_n_chars; ++ ++ /* Whether we "own" the buffer - i.e., we know we created it, ++ * and can realloc() it to grow it, and should free() it to ++ * delete it. ++ */ ++ int yy_is_our_buffer; ++ ++ /* Whether this is an "interactive" input source; if so, and ++ * if we're using stdio for input, then we want to use getc() ++ * instead of fread(), to make sure we stop fetching input after ++ * each newline. ++ */ ++ int yy_is_interactive; ++ ++ /* Whether we're considered to be at the beginning of a line. ++ * If so, '^' rules will be active on the next match, otherwise ++ * not. ++ */ ++ int yy_at_bol; ++ ++ int yy_bs_lineno; /**< The line count. */ ++ int yy_bs_column; /**< The column count. */ ++ ++ /* Whether to try to fill the input buffer when we reach the ++ * end of it. ++ */ ++ int yy_fill_buffer; ++ ++ int yy_buffer_status; ++ ++#define YY_BUFFER_NEW 0 ++#define YY_BUFFER_NORMAL 1 ++ /* When an EOF's been seen but there's still some text to process ++ * then we mark the buffer as YY_EOF_PENDING, to indicate that we ++ * shouldn't try reading from the input source any more. We might ++ * still have a bunch of tokens to match, though, because of ++ * possible backing-up. ++ * ++ * When we actually see the EOF, we change the status to "new" ++ * (via yyrestart()), so that the user can continue scanning by ++ * just pointing yyin at a new input file. ++ */ ++#define YY_BUFFER_EOF_PENDING 2 ++ ++ }; ++#endif /* !YY_STRUCT_YY_BUFFER_STATE */ ++ ++/* Stack of input buffers. */ ++static size_t yy_buffer_stack_top = 0; /**< index of top of stack. */ ++static size_t yy_buffer_stack_max = 0; /**< capacity of stack. */ ++static YY_BUFFER_STATE * yy_buffer_stack = 0; /**< Stack as an array. */ ++ ++/* We provide macros for accessing buffer states in case in the ++ * future we want to put the buffer states in a more general ++ * "scanner state". ++ * ++ * Returns the top of the stack, or NULL. ++ */ ++#define YY_CURRENT_BUFFER ( (yy_buffer_stack) \ ++ ? (yy_buffer_stack)[(yy_buffer_stack_top)] \ ++ : NULL) ++ ++/* Same as previous macro, but useful when we know that the buffer stack is not ++ * NULL or when we need an lvalue. For internal use only. ++ */ ++#define YY_CURRENT_BUFFER_LVALUE (yy_buffer_stack)[(yy_buffer_stack_top)] ++ ++/* yy_hold_char holds the character lost when yytext is formed. */ ++static char yy_hold_char; ++static int yy_n_chars; /* number of characters read into yy_ch_buf */ ++int yyleng; ++ ++/* Points to current character in buffer. */ ++static char *yy_c_buf_p = (char *) 0; ++static int yy_init = 0; /* whether we need to initialize */ ++static int yy_start = 0; /* start state number */ ++ ++/* Flag which is used to allow yywrap()'s to do buffer switches ++ * instead of setting up a fresh yyin. A bit of a hack ... ++ */ ++static int yy_did_buffer_switch_on_eof; ++ ++void yyrestart (FILE *input_file ); ++void yy_switch_to_buffer (YY_BUFFER_STATE new_buffer ); ++YY_BUFFER_STATE yy_create_buffer (FILE *file,int size ); ++void yy_delete_buffer (YY_BUFFER_STATE b ); ++void yy_flush_buffer (YY_BUFFER_STATE b ); ++void yypush_buffer_state (YY_BUFFER_STATE new_buffer ); ++void yypop_buffer_state (void ); ++ ++static void yyensure_buffer_stack (void ); ++static void yy_load_buffer_state (void ); ++static void yy_init_buffer (YY_BUFFER_STATE b,FILE *file ); ++ ++#define YY_FLUSH_BUFFER yy_flush_buffer(YY_CURRENT_BUFFER ) ++ ++YY_BUFFER_STATE yy_scan_buffer (char *base,yy_size_t size ); ++YY_BUFFER_STATE yy_scan_string (yyconst char *yy_str ); ++YY_BUFFER_STATE yy_scan_bytes (yyconst char *bytes,int len ); ++ ++void *yyalloc (yy_size_t ); ++void *yyrealloc (void *,yy_size_t ); ++void yyfree (void * ); ++ ++#define yy_new_buffer yy_create_buffer ++ ++#define yy_set_interactive(is_interactive) \ ++ { \ ++ if ( ! YY_CURRENT_BUFFER ){ \ ++ yyensure_buffer_stack (); \ ++ YY_CURRENT_BUFFER_LVALUE = \ ++ yy_create_buffer(yyin,YY_BUF_SIZE ); \ ++ } \ ++ YY_CURRENT_BUFFER_LVALUE->yy_is_interactive = is_interactive; \ ++ } ++ ++#define yy_set_bol(at_bol) \ ++ { \ ++ if ( ! YY_CURRENT_BUFFER ){\ ++ yyensure_buffer_stack (); \ ++ YY_CURRENT_BUFFER_LVALUE = \ ++ yy_create_buffer(yyin,YY_BUF_SIZE ); \ ++ } \ ++ YY_CURRENT_BUFFER_LVALUE->yy_at_bol = at_bol; \ ++ } ++ ++#define YY_AT_BOL() (YY_CURRENT_BUFFER_LVALUE->yy_at_bol) ++ ++/* Begin user sect3 */ ++ ++#define yywrap() 1 ++#define YY_SKIP_YYWRAP ++ ++typedef unsigned char YY_CHAR; ++ ++FILE *yyin = (FILE *) 0, *yyout = (FILE *) 0; ++ ++typedef int yy_state_type; ++ ++extern int yylineno; ++ ++int yylineno = 1; ++ ++extern char *yytext; ++#define yytext_ptr yytext ++ ++static yy_state_type yy_get_previous_state (void ); ++static yy_state_type yy_try_NUL_trans (yy_state_type current_state ); ++static int yy_get_next_buffer (void ); ++static void yy_fatal_error (yyconst char msg[] ); ++ ++/* Done after the current pattern has been matched and before the ++ * corresponding action - sets up yytext. ++ */ ++#define YY_DO_BEFORE_ACTION \ ++ (yytext_ptr) = yy_bp; \ ++ yyleng = (size_t) (yy_cp - yy_bp); \ ++ (yy_hold_char) = *yy_cp; \ ++ *yy_cp = '\0'; \ ++ (yy_c_buf_p) = yy_cp; ++ ++#define YY_NUM_RULES 20 ++#define YY_END_OF_BUFFER 21 ++/* This struct is not used in this scanner, ++ but its presence is necessary. */ ++struct yy_trans_info ++ { ++ flex_int32_t yy_verify; ++ flex_int32_t yy_nxt; ++ }; ++static yyconst flex_int16_t yy_accept[94] = ++ { 0, ++ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ++ 21, 19, 16, 16, 19, 19, 19, 8, 8, 19, ++ 8, 19, 19, 19, 19, 14, 15, 15, 19, 9, ++ 9, 16, 0, 3, 0, 0, 10, 0, 0, 0, ++ 0, 0, 0, 8, 8, 6, 0, 7, 0, 2, ++ 0, 13, 13, 15, 15, 9, 0, 12, 10, 0, ++ 0, 0, 0, 18, 0, 0, 0, 2, 9, 0, ++ 17, 0, 0, 0, 11, 0, 0, 0, 0, 0, ++ 0, 0, 0, 0, 4, 0, 0, 1, 0, 0, ++ 0, 5, 0 ++ ++ } ; ++ ++static yyconst flex_int32_t yy_ec[256] = ++ { 0, ++ 1, 1, 1, 1, 1, 1, 1, 1, 2, 3, ++ 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 2, 1, 4, 5, 1, 1, 6, 1, 1, ++ 1, 7, 8, 8, 9, 8, 10, 11, 12, 13, ++ 13, 13, 13, 13, 13, 13, 13, 14, 1, 1, ++ 1, 1, 8, 8, 15, 15, 15, 15, 15, 15, ++ 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, ++ 16, 16, 16, 16, 16, 16, 16, 17, 16, 16, ++ 1, 18, 19, 1, 16, 1, 15, 20, 21, 22, ++ ++ 23, 15, 16, 24, 25, 16, 16, 26, 27, 28, ++ 24, 16, 16, 29, 30, 31, 32, 33, 16, 17, ++ 16, 16, 34, 1, 35, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1 ++ } ; ++ ++static yyconst flex_int32_t yy_meta[36] = ++ { 0, ++ 1, 1, 1, 1, 2, 1, 2, 2, 2, 3, ++ 4, 4, 4, 5, 6, 7, 7, 1, 1, 6, ++ 6, 6, 6, 7, 7, 7, 7, 7, 7, 7, ++ 7, 7, 7, 8, 1 ++ } ; ++ ++static yyconst flex_int16_t yy_base[107] = ++ { 0, ++ 0, 0, 32, 0, 53, 0, 76, 0, 108, 111, ++ 280, 288, 37, 39, 33, 36, 106, 0, 123, 146, ++ 255, 251, 45, 0, 159, 288, 0, 53, 108, 172, ++ 114, 127, 158, 288, 245, 0, 0, 234, 235, 236, ++ 197, 195, 199, 0, 0, 288, 0, 288, 160, 288, ++ 183, 288, 0, 0, 183, 182, 0, 0, 0, 0, ++ 204, 189, 207, 288, 179, 187, 180, 194, 0, 171, ++ 288, 196, 178, 174, 288, 169, 169, 177, 165, 153, ++ 143, 155, 137, 118, 288, 122, 42, 288, 36, 36, ++ 40, 288, 288, 212, 218, 223, 229, 234, 239, 245, ++ ++ 251, 255, 262, 270, 275, 280 ++ } ; ++ ++static yyconst flex_int16_t yy_def[107] = ++ { 0, ++ 93, 1, 1, 3, 3, 5, 93, 7, 3, 3, ++ 93, 93, 93, 93, 94, 95, 93, 96, 93, 19, ++ 19, 20, 97, 98, 20, 93, 99, 100, 95, 93, ++ 93, 93, 94, 93, 94, 101, 102, 93, 103, 104, ++ 93, 93, 93, 96, 19, 93, 20, 93, 97, 93, ++ 97, 93, 20, 99, 100, 93, 105, 101, 102, 106, ++ 103, 103, 104, 93, 93, 93, 93, 94, 105, 106, ++ 93, 93, 93, 93, 93, 93, 93, 93, 93, 93, ++ 93, 93, 93, 93, 93, 93, 93, 93, 93, 93, ++ 93, 93, 0, 93, 93, 93, 93, 93, 93, 93, ++ ++ 93, 93, 93, 93, 93, 93 ++ } ; ++ ++static yyconst flex_int16_t yy_nxt[324] = ++ { 0, ++ 12, 13, 14, 15, 12, 16, 12, 12, 12, 17, ++ 18, 18, 18, 12, 19, 20, 20, 12, 12, 21, ++ 19, 21, 19, 22, 20, 20, 20, 20, 20, 20, ++ 20, 20, 20, 12, 12, 23, 34, 12, 32, 32, ++ 32, 32, 12, 12, 12, 36, 20, 33, 50, 92, ++ 35, 20, 20, 20, 20, 20, 15, 54, 91, 54, ++ 54, 54, 51, 24, 24, 24, 46, 25, 90, 38, ++ 89, 26, 25, 25, 25, 25, 12, 13, 14, 15, ++ 27, 12, 27, 27, 27, 17, 27, 27, 27, 12, ++ 28, 28, 28, 12, 12, 28, 28, 28, 28, 28, ++ ++ 28, 28, 28, 28, 28, 28, 28, 28, 28, 12, ++ 12, 15, 39, 29, 15, 40, 29, 93, 30, 31, ++ 31, 30, 31, 31, 56, 56, 56, 41, 32, 32, ++ 42, 88, 43, 45, 45, 45, 46, 45, 47, 47, ++ 87, 38, 45, 45, 45, 45, 47, 47, 47, 47, ++ 47, 47, 47, 47, 47, 47, 47, 47, 47, 86, ++ 47, 34, 33, 50, 85, 47, 47, 47, 47, 53, ++ 53, 53, 84, 53, 83, 35, 82, 51, 53, 53, ++ 53, 53, 56, 56, 56, 93, 68, 54, 57, 54, ++ 54, 54, 56, 56, 56, 62, 46, 34, 71, 81, ++ ++ 80, 79, 78, 77, 76, 75, 74, 73, 72, 64, ++ 62, 35, 33, 33, 33, 33, 33, 33, 33, 33, ++ 37, 67, 66, 37, 37, 37, 44, 65, 44, 49, ++ 49, 49, 49, 49, 49, 49, 49, 52, 64, 52, ++ 54, 62, 54, 60, 54, 54, 55, 93, 55, 55, ++ 55, 55, 58, 58, 58, 48, 58, 58, 59, 48, ++ 59, 59, 61, 61, 61, 61, 61, 61, 61, 61, ++ 63, 63, 63, 63, 63, 63, 63, 63, 69, 93, ++ 69, 70, 70, 70, 93, 70, 70, 11, 93, 93, ++ 93, 93, 93, 93, 93, 93, 93, 93, 93, 93, ++ ++ 93, 93, 93, 93, 93, 93, 93, 93, 93, 93, ++ 93, 93, 93, 93, 93, 93, 93, 93, 93, 93, ++ 93, 93, 93 ++ } ; ++ ++static yyconst flex_int16_t yy_chk[324] = ++ { 0, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ++ 1, 1, 1, 1, 1, 3, 15, 3, 13, 13, ++ 14, 14, 3, 3, 3, 16, 3, 23, 23, 91, ++ 15, 3, 3, 3, 3, 3, 5, 28, 90, 28, ++ 28, 28, 23, 5, 5, 5, 28, 5, 89, 16, ++ 87, 5, 5, 5, 5, 5, 7, 7, 7, 7, ++ 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, ++ 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, ++ ++ 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, ++ 7, 9, 17, 9, 10, 17, 10, 29, 9, 9, ++ 9, 10, 10, 10, 31, 31, 31, 17, 32, 32, ++ 17, 86, 17, 19, 19, 19, 19, 19, 19, 19, ++ 84, 29, 19, 19, 19, 19, 19, 19, 19, 19, ++ 19, 19, 19, 19, 19, 19, 20, 20, 20, 83, ++ 20, 33, 49, 49, 82, 20, 20, 20, 20, 25, ++ 25, 25, 81, 25, 80, 33, 79, 49, 25, 25, ++ 25, 25, 30, 30, 30, 51, 51, 55, 30, 55, ++ 55, 55, 56, 56, 56, 62, 55, 68, 62, 78, ++ ++ 77, 76, 74, 73, 72, 70, 67, 66, 65, 63, ++ 61, 68, 94, 94, 94, 94, 94, 94, 94, 94, ++ 95, 43, 42, 95, 95, 95, 96, 41, 96, 97, ++ 97, 97, 97, 97, 97, 97, 97, 98, 40, 98, ++ 99, 39, 99, 38, 99, 99, 100, 35, 100, 100, ++ 100, 100, 101, 101, 101, 22, 101, 101, 102, 21, ++ 102, 102, 103, 103, 103, 103, 103, 103, 103, 103, ++ 104, 104, 104, 104, 104, 104, 104, 104, 105, 11, ++ 105, 106, 106, 106, 0, 106, 106, 93, 93, 93, ++ 93, 93, 93, 93, 93, 93, 93, 93, 93, 93, ++ ++ 93, 93, 93, 93, 93, 93, 93, 93, 93, 93, ++ 93, 93, 93, 93, 93, 93, 93, 93, 93, 93, ++ 93, 93, 93 ++ } ; ++ ++/* Table of booleans, true if rule could match eol. */ ++static yyconst flex_int32_t yy_rule_can_match_eol[21] = ++ { 0, ++0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, ++ 0, }; ++ ++static yy_state_type yy_last_accepting_state; ++static char *yy_last_accepting_cpos; ++ ++extern int yy_flex_debug; ++int yy_flex_debug = 0; ++ ++/* The intent behind this definition is that it'll catch ++ * any uses of REJECT which flex missed. ++ */ ++#define REJECT reject_used_but_not_detected ++#define yymore() yymore_used_but_not_detected ++#define YY_MORE_ADJ 0 ++#define YY_RESTORE_YY_MORE_OFFSET ++char *yytext; ++#line 1 "dtc-lexer.l" ++/* ++ * (C) Copyright David Gibson <dwg@au1.ibm.com>, IBM Corporation. 2005. ++ * ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 ++ * USA ++ */ ++ ++ ++ ++ ++#line 33 "dtc-lexer.l" ++#include "dtc.h" ++#include "srcpos.h" ++#include "dtc-parser.tab.h" ++ ++ ++/*#define LEXDEBUG 1*/ ++ ++#ifdef LEXDEBUG ++#define DPRINT(fmt, ...) fprintf(stderr, fmt, ##__VA_ARGS__) ++#else ++#define DPRINT(fmt, ...) do { } while (0) ++#endif ++ ++static int dts_version; /* = 0 */ ++ ++#define BEGIN_DEFAULT() if (dts_version == 0) { \ ++ DPRINT("<INITIAL>\n"); \ ++ BEGIN(INITIAL); \ ++ } else { \ ++ DPRINT("<V1>\n"); \ ++ BEGIN(V1); \ ++ } ++#line 627 "dtc-lexer.lex.c" ++ ++#define INITIAL 0 ++#define INCLUDE 1 ++#define BYTESTRING 2 ++#define PROPNODENAME 3 ++#define V1 4 ++ ++#ifndef YY_NO_UNISTD_H ++/* Special case for "unistd.h", since it is non-ANSI. We include it way ++ * down here because we want the user's section 1 to have been scanned first. ++ * The user has a chance to override it with an option. ++ */ ++#include <unistd.h> ++#endif ++ ++#ifndef YY_EXTRA_TYPE ++#define YY_EXTRA_TYPE void * ++#endif ++ ++static int yy_init_globals (void ); ++ ++/* Macros after this point can all be overridden by user definitions in ++ * section 1. ++ */ ++ ++#ifndef YY_SKIP_YYWRAP ++#ifdef __cplusplus ++extern "C" int yywrap (void ); ++#else ++extern int yywrap (void ); ++#endif ++#endif ++ ++#ifndef yytext_ptr ++static void yy_flex_strncpy (char *,yyconst char *,int ); ++#endif ++ ++#ifdef YY_NEED_STRLEN ++static int yy_flex_strlen (yyconst char * ); ++#endif ++ ++#ifndef YY_NO_INPUT ++ ++#ifdef __cplusplus ++static int yyinput (void ); ++#else ++static int input (void ); ++#endif ++ ++#endif ++ ++/* Amount of stuff to slurp up with each read. */ ++#ifndef YY_READ_BUF_SIZE ++#define YY_READ_BUF_SIZE 8192 ++#endif ++ ++/* Copy whatever the last rule matched to the standard output. */ ++#ifndef ECHO ++/* This used to be an fputs(), but since the string might contain NUL's, ++ * we now use fwrite(). ++ */ ++#define ECHO (void) fwrite( yytext, yyleng, 1, yyout ) ++#endif ++ ++/* Gets input and stuffs it into "buf". number of characters read, or YY_NULL, ++ * is returned in "result". ++ */ ++#ifndef YY_INPUT ++#define YY_INPUT(buf,result,max_size) \ ++ if ( YY_CURRENT_BUFFER_LVALUE->yy_is_interactive ) \ ++ { \ ++ int c = '*'; \ ++ size_t n; \ ++ for ( n = 0; n < max_size && \ ++ (c = getc( yyin )) != EOF && c != '\n'; ++n ) \ ++ buf[n] = (char) c; \ ++ if ( c == '\n' ) \ ++ buf[n++] = (char) c; \ ++ if ( c == EOF && ferror( yyin ) ) \ ++ YY_FATAL_ERROR( "input in flex scanner failed" ); \ ++ result = n; \ ++ } \ ++ else \ ++ { \ ++ errno=0; \ ++ while ( (result = fread(buf, 1, max_size, yyin))==0 && ferror(yyin)) \ ++ { \ ++ if( errno != EINTR) \ ++ { \ ++ YY_FATAL_ERROR( "input in flex scanner failed" ); \ ++ break; \ ++ } \ ++ errno=0; \ ++ clearerr(yyin); \ ++ } \ ++ }\ ++\ ++ ++#endif ++ ++/* No semi-colon after return; correct usage is to write "yyterminate();" - ++ * we don't want an extra ';' after the "return" because that will cause ++ * some compilers to complain about unreachable statements. ++ */ ++#ifndef yyterminate ++#define yyterminate() return YY_NULL ++#endif ++ ++/* Number of entries by which start-condition stack grows. */ ++#ifndef YY_START_STACK_INCR ++#define YY_START_STACK_INCR 25 ++#endif ++ ++/* Report a fatal error. */ ++#ifndef YY_FATAL_ERROR ++#define YY_FATAL_ERROR(msg) yy_fatal_error( msg ) ++#endif ++ ++/* end tables serialization structures and prototypes */ ++ ++/* Default declaration of generated scanner - a define so the user can ++ * easily add parameters. ++ */ ++#ifndef YY_DECL ++#define YY_DECL_IS_OURS 1 ++ ++extern int yylex (void); ++ ++#define YY_DECL int yylex (void) ++#endif /* !YY_DECL */ ++ ++/* Code executed at the beginning of each rule, after yytext and yyleng ++ * have been set up. ++ */ ++#ifndef YY_USER_ACTION ++#define YY_USER_ACTION ++#endif ++ ++/* Code executed at the end of each rule. */ ++#ifndef YY_BREAK ++#define YY_BREAK break; ++#endif ++ ++#define YY_RULE_SETUP \ ++ YY_USER_ACTION ++ ++/** The main scanner function which does all the work. ++ */ ++YY_DECL ++{ ++ register yy_state_type yy_current_state; ++ register char *yy_cp, *yy_bp; ++ register int yy_act; ++ ++#line 57 "dtc-lexer.l" ++ ++#line 784 "dtc-lexer.lex.c" ++ ++ if ( !(yy_init) ) ++ { ++ (yy_init) = 1; ++ ++#ifdef YY_USER_INIT ++ YY_USER_INIT; ++#endif ++ ++ if ( ! (yy_start) ) ++ (yy_start) = 1; /* first start state */ ++ ++ if ( ! yyin ) ++ yyin = stdin; ++ ++ if ( ! yyout ) ++ yyout = stdout; ++ ++ if ( ! YY_CURRENT_BUFFER ) { ++ yyensure_buffer_stack (); ++ YY_CURRENT_BUFFER_LVALUE = ++ yy_create_buffer(yyin,YY_BUF_SIZE ); ++ } ++ ++ yy_load_buffer_state( ); ++ } ++ ++ while ( 1 ) /* loops until end-of-file is reached */ ++ { ++ yy_cp = (yy_c_buf_p); ++ ++ /* Support of yytext. */ ++ *yy_cp = (yy_hold_char); ++ ++ /* yy_bp points to the position in yy_ch_buf of the start of ++ * the current run. ++ */ ++ yy_bp = yy_cp; ++ ++ yy_current_state = (yy_start); ++yy_match: ++ do ++ { ++ register YY_CHAR yy_c = yy_ec[YY_SC_TO_UI(*yy_cp)]; ++ if ( yy_accept[yy_current_state] ) ++ { ++ (yy_last_accepting_state) = yy_current_state; ++ (yy_last_accepting_cpos) = yy_cp; ++ } ++ while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state ) ++ { ++ yy_current_state = (int) yy_def[yy_current_state]; ++ if ( yy_current_state >= 94 ) ++ yy_c = yy_meta[(unsigned int) yy_c]; ++ } ++ yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c]; ++ ++yy_cp; ++ } ++ while ( yy_base[yy_current_state] != 288 ); ++ ++yy_find_action: ++ yy_act = yy_accept[yy_current_state]; ++ if ( yy_act == 0 ) ++ { /* have to back up */ ++ yy_cp = (yy_last_accepting_cpos); ++ yy_current_state = (yy_last_accepting_state); ++ yy_act = yy_accept[yy_current_state]; ++ } ++ ++ YY_DO_BEFORE_ACTION; ++ ++ if ( yy_act != YY_END_OF_BUFFER && yy_rule_can_match_eol[yy_act] ) ++ { ++ int yyl; ++ for ( yyl = 0; yyl < yyleng; ++yyl ) ++ if ( yytext[yyl] == '\n' ) ++ ++ yylineno++; ++; ++ } ++ ++do_action: /* This label is used only to access EOF actions. */ ++ ++ switch ( yy_act ) ++ { /* beginning of action switch */ ++ case 0: /* must back up */ ++ /* undo the effects of YY_DO_BEFORE_ACTION */ ++ *yy_cp = (yy_hold_char); ++ yy_cp = (yy_last_accepting_cpos); ++ yy_current_state = (yy_last_accepting_state); ++ goto yy_find_action; ++ ++case 1: ++YY_RULE_SETUP ++#line 58 "dtc-lexer.l" ++BEGIN(INCLUDE); ++ YY_BREAK ++case 2: ++YY_RULE_SETUP ++#line 60 "dtc-lexer.l" ++{ ++ yytext[strlen(yytext) - 1] = 0; ++ if (!push_input_file(yytext + 1)) { ++ /* Some unrecoverable error.*/ ++ exit(1); ++ } ++ BEGIN_DEFAULT(); ++ } ++ YY_BREAK ++case YY_STATE_EOF(INITIAL): ++case YY_STATE_EOF(INCLUDE): ++case YY_STATE_EOF(BYTESTRING): ++case YY_STATE_EOF(PROPNODENAME): ++case YY_STATE_EOF(V1): ++#line 70 "dtc-lexer.l" ++{ ++ if (!pop_input_file()) { ++ yyterminate(); ++ } ++ } ++ YY_BREAK ++case 3: ++/* rule 3 can match eol */ ++YY_RULE_SETUP ++#line 76 "dtc-lexer.l" ++{ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("String: %s\n", yytext); ++ yylval.data = data_copy_escape_string(yytext+1, ++ yyleng-2); ++ yylloc.first_line = yylineno; ++ return DT_STRING; ++ } ++ YY_BREAK ++case 4: ++YY_RULE_SETUP ++#line 86 "dtc-lexer.l" ++{ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Keyword: /dts-v1/\n"); ++ dts_version = 1; ++ BEGIN_DEFAULT(); ++ return DT_V1; ++ } ++ YY_BREAK ++case 5: ++YY_RULE_SETUP ++#line 95 "dtc-lexer.l" ++{ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Keyword: /memreserve/\n"); ++ BEGIN_DEFAULT(); ++ return DT_MEMRESERVE; ++ } ++ YY_BREAK ++case 6: ++YY_RULE_SETUP ++#line 103 "dtc-lexer.l" ++{ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Label: %s\n", yytext); ++ yylval.labelref = strdup(yytext); ++ yylval.labelref[yyleng-1] = '\0'; ++ return DT_LABEL; ++ } ++ YY_BREAK ++case 7: ++YY_RULE_SETUP ++#line 112 "dtc-lexer.l" ++{ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ if (*yytext == 'b') ++ yylval.cbase = 2; ++ else if (*yytext == 'o') ++ yylval.cbase = 8; ++ else if (*yytext == 'd') ++ yylval.cbase = 10; ++ else ++ yylval.cbase = 16; ++ DPRINT("Base: %d\n", yylval.cbase); ++ return DT_BASE; ++ } ++ YY_BREAK ++case 8: ++YY_RULE_SETUP ++#line 127 "dtc-lexer.l" ++{ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ yylval.literal = strdup(yytext); ++ DPRINT("Literal: '%s'\n", yylval.literal); ++ return DT_LEGACYLITERAL; ++ } ++ YY_BREAK ++case 9: ++YY_RULE_SETUP ++#line 135 "dtc-lexer.l" ++{ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ yylval.literal = strdup(yytext); ++ DPRINT("Literal: '%s'\n", yylval.literal); ++ return DT_LITERAL; ++ } ++ YY_BREAK ++case 10: ++YY_RULE_SETUP ++#line 143 "dtc-lexer.l" ++{ /* label reference */ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Ref: %s\n", yytext+1); ++ yylval.labelref = strdup(yytext+1); ++ return DT_REF; ++ } ++ YY_BREAK ++case 11: ++YY_RULE_SETUP ++#line 151 "dtc-lexer.l" ++{ /* new-style path reference */ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ yytext[yyleng-1] = '\0'; ++ DPRINT("Ref: %s\n", yytext+2); ++ yylval.labelref = strdup(yytext+2); ++ return DT_REF; ++ } ++ YY_BREAK ++case 12: ++YY_RULE_SETUP ++#line 160 "dtc-lexer.l" ++{ /* old-style path reference */ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Ref: %s\n", yytext+1); ++ yylval.labelref = strdup(yytext+1); ++ return DT_REF; ++ } ++ YY_BREAK ++case 13: ++YY_RULE_SETUP ++#line 168 "dtc-lexer.l" ++{ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ yylval.byte = strtol(yytext, NULL, 16); ++ DPRINT("Byte: %02x\n", (int)yylval.byte); ++ return DT_BYTE; ++ } ++ YY_BREAK ++case 14: ++YY_RULE_SETUP ++#line 176 "dtc-lexer.l" ++{ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("/BYTESTRING\n"); ++ BEGIN_DEFAULT(); ++ return ']'; ++ } ++ YY_BREAK ++case 15: ++YY_RULE_SETUP ++#line 184 "dtc-lexer.l" ++{ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("PropNodeName: %s\n", yytext); ++ yylval.propnodename = strdup(yytext); ++ BEGIN_DEFAULT(); ++ return DT_PROPNODENAME; ++ } ++ YY_BREAK ++case 16: ++/* rule 16 can match eol */ ++YY_RULE_SETUP ++#line 194 "dtc-lexer.l" ++/* eat whitespace */ ++ YY_BREAK ++case 17: ++/* rule 17 can match eol */ ++YY_RULE_SETUP ++#line 196 "dtc-lexer.l" ++{ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Comment: %s\n", yytext); ++ /* eat comments */ ++ } ++ YY_BREAK ++case 18: ++/* rule 18 can match eol */ ++YY_RULE_SETUP ++#line 203 "dtc-lexer.l" ++/* eat line comments */ ++ YY_BREAK ++case 19: ++YY_RULE_SETUP ++#line 205 "dtc-lexer.l" ++{ ++ yylloc.filenum = srcpos_filenum; ++ yylloc.first_line = yylineno; ++ DPRINT("Char: %c (\\x%02x)\n", yytext[0], ++ (unsigned)yytext[0]); ++ if (yytext[0] == '[') { ++ DPRINT("<BYTESTRING>\n"); ++ BEGIN(BYTESTRING); ++ } ++ if ((yytext[0] == '{') ++ || (yytext[0] == ';')) { ++ DPRINT("<PROPNODENAME>\n"); ++ BEGIN(PROPNODENAME); ++ } ++ return yytext[0]; ++ } ++ YY_BREAK ++case 20: ++YY_RULE_SETUP ++#line 222 "dtc-lexer.l" ++ECHO; ++ YY_BREAK ++#line 1111 "dtc-lexer.lex.c" ++ ++ case YY_END_OF_BUFFER: ++ { ++ /* Amount of text matched not including the EOB char. */ ++ int yy_amount_of_matched_text = (int) (yy_cp - (yytext_ptr)) - 1; ++ ++ /* Undo the effects of YY_DO_BEFORE_ACTION. */ ++ *yy_cp = (yy_hold_char); ++ YY_RESTORE_YY_MORE_OFFSET ++ ++ if ( YY_CURRENT_BUFFER_LVALUE->yy_buffer_status == YY_BUFFER_NEW ) ++ { ++ /* We're scanning a new file or input source. It's ++ * possible that this happened because the user ++ * just pointed yyin at a new source and called ++ * yylex(). If so, then we have to assure ++ * consistency between YY_CURRENT_BUFFER and our ++ * globals. Here is the right place to do so, because ++ * this is the first action (other than possibly a ++ * back-up) that will match for the new input source. ++ */ ++ (yy_n_chars) = YY_CURRENT_BUFFER_LVALUE->yy_n_chars; ++ YY_CURRENT_BUFFER_LVALUE->yy_input_file = yyin; ++ YY_CURRENT_BUFFER_LVALUE->yy_buffer_status = YY_BUFFER_NORMAL; ++ } ++ ++ /* Note that here we test for yy_c_buf_p "<=" to the position ++ * of the first EOB in the buffer, since yy_c_buf_p will ++ * already have been incremented past the NUL character ++ * (since all states make transitions on EOB to the ++ * end-of-buffer state). Contrast this with the test ++ * in input(). ++ */ ++ if ( (yy_c_buf_p) <= &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)] ) ++ { /* This was really a NUL. */ ++ yy_state_type yy_next_state; ++ ++ (yy_c_buf_p) = (yytext_ptr) + yy_amount_of_matched_text; ++ ++ yy_current_state = yy_get_previous_state( ); ++ ++ /* Okay, we're now positioned to make the NUL ++ * transition. We couldn't have ++ * yy_get_previous_state() go ahead and do it ++ * for us because it doesn't know how to deal ++ * with the possibility of jamming (and we don't ++ * want to build jamming into it because then it ++ * will run more slowly). ++ */ ++ ++ yy_next_state = yy_try_NUL_trans( yy_current_state ); ++ ++ yy_bp = (yytext_ptr) + YY_MORE_ADJ; ++ ++ if ( yy_next_state ) ++ { ++ /* Consume the NUL. */ ++ yy_cp = ++(yy_c_buf_p); ++ yy_current_state = yy_next_state; ++ goto yy_match; ++ } ++ ++ else ++ { ++ yy_cp = (yy_c_buf_p); ++ goto yy_find_action; ++ } ++ } ++ ++ else switch ( yy_get_next_buffer( ) ) ++ { ++ case EOB_ACT_END_OF_FILE: ++ { ++ (yy_did_buffer_switch_on_eof) = 0; ++ ++ if ( yywrap( ) ) ++ { ++ /* Note: because we've taken care in ++ * yy_get_next_buffer() to have set up ++ * yytext, we can now set up ++ * yy_c_buf_p so that if some total ++ * hoser (like flex itself) wants to ++ * call the scanner after we return the ++ * YY_NULL, it'll still work - another ++ * YY_NULL will get returned. ++ */ ++ (yy_c_buf_p) = (yytext_ptr) + YY_MORE_ADJ; ++ ++ yy_act = YY_STATE_EOF(YY_START); ++ goto do_action; ++ } ++ ++ else ++ { ++ if ( ! (yy_did_buffer_switch_on_eof) ) ++ YY_NEW_FILE; ++ } ++ break; ++ } ++ ++ case EOB_ACT_CONTINUE_SCAN: ++ (yy_c_buf_p) = ++ (yytext_ptr) + yy_amount_of_matched_text; ++ ++ yy_current_state = yy_get_previous_state( ); ++ ++ yy_cp = (yy_c_buf_p); ++ yy_bp = (yytext_ptr) + YY_MORE_ADJ; ++ goto yy_match; ++ ++ case EOB_ACT_LAST_MATCH: ++ (yy_c_buf_p) = ++ &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)]; ++ ++ yy_current_state = yy_get_previous_state( ); ++ ++ yy_cp = (yy_c_buf_p); ++ yy_bp = (yytext_ptr) + YY_MORE_ADJ; ++ goto yy_find_action; ++ } ++ break; ++ } ++ ++ default: ++ YY_FATAL_ERROR( ++ "fatal flex scanner internal error--no action found" ); ++ } /* end of action switch */ ++ } /* end of scanning one token */ ++} /* end of yylex */ ++ ++/* yy_get_next_buffer - try to read in a new buffer ++ * ++ * Returns a code representing an action: ++ * EOB_ACT_LAST_MATCH - ++ * EOB_ACT_CONTINUE_SCAN - continue scanning from current position ++ * EOB_ACT_END_OF_FILE - end of file ++ */ ++static int yy_get_next_buffer (void) ++{ ++ register char *dest = YY_CURRENT_BUFFER_LVALUE->yy_ch_buf; ++ register char *source = (yytext_ptr); ++ register int number_to_move, i; ++ int ret_val; ++ ++ if ( (yy_c_buf_p) > &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars) + 1] ) ++ YY_FATAL_ERROR( ++ "fatal flex scanner internal error--end of buffer missed" ); ++ ++ if ( YY_CURRENT_BUFFER_LVALUE->yy_fill_buffer == 0 ) ++ { /* Don't try to fill the buffer, so this is an EOF. */ ++ if ( (yy_c_buf_p) - (yytext_ptr) - YY_MORE_ADJ == 1 ) ++ { ++ /* We matched a single character, the EOB, so ++ * treat this as a final EOF. ++ */ ++ return EOB_ACT_END_OF_FILE; ++ } ++ ++ else ++ { ++ /* We matched some text prior to the EOB, first ++ * process it. ++ */ ++ return EOB_ACT_LAST_MATCH; ++ } ++ } ++ ++ /* Try to read more data. */ ++ ++ /* First move last chars to start of buffer. */ ++ number_to_move = (int) ((yy_c_buf_p) - (yytext_ptr)) - 1; ++ ++ for ( i = 0; i < number_to_move; ++i ) ++ *(dest++) = *(source++); ++ ++ if ( YY_CURRENT_BUFFER_LVALUE->yy_buffer_status == YY_BUFFER_EOF_PENDING ) ++ /* don't do the read, it's not guaranteed to return an EOF, ++ * just force an EOF ++ */ ++ YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars) = 0; ++ ++ else ++ { ++ int num_to_read = ++ YY_CURRENT_BUFFER_LVALUE->yy_buf_size - number_to_move - 1; ++ ++ while ( num_to_read <= 0 ) ++ { /* Not enough room in the buffer - grow it. */ ++ ++ /* just a shorter name for the current buffer */ ++ YY_BUFFER_STATE b = YY_CURRENT_BUFFER; ++ ++ int yy_c_buf_p_offset = ++ (int) ((yy_c_buf_p) - b->yy_ch_buf); ++ ++ if ( b->yy_is_our_buffer ) ++ { ++ int new_size = b->yy_buf_size * 2; ++ ++ if ( new_size <= 0 ) ++ b->yy_buf_size += b->yy_buf_size / 8; ++ else ++ b->yy_buf_size *= 2; ++ ++ b->yy_ch_buf = (char *) ++ /* Include room in for 2 EOB chars. */ ++ yyrealloc((void *) b->yy_ch_buf,b->yy_buf_size + 2 ); ++ } ++ else ++ /* Can't grow it, we don't own it. */ ++ b->yy_ch_buf = 0; ++ ++ if ( ! b->yy_ch_buf ) ++ YY_FATAL_ERROR( ++ "fatal error - scanner input buffer overflow" ); ++ ++ (yy_c_buf_p) = &b->yy_ch_buf[yy_c_buf_p_offset]; ++ ++ num_to_read = YY_CURRENT_BUFFER_LVALUE->yy_buf_size - ++ number_to_move - 1; ++ ++ } ++ ++ if ( num_to_read > YY_READ_BUF_SIZE ) ++ num_to_read = YY_READ_BUF_SIZE; ++ ++ /* Read in more data. */ ++ YY_INPUT( (&YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[number_to_move]), ++ (yy_n_chars), (size_t) num_to_read ); ++ ++ YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars); ++ } ++ ++ if ( (yy_n_chars) == 0 ) ++ { ++ if ( number_to_move == YY_MORE_ADJ ) ++ { ++ ret_val = EOB_ACT_END_OF_FILE; ++ yyrestart(yyin ); ++ } ++ ++ else ++ { ++ ret_val = EOB_ACT_LAST_MATCH; ++ YY_CURRENT_BUFFER_LVALUE->yy_buffer_status = ++ YY_BUFFER_EOF_PENDING; ++ } ++ } ++ ++ else ++ ret_val = EOB_ACT_CONTINUE_SCAN; ++ ++ (yy_n_chars) += number_to_move; ++ YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)] = YY_END_OF_BUFFER_CHAR; ++ YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars) + 1] = YY_END_OF_BUFFER_CHAR; ++ ++ (yytext_ptr) = &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[0]; ++ ++ return ret_val; ++} ++ ++/* yy_get_previous_state - get the state just before the EOB char was reached */ ++ ++ static yy_state_type yy_get_previous_state (void) ++{ ++ register yy_state_type yy_current_state; ++ register char *yy_cp; ++ ++ yy_current_state = (yy_start); ++ ++ for ( yy_cp = (yytext_ptr) + YY_MORE_ADJ; yy_cp < (yy_c_buf_p); ++yy_cp ) ++ { ++ register YY_CHAR yy_c = (*yy_cp ? yy_ec[YY_SC_TO_UI(*yy_cp)] : 1); ++ if ( yy_accept[yy_current_state] ) ++ { ++ (yy_last_accepting_state) = yy_current_state; ++ (yy_last_accepting_cpos) = yy_cp; ++ } ++ while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state ) ++ { ++ yy_current_state = (int) yy_def[yy_current_state]; ++ if ( yy_current_state >= 94 ) ++ yy_c = yy_meta[(unsigned int) yy_c]; ++ } ++ yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c]; ++ } ++ ++ return yy_current_state; ++} ++ ++/* yy_try_NUL_trans - try to make a transition on the NUL character ++ * ++ * synopsis ++ * next_state = yy_try_NUL_trans( current_state ); ++ */ ++ static yy_state_type yy_try_NUL_trans (yy_state_type yy_current_state ) ++{ ++ register int yy_is_jam; ++ register char *yy_cp = (yy_c_buf_p); ++ ++ register YY_CHAR yy_c = 1; ++ if ( yy_accept[yy_current_state] ) ++ { ++ (yy_last_accepting_state) = yy_current_state; ++ (yy_last_accepting_cpos) = yy_cp; ++ } ++ while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state ) ++ { ++ yy_current_state = (int) yy_def[yy_current_state]; ++ if ( yy_current_state >= 94 ) ++ yy_c = yy_meta[(unsigned int) yy_c]; ++ } ++ yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c]; ++ yy_is_jam = (yy_current_state == 93); ++ ++ return yy_is_jam ? 0 : yy_current_state; ++} ++ ++#ifndef YY_NO_INPUT ++#ifdef __cplusplus ++ static int yyinput (void) ++#else ++ static int input (void) ++#endif ++ ++{ ++ int c; ++ ++ *(yy_c_buf_p) = (yy_hold_char); ++ ++ if ( *(yy_c_buf_p) == YY_END_OF_BUFFER_CHAR ) ++ { ++ /* yy_c_buf_p now points to the character we want to return. ++ * If this occurs *before* the EOB characters, then it's a ++ * valid NUL; if not, then we've hit the end of the buffer. ++ */ ++ if ( (yy_c_buf_p) < &YY_CURRENT_BUFFER_LVALUE->yy_ch_buf[(yy_n_chars)] ) ++ /* This was really a NUL. */ ++ *(yy_c_buf_p) = '\0'; ++ ++ else ++ { /* need more input */ ++ int offset = (yy_c_buf_p) - (yytext_ptr); ++ ++(yy_c_buf_p); ++ ++ switch ( yy_get_next_buffer( ) ) ++ { ++ case EOB_ACT_LAST_MATCH: ++ /* This happens because yy_g_n_b() ++ * sees that we've accumulated a ++ * token and flags that we need to ++ * try matching the token before ++ * proceeding. But for input(), ++ * there's no matching to consider. ++ * So convert the EOB_ACT_LAST_MATCH ++ * to EOB_ACT_END_OF_FILE. ++ */ ++ ++ /* Reset buffer status. */ ++ yyrestart(yyin ); ++ ++ /*FALLTHROUGH*/ ++ ++ case EOB_ACT_END_OF_FILE: ++ { ++ if ( yywrap( ) ) ++ return EOF; ++ ++ if ( ! (yy_did_buffer_switch_on_eof) ) ++ YY_NEW_FILE; ++#ifdef __cplusplus ++ return yyinput(); ++#else ++ return input(); ++#endif ++ } ++ ++ case EOB_ACT_CONTINUE_SCAN: ++ (yy_c_buf_p) = (yytext_ptr) + offset; ++ break; ++ } ++ } ++ } ++ ++ c = *(unsigned char *) (yy_c_buf_p); /* cast for 8-bit char's */ ++ *(yy_c_buf_p) = '\0'; /* preserve yytext */ ++ (yy_hold_char) = *++(yy_c_buf_p); ++ ++ if ( c == '\n' ) ++ ++ yylineno++; ++; ++ ++ return c; ++} ++#endif /* ifndef YY_NO_INPUT */ ++ ++/** Immediately switch to a different input stream. ++ * @param input_file A readable stream. ++ * ++ * @note This function does not reset the start condition to @c INITIAL . ++ */ ++ void yyrestart (FILE * input_file ) ++{ ++ ++ if ( ! YY_CURRENT_BUFFER ){ ++ yyensure_buffer_stack (); ++ YY_CURRENT_BUFFER_LVALUE = ++ yy_create_buffer(yyin,YY_BUF_SIZE ); ++ } ++ ++ yy_init_buffer(YY_CURRENT_BUFFER,input_file ); ++ yy_load_buffer_state( ); ++} ++ ++/** Switch to a different input buffer. ++ * @param new_buffer The new input buffer. ++ * ++ */ ++ void yy_switch_to_buffer (YY_BUFFER_STATE new_buffer ) ++{ ++ ++ /* TODO. We should be able to replace this entire function body ++ * with ++ * yypop_buffer_state(); ++ * yypush_buffer_state(new_buffer); ++ */ ++ yyensure_buffer_stack (); ++ if ( YY_CURRENT_BUFFER == new_buffer ) ++ return; ++ ++ if ( YY_CURRENT_BUFFER ) ++ { ++ /* Flush out information for old buffer. */ ++ *(yy_c_buf_p) = (yy_hold_char); ++ YY_CURRENT_BUFFER_LVALUE->yy_buf_pos = (yy_c_buf_p); ++ YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars); ++ } ++ ++ YY_CURRENT_BUFFER_LVALUE = new_buffer; ++ yy_load_buffer_state( ); ++ ++ /* We don't actually know whether we did this switch during ++ * EOF (yywrap()) processing, but the only time this flag ++ * is looked at is after yywrap() is called, so it's safe ++ * to go ahead and always set it. ++ */ ++ (yy_did_buffer_switch_on_eof) = 1; ++} ++ ++static void yy_load_buffer_state (void) ++{ ++ (yy_n_chars) = YY_CURRENT_BUFFER_LVALUE->yy_n_chars; ++ (yytext_ptr) = (yy_c_buf_p) = YY_CURRENT_BUFFER_LVALUE->yy_buf_pos; ++ yyin = YY_CURRENT_BUFFER_LVALUE->yy_input_file; ++ (yy_hold_char) = *(yy_c_buf_p); ++} ++ ++/** Allocate and initialize an input buffer state. ++ * @param file A readable stream. ++ * @param size The character buffer size in bytes. When in doubt, use @c YY_BUF_SIZE. ++ * ++ * @return the allocated buffer state. ++ */ ++ YY_BUFFER_STATE yy_create_buffer (FILE * file, int size ) ++{ ++ YY_BUFFER_STATE b; ++ ++ b = (YY_BUFFER_STATE) yyalloc(sizeof( struct yy_buffer_state ) ); ++ if ( ! b ) ++ YY_FATAL_ERROR( "out of dynamic memory in yy_create_buffer()" ); ++ ++ b->yy_buf_size = size; ++ ++ /* yy_ch_buf has to be 2 characters longer than the size given because ++ * we need to put in 2 end-of-buffer characters. ++ */ ++ b->yy_ch_buf = (char *) yyalloc(b->yy_buf_size + 2 ); ++ if ( ! b->yy_ch_buf ) ++ YY_FATAL_ERROR( "out of dynamic memory in yy_create_buffer()" ); ++ ++ b->yy_is_our_buffer = 1; ++ ++ yy_init_buffer(b,file ); ++ ++ return b; ++} ++ ++/** Destroy the buffer. ++ * @param b a buffer created with yy_create_buffer() ++ * ++ */ ++ void yy_delete_buffer (YY_BUFFER_STATE b ) ++{ ++ ++ if ( ! b ) ++ return; ++ ++ if ( b == YY_CURRENT_BUFFER ) /* Not sure if we should pop here. */ ++ YY_CURRENT_BUFFER_LVALUE = (YY_BUFFER_STATE) 0; ++ ++ if ( b->yy_is_our_buffer ) ++ yyfree((void *) b->yy_ch_buf ); ++ ++ yyfree((void *) b ); ++} ++ ++#ifndef __cplusplus ++extern int isatty (int ); ++#endif /* __cplusplus */ ++ ++/* Initializes or reinitializes a buffer. ++ * This function is sometimes called more than once on the same buffer, ++ * such as during a yyrestart() or at EOF. ++ */ ++ static void yy_init_buffer (YY_BUFFER_STATE b, FILE * file ) ++ ++{ ++ int oerrno = errno; ++ ++ yy_flush_buffer(b ); ++ ++ b->yy_input_file = file; ++ b->yy_fill_buffer = 1; ++ ++ /* If b is the current buffer, then yy_init_buffer was _probably_ ++ * called from yyrestart() or through yy_get_next_buffer. ++ * In that case, we don't want to reset the lineno or column. ++ */ ++ if (b != YY_CURRENT_BUFFER){ ++ b->yy_bs_lineno = 1; ++ b->yy_bs_column = 0; ++ } ++ ++ b->yy_is_interactive = file ? (isatty( fileno(file) ) > 0) : 0; ++ ++ errno = oerrno; ++} ++ ++/** Discard all buffered characters. On the next scan, YY_INPUT will be called. ++ * @param b the buffer state to be flushed, usually @c YY_CURRENT_BUFFER. ++ * ++ */ ++ void yy_flush_buffer (YY_BUFFER_STATE b ) ++{ ++ if ( ! b ) ++ return; ++ ++ b->yy_n_chars = 0; ++ ++ /* We always need two end-of-buffer characters. The first causes ++ * a transition to the end-of-buffer state. The second causes ++ * a jam in that state. ++ */ ++ b->yy_ch_buf[0] = YY_END_OF_BUFFER_CHAR; ++ b->yy_ch_buf[1] = YY_END_OF_BUFFER_CHAR; ++ ++ b->yy_buf_pos = &b->yy_ch_buf[0]; ++ ++ b->yy_at_bol = 1; ++ b->yy_buffer_status = YY_BUFFER_NEW; ++ ++ if ( b == YY_CURRENT_BUFFER ) ++ yy_load_buffer_state( ); ++} ++ ++/** Pushes the new state onto the stack. The new state becomes ++ * the current state. This function will allocate the stack ++ * if necessary. ++ * @param new_buffer The new state. ++ * ++ */ ++void yypush_buffer_state (YY_BUFFER_STATE new_buffer ) ++{ ++ if (new_buffer == NULL) ++ return; ++ ++ yyensure_buffer_stack(); ++ ++ /* This block is copied from yy_switch_to_buffer. */ ++ if ( YY_CURRENT_BUFFER ) ++ { ++ /* Flush out information for old buffer. */ ++ *(yy_c_buf_p) = (yy_hold_char); ++ YY_CURRENT_BUFFER_LVALUE->yy_buf_pos = (yy_c_buf_p); ++ YY_CURRENT_BUFFER_LVALUE->yy_n_chars = (yy_n_chars); ++ } ++ ++ /* Only push if top exists. Otherwise, replace top. */ ++ if (YY_CURRENT_BUFFER) ++ (yy_buffer_stack_top)++; ++ YY_CURRENT_BUFFER_LVALUE = new_buffer; ++ ++ /* copied from yy_switch_to_buffer. */ ++ yy_load_buffer_state( ); ++ (yy_did_buffer_switch_on_eof) = 1; ++} ++ ++/** Removes and deletes the top of the stack, if present. ++ * The next element becomes the new top. ++ * ++ */ ++void yypop_buffer_state (void) ++{ ++ if (!YY_CURRENT_BUFFER) ++ return; ++ ++ yy_delete_buffer(YY_CURRENT_BUFFER ); ++ YY_CURRENT_BUFFER_LVALUE = NULL; ++ if ((yy_buffer_stack_top) > 0) ++ --(yy_buffer_stack_top); ++ ++ if (YY_CURRENT_BUFFER) { ++ yy_load_buffer_state( ); ++ (yy_did_buffer_switch_on_eof) = 1; ++ } ++} ++ ++/* Allocates the stack if it does not exist. ++ * Guarantees space for at least one push. ++ */ ++static void yyensure_buffer_stack (void) ++{ ++ int num_to_alloc; ++ ++ if (!(yy_buffer_stack)) { ++ ++ /* First allocation is just for 2 elements, since we don't know if this ++ * scanner will even need a stack. We use 2 instead of 1 to avoid an ++ * immediate realloc on the next call. ++ */ ++ num_to_alloc = 1; ++ (yy_buffer_stack) = (struct yy_buffer_state**)yyalloc ++ (num_to_alloc * sizeof(struct yy_buffer_state*) ++ ); ++ ++ memset((yy_buffer_stack), 0, num_to_alloc * sizeof(struct yy_buffer_state*)); ++ ++ (yy_buffer_stack_max) = num_to_alloc; ++ (yy_buffer_stack_top) = 0; ++ return; ++ } ++ ++ if ((yy_buffer_stack_top) >= ((yy_buffer_stack_max)) - 1){ ++ ++ /* Increase the buffer to prepare for a possible push. */ ++ int grow_size = 8 /* arbitrary grow size */; ++ ++ num_to_alloc = (yy_buffer_stack_max) + grow_size; ++ (yy_buffer_stack) = (struct yy_buffer_state**)yyrealloc ++ ((yy_buffer_stack), ++ num_to_alloc * sizeof(struct yy_buffer_state*) ++ ); ++ ++ /* zero only the new slots.*/ ++ memset((yy_buffer_stack) + (yy_buffer_stack_max), 0, grow_size * sizeof(struct yy_buffer_state*)); ++ (yy_buffer_stack_max) = num_to_alloc; ++ } ++} ++ ++/** Setup the input buffer state to scan directly from a user-specified character buffer. ++ * @param base the character buffer ++ * @param size the size in bytes of the character buffer ++ * ++ * @return the newly allocated buffer state object. ++ */ ++YY_BUFFER_STATE yy_scan_buffer (char * base, yy_size_t size ) ++{ ++ YY_BUFFER_STATE b; ++ ++ if ( size < 2 || ++ base[size-2] != YY_END_OF_BUFFER_CHAR || ++ base[size-1] != YY_END_OF_BUFFER_CHAR ) ++ /* They forgot to leave room for the EOB's. */ ++ return 0; ++ ++ b = (YY_BUFFER_STATE) yyalloc(sizeof( struct yy_buffer_state ) ); ++ if ( ! b ) ++ YY_FATAL_ERROR( "out of dynamic memory in yy_scan_buffer()" ); ++ ++ b->yy_buf_size = size - 2; /* "- 2" to take care of EOB's */ ++ b->yy_buf_pos = b->yy_ch_buf = base; ++ b->yy_is_our_buffer = 0; ++ b->yy_input_file = 0; ++ b->yy_n_chars = b->yy_buf_size; ++ b->yy_is_interactive = 0; ++ b->yy_at_bol = 1; ++ b->yy_fill_buffer = 0; ++ b->yy_buffer_status = YY_BUFFER_NEW; ++ ++ yy_switch_to_buffer(b ); ++ ++ return b; ++} ++ ++/** Setup the input buffer state to scan a string. The next call to yylex() will ++ * scan from a @e copy of @a str. ++ * @param yystr a NUL-terminated string to scan ++ * ++ * @return the newly allocated buffer state object. ++ * @note If you want to scan bytes that may contain NUL values, then use ++ * yy_scan_bytes() instead. ++ */ ++YY_BUFFER_STATE yy_scan_string (yyconst char * yystr ) ++{ ++ ++ return yy_scan_bytes(yystr,strlen(yystr) ); ++} ++ ++/** Setup the input buffer state to scan the given bytes. The next call to yylex() will ++ * scan from a @e copy of @a bytes. ++ * @param bytes the byte buffer to scan ++ * @param len the number of bytes in the buffer pointed to by @a bytes. ++ * ++ * @return the newly allocated buffer state object. ++ */ ++YY_BUFFER_STATE yy_scan_bytes (yyconst char * yybytes, int _yybytes_len ) ++{ ++ YY_BUFFER_STATE b; ++ char *buf; ++ yy_size_t n; ++ int i; ++ ++ /* Get memory for full buffer, including space for trailing EOB's. */ ++ n = _yybytes_len + 2; ++ buf = (char *) yyalloc(n ); ++ if ( ! buf ) ++ YY_FATAL_ERROR( "out of dynamic memory in yy_scan_bytes()" ); ++ ++ for ( i = 0; i < _yybytes_len; ++i ) ++ buf[i] = yybytes[i]; ++ ++ buf[_yybytes_len] = buf[_yybytes_len+1] = YY_END_OF_BUFFER_CHAR; ++ ++ b = yy_scan_buffer(buf,n ); ++ if ( ! b ) ++ YY_FATAL_ERROR( "bad buffer in yy_scan_bytes()" ); ++ ++ /* It's okay to grow etc. this buffer, and we should throw it ++ * away when we're done. ++ */ ++ b->yy_is_our_buffer = 1; ++ ++ return b; ++} ++ ++#ifndef YY_EXIT_FAILURE ++#define YY_EXIT_FAILURE 2 ++#endif ++ ++static void yy_fatal_error (yyconst char* msg ) ++{ ++ (void) fprintf( stderr, "%s\n", msg ); ++ exit( YY_EXIT_FAILURE ); ++} ++ ++/* Redefine yyless() so it works in section 3 code. */ ++ ++#undef yyless ++#define yyless(n) \ ++ do \ ++ { \ ++ /* Undo effects of setting up yytext. */ \ ++ int yyless_macro_arg = (n); \ ++ YY_LESS_LINENO(yyless_macro_arg);\ ++ yytext[yyleng] = (yy_hold_char); \ ++ (yy_c_buf_p) = yytext + yyless_macro_arg; \ ++ (yy_hold_char) = *(yy_c_buf_p); \ ++ *(yy_c_buf_p) = '\0'; \ ++ yyleng = yyless_macro_arg; \ ++ } \ ++ while ( 0 ) ++ ++/* Accessor methods (get/set functions) to struct members. */ ++ ++/** Get the current line number. ++ * ++ */ ++int yyget_lineno (void) ++{ ++ ++ return yylineno; ++} ++ ++/** Get the input stream. ++ * ++ */ ++FILE *yyget_in (void) ++{ ++ return yyin; ++} ++ ++/** Get the output stream. ++ * ++ */ ++FILE *yyget_out (void) ++{ ++ return yyout; ++} ++ ++/** Get the length of the current token. ++ * ++ */ ++int yyget_leng (void) ++{ ++ return yyleng; ++} ++ ++/** Get the current token. ++ * ++ */ ++ ++char *yyget_text (void) ++{ ++ return yytext; ++} ++ ++/** Set the current line number. ++ * @param line_number ++ * ++ */ ++void yyset_lineno (int line_number ) ++{ ++ ++ yylineno = line_number; ++} ++ ++/** Set the input stream. This does not discard the current ++ * input buffer. ++ * @param in_str A readable stream. ++ * ++ * @see yy_switch_to_buffer ++ */ ++void yyset_in (FILE * in_str ) ++{ ++ yyin = in_str ; ++} ++ ++void yyset_out (FILE * out_str ) ++{ ++ yyout = out_str ; ++} ++ ++int yyget_debug (void) ++{ ++ return yy_flex_debug; ++} ++ ++void yyset_debug (int bdebug ) ++{ ++ yy_flex_debug = bdebug ; ++} ++ ++static int yy_init_globals (void) ++{ ++ /* Initialization is the same as for the non-reentrant scanner. ++ * This function is called from yylex_destroy(), so don't allocate here. ++ */ ++ ++ /* We do not touch yylineno unless the option is enabled. */ ++ yylineno = 1; ++ ++ (yy_buffer_stack) = 0; ++ (yy_buffer_stack_top) = 0; ++ (yy_buffer_stack_max) = 0; ++ (yy_c_buf_p) = (char *) 0; ++ (yy_init) = 0; ++ (yy_start) = 0; ++ ++/* Defined in main.c */ ++#ifdef YY_STDINIT ++ yyin = stdin; ++ yyout = stdout; ++#else ++ yyin = (FILE *) 0; ++ yyout = (FILE *) 0; ++#endif ++ ++ /* For future reference: Set errno on error, since we are called by ++ * yylex_init() ++ */ ++ return 0; ++} ++ ++/* yylex_destroy is for both reentrant and non-reentrant scanners. */ ++int yylex_destroy (void) ++{ ++ ++ /* Pop the buffer stack, destroying each element. */ ++ while(YY_CURRENT_BUFFER){ ++ yy_delete_buffer(YY_CURRENT_BUFFER ); ++ YY_CURRENT_BUFFER_LVALUE = NULL; ++ yypop_buffer_state(); ++ } ++ ++ /* Destroy the stack itself. */ ++ yyfree((yy_buffer_stack) ); ++ (yy_buffer_stack) = NULL; ++ ++ /* Reset the globals. This is important in a non-reentrant scanner so the next time ++ * yylex() is called, initialization will occur. */ ++ yy_init_globals( ); ++ ++ return 0; ++} ++ ++/* ++ * Internal utility routines. ++ */ ++ ++#ifndef yytext_ptr ++static void yy_flex_strncpy (char* s1, yyconst char * s2, int n ) ++{ ++ register int i; ++ for ( i = 0; i < n; ++i ) ++ s1[i] = s2[i]; ++} ++#endif ++ ++#ifdef YY_NEED_STRLEN ++static int yy_flex_strlen (yyconst char * s ) ++{ ++ register int n; ++ for ( n = 0; s[n]; ++n ) ++ ; ++ ++ return n; ++} ++#endif ++ ++void *yyalloc (yy_size_t size ) ++{ ++ return (void *) malloc( size ); ++} ++ ++void *yyrealloc (void * ptr, yy_size_t size ) ++{ ++ /* The cast to (char *) in the following accommodates both ++ * implementations that use char* generic pointers, and those ++ * that use void* generic pointers. It works with the latter ++ * because both ANSI C and C++ allow castless assignment from ++ * any pointer type to void*, and deal with argument conversions ++ * as though doing an assignment. ++ */ ++ return (void *) realloc( (char *) ptr, size ); ++} ++ ++void yyfree (void * ptr ) ++{ ++ free( (char *) ptr ); /* see yyrealloc() for (char *) cast */ ++} ++ ++#define YYTABLES_NAME "yytables" ++ ++#line 222 "dtc-lexer.l" ++ ++ ++ ++ ++/* ++ * Stack of nested include file contexts. ++ */ ++ ++struct incl_file { ++ int filenum; ++ FILE *file; ++ YY_BUFFER_STATE yy_prev_buf; ++ int yy_prev_lineno; ++ struct incl_file *prev; ++}; ++ ++struct incl_file *incl_file_stack; ++ ++ ++/* ++ * Detect infinite include recursion. ++ */ ++#define MAX_INCLUDE_DEPTH (100) ++ ++static int incl_depth = 0; ++ ++ ++int push_input_file(const char *filename) ++{ ++ FILE *f; ++ struct incl_file *incl_file; ++ ++ if (!filename) { ++ yyerror("No include file name given."); ++ return 0; ++ } ++ ++ if (incl_depth++ >= MAX_INCLUDE_DEPTH) { ++ yyerror("Includes nested too deeply"); ++ return 0; ++ } ++ ++ f = dtc_open_file(filename); ++ ++ incl_file = malloc(sizeof(struct incl_file)); ++ if (!incl_file) { ++ yyerror("Can not allocate include file space."); ++ return 0; ++ } ++ ++ /* ++ * Save current context. ++ */ ++ incl_file->yy_prev_buf = YY_CURRENT_BUFFER; ++ incl_file->yy_prev_lineno = yylineno; ++ incl_file->filenum = srcpos_filenum; ++ incl_file->file = yyin; ++ incl_file->prev = incl_file_stack; ++ ++ incl_file_stack = incl_file; ++ ++ /* ++ * Establish new context. ++ */ ++ srcpos_filenum = lookup_file_name(filename, 0); ++ yylineno = 1; ++ yyin = f; ++ yy_switch_to_buffer(yy_create_buffer(yyin,YY_BUF_SIZE)); ++ ++ return 1; ++} ++ ++ ++int pop_input_file(void) ++{ ++ struct incl_file *incl_file; ++ ++ if (incl_file_stack == 0) ++ return 0; ++ ++ fclose(yyin); ++ ++ /* ++ * Pop. ++ */ ++ --incl_depth; ++ incl_file = incl_file_stack; ++ incl_file_stack = incl_file->prev; ++ ++ /* ++ * Recover old context. ++ */ ++ yy_delete_buffer(YY_CURRENT_BUFFER); ++ yy_switch_to_buffer(incl_file->yy_prev_buf); ++ yylineno = incl_file->yy_prev_lineno; ++ srcpos_filenum = incl_file->filenum; ++ yyin = incl_file->file; ++ ++ /* ++ * Free old state. ++ */ ++ free(incl_file); ++ ++ if (YY_CURRENT_BUFFER == 0) ++ return 0; ++ ++ return 1; ++} ++ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/dtc-parser.tab.c_shipped powerpc.git/arch/powerpc/boot/dtc-src/dtc-parser.tab.c_shipped +--- linux-2.6.24/arch/powerpc/boot/dtc-src/dtc-parser.tab.c_shipped 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/dtc-parser.tab.c_shipped 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,1983 @@ ++/* A Bison parser, made by GNU Bison 2.3. */ ++ ++/* Skeleton implementation for Bison's Yacc-like parsers in C ++ ++ Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006 ++ Free Software Foundation, Inc. ++ ++ This program is free software; you can redistribute it and/or modify ++ it under the terms of the GNU General Public License as published by ++ the Free Software Foundation; either version 2, or (at your option) ++ any later version. ++ ++ This program is distributed in the hope that it will be useful, ++ but WITHOUT ANY WARRANTY; without even the implied warranty of ++ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ GNU General Public License for more details. ++ ++ You should have received a copy of the GNU General Public License ++ along with this program; if not, write to the Free Software ++ Foundation, Inc., 51 Franklin Street, Fifth Floor, ++ Boston, MA 02110-1301, USA. */ ++ ++/* As a special exception, you may create a larger work that contains ++ part or all of the Bison parser skeleton and distribute that work ++ under terms of your choice, so long as that work isn't itself a ++ parser generator using the skeleton or a modified version thereof ++ as a parser skeleton. Alternatively, if you modify or redistribute ++ the parser skeleton itself, you may (at your option) remove this ++ special exception, which will cause the skeleton and the resulting ++ Bison output files to be licensed under the GNU General Public ++ License without this special exception. ++ ++ This special exception was added by the Free Software Foundation in ++ version 2.2 of Bison. */ ++ ++/* C LALR(1) parser skeleton written by Richard Stallman, by ++ simplifying the original so-called "semantic" parser. */ ++ ++/* All symbols defined below should begin with yy or YY, to avoid ++ infringing on user name space. This should be done even for local ++ variables, as they might otherwise be expanded by user macros. ++ There are some unavoidable exceptions within include files to ++ define necessary library symbols; they are noted "INFRINGES ON ++ USER NAME SPACE" below. */ ++ ++/* Identify Bison output. */ ++#define YYBISON 1 ++ ++/* Bison version. */ ++#define YYBISON_VERSION "2.3" ++ ++/* Skeleton name. */ ++#define YYSKELETON_NAME "yacc.c" ++ ++/* Pure parsers. */ ++#define YYPURE 0 ++ ++/* Using locations. */ ++#define YYLSP_NEEDED 1 ++ ++ ++ ++/* Tokens. */ ++#ifndef YYTOKENTYPE ++# define YYTOKENTYPE ++ /* Put the tokens into the symbol table, so that GDB and other debuggers ++ know about them. */ ++ enum yytokentype { ++ DT_V1 = 258, ++ DT_MEMRESERVE = 259, ++ DT_PROPNODENAME = 260, ++ DT_LITERAL = 261, ++ DT_LEGACYLITERAL = 262, ++ DT_BASE = 263, ++ DT_BYTE = 264, ++ DT_STRING = 265, ++ DT_LABEL = 266, ++ DT_REF = 267 ++ }; ++#endif ++/* Tokens. */ ++#define DT_V1 258 ++#define DT_MEMRESERVE 259 ++#define DT_PROPNODENAME 260 ++#define DT_LITERAL 261 ++#define DT_LEGACYLITERAL 262 ++#define DT_BASE 263 ++#define DT_BYTE 264 ++#define DT_STRING 265 ++#define DT_LABEL 266 ++#define DT_REF 267 ++ ++ ++ ++ ++/* Copy the first part of user declarations. */ ++#line 23 "dtc-parser.y" ++ ++#include "dtc.h" ++#include "srcpos.h" ++ ++int yylex(void); ++unsigned long long eval_literal(const char *s, int base, int bits); ++ ++extern struct boot_info *the_boot_info; ++ ++ ++ ++/* Enabling traces. */ ++#ifndef YYDEBUG ++# define YYDEBUG 0 ++#endif ++ ++/* Enabling verbose error messages. */ ++#ifdef YYERROR_VERBOSE ++# undef YYERROR_VERBOSE ++# define YYERROR_VERBOSE 1 ++#else ++# define YYERROR_VERBOSE 0 ++#endif ++ ++/* Enabling the token table. */ ++#ifndef YYTOKEN_TABLE ++# define YYTOKEN_TABLE 0 ++#endif ++ ++#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED ++typedef union YYSTYPE ++#line 34 "dtc-parser.y" ++{ ++ char *propnodename; ++ char *literal; ++ char *labelref; ++ unsigned int cbase; ++ u8 byte; ++ struct data data; ++ ++ u64 addr; ++ cell_t cell; ++ struct property *prop; ++ struct property *proplist; ++ struct node *node; ++ struct node *nodelist; ++ struct reserve_info *re; ++} ++/* Line 187 of yacc.c. */ ++#line 148 "dtc-parser.tab.c" ++ YYSTYPE; ++# define yystype YYSTYPE /* obsolescent; will be withdrawn */ ++# define YYSTYPE_IS_DECLARED 1 ++# define YYSTYPE_IS_TRIVIAL 1 ++#endif ++ ++#if ! defined YYLTYPE && ! defined YYLTYPE_IS_DECLARED ++typedef struct YYLTYPE ++{ ++ int first_line; ++ int first_column; ++ int last_line; ++ int last_column; ++} YYLTYPE; ++# define yyltype YYLTYPE /* obsolescent; will be withdrawn */ ++# define YYLTYPE_IS_DECLARED 1 ++# define YYLTYPE_IS_TRIVIAL 1 ++#endif ++ ++ ++/* Copy the second part of user declarations. */ ++ ++ ++/* Line 216 of yacc.c. */ ++#line 173 "dtc-parser.tab.c" ++ ++#ifdef short ++# undef short ++#endif ++ ++#ifdef YYTYPE_UINT8 ++typedef YYTYPE_UINT8 yytype_uint8; ++#else ++typedef unsigned char yytype_uint8; ++#endif ++ ++#ifdef YYTYPE_INT8 ++typedef YYTYPE_INT8 yytype_int8; ++#elif (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++typedef signed char yytype_int8; ++#else ++typedef short int yytype_int8; ++#endif ++ ++#ifdef YYTYPE_UINT16 ++typedef YYTYPE_UINT16 yytype_uint16; ++#else ++typedef unsigned short int yytype_uint16; ++#endif ++ ++#ifdef YYTYPE_INT16 ++typedef YYTYPE_INT16 yytype_int16; ++#else ++typedef short int yytype_int16; ++#endif ++ ++#ifndef YYSIZE_T ++# ifdef __SIZE_TYPE__ ++# define YYSIZE_T __SIZE_TYPE__ ++# elif defined size_t ++# define YYSIZE_T size_t ++# elif ! defined YYSIZE_T && (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++# include <stddef.h> /* INFRINGES ON USER NAME SPACE */ ++# define YYSIZE_T size_t ++# else ++# define YYSIZE_T unsigned int ++# endif ++#endif ++ ++#define YYSIZE_MAXIMUM ((YYSIZE_T) -1) ++ ++#ifndef YY_ ++# if YYENABLE_NLS ++# if ENABLE_NLS ++# include <libintl.h> /* INFRINGES ON USER NAME SPACE */ ++# define YY_(msgid) dgettext ("bison-runtime", msgid) ++# endif ++# endif ++# ifndef YY_ ++# define YY_(msgid) msgid ++# endif ++#endif ++ ++/* Suppress unused-variable warnings by "using" E. */ ++#if ! defined lint || defined __GNUC__ ++# define YYUSE(e) ((void) (e)) ++#else ++# define YYUSE(e) /* empty */ ++#endif ++ ++/* Identity function, used to suppress warnings about constant conditions. */ ++#ifndef lint ++# define YYID(n) (n) ++#else ++#if (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++static int ++YYID (int i) ++#else ++static int ++YYID (i) ++ int i; ++#endif ++{ ++ return i; ++} ++#endif ++ ++#if ! defined yyoverflow || YYERROR_VERBOSE ++ ++/* The parser invokes alloca or malloc; define the necessary symbols. */ ++ ++# ifdef YYSTACK_USE_ALLOCA ++# if YYSTACK_USE_ALLOCA ++# ifdef __GNUC__ ++# define YYSTACK_ALLOC __builtin_alloca ++# elif defined __BUILTIN_VA_ARG_INCR ++# include <alloca.h> /* INFRINGES ON USER NAME SPACE */ ++# elif defined _AIX ++# define YYSTACK_ALLOC __alloca ++# elif defined _MSC_VER ++# include <malloc.h> /* INFRINGES ON USER NAME SPACE */ ++# define alloca _alloca ++# else ++# define YYSTACK_ALLOC alloca ++# if ! defined _ALLOCA_H && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++# include <stdlib.h> /* INFRINGES ON USER NAME SPACE */ ++# ifndef _STDLIB_H ++# define _STDLIB_H 1 ++# endif ++# endif ++# endif ++# endif ++# endif ++ ++# ifdef YYSTACK_ALLOC ++ /* Pacify GCC's `empty if-body' warning. */ ++# define YYSTACK_FREE(Ptr) do { /* empty */; } while (YYID (0)) ++# ifndef YYSTACK_ALLOC_MAXIMUM ++ /* The OS might guarantee only one guard page at the bottom of the stack, ++ and a page size can be as small as 4096 bytes. So we cannot safely ++ invoke alloca (N) if N exceeds 4096. Use a slightly smaller number ++ to allow for a few compiler-allocated temporary stack slots. */ ++# define YYSTACK_ALLOC_MAXIMUM 4032 /* reasonable circa 2006 */ ++# endif ++# else ++# define YYSTACK_ALLOC YYMALLOC ++# define YYSTACK_FREE YYFREE ++# ifndef YYSTACK_ALLOC_MAXIMUM ++# define YYSTACK_ALLOC_MAXIMUM YYSIZE_MAXIMUM ++# endif ++# if (defined __cplusplus && ! defined _STDLIB_H \ ++ && ! ((defined YYMALLOC || defined malloc) \ ++ && (defined YYFREE || defined free))) ++# include <stdlib.h> /* INFRINGES ON USER NAME SPACE */ ++# ifndef _STDLIB_H ++# define _STDLIB_H 1 ++# endif ++# endif ++# ifndef YYMALLOC ++# define YYMALLOC malloc ++# if ! defined malloc && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++void *malloc (YYSIZE_T); /* INFRINGES ON USER NAME SPACE */ ++# endif ++# endif ++# ifndef YYFREE ++# define YYFREE free ++# if ! defined free && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++void free (void *); /* INFRINGES ON USER NAME SPACE */ ++# endif ++# endif ++# endif ++#endif /* ! defined yyoverflow || YYERROR_VERBOSE */ ++ ++ ++#if (! defined yyoverflow \ ++ && (! defined __cplusplus \ ++ || (defined YYLTYPE_IS_TRIVIAL && YYLTYPE_IS_TRIVIAL \ ++ && defined YYSTYPE_IS_TRIVIAL && YYSTYPE_IS_TRIVIAL))) ++ ++/* A type that is properly aligned for any stack member. */ ++union yyalloc ++{ ++ yytype_int16 yyss; ++ YYSTYPE yyvs; ++ YYLTYPE yyls; ++}; ++ ++/* The size of the maximum gap between one aligned stack and the next. */ ++# define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1) ++ ++/* The size of an array large to enough to hold all stacks, each with ++ N elements. */ ++# define YYSTACK_BYTES(N) \ ++ ((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE) + sizeof (YYLTYPE)) \ ++ + 2 * YYSTACK_GAP_MAXIMUM) ++ ++/* Copy COUNT objects from FROM to TO. The source and destination do ++ not overlap. */ ++# ifndef YYCOPY ++# if defined __GNUC__ && 1 < __GNUC__ ++# define YYCOPY(To, From, Count) \ ++ __builtin_memcpy (To, From, (Count) * sizeof (*(From))) ++# else ++# define YYCOPY(To, From, Count) \ ++ do \ ++ { \ ++ YYSIZE_T yyi; \ ++ for (yyi = 0; yyi < (Count); yyi++) \ ++ (To)[yyi] = (From)[yyi]; \ ++ } \ ++ while (YYID (0)) ++# endif ++# endif ++ ++/* Relocate STACK from its old location to the new one. The ++ local variables YYSIZE and YYSTACKSIZE give the old and new number of ++ elements in the stack, and YYPTR gives the new location of the ++ stack. Advance YYPTR to a properly aligned location for the next ++ stack. */ ++# define YYSTACK_RELOCATE(Stack) \ ++ do \ ++ { \ ++ YYSIZE_T yynewbytes; \ ++ YYCOPY (&yyptr->Stack, Stack, yysize); \ ++ Stack = &yyptr->Stack; \ ++ yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \ ++ yyptr += yynewbytes / sizeof (*yyptr); \ ++ } \ ++ while (YYID (0)) ++ ++#endif ++ ++/* YYFINAL -- State number of the termination state. */ ++#define YYFINAL 9 ++/* YYLAST -- Last index in YYTABLE. */ ++#define YYLAST 60 ++ ++/* YYNTOKENS -- Number of terminals. */ ++#define YYNTOKENS 24 ++/* YYNNTS -- Number of nonterminals. */ ++#define YYNNTS 20 ++/* YYNRULES -- Number of rules. */ ++#define YYNRULES 43 ++/* YYNRULES -- Number of states. */ ++#define YYNSTATES 67 ++ ++/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */ ++#define YYUNDEFTOK 2 ++#define YYMAXUTOK 267 ++ ++#define YYTRANSLATE(YYX) \ ++ ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK) ++ ++/* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX. */ ++static const yytype_uint8 yytranslate[] = ++{ ++ 0, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 23, 14, 2, 15, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 13, ++ 19, 18, 20, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 21, 2, 22, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 16, 2, 17, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, ++ 2, 2, 2, 2, 2, 2, 1, 2, 3, 4, ++ 5, 6, 7, 8, 9, 10, 11, 12 ++}; ++ ++#if YYDEBUG ++/* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in ++ YYRHS. */ ++static const yytype_uint8 yyprhs[] = ++{ ++ 0, 0, 3, 8, 11, 12, 15, 21, 22, 25, ++ 27, 34, 36, 38, 41, 47, 48, 51, 57, 61, ++ 64, 69, 74, 77, 80, 81, 84, 87, 88, 91, ++ 94, 97, 98, 100, 102, 105, 106, 109, 112, 113, ++ 116, 119, 123, 124 ++}; ++ ++/* YYRHS -- A `-1'-separated list of the rules' RHS. */ ++static const yytype_int8 yyrhs[] = ++{ ++ 25, 0, -1, 3, 13, 26, 31, -1, 28, 31, ++ -1, -1, 27, 26, -1, 43, 4, 30, 30, 13, ++ -1, -1, 29, 28, -1, 27, -1, 43, 4, 30, ++ 14, 30, 13, -1, 6, -1, 7, -1, 15, 32, ++ -1, 16, 33, 41, 17, 13, -1, -1, 33, 34, ++ -1, 43, 5, 18, 35, 13, -1, 43, 5, 13, ++ -1, 36, 10, -1, 36, 19, 37, 20, -1, 36, ++ 21, 40, 22, -1, 36, 12, -1, 35, 11, -1, ++ -1, 35, 23, -1, 36, 11, -1, -1, 37, 39, ++ -1, 37, 12, -1, 37, 11, -1, -1, 8, -1, ++ 6, -1, 38, 7, -1, -1, 40, 9, -1, 40, ++ 11, -1, -1, 42, 41, -1, 42, 34, -1, 43, ++ 5, 32, -1, -1, 11, -1 ++}; ++ ++/* YYRLINE[YYN] -- source line where rule number YYN was defined. */ ++static const yytype_uint16 yyrline[] = ++{ ++ 0, 85, 85, 89, 97, 100, 107, 115, 118, 125, ++ 129, 136, 140, 147, 154, 162, 165, 172, 176, 183, ++ 187, 191, 195, 199, 207, 210, 214, 222, 225, 229, ++ 234, 242, 245, 249, 253, 261, 264, 268, 276, 279, ++ 283, 291, 299, 302 ++}; ++#endif ++ ++#if YYDEBUG || YYERROR_VERBOSE || YYTOKEN_TABLE ++/* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM. ++ First, the terminals, then, starting at YYNTOKENS, nonterminals. */ ++static const char *const yytname[] = ++{ ++ "$end", "error", "$undefined", "DT_V1", "DT_MEMRESERVE", ++ "DT_PROPNODENAME", "DT_LITERAL", "DT_LEGACYLITERAL", "DT_BASE", ++ "DT_BYTE", "DT_STRING", "DT_LABEL", "DT_REF", "';'", "'-'", "'/'", "'{'", ++ "'}'", "'='", "'<'", "'>'", "'['", "']'", "','", "$accept", "sourcefile", ++ "memreserves", "memreserve", "v0_memreserves", "v0_memreserve", "addr", ++ "devicetree", "nodedef", "proplist", "propdef", "propdata", ++ "propdataprefix", "celllist", "cellbase", "cellval", "bytestring", ++ "subnodes", "subnode", "label", 0 ++}; ++#endif ++ ++# ifdef YYPRINT ++/* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to ++ token YYLEX-NUM. */ ++static const yytype_uint16 yytoknum[] = ++{ ++ 0, 256, 257, 258, 259, 260, 261, 262, 263, 264, ++ 265, 266, 267, 59, 45, 47, 123, 125, 61, 60, ++ 62, 91, 93, 44 ++}; ++# endif ++ ++/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */ ++static const yytype_uint8 yyr1[] = ++{ ++ 0, 24, 25, 25, 26, 26, 27, 28, 28, 29, ++ 29, 30, 30, 31, 32, 33, 33, 34, 34, 35, ++ 35, 35, 35, 35, 36, 36, 36, 37, 37, 37, ++ 37, 38, 38, 39, 39, 40, 40, 40, 41, 41, ++ 41, 42, 43, 43 ++}; ++ ++/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */ ++static const yytype_uint8 yyr2[] = ++{ ++ 0, 2, 4, 2, 0, 2, 5, 0, 2, 1, ++ 6, 1, 1, 2, 5, 0, 2, 5, 3, 2, ++ 4, 4, 2, 2, 0, 2, 2, 0, 2, 2, ++ 2, 0, 1, 1, 2, 0, 2, 2, 0, 2, ++ 2, 3, 0, 1 ++}; ++ ++/* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state ++ STATE-NUM when YYTABLE doesn't specify something else to do. Zero ++ means the default is an error. */ ++static const yytype_uint8 yydefact[] = ++{ ++ 7, 0, 43, 0, 9, 0, 7, 0, 4, 1, ++ 0, 3, 8, 0, 0, 4, 0, 15, 13, 11, ++ 12, 0, 2, 5, 0, 38, 0, 0, 0, 16, ++ 0, 38, 0, 0, 6, 0, 40, 39, 0, 10, ++ 14, 18, 24, 41, 0, 0, 23, 17, 25, 19, ++ 26, 22, 27, 35, 31, 0, 33, 32, 30, 29, ++ 20, 0, 28, 36, 37, 21, 34 ++}; ++ ++/* YYDEFGOTO[NTERM-NUM]. */ ++static const yytype_int8 yydefgoto[] = ++{ ++ -1, 3, 14, 4, 5, 6, 27, 11, 18, 25, ++ 29, 44, 45, 54, 61, 62, 55, 30, 31, 7 ++}; ++ ++/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing ++ STATE-NUM. */ ++#define YYPACT_NINF -13 ++static const yytype_int8 yypact[] = ++{ ++ 23, 11, -13, 37, -13, -4, 18, 39, 18, -13, ++ 28, -13, -13, 34, -4, 18, 41, -13, -13, -13, ++ -13, 25, -13, -13, 34, -3, 34, 33, 34, -13, ++ 30, -3, 43, 36, -13, 38, -13, -13, 20, -13, ++ -13, -13, -13, -13, 2, 9, -13, -13, -13, -13, ++ -13, -13, -13, -13, -2, -6, -13, -13, -13, -13, ++ -13, 45, -13, -13, -13, -13, -13 ++}; ++ ++/* YYPGOTO[NTERM-NUM]. */ ++static const yytype_int8 yypgoto[] = ++{ ++ -13, -13, 35, 27, 47, -13, -12, 40, 17, -13, ++ 26, -13, -13, -13, -13, -13, -13, 29, -13, -8 ++}; ++ ++/* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If ++ positive, shift that token. If negative, reduce the rule which ++ number is the opposite. If zero, do what YYDEFACT says. ++ If YYTABLE_NINF, syntax error. */ ++#define YYTABLE_NINF -43 ++static const yytype_int8 yytable[] = ++{ ++ 16, 21, -42, 63, 56, 64, 57, 16, 2, 58, ++ 59, 10, 28, 46, 33, 47, 65, 32, 60, 49, ++ 50, 51, -42, 32, 8, 48, 1, -42, 52, 2, ++ 53, 19, 20, 41, 2, 15, 17, 9, 42, 26, ++ 19, 20, 15, 13, 17, 24, 34, 35, 38, 39, ++ 23, 40, 66, 12, 22, 43, 0, 36, 0, 0, ++ 37 ++}; ++ ++static const yytype_int8 yycheck[] = ++{ ++ 8, 13, 5, 9, 6, 11, 8, 15, 11, 11, ++ 12, 15, 24, 11, 26, 13, 22, 25, 20, 10, ++ 11, 12, 4, 31, 13, 23, 3, 4, 19, 11, ++ 21, 6, 7, 13, 11, 8, 16, 0, 18, 14, ++ 6, 7, 15, 4, 16, 4, 13, 17, 5, 13, ++ 15, 13, 7, 6, 14, 38, -1, 31, -1, -1, ++ 31 ++}; ++ ++/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing ++ symbol of state STATE-NUM. */ ++static const yytype_uint8 yystos[] = ++{ ++ 0, 3, 11, 25, 27, 28, 29, 43, 13, 0, ++ 15, 31, 28, 4, 26, 27, 43, 16, 32, 6, ++ 7, 30, 31, 26, 4, 33, 14, 30, 30, 34, ++ 41, 42, 43, 30, 13, 17, 34, 41, 5, 13, ++ 13, 13, 18, 32, 35, 36, 11, 13, 23, 10, ++ 11, 12, 19, 21, 37, 40, 6, 8, 11, 12, ++ 20, 38, 39, 9, 11, 22, 7 ++}; ++ ++#define yyerrok (yyerrstatus = 0) ++#define yyclearin (yychar = YYEMPTY) ++#define YYEMPTY (-2) ++#define YYEOF 0 ++ ++#define YYACCEPT goto yyacceptlab ++#define YYABORT goto yyabortlab ++#define YYERROR goto yyerrorlab ++ ++ ++/* Like YYERROR except do call yyerror. This remains here temporarily ++ to ease the transition to the new meaning of YYERROR, for GCC. ++ Once GCC version 2 has supplanted version 1, this can go. */ ++ ++#define YYFAIL goto yyerrlab ++ ++#define YYRECOVERING() (!!yyerrstatus) ++ ++#define YYBACKUP(Token, Value) \ ++do \ ++ if (yychar == YYEMPTY && yylen == 1) \ ++ { \ ++ yychar = (Token); \ ++ yylval = (Value); \ ++ yytoken = YYTRANSLATE (yychar); \ ++ YYPOPSTACK (1); \ ++ goto yybackup; \ ++ } \ ++ else \ ++ { \ ++ yyerror (YY_("syntax error: cannot back up")); \ ++ YYERROR; \ ++ } \ ++while (YYID (0)) ++ ++ ++#define YYTERROR 1 ++#define YYERRCODE 256 ++ ++ ++/* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N]. ++ If N is 0, then set CURRENT to the empty location which ends ++ the previous symbol: RHS[0] (always defined). */ ++ ++#define YYRHSLOC(Rhs, K) ((Rhs)[K]) ++#ifndef YYLLOC_DEFAULT ++# define YYLLOC_DEFAULT(Current, Rhs, N) \ ++ do \ ++ if (YYID (N)) \ ++ { \ ++ (Current).first_line = YYRHSLOC (Rhs, 1).first_line; \ ++ (Current).first_column = YYRHSLOC (Rhs, 1).first_column; \ ++ (Current).last_line = YYRHSLOC (Rhs, N).last_line; \ ++ (Current).last_column = YYRHSLOC (Rhs, N).last_column; \ ++ } \ ++ else \ ++ { \ ++ (Current).first_line = (Current).last_line = \ ++ YYRHSLOC (Rhs, 0).last_line; \ ++ (Current).first_column = (Current).last_column = \ ++ YYRHSLOC (Rhs, 0).last_column; \ ++ } \ ++ while (YYID (0)) ++#endif ++ ++ ++/* YY_LOCATION_PRINT -- Print the location on the stream. ++ This macro was not mandated originally: define only if we know ++ we won't break user code: when these are the locations we know. */ ++ ++#ifndef YY_LOCATION_PRINT ++# if YYLTYPE_IS_TRIVIAL ++# define YY_LOCATION_PRINT(File, Loc) \ ++ fprintf (File, "%d.%d-%d.%d", \ ++ (Loc).first_line, (Loc).first_column, \ ++ (Loc).last_line, (Loc).last_column) ++# else ++# define YY_LOCATION_PRINT(File, Loc) ((void) 0) ++# endif ++#endif ++ ++ ++/* YYLEX -- calling `yylex' with the right arguments. */ ++ ++#ifdef YYLEX_PARAM ++# define YYLEX yylex (YYLEX_PARAM) ++#else ++# define YYLEX yylex () ++#endif ++ ++/* Enable debugging if requested. */ ++#if YYDEBUG ++ ++# ifndef YYFPRINTF ++# include <stdio.h> /* INFRINGES ON USER NAME SPACE */ ++# define YYFPRINTF fprintf ++# endif ++ ++# define YYDPRINTF(Args) \ ++do { \ ++ if (yydebug) \ ++ YYFPRINTF Args; \ ++} while (YYID (0)) ++ ++# define YY_SYMBOL_PRINT(Title, Type, Value, Location) \ ++do { \ ++ if (yydebug) \ ++ { \ ++ YYFPRINTF (stderr, "%s ", Title); \ ++ yy_symbol_print (stderr, \ ++ Type, Value, Location); \ ++ YYFPRINTF (stderr, "\n"); \ ++ } \ ++} while (YYID (0)) ++ ++ ++/*--------------------------------. ++| Print this symbol on YYOUTPUT. | ++`--------------------------------*/ ++ ++/*ARGSUSED*/ ++#if (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++static void ++yy_symbol_value_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep, YYLTYPE const * const yylocationp) ++#else ++static void ++yy_symbol_value_print (yyoutput, yytype, yyvaluep, yylocationp) ++ FILE *yyoutput; ++ int yytype; ++ YYSTYPE const * const yyvaluep; ++ YYLTYPE const * const yylocationp; ++#endif ++{ ++ if (!yyvaluep) ++ return; ++ YYUSE (yylocationp); ++# ifdef YYPRINT ++ if (yytype < YYNTOKENS) ++ YYPRINT (yyoutput, yytoknum[yytype], *yyvaluep); ++# else ++ YYUSE (yyoutput); ++# endif ++ switch (yytype) ++ { ++ default: ++ break; ++ } ++} ++ ++ ++/*--------------------------------. ++| Print this symbol on YYOUTPUT. | ++`--------------------------------*/ ++ ++#if (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++static void ++yy_symbol_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep, YYLTYPE const * const yylocationp) ++#else ++static void ++yy_symbol_print (yyoutput, yytype, yyvaluep, yylocationp) ++ FILE *yyoutput; ++ int yytype; ++ YYSTYPE const * const yyvaluep; ++ YYLTYPE const * const yylocationp; ++#endif ++{ ++ if (yytype < YYNTOKENS) ++ YYFPRINTF (yyoutput, "token %s (", yytname[yytype]); ++ else ++ YYFPRINTF (yyoutput, "nterm %s (", yytname[yytype]); ++ ++ YY_LOCATION_PRINT (yyoutput, *yylocationp); ++ YYFPRINTF (yyoutput, ": "); ++ yy_symbol_value_print (yyoutput, yytype, yyvaluep, yylocationp); ++ YYFPRINTF (yyoutput, ")"); ++} ++ ++/*------------------------------------------------------------------. ++| yy_stack_print -- Print the state stack from its BOTTOM up to its | ++| TOP (included). | ++`------------------------------------------------------------------*/ ++ ++#if (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++static void ++yy_stack_print (yytype_int16 *bottom, yytype_int16 *top) ++#else ++static void ++yy_stack_print (bottom, top) ++ yytype_int16 *bottom; ++ yytype_int16 *top; ++#endif ++{ ++ YYFPRINTF (stderr, "Stack now"); ++ for (; bottom <= top; ++bottom) ++ YYFPRINTF (stderr, " %d", *bottom); ++ YYFPRINTF (stderr, "\n"); ++} ++ ++# define YY_STACK_PRINT(Bottom, Top) \ ++do { \ ++ if (yydebug) \ ++ yy_stack_print ((Bottom), (Top)); \ ++} while (YYID (0)) ++ ++ ++/*------------------------------------------------. ++| Report that the YYRULE is going to be reduced. | ++`------------------------------------------------*/ ++ ++#if (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++static void ++yy_reduce_print (YYSTYPE *yyvsp, YYLTYPE *yylsp, int yyrule) ++#else ++static void ++yy_reduce_print (yyvsp, yylsp, yyrule) ++ YYSTYPE *yyvsp; ++ YYLTYPE *yylsp; ++ int yyrule; ++#endif ++{ ++ int yynrhs = yyr2[yyrule]; ++ int yyi; ++ unsigned long int yylno = yyrline[yyrule]; ++ YYFPRINTF (stderr, "Reducing stack by rule %d (line %lu):\n", ++ yyrule - 1, yylno); ++ /* The symbols being reduced. */ ++ for (yyi = 0; yyi < yynrhs; yyi++) ++ { ++ fprintf (stderr, " $%d = ", yyi + 1); ++ yy_symbol_print (stderr, yyrhs[yyprhs[yyrule] + yyi], ++ &(yyvsp[(yyi + 1) - (yynrhs)]) ++ , &(yylsp[(yyi + 1) - (yynrhs)]) ); ++ fprintf (stderr, "\n"); ++ } ++} ++ ++# define YY_REDUCE_PRINT(Rule) \ ++do { \ ++ if (yydebug) \ ++ yy_reduce_print (yyvsp, yylsp, Rule); \ ++} while (YYID (0)) ++ ++/* Nonzero means print parse trace. It is left uninitialized so that ++ multiple parsers can coexist. */ ++int yydebug; ++#else /* !YYDEBUG */ ++# define YYDPRINTF(Args) ++# define YY_SYMBOL_PRINT(Title, Type, Value, Location) ++# define YY_STACK_PRINT(Bottom, Top) ++# define YY_REDUCE_PRINT(Rule) ++#endif /* !YYDEBUG */ ++ ++ ++/* YYINITDEPTH -- initial size of the parser's stacks. */ ++#ifndef YYINITDEPTH ++# define YYINITDEPTH 200 ++#endif ++ ++/* YYMAXDEPTH -- maximum size the stacks can grow to (effective only ++ if the built-in stack extension method is used). ++ ++ Do not make this value too large; the results are undefined if ++ YYSTACK_ALLOC_MAXIMUM < YYSTACK_BYTES (YYMAXDEPTH) ++ evaluated with infinite-precision integer arithmetic. */ ++ ++#ifndef YYMAXDEPTH ++# define YYMAXDEPTH 10000 ++#endif ++ ++ ++ ++#if YYERROR_VERBOSE ++ ++# ifndef yystrlen ++# if defined __GLIBC__ && defined _STRING_H ++# define yystrlen strlen ++# else ++/* Return the length of YYSTR. */ ++#if (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++static YYSIZE_T ++yystrlen (const char *yystr) ++#else ++static YYSIZE_T ++yystrlen (yystr) ++ const char *yystr; ++#endif ++{ ++ YYSIZE_T yylen; ++ for (yylen = 0; yystr[yylen]; yylen++) ++ continue; ++ return yylen; ++} ++# endif ++# endif ++ ++# ifndef yystpcpy ++# if defined __GLIBC__ && defined _STRING_H && defined _GNU_SOURCE ++# define yystpcpy stpcpy ++# else ++/* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in ++ YYDEST. */ ++#if (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++static char * ++yystpcpy (char *yydest, const char *yysrc) ++#else ++static char * ++yystpcpy (yydest, yysrc) ++ char *yydest; ++ const char *yysrc; ++#endif ++{ ++ char *yyd = yydest; ++ const char *yys = yysrc; ++ ++ while ((*yyd++ = *yys++) != '\0') ++ continue; ++ ++ return yyd - 1; ++} ++# endif ++# endif ++ ++# ifndef yytnamerr ++/* Copy to YYRES the contents of YYSTR after stripping away unnecessary ++ quotes and backslashes, so that it's suitable for yyerror. The ++ heuristic is that double-quoting is unnecessary unless the string ++ contains an apostrophe, a comma, or backslash (other than ++ backslash-backslash). YYSTR is taken from yytname. If YYRES is ++ null, do not copy; instead, return the length of what the result ++ would have been. */ ++static YYSIZE_T ++yytnamerr (char *yyres, const char *yystr) ++{ ++ if (*yystr == '"') ++ { ++ YYSIZE_T yyn = 0; ++ char const *yyp = yystr; ++ ++ for (;;) ++ switch (*++yyp) ++ { ++ case '\'': ++ case ',': ++ goto do_not_strip_quotes; ++ ++ case '\\': ++ if (*++yyp != '\\') ++ goto do_not_strip_quotes; ++ /* Fall through. */ ++ default: ++ if (yyres) ++ yyres[yyn] = *yyp; ++ yyn++; ++ break; ++ ++ case '"': ++ if (yyres) ++ yyres[yyn] = '\0'; ++ return yyn; ++ } ++ do_not_strip_quotes: ; ++ } ++ ++ if (! yyres) ++ return yystrlen (yystr); ++ ++ return yystpcpy (yyres, yystr) - yyres; ++} ++# endif ++ ++/* Copy into YYRESULT an error message about the unexpected token ++ YYCHAR while in state YYSTATE. Return the number of bytes copied, ++ including the terminating null byte. If YYRESULT is null, do not ++ copy anything; just return the number of bytes that would be ++ copied. As a special case, return 0 if an ordinary "syntax error" ++ message will do. Return YYSIZE_MAXIMUM if overflow occurs during ++ size calculation. */ ++static YYSIZE_T ++yysyntax_error (char *yyresult, int yystate, int yychar) ++{ ++ int yyn = yypact[yystate]; ++ ++ if (! (YYPACT_NINF < yyn && yyn <= YYLAST)) ++ return 0; ++ else ++ { ++ int yytype = YYTRANSLATE (yychar); ++ YYSIZE_T yysize0 = yytnamerr (0, yytname[yytype]); ++ YYSIZE_T yysize = yysize0; ++ YYSIZE_T yysize1; ++ int yysize_overflow = 0; ++ enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 }; ++ char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM]; ++ int yyx; ++ ++# if 0 ++ /* This is so xgettext sees the translatable formats that are ++ constructed on the fly. */ ++ YY_("syntax error, unexpected %s"); ++ YY_("syntax error, unexpected %s, expecting %s"); ++ YY_("syntax error, unexpected %s, expecting %s or %s"); ++ YY_("syntax error, unexpected %s, expecting %s or %s or %s"); ++ YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s"); ++# endif ++ char *yyfmt; ++ char const *yyf; ++ static char const yyunexpected[] = "syntax error, unexpected %s"; ++ static char const yyexpecting[] = ", expecting %s"; ++ static char const yyor[] = " or %s"; ++ char yyformat[sizeof yyunexpected ++ + sizeof yyexpecting - 1 ++ + ((YYERROR_VERBOSE_ARGS_MAXIMUM - 2) ++ * (sizeof yyor - 1))]; ++ char const *yyprefix = yyexpecting; ++ ++ /* Start YYX at -YYN if negative to avoid negative indexes in ++ YYCHECK. */ ++ int yyxbegin = yyn < 0 ? -yyn : 0; ++ ++ /* Stay within bounds of both yycheck and yytname. */ ++ int yychecklim = YYLAST - yyn + 1; ++ int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS; ++ int yycount = 1; ++ ++ yyarg[0] = yytname[yytype]; ++ yyfmt = yystpcpy (yyformat, yyunexpected); ++ ++ for (yyx = yyxbegin; yyx < yyxend; ++yyx) ++ if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR) ++ { ++ if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM) ++ { ++ yycount = 1; ++ yysize = yysize0; ++ yyformat[sizeof yyunexpected - 1] = '\0'; ++ break; ++ } ++ yyarg[yycount++] = yytname[yyx]; ++ yysize1 = yysize + yytnamerr (0, yytname[yyx]); ++ yysize_overflow |= (yysize1 < yysize); ++ yysize = yysize1; ++ yyfmt = yystpcpy (yyfmt, yyprefix); ++ yyprefix = yyor; ++ } ++ ++ yyf = YY_(yyformat); ++ yysize1 = yysize + yystrlen (yyf); ++ yysize_overflow |= (yysize1 < yysize); ++ yysize = yysize1; ++ ++ if (yysize_overflow) ++ return YYSIZE_MAXIMUM; ++ ++ if (yyresult) ++ { ++ /* Avoid sprintf, as that infringes on the user's name space. ++ Don't have undefined behavior even if the translation ++ produced a string with the wrong number of "%s"s. */ ++ char *yyp = yyresult; ++ int yyi = 0; ++ while ((*yyp = *yyf) != '\0') ++ { ++ if (*yyp == '%' && yyf[1] == 's' && yyi < yycount) ++ { ++ yyp += yytnamerr (yyp, yyarg[yyi++]); ++ yyf += 2; ++ } ++ else ++ { ++ yyp++; ++ yyf++; ++ } ++ } ++ } ++ return yysize; ++ } ++} ++#endif /* YYERROR_VERBOSE */ ++ ++ ++/*-----------------------------------------------. ++| Release the memory associated to this symbol. | ++`-----------------------------------------------*/ ++ ++/*ARGSUSED*/ ++#if (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++static void ++yydestruct (const char *yymsg, int yytype, YYSTYPE *yyvaluep, YYLTYPE *yylocationp) ++#else ++static void ++yydestruct (yymsg, yytype, yyvaluep, yylocationp) ++ const char *yymsg; ++ int yytype; ++ YYSTYPE *yyvaluep; ++ YYLTYPE *yylocationp; ++#endif ++{ ++ YYUSE (yyvaluep); ++ YYUSE (yylocationp); ++ ++ if (!yymsg) ++ yymsg = "Deleting"; ++ YY_SYMBOL_PRINT (yymsg, yytype, yyvaluep, yylocationp); ++ ++ switch (yytype) ++ { ++ ++ default: ++ break; ++ } ++} ++ ++ ++/* Prevent warnings from -Wmissing-prototypes. */ ++ ++#ifdef YYPARSE_PARAM ++#if defined __STDC__ || defined __cplusplus ++int yyparse (void *YYPARSE_PARAM); ++#else ++int yyparse (); ++#endif ++#else /* ! YYPARSE_PARAM */ ++#if defined __STDC__ || defined __cplusplus ++int yyparse (void); ++#else ++int yyparse (); ++#endif ++#endif /* ! YYPARSE_PARAM */ ++ ++ ++ ++/* The look-ahead symbol. */ ++int yychar; ++ ++/* The semantic value of the look-ahead symbol. */ ++YYSTYPE yylval; ++ ++/* Number of syntax errors so far. */ ++int yynerrs; ++/* Location data for the look-ahead symbol. */ ++YYLTYPE yylloc; ++ ++ ++ ++/*----------. ++| yyparse. | ++`----------*/ ++ ++#ifdef YYPARSE_PARAM ++#if (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++int ++yyparse (void *YYPARSE_PARAM) ++#else ++int ++yyparse (YYPARSE_PARAM) ++ void *YYPARSE_PARAM; ++#endif ++#else /* ! YYPARSE_PARAM */ ++#if (defined __STDC__ || defined __C99__FUNC__ \ ++ || defined __cplusplus || defined _MSC_VER) ++int ++yyparse (void) ++#else ++int ++yyparse () ++ ++#endif ++#endif ++{ ++ ++ int yystate; ++ int yyn; ++ int yyresult; ++ /* Number of tokens to shift before error messages enabled. */ ++ int yyerrstatus; ++ /* Look-ahead token as an internal (translated) token number. */ ++ int yytoken = 0; ++#if YYERROR_VERBOSE ++ /* Buffer for error messages, and its allocated size. */ ++ char yymsgbuf[128]; ++ char *yymsg = yymsgbuf; ++ YYSIZE_T yymsg_alloc = sizeof yymsgbuf; ++#endif ++ ++ /* Three stacks and their tools: ++ `yyss': related to states, ++ `yyvs': related to semantic values, ++ `yyls': related to locations. ++ ++ Refer to the stacks thru separate pointers, to allow yyoverflow ++ to reallocate them elsewhere. */ ++ ++ /* The state stack. */ ++ yytype_int16 yyssa[YYINITDEPTH]; ++ yytype_int16 *yyss = yyssa; ++ yytype_int16 *yyssp; ++ ++ /* The semantic value stack. */ ++ YYSTYPE yyvsa[YYINITDEPTH]; ++ YYSTYPE *yyvs = yyvsa; ++ YYSTYPE *yyvsp; ++ ++ /* The location stack. */ ++ YYLTYPE yylsa[YYINITDEPTH]; ++ YYLTYPE *yyls = yylsa; ++ YYLTYPE *yylsp; ++ /* The locations where the error started and ended. */ ++ YYLTYPE yyerror_range[2]; ++ ++#define YYPOPSTACK(N) (yyvsp -= (N), yyssp -= (N), yylsp -= (N)) ++ ++ YYSIZE_T yystacksize = YYINITDEPTH; ++ ++ /* The variables used to return semantic value and location from the ++ action routines. */ ++ YYSTYPE yyval; ++ YYLTYPE yyloc; ++ ++ /* The number of symbols on the RHS of the reduced rule. ++ Keep to zero when no symbol should be popped. */ ++ int yylen = 0; ++ ++ YYDPRINTF ((stderr, "Starting parse\n")); ++ ++ yystate = 0; ++ yyerrstatus = 0; ++ yynerrs = 0; ++ yychar = YYEMPTY; /* Cause a token to be read. */ ++ ++ /* Initialize stack pointers. ++ Waste one element of value and location stack ++ so that they stay on the same level as the state stack. ++ The wasted elements are never initialized. */ ++ ++ yyssp = yyss; ++ yyvsp = yyvs; ++ yylsp = yyls; ++#if YYLTYPE_IS_TRIVIAL ++ /* Initialize the default location before parsing starts. */ ++ yylloc.first_line = yylloc.last_line = 1; ++ yylloc.first_column = yylloc.last_column = 0; ++#endif ++ ++ goto yysetstate; ++ ++/*------------------------------------------------------------. ++| yynewstate -- Push a new state, which is found in yystate. | ++`------------------------------------------------------------*/ ++ yynewstate: ++ /* In all cases, when you get here, the value and location stacks ++ have just been pushed. So pushing a state here evens the stacks. */ ++ yyssp++; ++ ++ yysetstate: ++ *yyssp = yystate; ++ ++ if (yyss + yystacksize - 1 <= yyssp) ++ { ++ /* Get the current used size of the three stacks, in elements. */ ++ YYSIZE_T yysize = yyssp - yyss + 1; ++ ++#ifdef yyoverflow ++ { ++ /* Give user a chance to reallocate the stack. Use copies of ++ these so that the &'s don't force the real ones into ++ memory. */ ++ YYSTYPE *yyvs1 = yyvs; ++ yytype_int16 *yyss1 = yyss; ++ YYLTYPE *yyls1 = yyls; ++ ++ /* Each stack pointer address is followed by the size of the ++ data in use in that stack, in bytes. This used to be a ++ conditional around just the two extra args, but that might ++ be undefined if yyoverflow is a macro. */ ++ yyoverflow (YY_("memory exhausted"), ++ &yyss1, yysize * sizeof (*yyssp), ++ &yyvs1, yysize * sizeof (*yyvsp), ++ &yyls1, yysize * sizeof (*yylsp), ++ &yystacksize); ++ yyls = yyls1; ++ yyss = yyss1; ++ yyvs = yyvs1; ++ } ++#else /* no yyoverflow */ ++# ifndef YYSTACK_RELOCATE ++ goto yyexhaustedlab; ++# else ++ /* Extend the stack our own way. */ ++ if (YYMAXDEPTH <= yystacksize) ++ goto yyexhaustedlab; ++ yystacksize *= 2; ++ if (YYMAXDEPTH < yystacksize) ++ yystacksize = YYMAXDEPTH; ++ ++ { ++ yytype_int16 *yyss1 = yyss; ++ union yyalloc *yyptr = ++ (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize)); ++ if (! yyptr) ++ goto yyexhaustedlab; ++ YYSTACK_RELOCATE (yyss); ++ YYSTACK_RELOCATE (yyvs); ++ YYSTACK_RELOCATE (yyls); ++# undef YYSTACK_RELOCATE ++ if (yyss1 != yyssa) ++ YYSTACK_FREE (yyss1); ++ } ++# endif ++#endif /* no yyoverflow */ ++ ++ yyssp = yyss + yysize - 1; ++ yyvsp = yyvs + yysize - 1; ++ yylsp = yyls + yysize - 1; ++ ++ YYDPRINTF ((stderr, "Stack size increased to %lu\n", ++ (unsigned long int) yystacksize)); ++ ++ if (yyss + yystacksize - 1 <= yyssp) ++ YYABORT; ++ } ++ ++ YYDPRINTF ((stderr, "Entering state %d\n", yystate)); ++ ++ goto yybackup; ++ ++/*-----------. ++| yybackup. | ++`-----------*/ ++yybackup: ++ ++ /* Do appropriate processing given the current state. Read a ++ look-ahead token if we need one and don't already have one. */ ++ ++ /* First try to decide what to do without reference to look-ahead token. */ ++ yyn = yypact[yystate]; ++ if (yyn == YYPACT_NINF) ++ goto yydefault; ++ ++ /* Not known => get a look-ahead token if don't already have one. */ ++ ++ /* YYCHAR is either YYEMPTY or YYEOF or a valid look-ahead symbol. */ ++ if (yychar == YYEMPTY) ++ { ++ YYDPRINTF ((stderr, "Reading a token: ")); ++ yychar = YYLEX; ++ } ++ ++ if (yychar <= YYEOF) ++ { ++ yychar = yytoken = YYEOF; ++ YYDPRINTF ((stderr, "Now at end of input.\n")); ++ } ++ else ++ { ++ yytoken = YYTRANSLATE (yychar); ++ YY_SYMBOL_PRINT ("Next token is", yytoken, &yylval, &yylloc); ++ } ++ ++ /* If the proper action on seeing token YYTOKEN is to reduce or to ++ detect an error, take that action. */ ++ yyn += yytoken; ++ if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken) ++ goto yydefault; ++ yyn = yytable[yyn]; ++ if (yyn <= 0) ++ { ++ if (yyn == 0 || yyn == YYTABLE_NINF) ++ goto yyerrlab; ++ yyn = -yyn; ++ goto yyreduce; ++ } ++ ++ if (yyn == YYFINAL) ++ YYACCEPT; ++ ++ /* Count tokens shifted since error; after three, turn off error ++ status. */ ++ if (yyerrstatus) ++ yyerrstatus--; ++ ++ /* Shift the look-ahead token. */ ++ YY_SYMBOL_PRINT ("Shifting", yytoken, &yylval, &yylloc); ++ ++ /* Discard the shifted token unless it is eof. */ ++ if (yychar != YYEOF) ++ yychar = YYEMPTY; ++ ++ yystate = yyn; ++ *++yyvsp = yylval; ++ *++yylsp = yylloc; ++ goto yynewstate; ++ ++ ++/*-----------------------------------------------------------. ++| yydefault -- do the default action for the current state. | ++`-----------------------------------------------------------*/ ++yydefault: ++ yyn = yydefact[yystate]; ++ if (yyn == 0) ++ goto yyerrlab; ++ goto yyreduce; ++ ++ ++/*-----------------------------. ++| yyreduce -- Do a reduction. | ++`-----------------------------*/ ++yyreduce: ++ /* yyn is the number of a rule to reduce with. */ ++ yylen = yyr2[yyn]; ++ ++ /* If YYLEN is nonzero, implement the default value of the action: ++ `$$ = $1'. ++ ++ Otherwise, the following line sets YYVAL to garbage. ++ This behavior is undocumented and Bison ++ users should not rely upon it. Assigning to YYVAL ++ unconditionally makes the parser a bit smaller, and it avoids a ++ GCC warning that YYVAL may be used uninitialized. */ ++ yyval = yyvsp[1-yylen]; ++ ++ /* Default location. */ ++ YYLLOC_DEFAULT (yyloc, (yylsp - yylen), yylen); ++ YY_REDUCE_PRINT (yyn); ++ switch (yyn) ++ { ++ case 2: ++#line 86 "dtc-parser.y" ++ { ++ the_boot_info = build_boot_info((yyvsp[(3) - (4)].re), (yyvsp[(4) - (4)].node)); ++ ;} ++ break; ++ ++ case 3: ++#line 90 "dtc-parser.y" ++ { ++ the_boot_info = build_boot_info((yyvsp[(1) - (2)].re), (yyvsp[(2) - (2)].node)); ++ ;} ++ break; ++ ++ case 4: ++#line 97 "dtc-parser.y" ++ { ++ (yyval.re) = NULL; ++ ;} ++ break; ++ ++ case 5: ++#line 101 "dtc-parser.y" ++ { ++ (yyval.re) = chain_reserve_entry((yyvsp[(1) - (2)].re), (yyvsp[(2) - (2)].re)); ++ ;} ++ break; ++ ++ case 6: ++#line 108 "dtc-parser.y" ++ { ++ (yyval.re) = build_reserve_entry((yyvsp[(3) - (5)].addr), (yyvsp[(4) - (5)].addr), (yyvsp[(1) - (5)].labelref)); ++ ;} ++ break; ++ ++ case 7: ++#line 115 "dtc-parser.y" ++ { ++ (yyval.re) = NULL; ++ ;} ++ break; ++ ++ case 8: ++#line 119 "dtc-parser.y" ++ { ++ (yyval.re) = chain_reserve_entry((yyvsp[(1) - (2)].re), (yyvsp[(2) - (2)].re)); ++ ;} ++ break; ++ ++ case 9: ++#line 126 "dtc-parser.y" ++ { ++ (yyval.re) = (yyvsp[(1) - (1)].re); ++ ;} ++ break; ++ ++ case 10: ++#line 130 "dtc-parser.y" ++ { ++ (yyval.re) = build_reserve_entry((yyvsp[(3) - (6)].addr), (yyvsp[(5) - (6)].addr) - (yyvsp[(3) - (6)].addr) + 1, (yyvsp[(1) - (6)].labelref)); ++ ;} ++ break; ++ ++ case 11: ++#line 137 "dtc-parser.y" ++ { ++ (yyval.addr) = eval_literal((yyvsp[(1) - (1)].literal), 0, 64); ++ ;} ++ break; ++ ++ case 12: ++#line 141 "dtc-parser.y" ++ { ++ (yyval.addr) = eval_literal((yyvsp[(1) - (1)].literal), 16, 64); ++ ;} ++ break; ++ ++ case 13: ++#line 148 "dtc-parser.y" ++ { ++ (yyval.node) = name_node((yyvsp[(2) - (2)].node), "", NULL); ++ ;} ++ break; ++ ++ case 14: ++#line 155 "dtc-parser.y" ++ { ++ (yyval.node) = build_node((yyvsp[(2) - (5)].proplist), (yyvsp[(3) - (5)].nodelist)); ++ ;} ++ break; ++ ++ case 15: ++#line 162 "dtc-parser.y" ++ { ++ (yyval.proplist) = NULL; ++ ;} ++ break; ++ ++ case 16: ++#line 166 "dtc-parser.y" ++ { ++ (yyval.proplist) = chain_property((yyvsp[(2) - (2)].prop), (yyvsp[(1) - (2)].proplist)); ++ ;} ++ break; ++ ++ case 17: ++#line 173 "dtc-parser.y" ++ { ++ (yyval.prop) = build_property((yyvsp[(2) - (5)].propnodename), (yyvsp[(4) - (5)].data), (yyvsp[(1) - (5)].labelref)); ++ ;} ++ break; ++ ++ case 18: ++#line 177 "dtc-parser.y" ++ { ++ (yyval.prop) = build_property((yyvsp[(2) - (3)].propnodename), empty_data, (yyvsp[(1) - (3)].labelref)); ++ ;} ++ break; ++ ++ case 19: ++#line 184 "dtc-parser.y" ++ { ++ (yyval.data) = data_merge((yyvsp[(1) - (2)].data), (yyvsp[(2) - (2)].data)); ++ ;} ++ break; ++ ++ case 20: ++#line 188 "dtc-parser.y" ++ { ++ (yyval.data) = data_merge((yyvsp[(1) - (4)].data), (yyvsp[(3) - (4)].data)); ++ ;} ++ break; ++ ++ case 21: ++#line 192 "dtc-parser.y" ++ { ++ (yyval.data) = data_merge((yyvsp[(1) - (4)].data), (yyvsp[(3) - (4)].data)); ++ ;} ++ break; ++ ++ case 22: ++#line 196 "dtc-parser.y" ++ { ++ (yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), REF_PATH, (yyvsp[(2) - (2)].labelref)); ++ ;} ++ break; ++ ++ case 23: ++#line 200 "dtc-parser.y" ++ { ++ (yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), LABEL, (yyvsp[(2) - (2)].labelref)); ++ ;} ++ break; ++ ++ case 24: ++#line 207 "dtc-parser.y" ++ { ++ (yyval.data) = empty_data; ++ ;} ++ break; ++ ++ case 25: ++#line 211 "dtc-parser.y" ++ { ++ (yyval.data) = (yyvsp[(1) - (2)].data); ++ ;} ++ break; ++ ++ case 26: ++#line 215 "dtc-parser.y" ++ { ++ (yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), LABEL, (yyvsp[(2) - (2)].labelref)); ++ ;} ++ break; ++ ++ case 27: ++#line 222 "dtc-parser.y" ++ { ++ (yyval.data) = empty_data; ++ ;} ++ break; ++ ++ case 28: ++#line 226 "dtc-parser.y" ++ { ++ (yyval.data) = data_append_cell((yyvsp[(1) - (2)].data), (yyvsp[(2) - (2)].cell)); ++ ;} ++ break; ++ ++ case 29: ++#line 230 "dtc-parser.y" ++ { ++ (yyval.data) = data_append_cell(data_add_marker((yyvsp[(1) - (2)].data), REF_PHANDLE, ++ (yyvsp[(2) - (2)].labelref)), -1); ++ ;} ++ break; ++ ++ case 30: ++#line 235 "dtc-parser.y" ++ { ++ (yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), LABEL, (yyvsp[(2) - (2)].labelref)); ++ ;} ++ break; ++ ++ case 31: ++#line 242 "dtc-parser.y" ++ { ++ (yyval.cbase) = 16; ++ ;} ++ break; ++ ++ case 33: ++#line 250 "dtc-parser.y" ++ { ++ (yyval.cell) = eval_literal((yyvsp[(1) - (1)].literal), 0, 32); ++ ;} ++ break; ++ ++ case 34: ++#line 254 "dtc-parser.y" ++ { ++ (yyval.cell) = eval_literal((yyvsp[(2) - (2)].literal), (yyvsp[(1) - (2)].cbase), 32); ++ ;} ++ break; ++ ++ case 35: ++#line 261 "dtc-parser.y" ++ { ++ (yyval.data) = empty_data; ++ ;} ++ break; ++ ++ case 36: ++#line 265 "dtc-parser.y" ++ { ++ (yyval.data) = data_append_byte((yyvsp[(1) - (2)].data), (yyvsp[(2) - (2)].byte)); ++ ;} ++ break; ++ ++ case 37: ++#line 269 "dtc-parser.y" ++ { ++ (yyval.data) = data_add_marker((yyvsp[(1) - (2)].data), LABEL, (yyvsp[(2) - (2)].labelref)); ++ ;} ++ break; ++ ++ case 38: ++#line 276 "dtc-parser.y" ++ { ++ (yyval.nodelist) = NULL; ++ ;} ++ break; ++ ++ case 39: ++#line 280 "dtc-parser.y" ++ { ++ (yyval.nodelist) = chain_node((yyvsp[(1) - (2)].node), (yyvsp[(2) - (2)].nodelist)); ++ ;} ++ break; ++ ++ case 40: ++#line 284 "dtc-parser.y" ++ { ++ yyerror("syntax error: properties must precede subnodes\n"); ++ YYERROR; ++ ;} ++ break; ++ ++ case 41: ++#line 292 "dtc-parser.y" ++ { ++ (yyval.node) = name_node((yyvsp[(3) - (3)].node), (yyvsp[(2) - (3)].propnodename), (yyvsp[(1) - (3)].labelref)); ++ ;} ++ break; ++ ++ case 42: ++#line 299 "dtc-parser.y" ++ { ++ (yyval.labelref) = NULL; ++ ;} ++ break; ++ ++ case 43: ++#line 303 "dtc-parser.y" ++ { ++ (yyval.labelref) = (yyvsp[(1) - (1)].labelref); ++ ;} ++ break; ++ ++ ++/* Line 1267 of yacc.c. */ ++#line 1734 "dtc-parser.tab.c" ++ default: break; ++ } ++ YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc); ++ ++ YYPOPSTACK (yylen); ++ yylen = 0; ++ YY_STACK_PRINT (yyss, yyssp); ++ ++ *++yyvsp = yyval; ++ *++yylsp = yyloc; ++ ++ /* Now `shift' the result of the reduction. Determine what state ++ that goes to, based on the state we popped back to and the rule ++ number reduced by. */ ++ ++ yyn = yyr1[yyn]; ++ ++ yystate = yypgoto[yyn - YYNTOKENS] + *yyssp; ++ if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp) ++ yystate = yytable[yystate]; ++ else ++ yystate = yydefgoto[yyn - YYNTOKENS]; ++ ++ goto yynewstate; ++ ++ ++/*------------------------------------. ++| yyerrlab -- here on detecting error | ++`------------------------------------*/ ++yyerrlab: ++ /* If not already recovering from an error, report this error. */ ++ if (!yyerrstatus) ++ { ++ ++yynerrs; ++#if ! YYERROR_VERBOSE ++ yyerror (YY_("syntax error")); ++#else ++ { ++ YYSIZE_T yysize = yysyntax_error (0, yystate, yychar); ++ if (yymsg_alloc < yysize && yymsg_alloc < YYSTACK_ALLOC_MAXIMUM) ++ { ++ YYSIZE_T yyalloc = 2 * yysize; ++ if (! (yysize <= yyalloc && yyalloc <= YYSTACK_ALLOC_MAXIMUM)) ++ yyalloc = YYSTACK_ALLOC_MAXIMUM; ++ if (yymsg != yymsgbuf) ++ YYSTACK_FREE (yymsg); ++ yymsg = (char *) YYSTACK_ALLOC (yyalloc); ++ if (yymsg) ++ yymsg_alloc = yyalloc; ++ else ++ { ++ yymsg = yymsgbuf; ++ yymsg_alloc = sizeof yymsgbuf; ++ } ++ } ++ ++ if (0 < yysize && yysize <= yymsg_alloc) ++ { ++ (void) yysyntax_error (yymsg, yystate, yychar); ++ yyerror (yymsg); ++ } ++ else ++ { ++ yyerror (YY_("syntax error")); ++ if (yysize != 0) ++ goto yyexhaustedlab; ++ } ++ } ++#endif ++ } ++ ++ yyerror_range[0] = yylloc; ++ ++ if (yyerrstatus == 3) ++ { ++ /* If just tried and failed to reuse look-ahead token after an ++ error, discard it. */ ++ ++ if (yychar <= YYEOF) ++ { ++ /* Return failure if at end of input. */ ++ if (yychar == YYEOF) ++ YYABORT; ++ } ++ else ++ { ++ yydestruct ("Error: discarding", ++ yytoken, &yylval, &yylloc); ++ yychar = YYEMPTY; ++ } ++ } ++ ++ /* Else will try to reuse look-ahead token after shifting the error ++ token. */ ++ goto yyerrlab1; ++ ++ ++/*---------------------------------------------------. ++| yyerrorlab -- error raised explicitly by YYERROR. | ++`---------------------------------------------------*/ ++yyerrorlab: ++ ++ /* Pacify compilers like GCC when the user code never invokes ++ YYERROR and the label yyerrorlab therefore never appears in user ++ code. */ ++ if (/*CONSTCOND*/ 0) ++ goto yyerrorlab; ++ ++ yyerror_range[0] = yylsp[1-yylen]; ++ /* Do not reclaim the symbols of the rule which action triggered ++ this YYERROR. */ ++ YYPOPSTACK (yylen); ++ yylen = 0; ++ YY_STACK_PRINT (yyss, yyssp); ++ yystate = *yyssp; ++ goto yyerrlab1; ++ ++ ++/*-------------------------------------------------------------. ++| yyerrlab1 -- common code for both syntax error and YYERROR. | ++`-------------------------------------------------------------*/ ++yyerrlab1: ++ yyerrstatus = 3; /* Each real token shifted decrements this. */ ++ ++ for (;;) ++ { ++ yyn = yypact[yystate]; ++ if (yyn != YYPACT_NINF) ++ { ++ yyn += YYTERROR; ++ if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR) ++ { ++ yyn = yytable[yyn]; ++ if (0 < yyn) ++ break; ++ } ++ } ++ ++ /* Pop the current state because it cannot handle the error token. */ ++ if (yyssp == yyss) ++ YYABORT; ++ ++ yyerror_range[0] = *yylsp; ++ yydestruct ("Error: popping", ++ yystos[yystate], yyvsp, yylsp); ++ YYPOPSTACK (1); ++ yystate = *yyssp; ++ YY_STACK_PRINT (yyss, yyssp); ++ } ++ ++ if (yyn == YYFINAL) ++ YYACCEPT; ++ ++ *++yyvsp = yylval; ++ ++ yyerror_range[1] = yylloc; ++ /* Using YYLLOC is tempting, but would change the location of ++ the look-ahead. YYLOC is available though. */ ++ YYLLOC_DEFAULT (yyloc, (yyerror_range - 1), 2); ++ *++yylsp = yyloc; ++ ++ /* Shift the error token. */ ++ YY_SYMBOL_PRINT ("Shifting", yystos[yyn], yyvsp, yylsp); ++ ++ yystate = yyn; ++ goto yynewstate; ++ ++ ++/*-------------------------------------. ++| yyacceptlab -- YYACCEPT comes here. | ++`-------------------------------------*/ ++yyacceptlab: ++ yyresult = 0; ++ goto yyreturn; ++ ++/*-----------------------------------. ++| yyabortlab -- YYABORT comes here. | ++`-----------------------------------*/ ++yyabortlab: ++ yyresult = 1; ++ goto yyreturn; ++ ++#ifndef yyoverflow ++/*-------------------------------------------------. ++| yyexhaustedlab -- memory exhaustion comes here. | ++`-------------------------------------------------*/ ++yyexhaustedlab: ++ yyerror (YY_("memory exhausted")); ++ yyresult = 2; ++ /* Fall through. */ ++#endif ++ ++yyreturn: ++ if (yychar != YYEOF && yychar != YYEMPTY) ++ yydestruct ("Cleanup: discarding lookahead", ++ yytoken, &yylval, &yylloc); ++ /* Do not reclaim the symbols of the rule which action triggered ++ this YYABORT or YYACCEPT. */ ++ YYPOPSTACK (yylen); ++ YY_STACK_PRINT (yyss, yyssp); ++ while (yyssp != yyss) ++ { ++ yydestruct ("Cleanup: popping", ++ yystos[*yyssp], yyvsp, yylsp); ++ YYPOPSTACK (1); ++ } ++#ifndef yyoverflow ++ if (yyss != yyssa) ++ YYSTACK_FREE (yyss); ++#endif ++#if YYERROR_VERBOSE ++ if (yymsg != yymsgbuf) ++ YYSTACK_FREE (yymsg); ++#endif ++ /* Make sure YYID is used. */ ++ return YYID (yyresult); ++} ++ ++ ++#line 308 "dtc-parser.y" ++ ++ ++void yyerror (char const *s) ++{ ++ const char *fname = srcpos_filename_for_num(yylloc.filenum); ++ ++ if (strcmp(fname, "-") == 0) ++ fname = "stdin"; ++ ++ fprintf(stderr, "%s:%d %s\n", ++ fname, yylloc.first_line, s); ++} ++ ++unsigned long long eval_literal(const char *s, int base, int bits) ++{ ++ unsigned long long val; ++ char *e; ++ ++ errno = 0; ++ val = strtoull(s, &e, base); ++ if (*e) ++ yyerror("bad characters in literal"); ++ else if ((errno == ERANGE) ++ || ((bits < 64) && (val >= (1ULL << bits)))) ++ yyerror("literal out of range"); ++ else if (errno != 0) ++ yyerror("bad literal"); ++ return val; ++} ++ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/dtc-parser.tab.h_shipped powerpc.git/arch/powerpc/boot/dtc-src/dtc-parser.tab.h_shipped +--- linux-2.6.24/arch/powerpc/boot/dtc-src/dtc-parser.tab.h_shipped 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/dtc-parser.tab.h_shipped 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,111 @@ ++/* A Bison parser, made by GNU Bison 2.3. */ ++ ++/* Skeleton interface for Bison's Yacc-like parsers in C ++ ++ Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006 ++ Free Software Foundation, Inc. ++ ++ This program is free software; you can redistribute it and/or modify ++ it under the terms of the GNU General Public License as published by ++ the Free Software Foundation; either version 2, or (at your option) ++ any later version. ++ ++ This program is distributed in the hope that it will be useful, ++ but WITHOUT ANY WARRANTY; without even the implied warranty of ++ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ GNU General Public License for more details. ++ ++ You should have received a copy of the GNU General Public License ++ along with this program; if not, write to the Free Software ++ Foundation, Inc., 51 Franklin Street, Fifth Floor, ++ Boston, MA 02110-1301, USA. */ ++ ++/* As a special exception, you may create a larger work that contains ++ part or all of the Bison parser skeleton and distribute that work ++ under terms of your choice, so long as that work isn't itself a ++ parser generator using the skeleton or a modified version thereof ++ as a parser skeleton. Alternatively, if you modify or redistribute ++ the parser skeleton itself, you may (at your option) remove this ++ special exception, which will cause the skeleton and the resulting ++ Bison output files to be licensed under the GNU General Public ++ License without this special exception. ++ ++ This special exception was added by the Free Software Foundation in ++ version 2.2 of Bison. */ ++ ++/* Tokens. */ ++#ifndef YYTOKENTYPE ++# define YYTOKENTYPE ++ /* Put the tokens into the symbol table, so that GDB and other debuggers ++ know about them. */ ++ enum yytokentype { ++ DT_V1 = 258, ++ DT_MEMRESERVE = 259, ++ DT_PROPNODENAME = 260, ++ DT_LITERAL = 261, ++ DT_LEGACYLITERAL = 262, ++ DT_BASE = 263, ++ DT_BYTE = 264, ++ DT_STRING = 265, ++ DT_LABEL = 266, ++ DT_REF = 267 ++ }; ++#endif ++/* Tokens. */ ++#define DT_V1 258 ++#define DT_MEMRESERVE 259 ++#define DT_PROPNODENAME 260 ++#define DT_LITERAL 261 ++#define DT_LEGACYLITERAL 262 ++#define DT_BASE 263 ++#define DT_BYTE 264 ++#define DT_STRING 265 ++#define DT_LABEL 266 ++#define DT_REF 267 ++ ++ ++ ++ ++#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED ++typedef union YYSTYPE ++#line 34 "dtc-parser.y" ++{ ++ char *propnodename; ++ char *literal; ++ char *labelref; ++ unsigned int cbase; ++ u8 byte; ++ struct data data; ++ ++ u64 addr; ++ cell_t cell; ++ struct property *prop; ++ struct property *proplist; ++ struct node *node; ++ struct node *nodelist; ++ struct reserve_info *re; ++} ++/* Line 1489 of yacc.c. */ ++#line 90 "dtc-parser.tab.h" ++ YYSTYPE; ++# define yystype YYSTYPE /* obsolescent; will be withdrawn */ ++# define YYSTYPE_IS_DECLARED 1 ++# define YYSTYPE_IS_TRIVIAL 1 ++#endif ++ ++extern YYSTYPE yylval; ++ ++#if ! defined YYLTYPE && ! defined YYLTYPE_IS_DECLARED ++typedef struct YYLTYPE ++{ ++ int first_line; ++ int first_column; ++ int last_line; ++ int last_column; ++} YYLTYPE; ++# define yyltype YYLTYPE /* obsolescent; will be withdrawn */ ++# define YYLTYPE_IS_DECLARED 1 ++# define YYLTYPE_IS_TRIVIAL 1 ++#endif ++ ++extern YYLTYPE yylloc; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/dtc-parser.y powerpc.git/arch/powerpc/boot/dtc-src/dtc-parser.y +--- linux-2.6.24/arch/powerpc/boot/dtc-src/dtc-parser.y 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/dtc-parser.y 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,336 @@ ++/* ++ * (C) Copyright David Gibson <dwg@au1.ibm.com>, IBM Corporation. 2005. ++ * ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 ++ * USA ++ */ ++ ++%locations ++ ++%{ ++#include "dtc.h" ++#include "srcpos.h" ++ ++int yylex(void); ++unsigned long long eval_literal(const char *s, int base, int bits); ++ ++extern struct boot_info *the_boot_info; ++ ++%} ++ ++%union { ++ char *propnodename; ++ char *literal; ++ char *labelref; ++ unsigned int cbase; ++ u8 byte; ++ struct data data; ++ ++ u64 addr; ++ cell_t cell; ++ struct property *prop; ++ struct property *proplist; ++ struct node *node; ++ struct node *nodelist; ++ struct reserve_info *re; ++} ++ ++%token DT_V1 ++%token DT_MEMRESERVE ++%token <propnodename> DT_PROPNODENAME ++%token <literal> DT_LITERAL ++%token <literal> DT_LEGACYLITERAL ++%token <cbase> DT_BASE ++%token <byte> DT_BYTE ++%token <data> DT_STRING ++%token <labelref> DT_LABEL ++%token <labelref> DT_REF ++ ++%type <data> propdata ++%type <data> propdataprefix ++%type <re> memreserve ++%type <re> memreserves ++%type <re> v0_memreserve ++%type <re> v0_memreserves ++%type <addr> addr ++%type <data> celllist ++%type <cbase> cellbase ++%type <cell> cellval ++%type <data> bytestring ++%type <prop> propdef ++%type <proplist> proplist ++ ++%type <node> devicetree ++%type <node> nodedef ++%type <node> subnode ++%type <nodelist> subnodes ++%type <labelref> label ++ ++%% ++ ++sourcefile: ++ DT_V1 ';' memreserves devicetree ++ { ++ the_boot_info = build_boot_info($3, $4); ++ } ++ | v0_memreserves devicetree ++ { ++ the_boot_info = build_boot_info($1, $2); ++ } ++ ; ++ ++memreserves: ++ /* empty */ ++ { ++ $$ = NULL; ++ } ++ | memreserve memreserves ++ { ++ $$ = chain_reserve_entry($1, $2); ++ } ++ ; ++ ++memreserve: ++ label DT_MEMRESERVE addr addr ';' ++ { ++ $$ = build_reserve_entry($3, $4, $1); ++ } ++ ; ++ ++v0_memreserves: ++ /* empty */ ++ { ++ $$ = NULL; ++ } ++ | v0_memreserve v0_memreserves ++ { ++ $$ = chain_reserve_entry($1, $2); ++ }; ++ ; ++ ++v0_memreserve: ++ memreserve ++ { ++ $$ = $1; ++ } ++ | label DT_MEMRESERVE addr '-' addr ';' ++ { ++ $$ = build_reserve_entry($3, $5 - $3 + 1, $1); ++ } ++ ; ++ ++addr: ++ DT_LITERAL ++ { ++ $$ = eval_literal($1, 0, 64); ++ } ++ | DT_LEGACYLITERAL ++ { ++ $$ = eval_literal($1, 16, 64); ++ } ++ ; ++ ++devicetree: ++ '/' nodedef ++ { ++ $$ = name_node($2, "", NULL); ++ } ++ ; ++ ++nodedef: ++ '{' proplist subnodes '}' ';' ++ { ++ $$ = build_node($2, $3); ++ } ++ ; ++ ++proplist: ++ /* empty */ ++ { ++ $$ = NULL; ++ } ++ | proplist propdef ++ { ++ $$ = chain_property($2, $1); ++ } ++ ; ++ ++propdef: ++ label DT_PROPNODENAME '=' propdata ';' ++ { ++ $$ = build_property($2, $4, $1); ++ } ++ | label DT_PROPNODENAME ';' ++ { ++ $$ = build_property($2, empty_data, $1); ++ } ++ ; ++ ++propdata: ++ propdataprefix DT_STRING ++ { ++ $$ = data_merge($1, $2); ++ } ++ | propdataprefix '<' celllist '>' ++ { ++ $$ = data_merge($1, $3); ++ } ++ | propdataprefix '[' bytestring ']' ++ { ++ $$ = data_merge($1, $3); ++ } ++ | propdataprefix DT_REF ++ { ++ $$ = data_add_marker($1, REF_PATH, $2); ++ } ++ | propdata DT_LABEL ++ { ++ $$ = data_add_marker($1, LABEL, $2); ++ } ++ ; ++ ++propdataprefix: ++ /* empty */ ++ { ++ $$ = empty_data; ++ } ++ | propdata ',' ++ { ++ $$ = $1; ++ } ++ | propdataprefix DT_LABEL ++ { ++ $$ = data_add_marker($1, LABEL, $2); ++ } ++ ; ++ ++celllist: ++ /* empty */ ++ { ++ $$ = empty_data; ++ } ++ | celllist cellval ++ { ++ $$ = data_append_cell($1, $2); ++ } ++ | celllist DT_REF ++ { ++ $$ = data_append_cell(data_add_marker($1, REF_PHANDLE, ++ $2), -1); ++ } ++ | celllist DT_LABEL ++ { ++ $$ = data_add_marker($1, LABEL, $2); ++ } ++ ; ++ ++cellbase: ++ /* empty */ ++ { ++ $$ = 16; ++ } ++ | DT_BASE ++ ; ++ ++cellval: ++ DT_LITERAL ++ { ++ $$ = eval_literal($1, 0, 32); ++ } ++ | cellbase DT_LEGACYLITERAL ++ { ++ $$ = eval_literal($2, $1, 32); ++ } ++ ; ++ ++bytestring: ++ /* empty */ ++ { ++ $$ = empty_data; ++ } ++ | bytestring DT_BYTE ++ { ++ $$ = data_append_byte($1, $2); ++ } ++ | bytestring DT_LABEL ++ { ++ $$ = data_add_marker($1, LABEL, $2); ++ } ++ ; ++ ++subnodes: ++ /* empty */ ++ { ++ $$ = NULL; ++ } ++ | subnode subnodes ++ { ++ $$ = chain_node($1, $2); ++ } ++ | subnode propdef ++ { ++ yyerror("syntax error: properties must precede subnodes\n"); ++ YYERROR; ++ } ++ ; ++ ++subnode: ++ label DT_PROPNODENAME nodedef ++ { ++ $$ = name_node($3, $2, $1); ++ } ++ ; ++ ++label: ++ /* empty */ ++ { ++ $$ = NULL; ++ } ++ | DT_LABEL ++ { ++ $$ = $1; ++ } ++ ; ++ ++%% ++ ++void yyerror (char const *s) ++{ ++ const char *fname = srcpos_filename_for_num(yylloc.filenum); ++ ++ if (strcmp(fname, "-") == 0) ++ fname = "stdin"; ++ ++ fprintf(stderr, "%s:%d %s\n", ++ fname, yylloc.first_line, s); ++} ++ ++unsigned long long eval_literal(const char *s, int base, int bits) ++{ ++ unsigned long long val; ++ char *e; ++ ++ errno = 0; ++ val = strtoull(s, &e, base); ++ if (*e) ++ yyerror("bad characters in literal"); ++ else if ((errno == ERANGE) ++ || ((bits < 64) && (val >= (1ULL << bits)))) ++ yyerror("literal out of range"); ++ else if (errno != 0) ++ yyerror("bad literal"); ++ return val; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/dtc.c powerpc.git/arch/powerpc/boot/dtc-src/dtc.c +--- linux-2.6.24/arch/powerpc/boot/dtc-src/dtc.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/dtc.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,231 @@ ++/* ++ * (C) Copyright David Gibson <dwg@au1.ibm.com>, IBM Corporation. 2005. ++ * ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 ++ * USA ++ */ ++ ++#include "dtc.h" ++#include "srcpos.h" ++ ++#include "version_gen.h" ++ ++/* ++ * Command line options ++ */ ++int quiet; /* Level of quietness */ ++int reservenum; /* Number of memory reservation slots */ ++int minsize; /* Minimum blob size */ ++int padsize; /* Additional padding to blob */ ++ ++char *join_path(const char *path, const char *name) ++{ ++ int lenp = strlen(path); ++ int lenn = strlen(name); ++ int len; ++ int needslash = 1; ++ char *str; ++ ++ len = lenp + lenn + 2; ++ if ((lenp > 0) && (path[lenp-1] == '/')) { ++ needslash = 0; ++ len--; ++ } ++ ++ str = xmalloc(len); ++ memcpy(str, path, lenp); ++ if (needslash) { ++ str[lenp] = '/'; ++ lenp++; ++ } ++ memcpy(str+lenp, name, lenn+1); ++ return str; ++} ++ ++void fill_fullpaths(struct node *tree, const char *prefix) ++{ ++ struct node *child; ++ const char *unit; ++ ++ tree->fullpath = join_path(prefix, tree->name); ++ ++ unit = strchr(tree->name, '@'); ++ if (unit) ++ tree->basenamelen = unit - tree->name; ++ else ++ tree->basenamelen = strlen(tree->name); ++ ++ for_each_child(tree, child) ++ fill_fullpaths(child, tree->fullpath); ++} ++ ++static void __attribute__ ((noreturn)) usage(void) ++{ ++ fprintf(stderr, "Usage:\n"); ++ fprintf(stderr, "\tdtc [options] <input file>\n"); ++ fprintf(stderr, "\nOptions:\n"); ++ fprintf(stderr, "\t-h\n"); ++ fprintf(stderr, "\t\tThis help text\n"); ++ fprintf(stderr, "\t-q\n"); ++ fprintf(stderr, "\t\tQuiet: -q suppress warnings, -qq errors, -qqq all\n"); ++ fprintf(stderr, "\t-I <input format>\n"); ++ fprintf(stderr, "\t\tInput formats are:\n"); ++ fprintf(stderr, "\t\t\tdts - device tree source text\n"); ++ fprintf(stderr, "\t\t\tdtb - device tree blob\n"); ++ fprintf(stderr, "\t\t\tfs - /proc/device-tree style directory\n"); ++ fprintf(stderr, "\t-o <output file>\n"); ++ fprintf(stderr, "\t-O <output format>\n"); ++ fprintf(stderr, "\t\tOutput formats are:\n"); ++ fprintf(stderr, "\t\t\tdts - device tree source text\n"); ++ fprintf(stderr, "\t\t\tdtb - device tree blob\n"); ++ fprintf(stderr, "\t\t\tasm - assembler source\n"); ++ fprintf(stderr, "\t-V <output version>\n"); ++ fprintf(stderr, "\t\tBlob version to produce, defaults to %d (relevant for dtb\n\t\tand asm output only)\n", DEFAULT_FDT_VERSION); ++ fprintf(stderr, "\t-R <number>\n"); ++ fprintf(stderr, "\t\tMake space for <number> reserve map entries (relevant for \n\t\tdtb and asm output only)\n"); ++ fprintf(stderr, "\t-S <bytes>\n"); ++ fprintf(stderr, "\t\tMake the blob at least <bytes> long (extra space)\n"); ++ fprintf(stderr, "\t-p <bytes>\n"); ++ fprintf(stderr, "\t\tAdd padding to the blob of <bytes> long (extra space)\n"); ++ fprintf(stderr, "\t-b <number>\n"); ++ fprintf(stderr, "\t\tSet the physical boot cpu\n"); ++ fprintf(stderr, "\t-f\n"); ++ fprintf(stderr, "\t\tForce - try to produce output even if the input tree has errors\n"); ++ fprintf(stderr, "\t-v\n"); ++ fprintf(stderr, "\t\tPrint DTC version and exit\n"); ++ exit(2); ++} ++ ++int main(int argc, char *argv[]) ++{ ++ struct boot_info *bi; ++ const char *inform = "dts"; ++ const char *outform = "dts"; ++ const char *outname = "-"; ++ int force = 0, check = 0; ++ const char *arg; ++ int opt; ++ FILE *inf = NULL; ++ FILE *outf = NULL; ++ int outversion = DEFAULT_FDT_VERSION; ++ int boot_cpuid_phys = 0xfeedbeef; ++ ++ quiet = 0; ++ reservenum = 0; ++ minsize = 0; ++ padsize = 0; ++ ++ while ((opt = getopt(argc, argv, "hI:O:o:V:R:S:p:fcqb:v")) != EOF) { ++ switch (opt) { ++ case 'I': ++ inform = optarg; ++ break; ++ case 'O': ++ outform = optarg; ++ break; ++ case 'o': ++ outname = optarg; ++ break; ++ case 'V': ++ outversion = strtol(optarg, NULL, 0); ++ break; ++ case 'R': ++ reservenum = strtol(optarg, NULL, 0); ++ break; ++ case 'S': ++ minsize = strtol(optarg, NULL, 0); ++ break; ++ case 'p': ++ padsize = strtol(optarg, NULL, 0); ++ break; ++ case 'f': ++ force = 1; ++ break; ++ case 'c': ++ check = 1; ++ break; ++ case 'q': ++ quiet++; ++ break; ++ case 'b': ++ boot_cpuid_phys = strtol(optarg, NULL, 0); ++ break; ++ case 'v': ++ printf("Version: %s\n", DTC_VERSION); ++ exit(0); ++ case 'h': ++ default: ++ usage(); ++ } ++ } ++ ++ if (argc > (optind+1)) ++ usage(); ++ else if (argc < (optind+1)) ++ arg = "-"; ++ else ++ arg = argv[optind]; ++ ++ /* minsize and padsize are mutually exclusive */ ++ if ((minsize) && (padsize)) { ++ die("Can't set both -p and -S\n"); ++ } ++ ++ fprintf(stderr, "DTC: %s->%s on file \"%s\"\n", ++ inform, outform, arg); ++ ++ if (streq(inform, "dts")) { ++ bi = dt_from_source(arg); ++ } else if (streq(inform, "fs")) { ++ bi = dt_from_fs(arg); ++ } else if(streq(inform, "dtb")) { ++ inf = dtc_open_file(arg); ++ bi = dt_from_blob(inf); ++ } else { ++ die("Unknown input format \"%s\"\n", inform); ++ } ++ ++ if (inf && (inf != stdin)) ++ fclose(inf); ++ ++ if (! bi || ! bi->dt) ++ die("Couldn't read input tree\n"); ++ ++ process_checks(force, bi, check, outversion, boot_cpuid_phys); ++ ++ if (streq(outname, "-")) { ++ outf = stdout; ++ } else { ++ outf = fopen(outname, "w"); ++ if (! outf) ++ die("Couldn't open output file %s: %s\n", ++ outname, strerror(errno)); ++ } ++ ++ if (streq(outform, "dts")) { ++ dt_to_source(outf, bi); ++ } else if (streq(outform, "dtb")) { ++ dt_to_blob(outf, bi, outversion, boot_cpuid_phys); ++ } else if (streq(outform, "asm")) { ++ dt_to_asm(outf, bi, outversion, boot_cpuid_phys); ++ } else if (streq(outform, "null")) { ++ /* do nothing */ ++ } else { ++ die("Unknown output format \"%s\"\n", outform); ++ } ++ ++ exit(0); ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/dtc.h powerpc.git/arch/powerpc/boot/dtc-src/dtc.h +--- linux-2.6.24/arch/powerpc/boot/dtc-src/dtc.h 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/dtc.h 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,269 @@ ++#ifndef _DTC_H ++#define _DTC_H ++ ++/* ++ * (C) Copyright David Gibson <dwg@au1.ibm.com>, IBM Corporation. 2005. ++ * ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 ++ * USA ++ */ ++ ++#include <stdio.h> ++#include <string.h> ++#include <stdlib.h> ++#include <stdint.h> ++#include <stdarg.h> ++#include <assert.h> ++#include <ctype.h> ++#include <errno.h> ++#include <unistd.h> ++#include <netinet/in.h> ++#include <endian.h> ++#include <byteswap.h> ++ ++#include <fdt.h> ++ ++#define DEFAULT_FDT_VERSION 17 ++/* ++ * Command line options ++ */ ++extern int quiet; /* Level of quietness */ ++extern int reservenum; /* Number of memory reservation slots */ ++extern int minsize; /* Minimum blob size */ ++extern int padsize; /* Additional padding to blob */ ++ ++static inline void __attribute__((noreturn)) die(char * str, ...) ++{ ++ va_list ap; ++ ++ va_start(ap, str); ++ fprintf(stderr, "FATAL ERROR: "); ++ vfprintf(stderr, str, ap); ++ exit(1); ++} ++ ++static inline void *xmalloc(size_t len) ++{ ++ void *new = malloc(len); ++ ++ if (! new) ++ die("malloc() failed\n"); ++ ++ return new; ++} ++ ++static inline void *xrealloc(void *p, size_t len) ++{ ++ void *new = realloc(p, len); ++ ++ if (! new) ++ die("realloc() failed (len=%d)\n", len); ++ ++ return new; ++} ++ ++typedef uint8_t u8; ++typedef uint16_t u16; ++typedef uint32_t u32; ++typedef uint64_t u64; ++typedef u32 cell_t; ++ ++#define cpu_to_be16(x) htons(x) ++#define be16_to_cpu(x) ntohs(x) ++ ++#define cpu_to_be32(x) htonl(x) ++#define be32_to_cpu(x) ntohl(x) ++ ++#if __BYTE_ORDER == __BIG_ENDIAN ++#define cpu_to_be64(x) (x) ++#define be64_to_cpu(x) (x) ++#else ++#define cpu_to_be64(x) bswap_64(x) ++#define be64_to_cpu(x) bswap_64(x) ++#endif ++ ++#define streq(a, b) (strcmp((a), (b)) == 0) ++#define strneq(a, b, n) (strncmp((a), (b), (n)) == 0) ++ ++#define ALIGN(x, a) (((x) + (a) - 1) & ~((a) - 1)) ++#define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0])) ++ ++/* Data blobs */ ++enum markertype { ++ REF_PHANDLE, ++ REF_PATH, ++ LABEL, ++}; ++ ++struct marker { ++ enum markertype type; ++ int offset; ++ char *ref; ++ struct marker *next; ++}; ++ ++struct data { ++ int len; ++ char *val; ++ int asize; ++ struct marker *markers; ++}; ++ ++ ++#define empty_data ((struct data){ /* all .members = 0 or NULL */ }) ++ ++#define for_each_marker(m) \ ++ for (; (m); (m) = (m)->next) ++#define for_each_marker_of_type(m, t) \ ++ for_each_marker(m) \ ++ if ((m)->type == (t)) ++ ++void data_free(struct data d); ++ ++struct data data_grow_for(struct data d, int xlen); ++ ++struct data data_copy_mem(const char *mem, int len); ++struct data data_copy_escape_string(const char *s, int len); ++struct data data_copy_file(FILE *f, size_t len); ++ ++struct data data_append_data(struct data d, const void *p, int len); ++struct data data_insert_at_marker(struct data d, struct marker *m, ++ const void *p, int len); ++struct data data_merge(struct data d1, struct data d2); ++struct data data_append_cell(struct data d, cell_t word); ++struct data data_append_re(struct data d, const struct fdt_reserve_entry *re); ++struct data data_append_addr(struct data d, u64 addr); ++struct data data_append_byte(struct data d, uint8_t byte); ++struct data data_append_zeroes(struct data d, int len); ++struct data data_append_align(struct data d, int align); ++ ++struct data data_add_marker(struct data d, enum markertype type, char *ref); ++ ++int data_is_one_string(struct data d); ++ ++/* DT constraints */ ++ ++#define MAX_PROPNAME_LEN 31 ++#define MAX_NODENAME_LEN 31 ++ ++/* Live trees */ ++struct property { ++ char *name; ++ struct data val; ++ ++ struct property *next; ++ ++ char *label; ++}; ++ ++struct node { ++ char *name; ++ struct property *proplist; ++ struct node *children; ++ ++ struct node *parent; ++ struct node *next_sibling; ++ ++ char *fullpath; ++ int basenamelen; ++ ++ cell_t phandle; ++ int addr_cells, size_cells; ++ ++ char *label; ++}; ++ ++#define for_each_property(n, p) \ ++ for ((p) = (n)->proplist; (p); (p) = (p)->next) ++ ++#define for_each_child(n, c) \ ++ for ((c) = (n)->children; (c); (c) = (c)->next_sibling) ++ ++struct property *build_property(char *name, struct data val, char *label); ++struct property *chain_property(struct property *first, struct property *list); ++struct property *reverse_properties(struct property *first); ++ ++struct node *build_node(struct property *proplist, struct node *children); ++struct node *name_node(struct node *node, char *name, char *label); ++struct node *chain_node(struct node *first, struct node *list); ++ ++void add_property(struct node *node, struct property *prop); ++void add_child(struct node *parent, struct node *child); ++ ++const char *get_unitname(struct node *node); ++struct property *get_property(struct node *node, const char *propname); ++cell_t propval_cell(struct property *prop); ++struct node *get_subnode(struct node *node, const char *nodename); ++struct node *get_node_by_path(struct node *tree, const char *path); ++struct node *get_node_by_label(struct node *tree, const char *label); ++struct node *get_node_by_phandle(struct node *tree, cell_t phandle); ++struct node *get_node_by_ref(struct node *tree, const char *ref); ++cell_t get_node_phandle(struct node *root, struct node *node); ++ ++/* Boot info (tree plus memreserve information */ ++ ++struct reserve_info { ++ struct fdt_reserve_entry re; ++ ++ struct reserve_info *next; ++ ++ char *label; ++}; ++ ++struct reserve_info *build_reserve_entry(u64 start, u64 len, char *label); ++struct reserve_info *chain_reserve_entry(struct reserve_info *first, ++ struct reserve_info *list); ++struct reserve_info *add_reserve_entry(struct reserve_info *list, ++ struct reserve_info *new); ++ ++ ++struct boot_info { ++ struct reserve_info *reservelist; ++ struct node *dt; /* the device tree */ ++}; ++ ++struct boot_info *build_boot_info(struct reserve_info *reservelist, ++ struct node *tree); ++ ++/* Checks */ ++ ++void process_checks(int force, struct boot_info *bi, ++ int checkflag, int outversion, int boot_cpuid_phys); ++ ++/* Flattened trees */ ++ ++void dt_to_blob(FILE *f, struct boot_info *bi, int version, ++ int boot_cpuid_phys); ++void dt_to_asm(FILE *f, struct boot_info *bi, int version, ++ int boot_cpuid_phys); ++ ++struct boot_info *dt_from_blob(FILE *f); ++ ++/* Tree source */ ++ ++void dt_to_source(FILE *f, struct boot_info *bi); ++struct boot_info *dt_from_source(const char *f); ++ ++/* FS trees */ ++ ++struct boot_info *dt_from_fs(const char *dirname); ++ ++/* misc */ ++ ++char *join_path(const char *path, const char *name); ++void fill_fullpaths(struct node *tree, const char *prefix); ++ ++#endif /* _DTC_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/flattree.c powerpc.git/arch/powerpc/boot/dtc-src/flattree.c +--- linux-2.6.24/arch/powerpc/boot/dtc-src/flattree.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/flattree.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,968 @@ ++/* ++ * (C) Copyright David Gibson <dwg@au1.ibm.com>, IBM Corporation. 2005. ++ * ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 ++ * USA ++ */ ++ ++#include "dtc.h" ++ ++#define FTF_FULLPATH 0x1 ++#define FTF_VARALIGN 0x2 ++#define FTF_NAMEPROPS 0x4 ++#define FTF_BOOTCPUID 0x8 ++#define FTF_STRTABSIZE 0x10 ++#define FTF_STRUCTSIZE 0x20 ++#define FTF_NOPS 0x40 ++ ++static struct version_info { ++ int version; ++ int last_comp_version; ++ int hdr_size; ++ int flags; ++} version_table[] = { ++ {1, 1, FDT_V1_SIZE, ++ FTF_FULLPATH|FTF_VARALIGN|FTF_NAMEPROPS}, ++ {2, 1, FDT_V2_SIZE, ++ FTF_FULLPATH|FTF_VARALIGN|FTF_NAMEPROPS|FTF_BOOTCPUID}, ++ {3, 1, FDT_V3_SIZE, ++ FTF_FULLPATH|FTF_VARALIGN|FTF_NAMEPROPS|FTF_BOOTCPUID|FTF_STRTABSIZE}, ++ {16, 16, FDT_V3_SIZE, ++ FTF_BOOTCPUID|FTF_STRTABSIZE|FTF_NOPS}, ++ {17, 16, FDT_V17_SIZE, ++ FTF_BOOTCPUID|FTF_STRTABSIZE|FTF_STRUCTSIZE|FTF_NOPS}, ++}; ++ ++struct emitter { ++ void (*cell)(void *, cell_t); ++ void (*string)(void *, char *, int); ++ void (*align)(void *, int); ++ void (*data)(void *, struct data); ++ void (*beginnode)(void *, const char *); ++ void (*endnode)(void *, const char *); ++ void (*property)(void *, const char *); ++}; ++ ++static void bin_emit_cell(void *e, cell_t val) ++{ ++ struct data *dtbuf = e; ++ ++ *dtbuf = data_append_cell(*dtbuf, val); ++} ++ ++static void bin_emit_string(void *e, char *str, int len) ++{ ++ struct data *dtbuf = e; ++ ++ if (len == 0) ++ len = strlen(str); ++ ++ *dtbuf = data_append_data(*dtbuf, str, len); ++ *dtbuf = data_append_byte(*dtbuf, '\0'); ++} ++ ++static void bin_emit_align(void *e, int a) ++{ ++ struct data *dtbuf = e; ++ ++ *dtbuf = data_append_align(*dtbuf, a); ++} ++ ++static void bin_emit_data(void *e, struct data d) ++{ ++ struct data *dtbuf = e; ++ ++ *dtbuf = data_append_data(*dtbuf, d.val, d.len); ++} ++ ++static void bin_emit_beginnode(void *e, const char *label) ++{ ++ bin_emit_cell(e, FDT_BEGIN_NODE); ++} ++ ++static void bin_emit_endnode(void *e, const char *label) ++{ ++ bin_emit_cell(e, FDT_END_NODE); ++} ++ ++static void bin_emit_property(void *e, const char *label) ++{ ++ bin_emit_cell(e, FDT_PROP); ++} ++ ++static struct emitter bin_emitter = { ++ .cell = bin_emit_cell, ++ .string = bin_emit_string, ++ .align = bin_emit_align, ++ .data = bin_emit_data, ++ .beginnode = bin_emit_beginnode, ++ .endnode = bin_emit_endnode, ++ .property = bin_emit_property, ++}; ++ ++static void emit_label(FILE *f, const char *prefix, const char *label) ++{ ++ fprintf(f, "\t.globl\t%s_%s\n", prefix, label); ++ fprintf(f, "%s_%s:\n", prefix, label); ++ fprintf(f, "_%s_%s:\n", prefix, label); ++} ++ ++static void emit_offset_label(FILE *f, const char *label, int offset) ++{ ++ fprintf(f, "\t.globl\t%s\n", label); ++ fprintf(f, "%s\t= . + %d\n", label, offset); ++} ++ ++static void asm_emit_cell(void *e, cell_t val) ++{ ++ FILE *f = e; ++ ++ fprintf(f, "\t.long\t0x%x\n", val); ++} ++ ++static void asm_emit_string(void *e, char *str, int len) ++{ ++ FILE *f = e; ++ char c = 0; ++ ++ if (len != 0) { ++ /* XXX: ewww */ ++ c = str[len]; ++ str[len] = '\0'; ++ } ++ ++ fprintf(f, "\t.string\t\"%s\"\n", str); ++ ++ if (len != 0) { ++ str[len] = c; ++ } ++} ++ ++static void asm_emit_align(void *e, int a) ++{ ++ FILE *f = e; ++ ++ fprintf(f, "\t.balign\t%d\n", a); ++} ++ ++static void asm_emit_data(void *e, struct data d) ++{ ++ FILE *f = e; ++ int off = 0; ++ struct marker *m; ++ ++ m = d.markers; ++ while (m) { ++ if (m->type == LABEL) ++ emit_offset_label(f, m->ref, m->offset); ++ m = m->next; ++ } ++ ++ while ((d.len - off) >= sizeof(u32)) { ++ fprintf(f, "\t.long\t0x%x\n", ++ be32_to_cpu(*((u32 *)(d.val+off)))); ++ off += sizeof(u32); ++ } ++ ++ if ((d.len - off) >= sizeof(u16)) { ++ fprintf(f, "\t.short\t0x%hx\n", ++ be16_to_cpu(*((u16 *)(d.val+off)))); ++ off += sizeof(u16); ++ } ++ ++ if ((d.len - off) >= 1) { ++ fprintf(f, "\t.byte\t0x%hhx\n", d.val[off]); ++ off += 1; ++ } ++ ++ assert(off == d.len); ++} ++ ++static void asm_emit_beginnode(void *e, const char *label) ++{ ++ FILE *f = e; ++ ++ if (label) { ++ fprintf(f, "\t.globl\t%s\n", label); ++ fprintf(f, "%s:\n", label); ++ } ++ fprintf(f, "\t.long\tFDT_BEGIN_NODE\n"); ++} ++ ++static void asm_emit_endnode(void *e, const char *label) ++{ ++ FILE *f = e; ++ ++ fprintf(f, "\t.long\tFDT_END_NODE\n"); ++ if (label) { ++ fprintf(f, "\t.globl\t%s_end\n", label); ++ fprintf(f, "%s_end:\n", label); ++ } ++} ++ ++static void asm_emit_property(void *e, const char *label) ++{ ++ FILE *f = e; ++ ++ if (label) { ++ fprintf(f, "\t.globl\t%s\n", label); ++ fprintf(f, "%s:\n", label); ++ } ++ fprintf(f, "\t.long\tFDT_PROP\n"); ++} ++ ++static struct emitter asm_emitter = { ++ .cell = asm_emit_cell, ++ .string = asm_emit_string, ++ .align = asm_emit_align, ++ .data = asm_emit_data, ++ .beginnode = asm_emit_beginnode, ++ .endnode = asm_emit_endnode, ++ .property = asm_emit_property, ++}; ++ ++static int stringtable_insert(struct data *d, const char *str) ++{ ++ int i; ++ ++ /* FIXME: do this more efficiently? */ ++ ++ for (i = 0; i < d->len; i++) { ++ if (streq(str, d->val + i)) ++ return i; ++ } ++ ++ *d = data_append_data(*d, str, strlen(str)+1); ++ return i; ++} ++ ++static void flatten_tree(struct node *tree, struct emitter *emit, ++ void *etarget, struct data *strbuf, ++ struct version_info *vi) ++{ ++ struct property *prop; ++ struct node *child; ++ int seen_name_prop = 0; ++ ++ emit->beginnode(etarget, tree->label); ++ ++ if (vi->flags & FTF_FULLPATH) ++ emit->string(etarget, tree->fullpath, 0); ++ else ++ emit->string(etarget, tree->name, 0); ++ ++ emit->align(etarget, sizeof(cell_t)); ++ ++ for_each_property(tree, prop) { ++ int nameoff; ++ ++ if (streq(prop->name, "name")) ++ seen_name_prop = 1; ++ ++ nameoff = stringtable_insert(strbuf, prop->name); ++ ++ emit->property(etarget, prop->label); ++ emit->cell(etarget, prop->val.len); ++ emit->cell(etarget, nameoff); ++ ++ if ((vi->flags & FTF_VARALIGN) && (prop->val.len >= 8)) ++ emit->align(etarget, 8); ++ ++ emit->data(etarget, prop->val); ++ emit->align(etarget, sizeof(cell_t)); ++ } ++ ++ if ((vi->flags & FTF_NAMEPROPS) && !seen_name_prop) { ++ emit->property(etarget, NULL); ++ emit->cell(etarget, tree->basenamelen+1); ++ emit->cell(etarget, stringtable_insert(strbuf, "name")); ++ ++ if ((vi->flags & FTF_VARALIGN) && ((tree->basenamelen+1) >= 8)) ++ emit->align(etarget, 8); ++ ++ emit->string(etarget, tree->name, tree->basenamelen); ++ emit->align(etarget, sizeof(cell_t)); ++ } ++ ++ for_each_child(tree, child) { ++ flatten_tree(child, emit, etarget, strbuf, vi); ++ } ++ ++ emit->endnode(etarget, tree->label); ++} ++ ++static struct data flatten_reserve_list(struct reserve_info *reservelist, ++ struct version_info *vi) ++{ ++ struct reserve_info *re; ++ struct data d = empty_data; ++ static struct fdt_reserve_entry null_re = {0,0}; ++ int j; ++ ++ for (re = reservelist; re; re = re->next) { ++ d = data_append_re(d, &re->re); ++ } ++ /* ++ * Add additional reserved slots if the user asked for them. ++ */ ++ for (j = 0; j < reservenum; j++) { ++ d = data_append_re(d, &null_re); ++ } ++ ++ return d; ++} ++ ++static void make_fdt_header(struct fdt_header *fdt, ++ struct version_info *vi, ++ int reservesize, int dtsize, int strsize, ++ int boot_cpuid_phys) ++{ ++ int reserve_off; ++ ++ reservesize += sizeof(struct fdt_reserve_entry); ++ ++ memset(fdt, 0xff, sizeof(*fdt)); ++ ++ fdt->magic = cpu_to_be32(FDT_MAGIC); ++ fdt->version = cpu_to_be32(vi->version); ++ fdt->last_comp_version = cpu_to_be32(vi->last_comp_version); ++ ++ /* Reserve map should be doubleword aligned */ ++ reserve_off = ALIGN(vi->hdr_size, 8); ++ ++ fdt->off_mem_rsvmap = cpu_to_be32(reserve_off); ++ fdt->off_dt_struct = cpu_to_be32(reserve_off + reservesize); ++ fdt->off_dt_strings = cpu_to_be32(reserve_off + reservesize ++ + dtsize); ++ fdt->totalsize = cpu_to_be32(reserve_off + reservesize + dtsize + strsize); ++ ++ if (vi->flags & FTF_BOOTCPUID) ++ fdt->boot_cpuid_phys = cpu_to_be32(boot_cpuid_phys); ++ if (vi->flags & FTF_STRTABSIZE) ++ fdt->size_dt_strings = cpu_to_be32(strsize); ++ if (vi->flags & FTF_STRUCTSIZE) ++ fdt->size_dt_struct = cpu_to_be32(dtsize); ++} ++ ++void dt_to_blob(FILE *f, struct boot_info *bi, int version, ++ int boot_cpuid_phys) ++{ ++ struct version_info *vi = NULL; ++ int i; ++ struct data blob = empty_data; ++ struct data reservebuf = empty_data; ++ struct data dtbuf = empty_data; ++ struct data strbuf = empty_data; ++ struct fdt_header fdt; ++ int padlen = 0; ++ ++ for (i = 0; i < ARRAY_SIZE(version_table); i++) { ++ if (version_table[i].version == version) ++ vi = &version_table[i]; ++ } ++ if (!vi) ++ die("Unknown device tree blob version %d\n", version); ++ ++ flatten_tree(bi->dt, &bin_emitter, &dtbuf, &strbuf, vi); ++ bin_emit_cell(&dtbuf, FDT_END); ++ ++ reservebuf = flatten_reserve_list(bi->reservelist, vi); ++ ++ /* Make header */ ++ make_fdt_header(&fdt, vi, reservebuf.len, dtbuf.len, strbuf.len, ++ boot_cpuid_phys); ++ ++ /* ++ * If the user asked for more space than is used, adjust the totalsize. ++ */ ++ if (minsize > 0) { ++ padlen = minsize - be32_to_cpu(fdt.totalsize); ++ if ((padlen < 0) && (quiet < 1)) ++ fprintf(stderr, ++ "Warning: blob size %d >= minimum size %d\n", ++ be32_to_cpu(fdt.totalsize), minsize); ++ } ++ ++ if (padsize > 0) ++ padlen = padsize; ++ ++ if (padlen > 0) { ++ int tsize = be32_to_cpu(fdt.totalsize); ++ tsize += padlen; ++ fdt.totalsize = cpu_to_be32(tsize); ++ } ++ ++ /* ++ * Assemble the blob: start with the header, add with alignment ++ * the reserve buffer, add the reserve map terminating zeroes, ++ * the device tree itself, and finally the strings. ++ */ ++ blob = data_append_data(blob, &fdt, sizeof(fdt)); ++ blob = data_append_align(blob, 8); ++ blob = data_merge(blob, reservebuf); ++ blob = data_append_zeroes(blob, sizeof(struct fdt_reserve_entry)); ++ blob = data_merge(blob, dtbuf); ++ blob = data_merge(blob, strbuf); ++ ++ /* ++ * If the user asked for more space than is used, pad out the blob. ++ */ ++ if (padlen > 0) ++ blob = data_append_zeroes(blob, padlen); ++ ++ fwrite(blob.val, blob.len, 1, f); ++ ++ if (ferror(f)) ++ die("Error writing device tree blob: %s\n", strerror(errno)); ++ ++ /* ++ * data_merge() frees the right-hand element so only the blob ++ * remains to be freed. ++ */ ++ data_free(blob); ++} ++ ++static void dump_stringtable_asm(FILE *f, struct data strbuf) ++{ ++ const char *p; ++ int len; ++ ++ p = strbuf.val; ++ ++ while (p < (strbuf.val + strbuf.len)) { ++ len = strlen(p); ++ fprintf(f, "\t.string \"%s\"\n", p); ++ p += len+1; ++ } ++} ++ ++void dt_to_asm(FILE *f, struct boot_info *bi, int version, int boot_cpuid_phys) ++{ ++ struct version_info *vi = NULL; ++ int i; ++ struct data strbuf = empty_data; ++ struct reserve_info *re; ++ const char *symprefix = "dt"; ++ ++ for (i = 0; i < ARRAY_SIZE(version_table); i++) { ++ if (version_table[i].version == version) ++ vi = &version_table[i]; ++ } ++ if (!vi) ++ die("Unknown device tree blob version %d\n", version); ++ ++ fprintf(f, "/* autogenerated by dtc, do not edit */\n\n"); ++ fprintf(f, "#define FDT_MAGIC 0x%x\n", FDT_MAGIC); ++ fprintf(f, "#define FDT_BEGIN_NODE 0x%x\n", FDT_BEGIN_NODE); ++ fprintf(f, "#define FDT_END_NODE 0x%x\n", FDT_END_NODE); ++ fprintf(f, "#define FDT_PROP 0x%x\n", FDT_PROP); ++ fprintf(f, "#define FDT_END 0x%x\n", FDT_END); ++ fprintf(f, "\n"); ++ ++ emit_label(f, symprefix, "blob_start"); ++ emit_label(f, symprefix, "header"); ++ fprintf(f, "\t.long\tFDT_MAGIC\t\t\t\t/* magic */\n"); ++ fprintf(f, "\t.long\t_%s_blob_abs_end - _%s_blob_start\t/* totalsize */\n", ++ symprefix, symprefix); ++ fprintf(f, "\t.long\t_%s_struct_start - _%s_blob_start\t/* off_dt_struct */\n", ++ symprefix, symprefix); ++ fprintf(f, "\t.long\t_%s_strings_start - _%s_blob_start\t/* off_dt_strings */\n", ++ symprefix, symprefix); ++ fprintf(f, "\t.long\t_%s_reserve_map - _%s_blob_start\t/* off_dt_strings */\n", ++ symprefix, symprefix); ++ fprintf(f, "\t.long\t%d\t\t\t\t\t/* version */\n", vi->version); ++ fprintf(f, "\t.long\t%d\t\t\t\t\t/* last_comp_version */\n", ++ vi->last_comp_version); ++ ++ if (vi->flags & FTF_BOOTCPUID) ++ fprintf(f, "\t.long\t%i\t\t\t\t\t/* boot_cpuid_phys */\n", ++ boot_cpuid_phys); ++ ++ if (vi->flags & FTF_STRTABSIZE) ++ fprintf(f, "\t.long\t_%s_strings_end - _%s_strings_start\t/* size_dt_strings */\n", ++ symprefix, symprefix); ++ ++ if (vi->flags & FTF_STRUCTSIZE) ++ fprintf(f, "\t.long\t_%s_struct_end - _%s_struct_start\t/* size_dt_struct */\n", ++ symprefix, symprefix); ++ ++ /* ++ * Reserve map entries. ++ * Align the reserve map to a doubleword boundary. ++ * Each entry is an (address, size) pair of u64 values. ++ * Always supply a zero-sized temination entry. ++ */ ++ asm_emit_align(f, 8); ++ emit_label(f, symprefix, "reserve_map"); ++ ++ fprintf(f, "/* Memory reserve map from source file */\n"); ++ ++ /* ++ * Use .long on high and low halfs of u64s to avoid .quad ++ * as it appears .quad isn't available in some assemblers. ++ */ ++ for (re = bi->reservelist; re; re = re->next) { ++ if (re->label) { ++ fprintf(f, "\t.globl\t%s\n", re->label); ++ fprintf(f, "%s:\n", re->label); ++ } ++ fprintf(f, "\t.long\t0x%08x, 0x%08x\n", ++ (unsigned int)(re->re.address >> 32), ++ (unsigned int)(re->re.address & 0xffffffff)); ++ fprintf(f, "\t.long\t0x%08x, 0x%08x\n", ++ (unsigned int)(re->re.size >> 32), ++ (unsigned int)(re->re.size & 0xffffffff)); ++ } ++ for (i = 0; i < reservenum; i++) { ++ fprintf(f, "\t.long\t0, 0\n\t.long\t0, 0\n"); ++ } ++ ++ fprintf(f, "\t.long\t0, 0\n\t.long\t0, 0\n"); ++ ++ emit_label(f, symprefix, "struct_start"); ++ flatten_tree(bi->dt, &asm_emitter, f, &strbuf, vi); ++ fprintf(f, "\t.long\tFDT_END\n"); ++ emit_label(f, symprefix, "struct_end"); ++ ++ emit_label(f, symprefix, "strings_start"); ++ dump_stringtable_asm(f, strbuf); ++ emit_label(f, symprefix, "strings_end"); ++ ++ emit_label(f, symprefix, "blob_end"); ++ ++ /* ++ * If the user asked for more space than is used, pad it out. ++ */ ++ if (minsize > 0) { ++ fprintf(f, "\t.space\t%d - (_%s_blob_end - _%s_blob_start), 0\n", ++ minsize, symprefix, symprefix); ++ } ++ if (padsize > 0) { ++ fprintf(f, "\t.space\t%d, 0\n", padsize); ++ } ++ emit_label(f, symprefix, "blob_abs_end"); ++ ++ data_free(strbuf); ++} ++ ++struct inbuf { ++ char *base, *limit, *ptr; ++}; ++ ++static void inbuf_init(struct inbuf *inb, void *base, void *limit) ++{ ++ inb->base = base; ++ inb->limit = limit; ++ inb->ptr = inb->base; ++} ++ ++static void flat_read_chunk(struct inbuf *inb, void *p, int len) ++{ ++ if ((inb->ptr + len) > inb->limit) ++ die("Premature end of data parsing flat device tree\n"); ++ ++ memcpy(p, inb->ptr, len); ++ ++ inb->ptr += len; ++} ++ ++static u32 flat_read_word(struct inbuf *inb) ++{ ++ u32 val; ++ ++ assert(((inb->ptr - inb->base) % sizeof(val)) == 0); ++ ++ flat_read_chunk(inb, &val, sizeof(val)); ++ ++ return be32_to_cpu(val); ++} ++ ++static void flat_realign(struct inbuf *inb, int align) ++{ ++ int off = inb->ptr - inb->base; ++ ++ inb->ptr = inb->base + ALIGN(off, align); ++ if (inb->ptr > inb->limit) ++ die("Premature end of data parsing flat device tree\n"); ++} ++ ++static char *flat_read_string(struct inbuf *inb) ++{ ++ int len = 0; ++ const char *p = inb->ptr; ++ char *str; ++ ++ do { ++ if (p >= inb->limit) ++ die("Premature end of data parsing flat device tree\n"); ++ len++; ++ } while ((*p++) != '\0'); ++ ++ str = strdup(inb->ptr); ++ ++ inb->ptr += len; ++ ++ flat_realign(inb, sizeof(u32)); ++ ++ return str; ++} ++ ++static struct data flat_read_data(struct inbuf *inb, int len) ++{ ++ struct data d = empty_data; ++ ++ if (len == 0) ++ return empty_data; ++ ++ d = data_grow_for(d, len); ++ d.len = len; ++ ++ flat_read_chunk(inb, d.val, len); ++ ++ flat_realign(inb, sizeof(u32)); ++ ++ return d; ++} ++ ++static char *flat_read_stringtable(struct inbuf *inb, int offset) ++{ ++ const char *p; ++ ++ p = inb->base + offset; ++ while (1) { ++ if (p >= inb->limit || p < inb->base) ++ die("String offset %d overruns string table\n", ++ offset); ++ ++ if (*p == '\0') ++ break; ++ ++ p++; ++ } ++ ++ return strdup(inb->base + offset); ++} ++ ++static struct property *flat_read_property(struct inbuf *dtbuf, ++ struct inbuf *strbuf, int flags) ++{ ++ u32 proplen, stroff; ++ char *name; ++ struct data val; ++ ++ proplen = flat_read_word(dtbuf); ++ stroff = flat_read_word(dtbuf); ++ ++ name = flat_read_stringtable(strbuf, stroff); ++ ++ if ((flags & FTF_VARALIGN) && (proplen >= 8)) ++ flat_realign(dtbuf, 8); ++ ++ val = flat_read_data(dtbuf, proplen); ++ ++ return build_property(name, val, NULL); ++} ++ ++ ++static struct reserve_info *flat_read_mem_reserve(struct inbuf *inb) ++{ ++ struct reserve_info *reservelist = NULL; ++ struct reserve_info *new; ++ const char *p; ++ struct fdt_reserve_entry re; ++ ++ /* ++ * Each entry is a pair of u64 (addr, size) values for 4 cell_t's. ++ * List terminates at an entry with size equal to zero. ++ * ++ * First pass, count entries. ++ */ ++ p = inb->ptr; ++ while (1) { ++ flat_read_chunk(inb, &re, sizeof(re)); ++ re.address = be64_to_cpu(re.address); ++ re.size = be64_to_cpu(re.size); ++ if (re.size == 0) ++ break; ++ ++ new = build_reserve_entry(re.address, re.size, NULL); ++ reservelist = add_reserve_entry(reservelist, new); ++ } ++ ++ return reservelist; ++} ++ ++ ++static char *nodename_from_path(const char *ppath, const char *cpath) ++{ ++ const char *lslash; ++ int plen; ++ ++ lslash = strrchr(cpath, '/'); ++ if (! lslash) ++ return NULL; ++ ++ plen = lslash - cpath; ++ ++ if (streq(cpath, "/") && streq(ppath, "")) ++ return ""; ++ ++ if ((plen == 0) && streq(ppath, "/")) ++ return strdup(lslash+1); ++ ++ if (! strneq(ppath, cpath, plen)) ++ return NULL; ++ ++ return strdup(lslash+1); ++} ++ ++static const char PROPCHAR[] = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789,._+*#?-"; ++static const char UNITCHAR[] = "0123456789abcdef,"; ++ ++static int check_node_name(const char *name) ++{ ++ const char *atpos; ++ int basenamelen; ++ ++ atpos = strrchr(name, '@'); ++ ++ if (atpos) ++ basenamelen = atpos - name; ++ else ++ basenamelen = strlen(name); ++ ++ if (strspn(name, PROPCHAR) < basenamelen) ++ return -1; ++ ++ if (atpos ++ && ((basenamelen + 1 + strspn(atpos+1, UNITCHAR)) < strlen(name))) ++ return -1; ++ ++ return basenamelen; ++} ++ ++static struct node *unflatten_tree(struct inbuf *dtbuf, ++ struct inbuf *strbuf, ++ const char *parent_path, int flags) ++{ ++ struct node *node; ++ u32 val; ++ ++ node = build_node(NULL, NULL); ++ ++ if (flags & FTF_FULLPATH) { ++ node->fullpath = flat_read_string(dtbuf); ++ node->name = nodename_from_path(parent_path, node->fullpath); ++ ++ if (! node->name) ++ die("Path \"%s\" is not valid as a child of \"%s\"\n", ++ node->fullpath, parent_path); ++ } else { ++ node->name = flat_read_string(dtbuf); ++ node->fullpath = join_path(parent_path, node->name); ++ } ++ ++ node->basenamelen = check_node_name(node->name); ++ if (node->basenamelen < 0) { ++ fprintf(stderr, "Warning \"%s\" has incorrect format\n", node->name); ++ } ++ ++ do { ++ struct property *prop; ++ struct node *child; ++ ++ val = flat_read_word(dtbuf); ++ switch (val) { ++ case FDT_PROP: ++ if (node->children) ++ fprintf(stderr, "Warning: Flat tree input has " ++ "subnodes preceding a property.\n"); ++ prop = flat_read_property(dtbuf, strbuf, flags); ++ add_property(node, prop); ++ break; ++ ++ case FDT_BEGIN_NODE: ++ child = unflatten_tree(dtbuf,strbuf, node->fullpath, ++ flags); ++ add_child(node, child); ++ break; ++ ++ case FDT_END_NODE: ++ break; ++ ++ case FDT_END: ++ die("Premature FDT_END in device tree blob\n"); ++ break; ++ ++ case FDT_NOP: ++ if (!(flags & FTF_NOPS)) ++ fprintf(stderr, "Warning: NOP tag found in flat tree" ++ " version <16\n"); ++ ++ /* Ignore */ ++ break; ++ ++ default: ++ die("Invalid opcode word %08x in device tree blob\n", ++ val); ++ } ++ } while (val != FDT_END_NODE); ++ ++ return node; ++} ++ ++ ++struct boot_info *dt_from_blob(FILE *f) ++{ ++ u32 magic, totalsize, version, size_str, size_dt; ++ u32 off_dt, off_str, off_mem_rsvmap; ++ int rc; ++ char *blob; ++ struct fdt_header *fdt; ++ char *p; ++ struct inbuf dtbuf, strbuf; ++ struct inbuf memresvbuf; ++ int sizeleft; ++ struct reserve_info *reservelist; ++ struct node *tree; ++ u32 val; ++ int flags = 0; ++ ++ rc = fread(&magic, sizeof(magic), 1, f); ++ if (ferror(f)) ++ die("Error reading DT blob magic number: %s\n", ++ strerror(errno)); ++ if (rc < 1) { ++ if (feof(f)) ++ die("EOF reading DT blob magic number\n"); ++ else ++ die("Mysterious short read reading magic number\n"); ++ } ++ ++ magic = be32_to_cpu(magic); ++ if (magic != FDT_MAGIC) ++ die("Blob has incorrect magic number\n"); ++ ++ rc = fread(&totalsize, sizeof(totalsize), 1, f); ++ if (ferror(f)) ++ die("Error reading DT blob size: %s\n", strerror(errno)); ++ if (rc < 1) { ++ if (feof(f)) ++ die("EOF reading DT blob size\n"); ++ else ++ die("Mysterious short read reading blob size\n"); ++ } ++ ++ totalsize = be32_to_cpu(totalsize); ++ if (totalsize < FDT_V1_SIZE) ++ die("DT blob size (%d) is too small\n", totalsize); ++ ++ blob = xmalloc(totalsize); ++ ++ fdt = (struct fdt_header *)blob; ++ fdt->magic = cpu_to_be32(magic); ++ fdt->totalsize = cpu_to_be32(totalsize); ++ ++ sizeleft = totalsize - sizeof(magic) - sizeof(totalsize); ++ p = blob + sizeof(magic) + sizeof(totalsize); ++ ++ while (sizeleft) { ++ if (feof(f)) ++ die("EOF before reading %d bytes of DT blob\n", ++ totalsize); ++ ++ rc = fread(p, 1, sizeleft, f); ++ if (ferror(f)) ++ die("Error reading DT blob: %s\n", ++ strerror(errno)); ++ ++ sizeleft -= rc; ++ p += rc; ++ } ++ ++ off_dt = be32_to_cpu(fdt->off_dt_struct); ++ off_str = be32_to_cpu(fdt->off_dt_strings); ++ off_mem_rsvmap = be32_to_cpu(fdt->off_mem_rsvmap); ++ version = be32_to_cpu(fdt->version); ++ ++ fprintf(stderr, "\tmagic:\t\t\t0x%x\n", magic); ++ fprintf(stderr, "\ttotalsize:\t\t%d\n", totalsize); ++ fprintf(stderr, "\toff_dt_struct:\t\t0x%x\n", off_dt); ++ fprintf(stderr, "\toff_dt_strings:\t\t0x%x\n", off_str); ++ fprintf(stderr, "\toff_mem_rsvmap:\t\t0x%x\n", off_mem_rsvmap); ++ fprintf(stderr, "\tversion:\t\t0x%x\n", version ); ++ fprintf(stderr, "\tlast_comp_version:\t0x%x\n", ++ be32_to_cpu(fdt->last_comp_version)); ++ ++ if (off_mem_rsvmap >= totalsize) ++ die("Mem Reserve structure offset exceeds total size\n"); ++ ++ if (off_dt >= totalsize) ++ die("DT structure offset exceeds total size\n"); ++ ++ if (off_str > totalsize) ++ die("String table offset exceeds total size\n"); ++ ++ if (version >= 2) ++ fprintf(stderr, "\tboot_cpuid_phys:\t0x%x\n", ++ be32_to_cpu(fdt->boot_cpuid_phys)); ++ ++ size_str = -1; ++ if (version >= 3) { ++ size_str = be32_to_cpu(fdt->size_dt_strings); ++ fprintf(stderr, "\tsize_dt_strings:\t%d\n", size_str); ++ if (off_str+size_str > totalsize) ++ die("String table extends past total size\n"); ++ } ++ ++ if (version >= 17) { ++ size_dt = be32_to_cpu(fdt->size_dt_struct); ++ fprintf(stderr, "\tsize_dt_struct:\t\t%d\n", size_dt); ++ if (off_dt+size_dt > totalsize) ++ die("Structure block extends past total size\n"); ++ } ++ ++ if (version < 16) { ++ flags |= FTF_FULLPATH | FTF_NAMEPROPS | FTF_VARALIGN; ++ } else { ++ flags |= FTF_NOPS; ++ } ++ ++ inbuf_init(&memresvbuf, ++ blob + off_mem_rsvmap, blob + totalsize); ++ inbuf_init(&dtbuf, blob + off_dt, blob + totalsize); ++ if (size_str >= 0) ++ inbuf_init(&strbuf, blob + off_str, blob + off_str + size_str); ++ else ++ inbuf_init(&strbuf, blob + off_str, blob + totalsize); ++ ++ reservelist = flat_read_mem_reserve(&memresvbuf); ++ ++ val = flat_read_word(&dtbuf); ++ ++ if (val != FDT_BEGIN_NODE) ++ die("Device tree blob doesn't begin with FDT_BEGIN_NODE (begins with 0x%08x)\n", val); ++ ++ tree = unflatten_tree(&dtbuf, &strbuf, "", flags); ++ ++ val = flat_read_word(&dtbuf); ++ if (val != FDT_END) ++ die("Device tree blob doesn't end with FDT_END\n"); ++ ++ free(blob); ++ ++ return build_boot_info(reservelist, tree); ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/fstree.c powerpc.git/arch/powerpc/boot/dtc-src/fstree.c +--- linux-2.6.24/arch/powerpc/boot/dtc-src/fstree.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/fstree.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,94 @@ ++/* ++ * (C) Copyright David Gibson <dwg@au1.ibm.com>, IBM Corporation. 2005. ++ * ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 ++ * USA ++ */ ++ ++#include "dtc.h" ++ ++#include <dirent.h> ++#include <sys/stat.h> ++ ++static struct node *read_fstree(const char *dirname) ++{ ++ DIR *d; ++ struct dirent *de; ++ struct stat st; ++ struct node *tree; ++ ++ d = opendir(dirname); ++ if (! d) ++ die("opendir(): %s\n", strerror(errno)); ++ ++ tree = build_node(NULL, NULL); ++ ++ while ((de = readdir(d)) != NULL) { ++ char *tmpnam; ++ ++ if (streq(de->d_name, ".") ++ || streq(de->d_name, "..")) ++ continue; ++ ++ tmpnam = join_path(dirname, de->d_name); ++ ++ if (lstat(tmpnam, &st) < 0) ++ die("stat(%s): %s\n", tmpnam, strerror(errno)); ++ ++ if (S_ISREG(st.st_mode)) { ++ struct property *prop; ++ FILE *pfile; ++ ++ pfile = fopen(tmpnam, "r"); ++ if (! pfile) { ++ fprintf(stderr, ++ "WARNING: Cannot open %s: %s\n", ++ tmpnam, strerror(errno)); ++ } else { ++ prop = build_property(strdup(de->d_name), ++ data_copy_file(pfile, ++ st.st_size), ++ NULL); ++ add_property(tree, prop); ++ fclose(pfile); ++ } ++ } else if (S_ISDIR(st.st_mode)) { ++ struct node *newchild; ++ ++ newchild = read_fstree(tmpnam); ++ newchild = name_node(newchild, strdup(de->d_name), ++ NULL); ++ add_child(tree, newchild); ++ } ++ ++ free(tmpnam); ++ } ++ ++ return tree; ++} ++ ++struct boot_info *dt_from_fs(const char *dirname) ++{ ++ struct node *tree; ++ ++ tree = read_fstree(dirname); ++ tree = name_node(tree, "", NULL); ++ ++ fill_fullpaths(tree, ""); ++ ++ return build_boot_info(NULL, tree); ++} ++ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/livetree.c powerpc.git/arch/powerpc/boot/dtc-src/livetree.c +--- linux-2.6.24/arch/powerpc/boot/dtc-src/livetree.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/livetree.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,305 @@ ++/* ++ * (C) Copyright David Gibson <dwg@au1.ibm.com>, IBM Corporation. 2005. ++ * ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 ++ * USA ++ */ ++ ++#include "dtc.h" ++ ++/* ++ * Tree building functions ++ */ ++ ++struct property *build_property(char *name, struct data val, char *label) ++{ ++ struct property *new = xmalloc(sizeof(*new)); ++ ++ new->name = name; ++ new->val = val; ++ ++ new->next = NULL; ++ ++ new->label = label; ++ ++ return new; ++} ++ ++struct property *chain_property(struct property *first, struct property *list) ++{ ++ assert(first->next == NULL); ++ ++ first->next = list; ++ return first; ++} ++ ++struct property *reverse_properties(struct property *first) ++{ ++ struct property *p = first; ++ struct property *head = NULL; ++ struct property *next; ++ ++ while (p) { ++ next = p->next; ++ p->next = head; ++ head = p; ++ p = next; ++ } ++ return head; ++} ++ ++struct node *build_node(struct property *proplist, struct node *children) ++{ ++ struct node *new = xmalloc(sizeof(*new)); ++ struct node *child; ++ ++ memset(new, 0, sizeof(*new)); ++ ++ new->proplist = reverse_properties(proplist); ++ new->children = children; ++ ++ for_each_child(new, child) { ++ child->parent = new; ++ } ++ ++ return new; ++} ++ ++struct node *name_node(struct node *node, char *name, char * label) ++{ ++ assert(node->name == NULL); ++ ++ node->name = name; ++ ++ node->label = label; ++ ++ return node; ++} ++ ++struct node *chain_node(struct node *first, struct node *list) ++{ ++ assert(first->next_sibling == NULL); ++ ++ first->next_sibling = list; ++ return first; ++} ++ ++void add_property(struct node *node, struct property *prop) ++{ ++ struct property **p; ++ ++ prop->next = NULL; ++ ++ p = &node->proplist; ++ while (*p) ++ p = &((*p)->next); ++ ++ *p = prop; ++} ++ ++void add_child(struct node *parent, struct node *child) ++{ ++ struct node **p; ++ ++ child->next_sibling = NULL; ++ ++ p = &parent->children; ++ while (*p) ++ p = &((*p)->next_sibling); ++ ++ *p = child; ++} ++ ++struct reserve_info *build_reserve_entry(u64 address, u64 size, char *label) ++{ ++ struct reserve_info *new = xmalloc(sizeof(*new)); ++ ++ new->re.address = address; ++ new->re.size = size; ++ ++ new->next = NULL; ++ ++ new->label = label; ++ ++ return new; ++} ++ ++struct reserve_info *chain_reserve_entry(struct reserve_info *first, ++ struct reserve_info *list) ++{ ++ assert(first->next == NULL); ++ ++ first->next = list; ++ return first; ++} ++ ++struct reserve_info *add_reserve_entry(struct reserve_info *list, ++ struct reserve_info *new) ++{ ++ struct reserve_info *last; ++ ++ new->next = NULL; ++ ++ if (! list) ++ return new; ++ ++ for (last = list; last->next; last = last->next) ++ ; ++ ++ last->next = new; ++ ++ return list; ++} ++ ++struct boot_info *build_boot_info(struct reserve_info *reservelist, ++ struct node *tree) ++{ ++ struct boot_info *bi; ++ ++ bi = xmalloc(sizeof(*bi)); ++ bi->reservelist = reservelist; ++ bi->dt = tree; ++ ++ return bi; ++} ++ ++/* ++ * Tree accessor functions ++ */ ++ ++const char *get_unitname(struct node *node) ++{ ++ if (node->name[node->basenamelen] == '\0') ++ return ""; ++ else ++ return node->name + node->basenamelen + 1; ++} ++ ++struct property *get_property(struct node *node, const char *propname) ++{ ++ struct property *prop; ++ ++ for_each_property(node, prop) ++ if (streq(prop->name, propname)) ++ return prop; ++ ++ return NULL; ++} ++ ++cell_t propval_cell(struct property *prop) ++{ ++ assert(prop->val.len == sizeof(cell_t)); ++ return be32_to_cpu(*((cell_t *)prop->val.val)); ++} ++ ++struct node *get_subnode(struct node *node, const char *nodename) ++{ ++ struct node *child; ++ ++ for_each_child(node, child) ++ if (streq(child->name, nodename)) ++ return child; ++ ++ return NULL; ++} ++ ++struct node *get_node_by_path(struct node *tree, const char *path) ++{ ++ const char *p; ++ struct node *child; ++ ++ if (!path || ! (*path)) ++ return tree; ++ ++ while (path[0] == '/') ++ path++; ++ ++ p = strchr(path, '/'); ++ ++ for_each_child(tree, child) { ++ if (p && strneq(path, child->name, p-path)) ++ return get_node_by_path(child, p+1); ++ else if (!p && streq(path, child->name)) ++ return child; ++ } ++ ++ return NULL; ++} ++ ++struct node *get_node_by_label(struct node *tree, const char *label) ++{ ++ struct node *child, *node; ++ ++ assert(label && (strlen(label) > 0)); ++ ++ if (tree->label && streq(tree->label, label)) ++ return tree; ++ ++ for_each_child(tree, child) { ++ node = get_node_by_label(child, label); ++ if (node) ++ return node; ++ } ++ ++ return NULL; ++} ++ ++struct node *get_node_by_phandle(struct node *tree, cell_t phandle) ++{ ++ struct node *child, *node; ++ ++ assert((phandle != 0) && (phandle != -1)); ++ ++ if (tree->phandle == phandle) ++ return tree; ++ ++ for_each_child(tree, child) { ++ node = get_node_by_phandle(child, phandle); ++ if (node) ++ return node; ++ } ++ ++ return NULL; ++} ++ ++struct node *get_node_by_ref(struct node *tree, const char *ref) ++{ ++ if (ref[0] == '/') ++ return get_node_by_path(tree, ref); ++ else ++ return get_node_by_label(tree, ref); ++} ++ ++cell_t get_node_phandle(struct node *root, struct node *node) ++{ ++ static cell_t phandle = 1; /* FIXME: ick, static local */ ++ ++ if ((node->phandle != 0) && (node->phandle != -1)) ++ return node->phandle; ++ ++ assert(! get_property(node, "linux,phandle")); ++ ++ while (get_node_by_phandle(root, phandle)) ++ phandle++; ++ ++ node->phandle = phandle; ++ add_property(node, ++ build_property("linux,phandle", ++ data_append_cell(empty_data, phandle), ++ NULL)); ++ ++ return node->phandle; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/srcpos.c powerpc.git/arch/powerpc/boot/dtc-src/srcpos.c +--- linux-2.6.24/arch/powerpc/boot/dtc-src/srcpos.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/srcpos.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,105 @@ ++/* ++ * Copyright 2007 Jon Loeliger, Freescale Semiconductor, Inc. ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 ++ * USA ++ */ ++ ++#include "dtc.h" ++#include "srcpos.h" ++ ++ ++/* ++ * Record the complete unique set of opened file names. ++ * Primarily used to cache source position file names. ++ */ ++#define MAX_N_FILE_NAMES (100) ++ ++const char *file_names[MAX_N_FILE_NAMES]; ++static int n_file_names = 0; ++ ++/* ++ * Like yylineno, this is the current open file pos. ++ */ ++ ++int srcpos_filenum = -1; ++ ++ ++ ++FILE *dtc_open_file(const char *fname) ++{ ++ FILE *f; ++ ++ if (lookup_file_name(fname, 1) < 0) ++ die("Too many files opened\n"); ++ ++ if (streq(fname, "-")) ++ f = stdin; ++ else ++ f = fopen(fname, "r"); ++ ++ if (! f) ++ die("Couldn't open \"%s\": %s\n", fname, strerror(errno)); ++ ++ return f; ++} ++ ++ ++ ++/* ++ * Locate and optionally add filename fname in the file_names[] array. ++ * ++ * If the filename is currently not in the array and the boolean ++ * add_it is non-zero, an attempt to add the filename will be made. ++ * ++ * Returns; ++ * Index [0..MAX_N_FILE_NAMES) where the filename is kept ++ * -1 if the name can not be recorded ++ */ ++ ++int lookup_file_name(const char *fname, int add_it) ++{ ++ int i; ++ ++ for (i = 0; i < n_file_names; i++) { ++ if (strcmp(file_names[i], fname) == 0) ++ return i; ++ } ++ ++ if (add_it) { ++ if (n_file_names < MAX_N_FILE_NAMES) { ++ file_names[n_file_names] = strdup(fname); ++ return n_file_names++; ++ } ++ } ++ ++ return -1; ++} ++ ++ ++const char *srcpos_filename_for_num(int filenum) ++{ ++ if (0 <= filenum && filenum < n_file_names) { ++ return file_names[filenum]; ++ } ++ ++ return 0; ++} ++ ++ ++const char *srcpos_get_filename(void) ++{ ++ return srcpos_filename_for_num(srcpos_filenum); ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/srcpos.h powerpc.git/arch/powerpc/boot/dtc-src/srcpos.h +--- linux-2.6.24/arch/powerpc/boot/dtc-src/srcpos.h 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/srcpos.h 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,75 @@ ++/* ++ * Copyright 2007 Jon Loeliger, Freescale Semiconductor, Inc. ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 ++ * USA ++ */ ++ ++/* ++ * Augment the standard YYLTYPE with a filenum index into an ++ * array of all opened filenames. ++ */ ++ ++#if ! defined(YYLTYPE) && ! defined(YYLTYPE_IS_DECLARED) ++typedef struct YYLTYPE { ++ int first_line; ++ int first_column; ++ int last_line; ++ int last_column; ++ int filenum; ++} YYLTYPE; ++ ++#define YYLTYPE_IS_DECLARED 1 ++#define YYLTYPE_IS_TRIVIAL 1 ++#endif ++ ++/* Cater to old parser templates. */ ++#ifndef YYID ++#define YYID(n) (n) ++#endif ++ ++#define YYLLOC_DEFAULT(Current, Rhs, N) \ ++ do \ ++ if (YYID (N)) \ ++ { \ ++ (Current).first_line = YYRHSLOC (Rhs, 1).first_line; \ ++ (Current).first_column = YYRHSLOC (Rhs, 1).first_column; \ ++ (Current).last_line = YYRHSLOC (Rhs, N).last_line; \ ++ (Current).last_column = YYRHSLOC (Rhs, N).last_column; \ ++ (Current).filenum = YYRHSLOC (Rhs, N).filenum; \ ++ } \ ++ else \ ++ { \ ++ (Current).first_line = (Current).last_line = \ ++ YYRHSLOC (Rhs, 0).last_line; \ ++ (Current).first_column = (Current).last_column = \ ++ YYRHSLOC (Rhs, 0).last_column; \ ++ (Current).filenum = YYRHSLOC (Rhs, 0).filenum; \ ++ } \ ++ while (YYID (0)) ++ ++ ++ ++extern void yyerror(char const *); ++ ++extern int srcpos_filenum; ++ ++extern int push_input_file(const char *filename); ++extern int pop_input_file(void); ++ ++extern FILE *dtc_open_file(const char *fname); ++extern int lookup_file_name(const char *fname, int add_it); ++extern const char *srcpos_filename_for_num(int filenum); ++const char *srcpos_get_filename(void); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/treesource.c powerpc.git/arch/powerpc/boot/dtc-src/treesource.c +--- linux-2.6.24/arch/powerpc/boot/dtc-src/treesource.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/treesource.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,275 @@ ++/* ++ * (C) Copyright David Gibson <dwg@au1.ibm.com>, IBM Corporation. 2005. ++ * ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 ++ * USA ++ */ ++ ++#include "dtc.h" ++#include "srcpos.h" ++ ++extern FILE *yyin; ++extern int yyparse(void); ++extern void yyerror(char const *); ++ ++struct boot_info *the_boot_info; ++ ++struct boot_info *dt_from_source(const char *fname) ++{ ++ the_boot_info = NULL; ++ ++ push_input_file(fname); ++ ++ if (yyparse() != 0) ++ return NULL; ++ ++ fill_fullpaths(the_boot_info->dt, ""); ++ ++ return the_boot_info; ++} ++ ++static void write_prefix(FILE *f, int level) ++{ ++ int i; ++ ++ for (i = 0; i < level; i++) ++ fputc('\t', f); ++} ++ ++int isstring(char c) ++{ ++ return (isprint(c) ++ || (c == '\0') ++ || strchr("\a\b\t\n\v\f\r", c)); ++} ++ ++static void write_propval_string(FILE *f, struct data val) ++{ ++ const char *str = val.val; ++ int i; ++ int newchunk = 1; ++ struct marker *m = val.markers; ++ ++ assert(str[val.len-1] == '\0'); ++ ++ for (i = 0; i < (val.len-1); i++) { ++ char c = str[i]; ++ ++ if (newchunk) { ++ while (m && (m->offset <= i)) { ++ if (m->type == LABEL) { ++ assert(m->offset == i); ++ fprintf(f, "%s: ", m->ref); ++ } ++ m = m->next; ++ } ++ fprintf(f, "\""); ++ newchunk = 0; ++ } ++ ++ switch (c) { ++ case '\a': ++ fprintf(f, "\\a"); ++ break; ++ case '\b': ++ fprintf(f, "\\b"); ++ break; ++ case '\t': ++ fprintf(f, "\\t"); ++ break; ++ case '\n': ++ fprintf(f, "\\n"); ++ break; ++ case '\v': ++ fprintf(f, "\\v"); ++ break; ++ case '\f': ++ fprintf(f, "\\f"); ++ break; ++ case '\r': ++ fprintf(f, "\\r"); ++ break; ++ case '\\': ++ fprintf(f, "\\\\"); ++ break; ++ case '\"': ++ fprintf(f, "\\\""); ++ break; ++ case '\0': ++ fprintf(f, "\", "); ++ newchunk = 1; ++ break; ++ default: ++ if (isprint(c)) ++ fprintf(f, "%c", c); ++ else ++ fprintf(f, "\\x%02hhx", c); ++ } ++ } ++ fprintf(f, "\""); ++ ++ /* Wrap up any labels at the end of the value */ ++ for_each_marker_of_type(m, LABEL) { ++ assert (m->offset == val.len); ++ fprintf(f, " %s:", m->ref); ++ } ++} ++ ++static void write_propval_cells(FILE *f, struct data val) ++{ ++ void *propend = val.val + val.len; ++ cell_t *cp = (cell_t *)val.val; ++ struct marker *m = val.markers; ++ ++ fprintf(f, "<"); ++ for (;;) { ++ while (m && (m->offset <= ((char *)cp - val.val))) { ++ if (m->type == LABEL) { ++ assert(m->offset == ((char *)cp - val.val)); ++ fprintf(f, "%s: ", m->ref); ++ } ++ m = m->next; ++ } ++ ++ fprintf(f, "0x%x", be32_to_cpu(*cp++)); ++ if ((void *)cp >= propend) ++ break; ++ fprintf(f, " "); ++ } ++ ++ /* Wrap up any labels at the end of the value */ ++ for_each_marker_of_type(m, LABEL) { ++ assert (m->offset == val.len); ++ fprintf(f, " %s:", m->ref); ++ } ++ fprintf(f, ">"); ++} ++ ++static void write_propval_bytes(FILE *f, struct data val) ++{ ++ void *propend = val.val + val.len; ++ const char *bp = val.val; ++ struct marker *m = val.markers; ++ ++ fprintf(f, "["); ++ for (;;) { ++ while (m && (m->offset == (bp-val.val))) { ++ if (m->type == LABEL) ++ fprintf(f, "%s: ", m->ref); ++ m = m->next; ++ } ++ ++ fprintf(f, "%02hhx", *bp++); ++ if ((void *)bp >= propend) ++ break; ++ fprintf(f, " "); ++ } ++ ++ /* Wrap up any labels at the end of the value */ ++ for_each_marker_of_type(m, LABEL) { ++ assert (m->offset == val.len); ++ fprintf(f, " %s:", m->ref); ++ } ++ fprintf(f, "]"); ++} ++ ++static void write_propval(FILE *f, struct property *prop) ++{ ++ int len = prop->val.len; ++ const char *p = prop->val.val; ++ struct marker *m = prop->val.markers; ++ int nnotstring = 0, nnul = 0; ++ int nnotstringlbl = 0, nnotcelllbl = 0; ++ int i; ++ ++ if (len == 0) { ++ fprintf(f, ";\n"); ++ return; ++ } ++ ++ for (i = 0; i < len; i++) { ++ if (! isstring(p[i])) ++ nnotstring++; ++ if (p[i] == '\0') ++ nnul++; ++ } ++ ++ for_each_marker_of_type(m, LABEL) { ++ if ((m->offset > 0) && (prop->val.val[m->offset - 1] != '\0')) ++ nnotstringlbl++; ++ if ((m->offset % sizeof(cell_t)) != 0) ++ nnotcelllbl++; ++ } ++ ++ fprintf(f, " = "); ++ if ((p[len-1] == '\0') && (nnotstring == 0) && (nnul < (len-nnul)) ++ && (nnotstringlbl == 0)) { ++ write_propval_string(f, prop->val); ++ } else if (((len % sizeof(cell_t)) == 0) && (nnotcelllbl == 0)) { ++ write_propval_cells(f, prop->val); ++ } else { ++ write_propval_bytes(f, prop->val); ++ } ++ ++ fprintf(f, ";\n"); ++} ++ ++static void write_tree_source_node(FILE *f, struct node *tree, int level) ++{ ++ struct property *prop; ++ struct node *child; ++ ++ write_prefix(f, level); ++ if (tree->label) ++ fprintf(f, "%s: ", tree->label); ++ if (tree->name && (*tree->name)) ++ fprintf(f, "%s {\n", tree->name); ++ else ++ fprintf(f, "/ {\n"); ++ ++ for_each_property(tree, prop) { ++ write_prefix(f, level+1); ++ if (prop->label) ++ fprintf(f, "%s: ", prop->label); ++ fprintf(f, "%s", prop->name); ++ write_propval(f, prop); ++ } ++ for_each_child(tree, child) { ++ fprintf(f, "\n"); ++ write_tree_source_node(f, child, level+1); ++ } ++ write_prefix(f, level); ++ fprintf(f, "};\n"); ++} ++ ++ ++void dt_to_source(FILE *f, struct boot_info *bi) ++{ ++ struct reserve_info *re; ++ ++ fprintf(f, "/dts-v1/;\n\n"); ++ ++ for (re = bi->reservelist; re; re = re->next) { ++ if (re->label) ++ fprintf(f, "%s: ", re->label); ++ fprintf(f, "/memreserve/\t0x%016llx 0x%016llx;\n", ++ (unsigned long long)re->re.address, ++ (unsigned long long)re->re.size); ++ } ++ ++ write_tree_source_node(f, bi->dt, 0); ++} ++ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dtc-src/version_gen.h powerpc.git/arch/powerpc/boot/dtc-src/version_gen.h +--- linux-2.6.24/arch/powerpc/boot/dtc-src/version_gen.h 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dtc-src/version_gen.h 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1 @@ ++#define DTC_VERSION "DTC 1.0.0-gd6f9b62f" +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/adder875-redboot.dts powerpc.git/arch/powerpc/boot/dts/adder875-redboot.dts +--- linux-2.6.24/arch/powerpc/boot/dts/adder875-redboot.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/adder875-redboot.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,184 @@ ++/* ++ * Device Tree Source for MPC885 ADS running RedBoot ++ * ++ * Copyright 2006 MontaVista Software, Inc. ++ * Copyright 2007 Freescale Semiconductor, Inc. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++/dts-v1/; ++/ { ++ model = "Analogue & Micro Adder MPC875"; ++ compatible = "analogue-and-micro,adder875"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ++ aliases { ++ console = &console; ++ ethernet0 = ð0; ++ ethernet1 = ð1; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ PowerPC,875@0 { ++ device_type = "cpu"; ++ reg = <0>; ++ d-cache-line-size = <16>; ++ i-cache-line-size = <16>; ++ d-cache-size = <8192>; ++ i-cache-size = <8192>; ++ timebase-frequency = <0>; ++ bus-frequency = <0>; ++ clock-frequency = <0>; ++ interrupts = <15 2>; // decrementer interrupt ++ interrupt-parent = <&PIC>; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <0 0x01000000>; ++ }; ++ ++ localbus@fa200100 { ++ compatible = "fsl,mpc885-localbus", "fsl,pq1-localbus", ++ "simple-bus"; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ reg = <0xfa200100 0x40>; ++ ++ ranges = < ++ 0 0 0xfe000000 0x00800000 ++ 2 0 0xfa100000 0x00008000 ++ >; ++ ++ flash@0,0 { ++ compatible = "cfi-flash"; ++ reg = <0 0 0x800000>; ++ bank-width = <2>; ++ device-width = <2>; ++ }; ++ }; ++ ++ soc@fa200000 { ++ compatible = "fsl,mpc875-immr", "fsl,pq1-soc", "simple-bus"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges = <0 0xfa200000 0x00004000>; ++ ++ // Temporary until code stops depending on it. ++ device_type = "soc"; ++ ++ // Temporary until get_immrbase() is fixed. ++ reg = <0xfa200000 0x4000>; ++ ++ mdio@e00 { ++ compatible = "fsl,mpc875-fec-mdio", "fsl,pq1-fec-mdio"; ++ reg = <0xe00 0x188>; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ PHY0: ethernet-phy@0 { ++ reg = <0>; ++ device_type = "ethernet-phy"; ++ }; ++ ++ PHY1: ethernet-phy@1 { ++ reg = <1>; ++ device_type = "ethernet-phy"; ++ }; ++ }; ++ ++ eth0: ethernet@e00 { ++ device_type = "network"; ++ compatible = "fsl,mpc875-fec-enet", ++ "fsl,pq1-fec-enet"; ++ reg = <0xe00 0x188>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ interrupts = <3 1>; ++ interrupt-parent = <&PIC>; ++ phy-handle = <&PHY0>; ++ linux,network-index = <0>; ++ }; ++ ++ eth1: ethernet@1e00 { ++ device_type = "network"; ++ compatible = "fsl,mpc875-fec-enet", ++ "fsl,pq1-fec-enet"; ++ reg = <0x1e00 0x188>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ interrupts = <7 1>; ++ interrupt-parent = <&PIC>; ++ phy-handle = <&PHY1>; ++ linux,network-index = <1>; ++ }; ++ ++ PIC: interrupt-controller@0 { ++ interrupt-controller; ++ #interrupt-cells = <2>; ++ reg = <0 0x24>; ++ compatible = "fsl,mpc875-pic", "fsl,pq1-pic"; ++ }; ++ ++ cpm@9c0 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ compatible = "fsl,mpc875-cpm", "fsl,cpm1", "simple-bus"; ++ interrupts = <0>; // cpm error interrupt ++ interrupt-parent = <&CPM_PIC>; ++ reg = <0x9c0 0x40>; ++ ranges; ++ ++ muram { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges = <0 0x2000 0x2000>; ++ ++ data@0 { ++ compatible = "fsl,cpm-muram-data"; ++ reg = <0 0x1c00>; ++ }; ++ }; ++ ++ brg@9f0 { ++ compatible = "fsl,mpc875-brg", ++ "fsl,cpm1-brg", ++ "fsl,cpm-brg"; ++ reg = <0x9f0 0x10>; ++ }; ++ ++ CPM_PIC: interrupt-controller@930 { ++ interrupt-controller; ++ #interrupt-cells = <1>; ++ interrupts = <5 2 0 2>; ++ interrupt-parent = <&PIC>; ++ reg = <0x930 0x20>; ++ compatible = "fsl,mpc875-cpm-pic", ++ "fsl,cpm1-pic"; ++ }; ++ ++ console: serial@a80 { ++ device_type = "serial"; ++ compatible = "fsl,mpc875-smc-uart", ++ "fsl,cpm1-smc-uart"; ++ reg = <0xa80 0x10 0x3e80 0x40>; ++ interrupts = <4>; ++ interrupt-parent = <&CPM_PIC>; ++ fsl,cpm-brg = <1>; ++ fsl,cpm-command = <0x0090>; ++ current-speed = <115200>; ++ }; ++ }; ++ }; ++ ++ chosen { ++ linux,stdout-path = &console; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/adder875-uboot.dts powerpc.git/arch/powerpc/boot/dts/adder875-uboot.dts +--- linux-2.6.24/arch/powerpc/boot/dts/adder875-uboot.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/adder875-uboot.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,183 @@ ++/* ++ * Device Tree Source for MPC885 ADS running U-Boot ++ * ++ * Copyright 2006 MontaVista Software, Inc. ++ * Copyright 2007 Freescale Semiconductor, Inc. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++/dts-v1/; ++/ { ++ model = "Analogue & Micro Adder MPC875"; ++ compatible = "analogue-and-micro,adder875"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ++ aliases { ++ console = &console; ++ ethernet0 = ð0; ++ ethernet1 = ð1; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ PowerPC,875@0 { ++ device_type = "cpu"; ++ reg = <0>; ++ d-cache-line-size = <16>; ++ i-cache-line-size = <16>; ++ d-cache-size = <8192>; ++ i-cache-size = <8192>; ++ timebase-frequency = <0>; ++ bus-frequency = <0>; ++ clock-frequency = <0>; ++ interrupts = <15 2>; // decrementer interrupt ++ interrupt-parent = <&PIC>; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <0 0x01000000>; ++ }; ++ ++ localbus@ff000100 { ++ compatible = "fsl,mpc885-localbus", "fsl,pq1-localbus", ++ "simple-bus"; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ reg = <0xff000100 0x40>; ++ ++ ranges = < ++ 0 0 0xfe000000 0x01000000 ++ >; ++ ++ flash@0,0 { ++ compatible = "cfi-flash"; ++ reg = <0 0 0x800000>; ++ bank-width = <2>; ++ device-width = <2>; ++ }; ++ }; ++ ++ soc@ff000000 { ++ compatible = "fsl,mpc875-immr", "fsl,pq1-soc", "simple-bus"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges = <0 0xff000000 0x00004000>; ++ ++ // Temporary until code stops depending on it. ++ device_type = "soc"; ++ ++ // Temporary until get_immrbase() is fixed. ++ reg = <0xff000000 0x4000>; ++ ++ mdio@e00 { ++ compatible = "fsl,mpc875-fec-mdio", "fsl,pq1-fec-mdio"; ++ reg = <0xe00 0x188>; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ PHY0: ethernet-phy@0 { ++ reg = <0>; ++ device_type = "ethernet-phy"; ++ }; ++ ++ PHY1: ethernet-phy@1 { ++ reg = <1>; ++ device_type = "ethernet-phy"; ++ }; ++ }; ++ ++ eth0: ethernet@e00 { ++ device_type = "network"; ++ compatible = "fsl,mpc875-fec-enet", ++ "fsl,pq1-fec-enet"; ++ reg = <0xe00 0x188>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ interrupts = <3 1>; ++ interrupt-parent = <&PIC>; ++ phy-handle = <&PHY0>; ++ linux,network-index = <0>; ++ }; ++ ++ eth1: ethernet@1e00 { ++ device_type = "network"; ++ compatible = "fsl,mpc875-fec-enet", ++ "fsl,pq1-fec-enet"; ++ reg = <0x1e00 0x188>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ interrupts = <7 1>; ++ interrupt-parent = <&PIC>; ++ phy-handle = <&PHY1>; ++ linux,network-index = <1>; ++ }; ++ ++ PIC: interrupt-controller@0 { ++ interrupt-controller; ++ #interrupt-cells = <2>; ++ reg = <0 0x24>; ++ compatible = "fsl,mpc875-pic", "fsl,pq1-pic"; ++ }; ++ ++ cpm@9c0 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ compatible = "fsl,mpc875-cpm", "fsl,cpm1", "simple-bus"; ++ interrupts = <0>; // cpm error interrupt ++ interrupt-parent = <&CPM_PIC>; ++ reg = <0x9c0 0x40>; ++ ranges; ++ ++ muram { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges = <0 0x2000 0x2000>; ++ ++ data@0 { ++ compatible = "fsl,cpm-muram-data"; ++ reg = <0 0x1c00>; ++ }; ++ }; ++ ++ brg@9f0 { ++ compatible = "fsl,mpc875-brg", ++ "fsl,cpm1-brg", ++ "fsl,cpm-brg"; ++ reg = <0x9f0 0x10>; ++ }; ++ ++ CPM_PIC: interrupt-controller@930 { ++ interrupt-controller; ++ #interrupt-cells = <1>; ++ interrupts = <5 2 0 2>; ++ interrupt-parent = <&PIC>; ++ reg = <0x930 0x20>; ++ compatible = "fsl,mpc875-cpm-pic", ++ "fsl,cpm1-pic"; ++ }; ++ ++ console: serial@a80 { ++ device_type = "serial"; ++ compatible = "fsl,mpc875-smc-uart", ++ "fsl,cpm1-smc-uart"; ++ reg = <0xa80 0x10 0x3e80 0x40>; ++ interrupts = <4>; ++ interrupt-parent = <&CPM_PIC>; ++ fsl,cpm-brg = <1>; ++ fsl,cpm-command = <0x0090>; ++ current-speed = <115200>; ++ }; ++ }; ++ }; ++ ++ chosen { ++ linux,stdout-path = &console; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/bamboo.dts powerpc.git/arch/powerpc/boot/dts/bamboo.dts +--- linux-2.6.24/arch/powerpc/boot/dts/bamboo.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/bamboo.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -16,14 +16,24 @@ + #size-cells = <1>; + model = "amcc,bamboo"; + compatible = "amcc,bamboo"; +- dcr-parent = <&/cpus/PowerPC,440EP@0>; ++ dcr-parent = <&/cpus/cpu@0>; ++ ++ aliases { ++ ethernet0 = &EMAC0; ++ ethernet1 = &EMAC1; ++ serial0 = &UART0; ++ serial1 = &UART1; ++ serial2 = &UART2; ++ serial3 = &UART3; ++ }; + + cpus { + #address-cells = <1>; + #size-cells = <0>; + +- PowerPC,440EP@0 { ++ cpu@0 { + device_type = "cpu"; ++ model = "PowerPC,440EP"; + reg = <0>; + clock-frequency = <0>; /* Filled in by zImage */ + timebase-frequency = <0>; /* Filled in by zImage */ +@@ -126,7 +136,6 @@ + #address-cells = <2>; + #size-cells = <1>; + clock-frequency = <0>; /* Filled in by zImage */ +- ranges; + interrupts = <5 1>; + interrupt-parent = <&UIC1>; + }; +@@ -238,11 +247,56 @@ + zmii-device = <&ZMII0>; + zmii-channel = <1>; + }; ++ ++ usb@ef601000 { ++ compatible = "ohci-be"; ++ reg = <ef601000 80>; ++ interrupts = <8 1 9 1>; ++ interrupt-parent = < &UIC1 >; ++ }; ++ }; ++ ++ PCI0: pci@ec000000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb440ep-pci", "ibm,plb-pci"; ++ primary; ++ reg = <0 eec00000 8 /* Config space access */ ++ 0 eed00000 4 /* IACK */ ++ 0 eed00000 4 /* Special cycle */ ++ 0 ef400000 40>; /* Internal registers */ ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed. Chip supports a second ++ * IO range but we don't use it for now ++ */ ++ ranges = <02000000 0 a0000000 0 a0000000 0 20000000 ++ 01000000 0 00000000 0 e8000000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 0 80000000>; ++ ++ /* Bamboo has all 4 IRQ pins tied together per slot */ ++ interrupt-map-mask = <f800 0 0 0>; ++ interrupt-map = < ++ /* IDSEL 1 */ ++ 0800 0 0 0 &UIC0 1c 8 ++ ++ /* IDSEL 2 */ ++ 1000 0 0 0 &UIC0 1b 8 ++ ++ /* IDSEL 3 */ ++ 1800 0 0 0 &UIC0 1a 8 ++ ++ /* IDSEL 4 */ ++ 2000 0 0 0 &UIC0 19 8 ++ >; + }; + }; + + chosen { + linux,stdout-path = "/plb/opb/serial@ef600300"; +- bootargs = "console=ttyS0,115200"; + }; + }; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/cm5200.dts powerpc.git/arch/powerpc/boot/dts/cm5200.dts +--- linux-2.6.24/arch/powerpc/boot/dts/cm5200.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/cm5200.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,236 @@ ++/* ++ * CM5200 board Device Tree Source ++ * ++ * Copyright (C) 2007 Semihalf ++ * Marian Balakowicz <m8@semihalf.com> ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++/* ++ * WARNING: Do not depend on this tree layout remaining static just yet. ++ * The MPC5200 device tree conventions are still in flux ++ * Keep an eye on the linuxppc-dev mailing list for more details ++ */ ++ ++/ { ++ model = "schindler,cm5200"; ++ compatible = "schindler,cm5200"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ PowerPC,5200@0 { ++ device_type = "cpu"; ++ reg = <0>; ++ d-cache-line-size = <20>; ++ i-cache-line-size = <20>; ++ d-cache-size = <4000>; // L1, 16K ++ i-cache-size = <4000>; // L1, 16K ++ timebase-frequency = <0>; // from bootloader ++ bus-frequency = <0>; // from bootloader ++ clock-frequency = <0>; // from bootloader ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <00000000 04000000>; // 64MB ++ }; ++ ++ soc5200@f0000000 { ++ model = "fsl,mpc5200b"; ++ compatible = "fsl,mpc5200b"; ++ revision = ""; // from bootloader ++ device_type = "soc"; ++ ranges = <0 f0000000 0000c000>; ++ reg = <f0000000 00000100>; ++ bus-frequency = <0>; // from bootloader ++ system-frequency = <0>; // from bootloader ++ ++ cdm@200 { ++ compatible = "mpc5200b-cdm","mpc5200-cdm"; ++ reg = <200 38>; ++ }; ++ ++ mpc5200_pic: pic@500 { ++ // 5200 interrupts are encoded into two levels; ++ interrupt-controller; ++ #interrupt-cells = <3>; ++ compatible = "mpc5200b-pic","mpc5200-pic"; ++ reg = <500 80>; ++ }; ++ ++ gpt@600 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <600 10>; ++ interrupts = <1 9 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ fsl,has-wdt; ++ }; ++ ++ gpt@610 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <610 10>; ++ interrupts = <1 a 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ gpt@620 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <620 10>; ++ interrupts = <1 b 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ gpt@630 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <630 10>; ++ interrupts = <1 c 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ gpt@640 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <640 10>; ++ interrupts = <1 d 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ gpt@650 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <650 10>; ++ interrupts = <1 e 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ gpt@660 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <660 10>; ++ interrupts = <1 f 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ gpt@670 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <670 10>; ++ interrupts = <1 10 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ rtc@800 { // Real time clock ++ compatible = "mpc5200b-rtc","mpc5200-rtc"; ++ reg = <800 100>; ++ interrupts = <1 5 0 1 6 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ gpio@b00 { ++ compatible = "mpc5200b-gpio","mpc5200-gpio"; ++ reg = <b00 40>; ++ interrupts = <1 7 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ gpio-wkup@c00 { ++ compatible = "mpc5200b-gpio-wkup","mpc5200-gpio-wkup"; ++ reg = <c00 40>; ++ interrupts = <1 8 0 0 3 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ spi@f00 { ++ compatible = "mpc5200b-spi","mpc5200-spi"; ++ reg = <f00 20>; ++ interrupts = <2 d 0 2 e 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ usb@1000 { ++ device_type = "usb-ohci-be"; ++ compatible = "mpc5200b-ohci","mpc5200-ohci","ohci-be"; ++ reg = <1000 ff>; ++ interrupts = <2 6 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ dma-controller@1200 { ++ compatible = "mpc5200b-bestcomm","mpc5200-bestcomm"; ++ reg = <1200 80>; ++ interrupts = <3 0 0 3 1 0 3 2 0 3 3 0 ++ 3 4 0 3 5 0 3 6 0 3 7 0 ++ 3 8 0 3 9 0 3 a 0 3 b 0 ++ 3 c 0 3 d 0 3 e 0 3 f 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ xlb@1f00 { ++ compatible = "mpc5200b-xlb","mpc5200-xlb"; ++ reg = <1f00 100>; ++ }; ++ ++ serial@2000 { // PSC1 ++ device_type = "serial"; ++ compatible = "mpc5200b-psc-uart","mpc5200-psc-uart"; ++ port-number = <0>; // Logical port assignment ++ reg = <2000 100>; ++ interrupts = <2 1 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ serial@2200 { // PSC2 ++ device_type = "serial"; ++ compatible = "mpc5200-psc-uart"; ++ port-number = <1>; // Logical port assignment ++ reg = <2200 100>; ++ interrupts = <2 2 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ serial@2400 { // PSC3 ++ device_type = "serial"; ++ compatible = "mpc5200-psc-uart"; ++ port-number = <2>; // Logical port assignment ++ reg = <2400 100>; ++ interrupts = <2 3 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ serial@2c00 { // PSC6 ++ device_type = "serial"; ++ compatible = "mpc5200b-psc-uart","mpc5200-psc-uart"; ++ port-number = <5>; // Logical port assignment ++ reg = <2c00 100>; ++ interrupts = <2 4 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ ethernet@3000 { ++ device_type = "network"; ++ compatible = "mpc5200b-fec","mpc5200-fec"; ++ reg = <3000 800>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; /* Filled in by U-Boot */ ++ interrupts = <2 5 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ i2c@3d40 { ++ compatible = "mpc5200b-i2c","mpc5200-i2c","fsl-i2c"; ++ reg = <3d40 40>; ++ interrupts = <2 10 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ fsl5200-clocking; ++ }; ++ ++ sram@8000 { ++ compatible = "mpc5200b-sram","mpc5200-sram"; ++ reg = <8000 4000>; ++ }; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/ebony.dts powerpc.git/arch/powerpc/boot/dts/ebony.dts +--- linux-2.6.24/arch/powerpc/boot/dts/ebony.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/ebony.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -16,14 +16,22 @@ + #size-cells = <1>; + model = "ibm,ebony"; + compatible = "ibm,ebony"; +- dcr-parent = <&/cpus/PowerPC,440GP@0>; ++ dcr-parent = <&/cpus/cpu@0>; ++ ++ aliases { ++ ethernet0 = &EMAC0; ++ ethernet1 = &EMAC1; ++ serial0 = &UART0; ++ serial1 = &UART1; ++ }; + + cpus { + #address-cells = <1>; + #size-cells = <0>; + +- PowerPC,440GP@0 { ++ cpu@0 { + device_type = "cpu"; ++ model = "PowerPC,440GP"; + reg = <0>; + clock-frequency = <0>; // Filled in by zImage + timebase-frequency = <0>; // Filled in by zImage +@@ -150,9 +158,10 @@ + }; + }; + +- ds1743@1,0 { ++ nvram@1,0 { + /* NVRAM & RTC */ +- compatible = "ds1743"; ++ compatible = "ds1743-nvram"; ++ #bytes = <2000>; + reg = <1 0 2000>; + }; + +@@ -284,12 +293,43 @@ + + }; + +- PCIX0: pci@1234 { ++ PCIX0: pci@20ec00000 { + device_type = "pci"; +- /* FIXME */ +- reg = <2 0ec00000 8 +- 2 0ec80000 f0 +- 2 0ec80100 fc>; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb440gp-pcix", "ibm,plb-pcix"; ++ primary; ++ reg = <2 0ec00000 8 /* Config space access */ ++ 0 0 0 /* no IACK cycles */ ++ 2 0ed00000 4 /* Special cycles */ ++ 2 0ec80000 f0 /* Internal registers */ ++ 2 0ec80100 fc>; /* Internal messaging registers */ ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed ++ */ ++ ranges = <02000000 0 80000000 00000003 80000000 0 80000000 ++ 01000000 0 00000000 00000002 08000000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 0 80000000>; ++ ++ /* Ebony has all 4 IRQ pins tied together per slot */ ++ interrupt-map-mask = <f800 0 0 0>; ++ interrupt-map = < ++ /* IDSEL 1 */ ++ 0800 0 0 0 &UIC0 17 8 ++ ++ /* IDSEL 2 */ ++ 1000 0 0 0 &UIC0 18 8 ++ ++ /* IDSEL 3 */ ++ 1800 0 0 0 &UIC0 19 8 ++ ++ /* IDSEL 4 */ ++ 2000 0 0 0 &UIC0 1a 8 ++ >; + }; + }; + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/ep405.dts powerpc.git/arch/powerpc/boot/dts/ep405.dts +--- linux-2.6.24/arch/powerpc/boot/dts/ep405.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/ep405.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,228 @@ ++/* ++ * Device Tree Source for EP405 ++ * ++ * Copyright 2007 IBM Corp. ++ * Benjamin Herrenschmidt <benh@kernel.crashing.org> ++ * ++ * This file is licensed under the terms of the GNU General Public ++ * License version 2. This program is licensed "as is" without ++ * any warranty of any kind, whether express or implied. ++ */ ++ ++/ { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ model = "ep405"; ++ compatible = "ep405"; ++ dcr-parent = <&/cpus/cpu@0>; ++ ++ aliases { ++ ethernet0 = &EMAC; ++ serial0 = &UART0; ++ serial1 = &UART1; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ cpu@0 { ++ device_type = "cpu"; ++ model = "PowerPC,405GP"; ++ reg = <0>; ++ clock-frequency = <bebc200>; /* Filled in by zImage */ ++ timebase-frequency = <0>; /* Filled in by zImage */ ++ i-cache-line-size = <20>; ++ d-cache-line-size = <20>; ++ i-cache-size = <4000>; ++ d-cache-size = <4000>; ++ dcr-controller; ++ dcr-access-method = "native"; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <0 0>; /* Filled in by zImage */ ++ }; ++ ++ UIC0: interrupt-controller { ++ compatible = "ibm,uic"; ++ interrupt-controller; ++ cell-index = <0>; ++ dcr-reg = <0c0 9>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ }; ++ ++ plb { ++ compatible = "ibm,plb3"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ ++ SDRAM0: memory-controller { ++ compatible = "ibm,sdram-405gp"; ++ dcr-reg = <010 2>; ++ }; ++ ++ MAL: mcmal { ++ compatible = "ibm,mcmal-405gp", "ibm,mcmal"; ++ dcr-reg = <180 62>; ++ num-tx-chans = <1>; ++ num-rx-chans = <1>; ++ interrupt-parent = <&UIC0>; ++ interrupts = < ++ b 4 /* TXEOB */ ++ c 4 /* RXEOB */ ++ a 4 /* SERR */ ++ d 4 /* TXDE */ ++ e 4 /* RXDE */>; ++ }; ++ ++ POB0: opb { ++ compatible = "ibm,opb-405gp", "ibm,opb"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges = <ef600000 ef600000 a00000>; ++ dcr-reg = <0a0 5>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ ++ UART0: serial@ef600300 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <ef600300 8>; ++ virtual-reg = <ef600300>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ current-speed = <2580>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <0 4>; ++ }; ++ ++ UART1: serial@ef600400 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <ef600400 8>; ++ virtual-reg = <ef600400>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ current-speed = <2580>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <1 4>; ++ }; ++ ++ IIC: i2c@ef600500 { ++ compatible = "ibm,iic-405gp", "ibm,iic"; ++ reg = <ef600500 11>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <2 4>; ++ }; ++ ++ GPIO: gpio@ef600700 { ++ compatible = "ibm,gpio-405gp"; ++ reg = <ef600700 20>; ++ }; ++ ++ EMAC: ethernet@ef600800 { ++ linux,network-index = <0>; ++ device_type = "network"; ++ compatible = "ibm,emac-405gp", "ibm,emac"; ++ interrupt-parent = <&UIC0>; ++ interrupts = < ++ f 4 /* Ethernet */ ++ 9 4 /* Ethernet Wake Up */>; ++ local-mac-address = [000000000000]; /* Filled in by zImage */ ++ reg = <ef600800 70>; ++ mal-device = <&MAL>; ++ mal-tx-channel = <0>; ++ mal-rx-channel = <0>; ++ cell-index = <0>; ++ max-frame-size = <5dc>; ++ rx-fifo-size = <1000>; ++ tx-fifo-size = <800>; ++ phy-mode = "rmii"; ++ phy-map = <00000000>; ++ }; ++ ++ }; ++ ++ EBC0: ebc { ++ compatible = "ibm,ebc-405gp", "ibm,ebc"; ++ dcr-reg = <012 2>; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ ++ ++ /* The ranges property is supplied by the bootwrapper ++ * and is based on the firmware's configuration of the ++ * EBC bridge ++ */ ++ clock-frequency = <0>; /* Filled in by zImage */ ++ ++ /* NVRAM and RTC */ ++ nvrtc@4,200000 { ++ compatible = "ds1742"; ++ reg = <4 200000 0>; /* size fixed up by zImage */ ++ }; ++ ++ /* "BCSR" CPLD contains a PCI irq controller */ ++ bcsr@4,0 { ++ compatible = "ep405-bcsr"; ++ reg = <4 0 10>; ++ interrupt-controller; ++ /* Routing table */ ++ irq-routing = [ 00 /* SYSERR */ ++ 01 /* STTM */ ++ 01 /* RTC */ ++ 01 /* FENET */ ++ 02 /* NB PCIIRQ mux ? */ ++ 03 /* SB Winbond 8259 ? */ ++ 04 /* Serial Ring */ ++ 05 /* USB (ep405pc) */ ++ 06 /* XIRQ 0 */ ++ 06 /* XIRQ 1 */ ++ 06 /* XIRQ 2 */ ++ 06 /* XIRQ 3 */ ++ 06 /* XIRQ 4 */ ++ 06 /* XIRQ 5 */ ++ 06 /* XIRQ 6 */ ++ 07]; /* Reserved */ ++ }; ++ }; ++ ++ PCI0: pci@ec000000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb405gp-pci", "ibm,plb-pci"; ++ primary; ++ reg = <eec00000 8 /* Config space access */ ++ eed80000 4 /* IACK */ ++ eed80000 4 /* Special cycle */ ++ ef480000 40>; /* Internal registers */ ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed. Chip supports a second ++ * IO range but we don't use it for now ++ */ ++ ranges = <02000000 0 80000000 80000000 0 20000000 ++ 01000000 0 00000000 e8000000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 80000000>; ++ ++ /* That's all I know about IRQs on that thing ... */ ++ interrupt-map-mask = <f800 0 0 0>; ++ interrupt-map = < ++ /* USB */ ++ 7000 0 0 0 &UIC0 1e 8 /* IRQ5 */ ++ >; ++ }; ++ }; ++ ++ chosen { ++ linux,stdout-path = "/plb/opb/serial@ef600300"; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/ep8248e.dts powerpc.git/arch/powerpc/boot/dts/ep8248e.dts +--- linux-2.6.24/arch/powerpc/boot/dts/ep8248e.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/ep8248e.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,207 @@ ++/* ++ * Device Tree for the Embedded Planet EP8248E board running PlanetCore. ++ * ++ * Copyright 2007 Freescale Semiconductor Inc. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++/dts-v1/; ++/ { ++ model = "EP8248E"; ++ compatible = "fsl,ep8248e"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ++ aliases { ++ planetcore-SMC1 = &smc1; ++ planetcore-SCC1 = &scc1; ++ ethernet0 = ð0; ++ ethernet1 = ð1; ++ serial0 = &smc1; ++ serial1 = &scc1; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ PowerPC,8248@0 { ++ device_type = "cpu"; ++ reg = <0>; ++ d-cache-line-size = <32>; ++ i-cache-line-size = <32>; ++ d-cache-size = <16384>; ++ i-cache-size = <16384>; ++ timebase-frequency = <0>; ++ clock-frequency = <0>; ++ }; ++ }; ++ ++ localbus@f0010100 { ++ compatible = "fsl,mpc8248-localbus", ++ "fsl,pq2-localbus", ++ "simple-bus"; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ reg = <0xf0010100 0x40>; ++ ++ ranges = <0 0 0xfc000000 0x04000000 ++ 1 0 0xfa000000 0x00008000>; ++ ++ flash@0,3800000 { ++ compatible = "cfi-flash"; ++ reg = <0 0x3800000 0x800000>; ++ bank-width = <4>; ++ device-width = <2>; ++ }; ++ ++ bcsr@1,0 { ++ #address-cells = <2>; ++ #size-cells = <1>; ++ reg = <1 0 0x10>; ++ compatible = "fsl,ep8248e-bcsr"; ++ ranges; ++ ++ mdio { ++ device_type = "mdio"; ++ compatible = "fsl,ep8248e-mdio-bitbang"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ reg = <1 8 1>; ++ ++ PHY0: ethernet-phy@0 { ++ interrupt-parent = <&PIC>; ++ reg = <0>; ++ device_type = "ethernet-phy"; ++ }; ++ ++ PHY1: ethernet-phy@1 { ++ interrupt-parent = <&PIC>; ++ reg = <1>; ++ device_type = "ethernet-phy"; ++ }; ++ }; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <0 0>; ++ }; ++ ++ soc@f0000000 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ compatible = "fsl,mpc8248-immr", "fsl,pq2-soc", "simple-bus"; ++ ranges = <0x00000000 0xf0000000 0x00053000>; ++ ++ // Temporary until code stops depending on it. ++ device_type = "soc"; ++ ++ // Temporary -- will go away once kernel uses ranges for get_immrbase(). ++ reg = <0xf0000000 0x00053000>; ++ ++ cpm@119c0 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ #interrupt-cells = <2>; ++ compatible = "fsl,mpc8248-cpm", "fsl,cpm2", ++ "simple-bus"; ++ reg = <0x119c0 0x30>; ++ ranges; ++ ++ muram { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges = <0 0 0x10000>; ++ ++ data@0 { ++ compatible = "fsl,cpm-muram-data"; ++ reg = <0 0x1100 0x1140 ++ 0xec0 0x9800 0x800>; ++ }; ++ }; ++ ++ brg@119f0 { ++ compatible = "fsl,mpc8248-brg", ++ "fsl,cpm2-brg", ++ "fsl,cpm-brg"; ++ reg = <0x119f0 0x10 0x115f0 0x10>; ++ }; ++ ++ /* Monitor port/SMC1 */ ++ smc1: serial@11a80 { ++ device_type = "serial"; ++ compatible = "fsl,mpc8248-smc-uart", ++ "fsl,cpm2-smc-uart"; ++ reg = <0x11a80 0x20 0x1100 0x40>; ++ interrupts = <4 8>; ++ interrupt-parent = <&PIC>; ++ fsl,cpm-brg = <7>; ++ fsl,cpm-command = <0x1d000000>; ++ linux,planetcore-label = "SMC1"; ++ }; ++ ++ /* "Serial" port/SCC1 */ ++ scc1: serial@11a00 { ++ device_type = "serial"; ++ compatible = "fsl,mpc8248-scc-uart", ++ "fsl,cpm2-scc-uart"; ++ reg = <0x11a00 0x20 0x8000 0x100>; ++ interrupts = <40 8>; ++ interrupt-parent = <&PIC>; ++ fsl,cpm-brg = <1>; ++ fsl,cpm-command = <0x00800000>; ++ linux,planetcore-label = "SCC1"; ++ }; ++ ++ eth0: ethernet@11300 { ++ device_type = "network"; ++ compatible = "fsl,mpc8248-fcc-enet", ++ "fsl,cpm2-fcc-enet"; ++ reg = <0x11300 0x20 0x8400 0x100 0x11390 1>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ interrupts = <32 8>; ++ interrupt-parent = <&PIC>; ++ phy-handle = <&PHY0>; ++ linux,network-index = <0>; ++ fsl,cpm-command = <0x12000300>; ++ }; ++ ++ eth1: ethernet@11320 { ++ device_type = "network"; ++ compatible = "fsl,mpc8248-fcc-enet", ++ "fsl,cpm2-fcc-enet"; ++ reg = <0x11320 0x20 0x8500 0x100 0x113b0 1>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ interrupts = <33 8>; ++ interrupt-parent = <&PIC>; ++ phy-handle = <&PHY1>; ++ linux,network-index = <1>; ++ fsl,cpm-command = <0x16200300>; ++ }; ++ ++ usb@11b60 { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ compatible = "fsl,mpc8248-usb", ++ "fsl,cpm2-usb"; ++ reg = <0x11b60 0x18 0x8b00 0x100>; ++ interrupt-parent = <&PIC>; ++ interrupts = <11 8>; ++ fsl,cpm-command = <0x2e600000>; ++ }; ++ }; ++ ++ PIC: interrupt-controller@10c00 { ++ #interrupt-cells = <2>; ++ interrupt-controller; ++ reg = <0x10c00 0x80>; ++ compatible = "fsl,mpc8248-pic", "fsl,pq2-pic"; ++ }; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/haleakala.dts powerpc.git/arch/powerpc/boot/dts/haleakala.dts +--- linux-2.6.24/arch/powerpc/boot/dts/haleakala.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/haleakala.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,274 @@ ++/* ++ * Device Tree Source for AMCC Haleakala (405EXr) ++ * ++ * Copyright 2008 DENX Software Engineering, Stefan Roese <sr@denx.de> ++ * ++ * This file is licensed under the terms of the GNU General Public ++ * License version 2. This program is licensed "as is" without ++ * any warranty of any kind, whether express or implied. ++ */ ++ ++/ { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ model = "amcc,haleakala"; ++ compatible = "amcc,kilauea"; ++ dcr-parent = <&/cpus/cpu@0>; ++ ++ aliases { ++ ethernet0 = &EMAC0; ++ serial0 = &UART0; ++ serial1 = &UART1; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ cpu@0 { ++ device_type = "cpu"; ++ model = "PowerPC,405EXr"; ++ reg = <0>; ++ clock-frequency = <0>; /* Filled in by U-Boot */ ++ timebase-frequency = <0>; /* Filled in by U-Boot */ ++ i-cache-line-size = <20>; ++ d-cache-line-size = <20>; ++ i-cache-size = <4000>; /* 16 kB */ ++ d-cache-size = <4000>; /* 16 kB */ ++ dcr-controller; ++ dcr-access-method = "native"; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <0 0>; /* Filled in by U-Boot */ ++ }; ++ ++ UIC0: interrupt-controller { ++ compatible = "ibm,uic-405exr", "ibm,uic"; ++ interrupt-controller; ++ cell-index = <0>; ++ dcr-reg = <0c0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ }; ++ ++ UIC1: interrupt-controller1 { ++ compatible = "ibm,uic-405exr","ibm,uic"; ++ interrupt-controller; ++ cell-index = <1>; ++ dcr-reg = <0d0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ interrupts = <1e 4 1f 4>; /* cascade */ ++ interrupt-parent = <&UIC0>; ++ }; ++ ++ UIC2: interrupt-controller2 { ++ compatible = "ibm,uic-405exr","ibm,uic"; ++ interrupt-controller; ++ cell-index = <2>; ++ dcr-reg = <0e0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ interrupts = <1c 4 1d 4>; /* cascade */ ++ interrupt-parent = <&UIC0>; ++ }; ++ ++ plb { ++ compatible = "ibm,plb-405exr", "ibm,plb4"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges; ++ clock-frequency = <0>; /* Filled in by U-Boot */ ++ ++ SDRAM0: memory-controller { ++ compatible = "ibm,sdram-405exr"; ++ dcr-reg = <010 2>; ++ }; ++ ++ MAL0: mcmal { ++ compatible = "ibm,mcmal-405exr", "ibm,mcmal2"; ++ dcr-reg = <180 62>; ++ num-tx-chans = <2>; ++ num-rx-chans = <2>; ++ interrupt-parent = <&MAL0>; ++ interrupts = <0 1 2 3 4>; ++ #interrupt-cells = <1>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ interrupt-map = </*TXEOB*/ 0 &UIC0 a 4 ++ /*RXEOB*/ 1 &UIC0 b 4 ++ /*SERR*/ 2 &UIC1 0 4 ++ /*TXDE*/ 3 &UIC1 1 4 ++ /*RXDE*/ 4 &UIC1 2 4>; ++ interrupt-map-mask = <ffffffff>; ++ }; ++ ++ POB0: opb { ++ compatible = "ibm,opb-405exr", "ibm,opb"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges = <80000000 80000000 10000000 ++ ef600000 ef600000 a00000 ++ f0000000 f0000000 10000000>; ++ dcr-reg = <0a0 5>; ++ clock-frequency = <0>; /* Filled in by U-Boot */ ++ ++ EBC0: ebc { ++ compatible = "ibm,ebc-405exr", "ibm,ebc"; ++ dcr-reg = <012 2>; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ clock-frequency = <0>; /* Filled in by U-Boot */ ++ /* ranges property is supplied by U-Boot */ ++ interrupts = <5 1>; ++ interrupt-parent = <&UIC1>; ++ ++ nor_flash@0,0 { ++ compatible = "amd,s29gl512n", "cfi-flash"; ++ bank-width = <2>; ++ reg = <0 000000 4000000>; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ partition@0 { ++ label = "kernel"; ++ reg = <0 200000>; ++ }; ++ partition@200000 { ++ label = "root"; ++ reg = <200000 200000>; ++ }; ++ partition@400000 { ++ label = "user"; ++ reg = <400000 3b60000>; ++ }; ++ partition@3f60000 { ++ label = "env"; ++ reg = <3f60000 40000>; ++ }; ++ partition@3fa0000 { ++ label = "u-boot"; ++ reg = <3fa0000 60000>; ++ }; ++ }; ++ }; ++ ++ UART0: serial@ef600200 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <ef600200 8>; ++ virtual-reg = <ef600200>; ++ clock-frequency = <0>; /* Filled in by U-Boot */ ++ current-speed = <0>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <1a 4>; ++ }; ++ ++ UART1: serial@ef600300 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <ef600300 8>; ++ virtual-reg = <ef600300>; ++ clock-frequency = <0>; /* Filled in by U-Boot */ ++ current-speed = <0>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <1 4>; ++ }; ++ ++ IIC0: i2c@ef600400 { ++ compatible = "ibm,iic-405exr", "ibm,iic"; ++ reg = <ef600400 14>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <2 4>; ++ }; ++ ++ IIC1: i2c@ef600500 { ++ compatible = "ibm,iic-405exr", "ibm,iic"; ++ reg = <ef600500 14>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <7 4>; ++ }; ++ ++ ++ RGMII0: emac-rgmii@ef600b00 { ++ compatible = "ibm,rgmii-405exr", "ibm,rgmii"; ++ reg = <ef600b00 104>; ++ has-mdio; ++ }; ++ ++ EMAC0: ethernet@ef600900 { ++ linux,network-index = <0>; ++ device_type = "network"; ++ compatible = "ibm,emac-405exr", "ibm,emac4"; ++ interrupt-parent = <&EMAC0>; ++ interrupts = <0 1>; ++ #interrupt-cells = <1>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ interrupt-map = </*Status*/ 0 &UIC0 18 4 ++ /*Wake*/ 1 &UIC1 1d 4>; ++ reg = <ef600900 70>; ++ local-mac-address = [000000000000]; /* Filled in by U-Boot */ ++ mal-device = <&MAL0>; ++ mal-tx-channel = <0>; ++ mal-rx-channel = <0>; ++ cell-index = <0>; ++ max-frame-size = <5dc>; ++ rx-fifo-size = <1000>; ++ tx-fifo-size = <800>; ++ phy-mode = "rgmii"; ++ phy-map = <00000000>; ++ rgmii-device = <&RGMII0>; ++ rgmii-channel = <0>; ++ has-inverted-stacr-oc; ++ has-new-stacr-staopc; ++ }; ++ }; ++ ++ PCIE0: pciex@0a0000000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb-pciex-405exr", "ibm,plb-pciex"; ++ primary; ++ port = <0>; /* port number */ ++ reg = <a0000000 20000000 /* Config space access */ ++ ef000000 00001000>; /* Registers */ ++ dcr-reg = <040 020>; ++ sdr-base = <400>; ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed ++ */ ++ ranges = <02000000 0 80000000 90000000 0 08000000 ++ 01000000 0 00000000 e0000000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 80000000>; ++ ++ /* This drives busses 0x00 to 0x3f */ ++ bus-range = <00 3f>; ++ ++ /* Legacy interrupts (note the weird polarity, the bridge seems ++ * to invert PCIe legacy interrupts). ++ * We are de-swizzling here because the numbers are actually for ++ * port of the root complex virtual P2P bridge. But I want ++ * to avoid putting a node for it in the tree, so the numbers ++ * below are basically de-swizzled numbers. ++ * The real slot is on idsel 0, so the swizzling is 1:1 ++ */ ++ interrupt-map-mask = <0000 0 0 7>; ++ interrupt-map = < ++ 0000 0 0 1 &UIC2 0 4 /* swizzled int A */ ++ 0000 0 0 2 &UIC2 1 4 /* swizzled int B */ ++ 0000 0 0 3 &UIC2 2 4 /* swizzled int C */ ++ 0000 0 0 4 &UIC2 3 4 /* swizzled int D */>; ++ }; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/katmai.dts powerpc.git/arch/powerpc/boot/dts/katmai.dts +--- linux-2.6.24/arch/powerpc/boot/dts/katmai.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/katmai.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,400 @@ ++/* ++ * Device Tree Source for AMCC Katmai eval board ++ * ++ * Copyright (c) 2006, 2007 IBM Corp. ++ * Benjamin Herrenschmidt <benh@kernel.crashing.org> ++ * ++ * Copyright (c) 2006, 2007 IBM Corp. ++ * Josh Boyer <jwboyer@linux.vnet.ibm.com> ++ * ++ * This file is licensed under the terms of the GNU General Public ++ * License version 2. This program is licensed "as is" without ++ * any warranty of any kind, whether express or implied. ++ */ ++ ++/ { ++ #address-cells = <2>; ++ #size-cells = <1>; ++ model = "amcc,katmai"; ++ compatible = "amcc,katmai"; ++ dcr-parent = <&/cpus/cpu@0>; ++ ++ aliases { ++ ethernet0 = &EMAC0; ++ serial0 = &UART0; ++ serial1 = &UART1; ++ serial2 = &UART2; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ cpu@0 { ++ device_type = "cpu"; ++ model = "PowerPC,440SPe"; ++ reg = <0>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ timebase-frequency = <0>; /* Filled in by zImage */ ++ i-cache-line-size = <20>; ++ d-cache-line-size = <20>; ++ i-cache-size = <20000>; ++ d-cache-size = <20000>; ++ dcr-controller; ++ dcr-access-method = "native"; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <0 0 0>; /* Filled in by zImage */ ++ }; ++ ++ UIC0: interrupt-controller0 { ++ compatible = "ibm,uic-440spe","ibm,uic"; ++ interrupt-controller; ++ cell-index = <0>; ++ dcr-reg = <0c0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ }; ++ ++ UIC1: interrupt-controller1 { ++ compatible = "ibm,uic-440spe","ibm,uic"; ++ interrupt-controller; ++ cell-index = <1>; ++ dcr-reg = <0d0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ interrupts = <1e 4 1f 4>; /* cascade */ ++ interrupt-parent = <&UIC0>; ++ }; ++ ++ UIC2: interrupt-controller2 { ++ compatible = "ibm,uic-440spe","ibm,uic"; ++ interrupt-controller; ++ cell-index = <2>; ++ dcr-reg = <0e0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ interrupts = <a 4 b 4>; /* cascade */ ++ interrupt-parent = <&UIC0>; ++ }; ++ ++ UIC3: interrupt-controller3 { ++ compatible = "ibm,uic-440spe","ibm,uic"; ++ interrupt-controller; ++ cell-index = <3>; ++ dcr-reg = <0f0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ interrupts = <10 4 11 4>; /* cascade */ ++ interrupt-parent = <&UIC0>; ++ }; ++ ++ SDR0: sdr { ++ compatible = "ibm,sdr-440spe"; ++ dcr-reg = <00e 002>; ++ }; ++ ++ CPR0: cpr { ++ compatible = "ibm,cpr-440spe"; ++ dcr-reg = <00c 002>; ++ }; ++ ++ plb { ++ compatible = "ibm,plb-440spe", "ibm,plb-440gp", "ibm,plb4"; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ ranges; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ ++ SDRAM0: sdram { ++ compatible = "ibm,sdram-440spe", "ibm,sdram-405gp"; ++ dcr-reg = <010 2>; ++ }; ++ ++ MAL0: mcmal { ++ compatible = "ibm,mcmal-440spe", "ibm,mcmal2"; ++ dcr-reg = <180 62>; ++ num-tx-chans = <2>; ++ num-rx-chans = <1>; ++ interrupt-parent = <&MAL0>; ++ interrupts = <0 1 2 3 4>; ++ #interrupt-cells = <1>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ interrupt-map = </*TXEOB*/ 0 &UIC1 6 4 ++ /*RXEOB*/ 1 &UIC1 7 4 ++ /*SERR*/ 2 &UIC1 1 4 ++ /*TXDE*/ 3 &UIC1 2 4 ++ /*RXDE*/ 4 &UIC1 3 4>; ++ }; ++ ++ POB0: opb { ++ compatible = "ibm,opb-440spe", "ibm,opb-440gp", "ibm,opb"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges = <00000000 4 e0000000 20000000>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ ++ EBC0: ebc { ++ compatible = "ibm,ebc-440spe", "ibm,ebc-440gp", "ibm,ebc"; ++ dcr-reg = <012 2>; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ interrupts = <5 1>; ++ interrupt-parent = <&UIC1>; ++ }; ++ ++ UART0: serial@10000200 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <10000200 8>; ++ virtual-reg = <a0000200>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ current-speed = <1c200>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <0 4>; ++ }; ++ ++ UART1: serial@10000300 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <10000300 8>; ++ virtual-reg = <a0000300>; ++ clock-frequency = <0>; ++ current-speed = <0>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <1 4>; ++ }; ++ ++ ++ UART2: serial@10000600 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <10000600 8>; ++ virtual-reg = <a0000600>; ++ clock-frequency = <0>; ++ current-speed = <0>; ++ interrupt-parent = <&UIC1>; ++ interrupts = <5 4>; ++ }; ++ ++ IIC0: i2c@10000400 { ++ device_type = "i2c"; ++ compatible = "ibm,iic-440spe", "ibm,iic-440gp", "ibm,iic"; ++ reg = <10000400 14>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <2 4>; ++ }; ++ ++ IIC1: i2c@10000500 { ++ device_type = "i2c"; ++ compatible = "ibm,iic-440spe", "ibm,iic-440gp", "ibm,iic"; ++ reg = <10000500 14>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <3 4>; ++ }; ++ ++ EMAC0: ethernet@10000800 { ++ linux,network-index = <0>; ++ device_type = "network"; ++ compatible = "ibm,emac-440spe", "ibm,emac4"; ++ interrupt-parent = <&UIC1>; ++ interrupts = <1c 4 1d 4>; ++ reg = <10000800 70>; ++ local-mac-address = [000000000000]; ++ mal-device = <&MAL0>; ++ mal-tx-channel = <0>; ++ mal-rx-channel = <0>; ++ cell-index = <0>; ++ max-frame-size = <5dc>; ++ rx-fifo-size = <1000>; ++ tx-fifo-size = <800>; ++ phy-mode = "gmii"; ++ phy-map = <00000000>; ++ has-inverted-stacr-oc; ++ has-new-stacr-staopc; ++ }; ++ }; ++ ++ PCIX0: pci@c0ec00000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb-pcix-440spe", "ibm,plb-pcix"; ++ primary; ++ large-inbound-windows; ++ enable-msi-hole; ++ reg = <c 0ec00000 8 /* Config space access */ ++ 0 0 0 /* no IACK cycles */ ++ c 0ed00000 4 /* Special cycles */ ++ c 0ec80000 100 /* Internal registers */ ++ c 0ec80100 fc>; /* Internal messaging registers */ ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed ++ */ ++ ranges = <02000000 0 80000000 0000000d 80000000 0 80000000 ++ 01000000 0 00000000 0000000c 08000000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 0 80000000>; ++ ++ /* This drives busses 0 to 0xf */ ++ bus-range = <0 f>; ++ ++ /* ++ * On Katmai, the following PCI-X interrupts signals ++ * have to be enabled via jumpers (only INTA is ++ * enabled per default): ++ * ++ * INTB: J3: 1-2 ++ * INTC: J2: 1-2 ++ * INTD: J1: 1-2 ++ */ ++ interrupt-map-mask = <f800 0 0 7>; ++ interrupt-map = < ++ /* IDSEL 1 */ ++ 0800 0 0 1 &UIC1 14 8 ++ 0800 0 0 2 &UIC1 13 8 ++ 0800 0 0 3 &UIC1 12 8 ++ 0800 0 0 4 &UIC1 11 8 ++ >; ++ }; ++ ++ PCIE0: pciex@d00000000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb-pciex-440spe", "ibm,plb-pciex"; ++ primary; ++ port = <0>; /* port number */ ++ reg = <d 00000000 20000000 /* Config space access */ ++ c 10000000 00001000>; /* Registers */ ++ dcr-reg = <100 020>; ++ sdr-base = <300>; ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed ++ */ ++ ranges = <02000000 0 80000000 0000000e 00000000 0 80000000 ++ 01000000 0 00000000 0000000f 80000000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 0 80000000>; ++ ++ /* This drives busses 10 to 0x1f */ ++ bus-range = <10 1f>; ++ ++ /* Legacy interrupts (note the weird polarity, the bridge seems ++ * to invert PCIe legacy interrupts). ++ * We are de-swizzling here because the numbers are actually for ++ * port of the root complex virtual P2P bridge. But I want ++ * to avoid putting a node for it in the tree, so the numbers ++ * below are basically de-swizzled numbers. ++ * The real slot is on idsel 0, so the swizzling is 1:1 ++ */ ++ interrupt-map-mask = <0000 0 0 7>; ++ interrupt-map = < ++ 0000 0 0 1 &UIC3 0 4 /* swizzled int A */ ++ 0000 0 0 2 &UIC3 1 4 /* swizzled int B */ ++ 0000 0 0 3 &UIC3 2 4 /* swizzled int C */ ++ 0000 0 0 4 &UIC3 3 4 /* swizzled int D */>; ++ }; ++ ++ PCIE1: pciex@d20000000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb-pciex-440spe", "ibm,plb-pciex"; ++ primary; ++ port = <1>; /* port number */ ++ reg = <d 20000000 20000000 /* Config space access */ ++ c 10001000 00001000>; /* Registers */ ++ dcr-reg = <120 020>; ++ sdr-base = <340>; ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed ++ */ ++ ranges = <02000000 0 80000000 0000000e 80000000 0 80000000 ++ 01000000 0 00000000 0000000f 80010000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 0 80000000>; ++ ++ /* This drives busses 10 to 0x1f */ ++ bus-range = <20 2f>; ++ ++ /* Legacy interrupts (note the weird polarity, the bridge seems ++ * to invert PCIe legacy interrupts). ++ * We are de-swizzling here because the numbers are actually for ++ * port of the root complex virtual P2P bridge. But I want ++ * to avoid putting a node for it in the tree, so the numbers ++ * below are basically de-swizzled numbers. ++ * The real slot is on idsel 0, so the swizzling is 1:1 ++ */ ++ interrupt-map-mask = <0000 0 0 7>; ++ interrupt-map = < ++ 0000 0 0 1 &UIC3 4 4 /* swizzled int A */ ++ 0000 0 0 2 &UIC3 5 4 /* swizzled int B */ ++ 0000 0 0 3 &UIC3 6 4 /* swizzled int C */ ++ 0000 0 0 4 &UIC3 7 4 /* swizzled int D */>; ++ }; ++ ++ PCIE2: pciex@d40000000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb-pciex-440spe", "ibm,plb-pciex"; ++ primary; ++ port = <2>; /* port number */ ++ reg = <d 40000000 20000000 /* Config space access */ ++ c 10002000 00001000>; /* Registers */ ++ dcr-reg = <140 020>; ++ sdr-base = <370>; ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed ++ */ ++ ranges = <02000000 0 80000000 0000000f 00000000 0 80000000 ++ 01000000 0 00000000 0000000f 80020000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 0 80000000>; ++ ++ /* This drives busses 10 to 0x1f */ ++ bus-range = <30 3f>; ++ ++ /* Legacy interrupts (note the weird polarity, the bridge seems ++ * to invert PCIe legacy interrupts). ++ * We are de-swizzling here because the numbers are actually for ++ * port of the root complex virtual P2P bridge. But I want ++ * to avoid putting a node for it in the tree, so the numbers ++ * below are basically de-swizzled numbers. ++ * The real slot is on idsel 0, so the swizzling is 1:1 ++ */ ++ interrupt-map-mask = <0000 0 0 7>; ++ interrupt-map = < ++ 0000 0 0 1 &UIC3 8 4 /* swizzled int A */ ++ 0000 0 0 2 &UIC3 9 4 /* swizzled int B */ ++ 0000 0 0 3 &UIC3 a 4 /* swizzled int C */ ++ 0000 0 0 4 &UIC3 b 4 /* swizzled int D */>; ++ }; ++ }; ++ ++ chosen { ++ linux,stdout-path = "/plb/opb/serial@10000200"; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/kilauea.dts powerpc.git/arch/powerpc/boot/dts/kilauea.dts +--- linux-2.6.24/arch/powerpc/boot/dts/kilauea.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/kilauea.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -13,14 +13,22 @@ + #size-cells = <1>; + model = "amcc,kilauea"; + compatible = "amcc,kilauea"; +- dcr-parent = <&/cpus/PowerPC,405EX@0>; ++ dcr-parent = <&/cpus/cpu@0>; ++ ++ aliases { ++ ethernet0 = &EMAC0; ++ ethernet1 = &EMAC1; ++ serial0 = &UART0; ++ serial1 = &UART1; ++ }; + + cpus { + #address-cells = <1>; + #size-cells = <0>; + +- PowerPC,405EX@0 { ++ cpu@0 { + device_type = "cpu"; ++ model = "PowerPC,405EX"; + reg = <0>; + clock-frequency = <0>; /* Filled in by U-Boot */ + timebase-frequency = <0>; /* Filled in by U-Boot */ +@@ -194,6 +202,7 @@ + device_type = "rgmii-interface"; + compatible = "ibm,rgmii-405ex", "ibm,rgmii"; + reg = <ef600b00 104>; ++ has-mdio; + }; + + EMAC0: ethernet@ef600900 { +@@ -220,6 +229,8 @@ + phy-map = <00000000>; + rgmii-device = <&RGMII0>; + rgmii-channel = <0>; ++ has-inverted-stacr-oc; ++ has-new-stacr-staopc; + }; + + EMAC1: ethernet@ef600a00 { +@@ -246,7 +257,91 @@ + phy-map = <00000000>; + rgmii-device = <&RGMII0>; + rgmii-channel = <1>; ++ has-inverted-stacr-oc; ++ has-new-stacr-staopc; + }; + }; ++ ++ PCIE0: pciex@0a0000000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb-pciex-405ex", "ibm,plb-pciex"; ++ primary; ++ port = <0>; /* port number */ ++ reg = <a0000000 20000000 /* Config space access */ ++ ef000000 00001000>; /* Registers */ ++ dcr-reg = <040 020>; ++ sdr-base = <400>; ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed ++ */ ++ ranges = <02000000 0 80000000 90000000 0 08000000 ++ 01000000 0 00000000 e0000000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 80000000>; ++ ++ /* This drives busses 0x00 to 0x3f */ ++ bus-range = <00 3f>; ++ ++ /* Legacy interrupts (note the weird polarity, the bridge seems ++ * to invert PCIe legacy interrupts). ++ * We are de-swizzling here because the numbers are actually for ++ * port of the root complex virtual P2P bridge. But I want ++ * to avoid putting a node for it in the tree, so the numbers ++ * below are basically de-swizzled numbers. ++ * The real slot is on idsel 0, so the swizzling is 1:1 ++ */ ++ interrupt-map-mask = <0000 0 0 7>; ++ interrupt-map = < ++ 0000 0 0 1 &UIC2 0 4 /* swizzled int A */ ++ 0000 0 0 2 &UIC2 1 4 /* swizzled int B */ ++ 0000 0 0 3 &UIC2 2 4 /* swizzled int C */ ++ 0000 0 0 4 &UIC2 3 4 /* swizzled int D */>; ++ }; ++ ++ PCIE1: pciex@0c0000000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb-pciex-405ex", "ibm,plb-pciex"; ++ primary; ++ port = <1>; /* port number */ ++ reg = <c0000000 20000000 /* Config space access */ ++ ef001000 00001000>; /* Registers */ ++ dcr-reg = <060 020>; ++ sdr-base = <440>; ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed ++ */ ++ ranges = <02000000 0 80000000 98000000 0 08000000 ++ 01000000 0 00000000 e0010000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 80000000>; ++ ++ /* This drives busses 0x40 to 0x7f */ ++ bus-range = <40 7f>; ++ ++ /* Legacy interrupts (note the weird polarity, the bridge seems ++ * to invert PCIe legacy interrupts). ++ * We are de-swizzling here because the numbers are actually for ++ * port of the root complex virtual P2P bridge. But I want ++ * to avoid putting a node for it in the tree, so the numbers ++ * below are basically de-swizzled numbers. ++ * The real slot is on idsel 0, so the swizzling is 1:1 ++ */ ++ interrupt-map-mask = <0000 0 0 7>; ++ interrupt-map = < ++ 0000 0 0 1 &UIC2 b 4 /* swizzled int A */ ++ 0000 0 0 2 &UIC2 c 4 /* swizzled int B */ ++ 0000 0 0 3 &UIC2 d 4 /* swizzled int C */ ++ 0000 0 0 4 &UIC2 e 4 /* swizzled int D */>; ++ }; + }; + }; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/kuroboxHD.dts powerpc.git/arch/powerpc/boot/dts/kuroboxHD.dts +--- linux-2.6.24/arch/powerpc/boot/dts/kuroboxHD.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/kuroboxHD.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -23,6 +23,12 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -60,7 +66,7 @@ + i2c@80003000 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "i2c"; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <80003000 1000>; + interrupts = <5 2>; +@@ -73,7 +79,8 @@ + }; + }; + +- serial@80004500 { ++ serial0: serial@80004500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <80004500 8>; +@@ -83,7 +90,8 @@ + interrupt-parent = <&mpic>; + }; + +- serial@80004600 { ++ serial1: serial@80004600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <80004600 8>; +@@ -102,7 +110,7 @@ + reg = <80040000 40000>; + }; + +- pci@fec00000 { ++ pci0: pci@fec00000 { + #address-cells = <3>; + #size-cells = <2>; + #interrupt-cells = <1>; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/kuroboxHG.dts powerpc.git/arch/powerpc/boot/dts/kuroboxHG.dts +--- linux-2.6.24/arch/powerpc/boot/dts/kuroboxHG.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/kuroboxHG.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -23,6 +23,12 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -60,7 +66,7 @@ + i2c@80003000 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "i2c"; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <80003000 1000>; + interrupts = <5 2>; +@@ -73,7 +79,8 @@ + }; + }; + +- serial@80004500 { ++ serial0: serial@80004500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <80004500 8>; +@@ -83,7 +90,8 @@ + interrupt-parent = <&mpic>; + }; + +- serial@80004600 { ++ serial1: serial@80004600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <80004600 8>; +@@ -102,7 +110,7 @@ + reg = <80040000 40000>; + }; + +- pci@fec00000 { ++ pci0: pci@fec00000 { + #address-cells = <3>; + #size-cells = <2>; + #interrupt-cells = <1>; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/lite5200.dts powerpc.git/arch/powerpc/boot/dts/lite5200.dts +--- linux-2.6.24/arch/powerpc/boot/dts/lite5200.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/lite5200.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -19,7 +19,7 @@ + / { + model = "fsl,lite5200"; + // revision = "1.0"; +- compatible = "fsl,lite5200","generic-mpc5200"; ++ compatible = "fsl,lite5200"; + #address-cells = <1>; + #size-cells = <1>; + +@@ -284,7 +284,8 @@ + }; + + i2c@3d00 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; + compatible = "mpc5200-i2c","fsl-i2c"; + cell-index = <0>; + reg = <3d00 40>; +@@ -294,7 +295,8 @@ + }; + + i2c@3d40 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; + compatible = "mpc5200-i2c","fsl-i2c"; + cell-index = <1>; + reg = <3d40 40>; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/lite5200b.dts powerpc.git/arch/powerpc/boot/dts/lite5200b.dts +--- linux-2.6.24/arch/powerpc/boot/dts/lite5200b.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/lite5200b.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -19,7 +19,7 @@ + / { + model = "fsl,lite5200b"; + // revision = "1.0"; +- compatible = "fsl,lite5200b","generic-mpc5200"; ++ compatible = "fsl,lite5200b"; + #address-cells = <1>; + #size-cells = <1>; + +@@ -300,7 +300,8 @@ + }; + + i2c@3d00 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; + compatible = "mpc5200b-i2c","mpc5200-i2c","fsl-i2c"; + cell-index = <0>; + reg = <3d00 40>; +@@ -310,7 +311,8 @@ + }; + + i2c@3d40 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; + compatible = "mpc5200b-i2c","mpc5200-i2c","fsl-i2c"; + cell-index = <1>; + reg = <3d40 40>; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/makalu.dts powerpc.git/arch/powerpc/boot/dts/makalu.dts +--- linux-2.6.24/arch/powerpc/boot/dts/makalu.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/makalu.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,347 @@ ++/* ++ * Device Tree Source for AMCC Makalu (405EX) ++ * ++ * Copyright 2007 DENX Software Engineering, Stefan Roese <sr@denx.de> ++ * ++ * This file is licensed under the terms of the GNU General Public ++ * License version 2. This program is licensed "as is" without ++ * any warranty of any kind, whether express or implied. ++ */ ++ ++/ { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ model = "amcc,makalu"; ++ compatible = "amcc,makalu"; ++ dcr-parent = <&/cpus/cpu@0>; ++ ++ aliases { ++ ethernet0 = &EMAC0; ++ ethernet1 = &EMAC1; ++ serial0 = &UART0; ++ serial1 = &UART1; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ cpu@0 { ++ device_type = "cpu"; ++ model = "PowerPC,405EX"; ++ reg = <0>; ++ clock-frequency = <0>; /* Filled in by U-Boot */ ++ timebase-frequency = <0>; /* Filled in by U-Boot */ ++ i-cache-line-size = <20>; ++ d-cache-line-size = <20>; ++ i-cache-size = <4000>; /* 16 kB */ ++ d-cache-size = <4000>; /* 16 kB */ ++ dcr-controller; ++ dcr-access-method = "native"; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <0 0>; /* Filled in by U-Boot */ ++ }; ++ ++ UIC0: interrupt-controller { ++ compatible = "ibm,uic-405ex", "ibm,uic"; ++ interrupt-controller; ++ cell-index = <0>; ++ dcr-reg = <0c0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ }; ++ ++ UIC1: interrupt-controller1 { ++ compatible = "ibm,uic-405ex","ibm,uic"; ++ interrupt-controller; ++ cell-index = <1>; ++ dcr-reg = <0d0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ interrupts = <1e 4 1f 4>; /* cascade */ ++ interrupt-parent = <&UIC0>; ++ }; ++ ++ UIC2: interrupt-controller2 { ++ compatible = "ibm,uic-405ex","ibm,uic"; ++ interrupt-controller; ++ cell-index = <2>; ++ dcr-reg = <0e0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ interrupts = <1c 4 1d 4>; /* cascade */ ++ interrupt-parent = <&UIC0>; ++ }; ++ ++ plb { ++ compatible = "ibm,plb-405ex", "ibm,plb4"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges; ++ clock-frequency = <0>; /* Filled in by U-Boot */ ++ ++ SDRAM0: memory-controller { ++ compatible = "ibm,sdram-405ex"; ++ dcr-reg = <010 2>; ++ }; ++ ++ MAL0: mcmal { ++ compatible = "ibm,mcmal-405ex", "ibm,mcmal2"; ++ dcr-reg = <180 62>; ++ num-tx-chans = <2>; ++ num-rx-chans = <2>; ++ interrupt-parent = <&MAL0>; ++ interrupts = <0 1 2 3 4>; ++ #interrupt-cells = <1>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ interrupt-map = </*TXEOB*/ 0 &UIC0 a 4 ++ /*RXEOB*/ 1 &UIC0 b 4 ++ /*SERR*/ 2 &UIC1 0 4 ++ /*TXDE*/ 3 &UIC1 1 4 ++ /*RXDE*/ 4 &UIC1 2 4>; ++ interrupt-map-mask = <ffffffff>; ++ }; ++ ++ POB0: opb { ++ compatible = "ibm,opb-405ex", "ibm,opb"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges = <80000000 80000000 10000000 ++ ef600000 ef600000 a00000 ++ f0000000 f0000000 10000000>; ++ dcr-reg = <0a0 5>; ++ clock-frequency = <0>; /* Filled in by U-Boot */ ++ ++ EBC0: ebc { ++ compatible = "ibm,ebc-405ex", "ibm,ebc"; ++ dcr-reg = <012 2>; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ clock-frequency = <0>; /* Filled in by U-Boot */ ++ /* ranges property is supplied by U-Boot */ ++ interrupts = <5 1>; ++ interrupt-parent = <&UIC1>; ++ ++ nor_flash@0,0 { ++ compatible = "amd,s29gl512n", "cfi-flash"; ++ bank-width = <2>; ++ reg = <0 000000 4000000>; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ partition@0 { ++ label = "kernel"; ++ reg = <0 200000>; ++ }; ++ partition@200000 { ++ label = "root"; ++ reg = <200000 200000>; ++ }; ++ partition@400000 { ++ label = "user"; ++ reg = <400000 3b60000>; ++ }; ++ partition@3f60000 { ++ label = "env"; ++ reg = <3f60000 40000>; ++ }; ++ partition@3fa0000 { ++ label = "u-boot"; ++ reg = <3fa0000 60000>; ++ }; ++ }; ++ }; ++ ++ UART0: serial@ef600200 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <ef600200 8>; ++ virtual-reg = <ef600200>; ++ clock-frequency = <0>; /* Filled in by U-Boot */ ++ current-speed = <0>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <1a 4>; ++ }; ++ ++ UART1: serial@ef600300 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <ef600300 8>; ++ virtual-reg = <ef600300>; ++ clock-frequency = <0>; /* Filled in by U-Boot */ ++ current-speed = <0>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <1 4>; ++ }; ++ ++ IIC0: i2c@ef600400 { ++ device_type = "i2c"; ++ compatible = "ibm,iic-405ex", "ibm,iic"; ++ reg = <ef600400 14>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <2 4>; ++ }; ++ ++ IIC1: i2c@ef600500 { ++ device_type = "i2c"; ++ compatible = "ibm,iic-405ex", "ibm,iic"; ++ reg = <ef600500 14>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <7 4>; ++ }; ++ ++ ++ RGMII0: emac-rgmii@ef600b00 { ++ device_type = "rgmii-interface"; ++ compatible = "ibm,rgmii-405ex", "ibm,rgmii"; ++ reg = <ef600b00 104>; ++ has-mdio; ++ }; ++ ++ EMAC0: ethernet@ef600900 { ++ linux,network-index = <0>; ++ device_type = "network"; ++ compatible = "ibm,emac-405ex", "ibm,emac4"; ++ interrupt-parent = <&EMAC0>; ++ interrupts = <0 1>; ++ #interrupt-cells = <1>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ interrupt-map = </*Status*/ 0 &UIC0 18 4 ++ /*Wake*/ 1 &UIC1 1d 4>; ++ reg = <ef600900 70>; ++ local-mac-address = [000000000000]; /* Filled in by U-Boot */ ++ mal-device = <&MAL0>; ++ mal-tx-channel = <0>; ++ mal-rx-channel = <0>; ++ cell-index = <0>; ++ max-frame-size = <5dc>; ++ rx-fifo-size = <1000>; ++ tx-fifo-size = <800>; ++ phy-mode = "rgmii"; ++ phy-map = <0000003f>; /* Start at 6 */ ++ rgmii-device = <&RGMII0>; ++ rgmii-channel = <0>; ++ has-inverted-stacr-oc; ++ has-new-stacr-staopc; ++ }; ++ ++ EMAC1: ethernet@ef600a00 { ++ linux,network-index = <1>; ++ device_type = "network"; ++ compatible = "ibm,emac-405ex", "ibm,emac4"; ++ interrupt-parent = <&EMAC1>; ++ interrupts = <0 1>; ++ #interrupt-cells = <1>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ interrupt-map = </*Status*/ 0 &UIC0 19 4 ++ /*Wake*/ 1 &UIC1 1f 4>; ++ reg = <ef600a00 70>; ++ local-mac-address = [000000000000]; /* Filled in by U-Boot */ ++ mal-device = <&MAL0>; ++ mal-tx-channel = <1>; ++ mal-rx-channel = <1>; ++ cell-index = <1>; ++ max-frame-size = <5dc>; ++ rx-fifo-size = <1000>; ++ tx-fifo-size = <800>; ++ phy-mode = "rgmii"; ++ phy-map = <00000000>; ++ rgmii-device = <&RGMII0>; ++ rgmii-channel = <1>; ++ has-inverted-stacr-oc; ++ has-new-stacr-staopc; ++ }; ++ }; ++ ++ PCIE0: pciex@0a0000000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb-pciex-405ex", "ibm,plb-pciex"; ++ primary; ++ port = <0>; /* port number */ ++ reg = <a0000000 20000000 /* Config space access */ ++ ef000000 00001000>; /* Registers */ ++ dcr-reg = <040 020>; ++ sdr-base = <400>; ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed ++ */ ++ ranges = <02000000 0 80000000 90000000 0 08000000 ++ 01000000 0 00000000 e0000000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 80000000>; ++ ++ /* This drives busses 0x00 to 0x3f */ ++ bus-range = <00 3f>; ++ ++ /* Legacy interrupts (note the weird polarity, the bridge seems ++ * to invert PCIe legacy interrupts). ++ * We are de-swizzling here because the numbers are actually for ++ * port of the root complex virtual P2P bridge. But I want ++ * to avoid putting a node for it in the tree, so the numbers ++ * below are basically de-swizzled numbers. ++ * The real slot is on idsel 0, so the swizzling is 1:1 ++ */ ++ interrupt-map-mask = <0000 0 0 7>; ++ interrupt-map = < ++ 0000 0 0 1 &UIC2 0 4 /* swizzled int A */ ++ 0000 0 0 2 &UIC2 1 4 /* swizzled int B */ ++ 0000 0 0 3 &UIC2 2 4 /* swizzled int C */ ++ 0000 0 0 4 &UIC2 3 4 /* swizzled int D */>; ++ }; ++ ++ PCIE1: pciex@0c0000000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb-pciex-405ex", "ibm,plb-pciex"; ++ primary; ++ port = <1>; /* port number */ ++ reg = <c0000000 20000000 /* Config space access */ ++ ef001000 00001000>; /* Registers */ ++ dcr-reg = <060 020>; ++ sdr-base = <440>; ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed ++ */ ++ ranges = <02000000 0 80000000 98000000 0 08000000 ++ 01000000 0 00000000 e0010000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 80000000>; ++ ++ /* This drives busses 0x40 to 0x7f */ ++ bus-range = <40 7f>; ++ ++ /* Legacy interrupts (note the weird polarity, the bridge seems ++ * to invert PCIe legacy interrupts). ++ * We are de-swizzling here because the numbers are actually for ++ * port of the root complex virtual P2P bridge. But I want ++ * to avoid putting a node for it in the tree, so the numbers ++ * below are basically de-swizzled numbers. ++ * The real slot is on idsel 0, so the swizzling is 1:1 ++ */ ++ interrupt-map-mask = <0000 0 0 7>; ++ interrupt-map = < ++ 0000 0 0 1 &UIC2 b 4 /* swizzled int A */ ++ 0000 0 0 2 &UIC2 c 4 /* swizzled int B */ ++ 0000 0 0 3 &UIC2 d 4 /* swizzled int C */ ++ 0000 0 0 4 &UIC2 e 4 /* swizzled int D */>; ++ }; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/motionpro.dts powerpc.git/arch/powerpc/boot/dts/motionpro.dts +--- linux-2.6.24/arch/powerpc/boot/dts/motionpro.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/motionpro.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,309 @@ ++/* ++ * Motion-PRO board Device Tree Source ++ * ++ * Copyright (C) 2007 Semihalf ++ * Marian Balakowicz <m8@semihalf.com> ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++/* ++ * WARNING: Do not depend on this tree layout remaining static just yet. ++ * The MPC5200 device tree conventions are still in flux ++ * Keep an eye on the linuxppc-dev mailing list for more details ++ */ ++ ++/ { ++ model = "promess,motionpro"; ++ compatible = "promess,motionpro"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ PowerPC,5200@0 { ++ device_type = "cpu"; ++ reg = <0>; ++ d-cache-line-size = <20>; ++ i-cache-line-size = <20>; ++ d-cache-size = <4000>; // L1, 16K ++ i-cache-size = <4000>; // L1, 16K ++ timebase-frequency = <0>; // from bootloader ++ bus-frequency = <0>; // from bootloader ++ clock-frequency = <0>; // from bootloader ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <00000000 04000000>; // 64MB ++ }; ++ ++ soc5200@f0000000 { ++ model = "fsl,mpc5200b"; ++ compatible = "fsl,mpc5200b"; ++ revision = ""; // from bootloader ++ device_type = "soc"; ++ ranges = <0 f0000000 0000c000>; ++ reg = <f0000000 00000100>; ++ bus-frequency = <0>; // from bootloader ++ system-frequency = <0>; // from bootloader ++ ++ cdm@200 { ++ compatible = "mpc5200b-cdm","mpc5200-cdm"; ++ reg = <200 38>; ++ }; ++ ++ mpc5200_pic: pic@500 { ++ // 5200 interrupts are encoded into two levels; ++ interrupt-controller; ++ #interrupt-cells = <3>; ++ compatible = "mpc5200b-pic","mpc5200-pic"; ++ reg = <500 80>; ++ }; ++ ++ gpt@600 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <600 10>; ++ interrupts = <1 9 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ fsl,has-wdt; ++ }; ++ ++ gpt@610 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <610 10>; ++ interrupts = <1 a 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ gpt@620 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <620 10>; ++ interrupts = <1 b 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ gpt@630 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <630 10>; ++ interrupts = <1 c 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ gpt@640 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <640 10>; ++ interrupts = <1 d 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ gpt@650 { // General Purpose Timer ++ compatible = "fsl,mpc5200b-gpt","fsl,mpc5200-gpt"; ++ reg = <650 10>; ++ interrupts = <1 e 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ motionpro-led@660 { // Motion-PRO status LED ++ compatible = "promess,motionpro-led"; ++ label = "motionpro-statusled"; ++ reg = <660 10>; ++ interrupts = <1 f 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ blink-delay = <64>; // 100 msec ++ }; ++ ++ motionpro-led@670 { // Motion-PRO ready LED ++ compatible = "promess,motionpro-led"; ++ label = "motionpro-readyled"; ++ reg = <670 10>; ++ interrupts = <1 10 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ rtc@800 { // Real time clock ++ compatible = "mpc5200b-rtc","mpc5200-rtc"; ++ reg = <800 100>; ++ interrupts = <1 5 0 1 6 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ mscan@980 { ++ compatible = "mpc5200b-mscan","mpc5200-mscan"; ++ interrupts = <2 12 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ reg = <980 80>; ++ }; ++ ++ gpio@b00 { ++ compatible = "mpc5200b-gpio","mpc5200-gpio"; ++ reg = <b00 40>; ++ interrupts = <1 7 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ gpio-wkup@c00 { ++ compatible = "mpc5200b-gpio-wkup","mpc5200-gpio-wkup"; ++ reg = <c00 40>; ++ interrupts = <1 8 0 0 3 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ ++ spi@f00 { ++ compatible = "mpc5200b-spi","mpc5200-spi"; ++ reg = <f00 20>; ++ interrupts = <2 d 0 2 e 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ usb@1000 { ++ compatible = "mpc5200b-ohci","mpc5200-ohci","ohci-be"; ++ reg = <1000 ff>; ++ interrupts = <2 6 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ dma-controller@1200 { ++ compatible = "mpc5200b-bestcomm","mpc5200-bestcomm"; ++ reg = <1200 80>; ++ interrupts = <3 0 0 3 1 0 3 2 0 3 3 0 ++ 3 4 0 3 5 0 3 6 0 3 7 0 ++ 3 8 0 3 9 0 3 a 0 3 b 0 ++ 3 c 0 3 d 0 3 e 0 3 f 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ xlb@1f00 { ++ compatible = "mpc5200b-xlb","mpc5200-xlb"; ++ reg = <1f00 100>; ++ }; ++ ++ serial@2000 { // PSC1 ++ device_type = "serial"; ++ compatible = "mpc5200b-psc-uart","mpc5200-psc-uart"; ++ port-number = <0>; // Logical port assignment ++ reg = <2000 100>; ++ interrupts = <2 1 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ // PSC2 in spi master mode ++ spi@2200 { // PSC2 ++ compatible = "mpc5200b-psc-spi","mpc5200-psc-spi"; ++ cell-index = <1>; ++ reg = <2200 100>; ++ interrupts = <2 2 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ // PSC5 in uart mode ++ serial@2800 { // PSC5 ++ device_type = "serial"; ++ compatible = "mpc5200b-psc-uart","mpc5200-psc-uart"; ++ port-number = <4>; // Logical port assignment ++ reg = <2800 100>; ++ interrupts = <2 c 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ ethernet@3000 { ++ device_type = "network"; ++ compatible = "mpc5200b-fec","mpc5200-fec"; ++ reg = <3000 800>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; /* Filled in by U-Boot */ ++ interrupts = <2 5 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ ata@3a00 { ++ compatible = "mpc5200b-ata","mpc5200-ata"; ++ reg = <3a00 100>; ++ interrupts = <2 7 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ i2c@3d40 { ++ compatible = "mpc5200b-i2c","mpc5200-i2c","fsl-i2c"; ++ reg = <3d40 40>; ++ interrupts = <2 10 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ fsl5200-clocking; ++ }; ++ ++ sram@8000 { ++ compatible = "mpc5200b-sram","mpc5200-sram"; ++ reg = <8000 4000>; ++ }; ++ }; ++ ++ lpb { ++ model = "fsl,lpb"; ++ compatible = "fsl,lpb"; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ ranges = <1 0 50000000 00010000 ++ 2 0 50010000 00010000 ++ 3 0 50020000 00010000>; ++ ++ // 8-bit DualPort SRAM on LocalPlus Bus CS1 ++ kollmorgen@1,0 { ++ compatible = "promess,motionpro-kollmorgen"; ++ reg = <1 0 10000>; ++ interrupts = <1 1 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ // 8-bit board CPLD on LocalPlus Bus CS2 ++ cpld@2,0 { ++ compatible = "promess,motionpro-cpld"; ++ reg = <2 0 10000>; ++ }; ++ ++ // 8-bit custom Anybus Module on LocalPlus Bus CS3 ++ anybus@3,0 { ++ compatible = "promess,motionpro-anybus"; ++ reg = <3 0 10000>; ++ }; ++ pro_module_general@3,0 { ++ compatible = "promess,pro_module_general"; ++ reg = <3 0 3>; ++ }; ++ pro_module_dio@3,800 { ++ compatible = "promess,pro_module_dio"; ++ reg = <3 800 2>; ++ }; ++ }; ++ ++ pci@f0000d00 { ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ device_type = "pci"; ++ compatible = "mpc5200b-pci","mpc5200-pci"; ++ reg = <f0000d00 100>; ++ interrupt-map-mask = <f800 0 0 7>; ++ interrupt-map = <c000 0 0 1 &mpc5200_pic 0 0 3 // 1st slot ++ c000 0 0 2 &mpc5200_pic 1 1 3 ++ c000 0 0 3 &mpc5200_pic 1 2 3 ++ c000 0 0 4 &mpc5200_pic 1 3 3 ++ ++ c800 0 0 1 &mpc5200_pic 1 1 3 // 2nd slot ++ c800 0 0 2 &mpc5200_pic 1 2 3 ++ c800 0 0 3 &mpc5200_pic 1 3 3 ++ c800 0 0 4 &mpc5200_pic 0 0 3>; ++ clock-frequency = <0>; // From boot loader ++ interrupts = <2 8 0 2 9 0 2 a 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ bus-range = <0 0>; ++ ranges = <42000000 0 80000000 80000000 0 20000000 ++ 02000000 0 a0000000 a0000000 0 10000000 ++ 01000000 0 00000000 b0000000 0 01000000>; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8313erdb.dts powerpc.git/arch/powerpc/boot/dts/mpc8313erdb.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8313erdb.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8313erdb.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -15,6 +15,14 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -37,10 +45,58 @@ + reg = <00000000 08000000>; // 128MB at 0 + }; + ++ localbus@e0005000 { ++ #address-cells = <2>; ++ #size-cells = <1>; ++ compatible = "fsl,mpc8313-elbc", "fsl,elbc", "simple-bus"; ++ reg = <e0005000 1000>; ++ interrupts = <d#77 8>; ++ interrupt-parent = <&ipic>; ++ ++ // CS0 and CS1 are swapped when ++ // booting from nand, but the ++ // addresses are the same. ++ ranges = <0 0 fe000000 00800000 ++ 1 0 e2800000 00008000 ++ 2 0 f0000000 00020000 ++ 3 0 fa000000 00008000>; ++ ++ flash@0,0 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ compatible = "cfi-flash"; ++ reg = <0 0 800000>; ++ bank-width = <2>; ++ device-width = <1>; ++ }; ++ ++ nand@1,0 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ compatible = "fsl,mpc8313-fcm-nand", ++ "fsl,elbc-fcm-nand"; ++ reg = <1 0 2000>; ++ ++ u-boot@0 { ++ reg = <0 100000>; ++ read-only; ++ }; ++ ++ kernel@100000 { ++ reg = <100000 300000>; ++ }; ++ ++ fs@400000 { ++ reg = <400000 1c00000>; ++ }; ++ }; ++ }; ++ + soc8313@e0000000 { + #address-cells = <1>; + #size-cells = <1>; + device_type = "soc"; ++ compatible = "simple-bus"; + ranges = <0 e0000000 00100000>; + reg = <e0000000 00000200>; + bus-frequency = <0>; +@@ -52,7 +108,9 @@ + }; + + i2c@3000 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <e 8>; +@@ -61,7 +119,9 @@ + }; + + i2c@3100 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <1>; + compatible = "fsl-i2c"; + reg = <3100 100>; + interrupts = <f 8>; +@@ -80,7 +140,6 @@ + + /* phy type (ULPI, UTMI, UTMI_WIDE, SERIAL) */ + usb@23000 { +- device_type = "usb"; + compatible = "fsl-usb2-dr"; + reg = <23000 1000>; + #address-cells = <1>; +@@ -91,11 +150,10 @@ + }; + + mdio@24520 { +- device_type = "mdio"; +- compatible = "gianfar"; +- reg = <24520 20>; + #address-cells = <1>; + #size-cells = <0>; ++ compatible = "fsl,gianfar-mdio"; ++ reg = <24520 20>; + phy1: ethernet-phy@1 { + interrupt-parent = < &ipic >; + interrupts = <13 8>; +@@ -110,7 +168,8 @@ + }; + }; + +- ethernet@24000 { ++ enet0: ethernet@24000 { ++ cell-index = <0>; + device_type = "network"; + model = "eTSEC"; + compatible = "gianfar"; +@@ -121,7 +180,8 @@ + phy-handle = < &phy1 >; + }; + +- ethernet@25000 { ++ enet1: ethernet@25000 { ++ cell-index = <1>; + device_type = "network"; + model = "eTSEC"; + compatible = "gianfar"; +@@ -132,7 +192,8 @@ + phy-handle = < &phy4 >; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; +@@ -141,7 +202,8 @@ + interrupt-parent = < &ipic >; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; +@@ -179,7 +241,8 @@ + }; + }; + +- pci@e0008500 { ++ pci0: pci@e0008500 { ++ cell-index = <1>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc832x_mds.dts powerpc.git/arch/powerpc/boot/dts/mpc832x_mds.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc832x_mds.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc832x_mds.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -7,6 +7,18 @@ + * under the terms of the GNU General Public License as published by the + * Free Software Foundation; either version 2 of the License, or (at your + * option) any later version. ++ ++ * To enable external serial I/O on a Freescale MPC 8323 SYS/MDS board, do ++ * this: ++ * ++ * 1) On chip U61, lift (disconnect) pins 21 (TXD) and 22 (RXD) from the board. ++ * 2) Solder a wire from U61-21 to P19A-23. P19 is a grid of pins on the board ++ * next to the serial ports. ++ * 3) Solder a wire from U61-22 to P19K-22. ++ * ++ * Note that there's a typo in the schematic. The board labels the last column ++ * of pins "P19K", but in the schematic, that column is called "P19J". So if ++ * you're going by the schematic, the pin is called "P19J-K22". + */ + + / { +@@ -15,6 +27,14 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -59,7 +79,7 @@ + i2c@3000 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "i2c"; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <e 8>; +@@ -72,7 +92,8 @@ + }; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; +@@ -81,7 +102,8 @@ + interrupt-parent = < &ipic >; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; +@@ -159,6 +181,23 @@ + 1 1e 1 0 1 0 /* TX_EN */ + 1 1f 2 0 1 0>;/* CRS */ + }; ++ pio5: ucc_pin@05 { ++ pio-map = < ++ /* ++ * open has ++ * port pin dir drain sel irq ++ */ ++ 2 0 1 0 2 0 /* TxD5 */ ++ 2 8 2 0 2 0 /* RxD5 */ ++ ++ 2 1d 2 0 0 0 /* CTS5 */ ++ 2 1f 1 0 2 0 /* RTS5 */ ++ ++ 2 18 2 0 0 0 /* CD */ ++ ++ >; ++ }; ++ + }; + }; + +@@ -166,6 +205,7 @@ + #address-cells = <1>; + #size-cells = <1>; + device_type = "qe"; ++ compatible = "fsl,qe"; + model = "QE"; + ranges = <0 e0100000 00100000>; + reg = <e0100000 480>; +@@ -200,7 +240,6 @@ + }; + + usb@6c0 { +- device_type = "usb"; + compatible = "qe_udc"; + reg = <6c0 40 8B00 100>; + interrupts = <b>; +@@ -208,48 +247,58 @@ + mode = "slave"; + }; + +- ucc@2200 { ++ enet0: ucc@2200 { + device_type = "network"; + compatible = "ucc_geth"; + model = "UCC"; ++ cell-index = <3>; + device-id = <3>; + reg = <2200 200>; + interrupts = <22>; + interrupt-parent = < &qeic >; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; +- rx-clock = <19>; +- tx-clock = <1a>; ++ rx-clock-name = "clk9"; ++ tx-clock-name = "clk10"; + phy-handle = < &phy3 >; + pio-handle = < &pio3 >; + }; + +- ucc@3200 { ++ enet1: ucc@3200 { + device_type = "network"; + compatible = "ucc_geth"; + model = "UCC"; ++ cell-index = <4>; + device-id = <4>; + reg = <3200 200>; + interrupts = <23>; + interrupt-parent = < &qeic >; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; +- rx-clock = <17>; +- tx-clock = <18>; ++ rx-clock-name = "clk7"; ++ tx-clock-name = "clk8"; + phy-handle = < &phy4 >; + pio-handle = < &pio4 >; + }; + ++ ucc@2400 { ++ device_type = "serial"; ++ compatible = "ucc_uart"; ++ model = "UCC"; ++ device-id = <5>; /* The UCC number, 1-7*/ ++ port-number = <0>; /* Which ttyQEx device */ ++ soft-uart; /* We need Soft-UART */ ++ reg = <2400 200>; ++ interrupts = <28>; /* From Table 18-12 */ ++ interrupt-parent = < &qeic >; ++ /* ++ * For Soft-UART, we need to set TX to 1X, which ++ * means specifying separate clock sources. ++ */ ++ rx-clock-name = "brg5"; ++ tx-clock-name = "brg6"; ++ pio-handle = < &pio5 >; ++ }; ++ ++ + mdio@2320 { + #address-cells = <1>; + #size-cells = <0>; +@@ -283,7 +332,8 @@ + }; + }; + +- pci@e0008500 { ++ pci0: pci@e0008500 { ++ cell-index = <1>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + /* IDSEL 0x11 AD17 */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc832x_rdb.dts powerpc.git/arch/powerpc/boot/dts/mpc832x_rdb.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc832x_rdb.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc832x_rdb.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -15,6 +15,14 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -52,7 +60,9 @@ + }; + + i2c@3000 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <e 8>; +@@ -60,7 +70,8 @@ + dfsrr; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; +@@ -69,7 +80,8 @@ + interrupt-parent = <&pic>; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; +@@ -187,44 +199,34 @@ + mode = "cpu"; + }; + +- ucc@3000 { ++ enet0: ucc@3000 { + device_type = "network"; + compatible = "ucc_geth"; + model = "UCC"; ++ cell-index = <2>; + device-id = <2>; + reg = <3000 200>; + interrupts = <21>; + interrupt-parent = <&qeic>; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; +- rx-clock = <20>; +- tx-clock = <13>; ++ rx-clock-name = "clk16"; ++ tx-clock-name = "clk3"; + phy-handle = <&phy00>; + pio-handle = <&ucc2pio>; + }; + +- ucc@2200 { ++ enet1: ucc@2200 { + device_type = "network"; + compatible = "ucc_geth"; + model = "UCC"; ++ cell-index = <3>; + device-id = <3>; + reg = <2200 200>; + interrupts = <22>; + interrupt-parent = <&qeic>; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; +- rx-clock = <19>; +- tx-clock = <1a>; ++ rx-clock-name = "clk9"; ++ tx-clock-name = "clk10"; + phy-handle = <&phy04>; + pio-handle = <&ucc3pio>; + }; +@@ -262,7 +264,8 @@ + }; + }; + +- pci@e0008500 { ++ pci0: pci@e0008500 { ++ cell-index = <1>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + /* IDSEL 0x10 AD16 (USB) */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8349emitx.dts powerpc.git/arch/powerpc/boot/dts/mpc8349emitx.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8349emitx.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8349emitx.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -14,6 +14,15 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ pci1 = &pci1; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -51,7 +60,9 @@ + }; + + i2c@3000 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <e 8>; +@@ -60,7 +71,9 @@ + }; + + i2c@3100 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <1>; + compatible = "fsl-i2c"; + reg = <3100 100>; + interrupts = <f 8>; +@@ -78,7 +91,6 @@ + }; + + usb@22000 { +- device_type = "usb"; + compatible = "fsl-usb2-mph"; + reg = <22000 1000>; + #address-cells = <1>; +@@ -90,7 +102,6 @@ + }; + + usb@23000 { +- device_type = "usb"; + compatible = "fsl-usb2-dr"; + reg = <23000 1000>; + #address-cells = <1>; +@@ -102,11 +113,10 @@ + }; + + mdio@24520 { +- device_type = "mdio"; +- compatible = "gianfar"; +- reg = <24520 20>; + #address-cells = <1>; + #size-cells = <0>; ++ compatible = "fsl,gianfar-mdio"; ++ reg = <24520 20>; + + /* Vitesse 8201 */ + phy1c: ethernet-phy@1c { +@@ -115,27 +125,14 @@ + reg = <1c>; + device_type = "ethernet-phy"; + }; +- +- /* Vitesse 7385 */ +- phy1f: ethernet-phy@1f { +- interrupt-parent = < &ipic >; +- interrupts = <12 8>; +- reg = <1f>; +- device_type = "ethernet-phy"; +- }; + }; + +- ethernet@24000 { ++ enet0: ethernet@24000 { ++ cell-index = <0>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; + reg = <24000 1000>; +- /* +- * address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <20 8 21 8 22 8>; + interrupt-parent = < &ipic >; +@@ -143,27 +140,22 @@ + linux,network-index = <0>; + }; + +- ethernet@25000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet1: ethernet@25000 { ++ cell-index = <1>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; + reg = <25000 1000>; +- /* +- * address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <23 8 24 8 25 8>; + interrupt-parent = < &ipic >; +- phy-handle = < &phy1f >; ++ /* Vitesse 7385 isn't on the MDIO bus */ ++ fixed-link = <1 1 d#1000 0 0>; + linux,network-index = <1>; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; +@@ -172,7 +164,8 @@ + interrupt-parent = < &ipic >; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; +@@ -203,7 +196,8 @@ + }; + }; + +- pci@e0008500 { ++ pci0: pci@e0008500 { ++ cell-index = <1>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + /* IDSEL 0x10 - SATA */ +@@ -224,7 +218,8 @@ + device_type = "pci"; + }; + +- pci@e0008600 { ++ pci1: pci@e0008600 { ++ cell-index = <2>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + /* IDSEL 0x0E - MiniPCI Slot */ +@@ -249,6 +244,21 @@ + device_type = "pci"; + }; + +- +- ++ localbus@e0005000 { ++ #address-cells = <2>; ++ #size-cells = <1>; ++ compatible = "fsl,mpc8349e-localbus", ++ "fsl,pq2pro-localbus"; ++ reg = <e0005000 d8>; ++ ranges = <3 0 f0000000 210>; ++ ++ pata@3,0 { ++ compatible = "fsl,mpc8349emitx-pata", "ata-generic"; ++ reg = <3 0 10 3 20c 4>; ++ reg-shift = <1>; ++ pio-mode = <6>; ++ interrupts = <17 8>; ++ interrupt-parent = <&ipic>; ++ }; ++ }; + }; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8349emitxgp.dts powerpc.git/arch/powerpc/boot/dts/mpc8349emitxgp.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8349emitxgp.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8349emitxgp.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -14,6 +14,13 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -51,7 +58,9 @@ + }; + + i2c@3000 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <e 8>; +@@ -60,7 +69,9 @@ + }; + + i2c@3100 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <1>; + compatible = "fsl-i2c"; + reg = <3100 100>; + interrupts = <f 8>; +@@ -78,7 +89,6 @@ + }; + + usb@23000 { +- device_type = "usb"; + compatible = "fsl-usb2-dr"; + reg = <23000 1000>; + #address-cells = <1>; +@@ -90,11 +100,10 @@ + }; + + mdio@24520 { +- device_type = "mdio"; +- compatible = "gianfar"; +- reg = <24520 20>; + #address-cells = <1>; + #size-cells = <0>; ++ compatible = "fsl,gianfar-mdio"; ++ reg = <24520 20>; + + /* Vitesse 8201 */ + phy1c: ethernet-phy@1c { +@@ -105,7 +114,8 @@ + }; + }; + +- ethernet@24000 { ++ enet0: ethernet@24000 { ++ cell-index = <0>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; +@@ -117,7 +127,8 @@ + linux,network-index = <0>; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; +@@ -126,7 +137,8 @@ + interrupt-parent = < &ipic >; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; +@@ -157,7 +169,8 @@ + }; + }; + +- pci@e0008600 { ++ pci0: pci@e0008600 { ++ cell-index = <2>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + /* IDSEL 0x0F - PCI Slot */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc834x_mds.dts powerpc.git/arch/powerpc/boot/dts/mpc834x_mds.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc834x_mds.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc834x_mds.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -15,6 +15,15 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ pci1 = &pci1; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -59,7 +68,7 @@ + i2c@3000 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "i2c"; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <e 8>; +@@ -75,7 +84,7 @@ + i2c@3100 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "i2c"; ++ cell-index = <1>; + compatible = "fsl-i2c"; + reg = <3100 100>; + interrupts = <f 8>; +@@ -95,7 +104,6 @@ + /* phy type (ULPI or SERIAL) are only types supportted for MPH */ + /* port = 0 or 1 */ + usb@22000 { +- device_type = "usb"; + compatible = "fsl-usb2-mph"; + reg = <22000 1000>; + #address-cells = <1>; +@@ -107,7 +115,6 @@ + }; + /* phy type (ULPI, UTMI, UTMI_WIDE, SERIAL) */ + usb@23000 { +- device_type = "usb"; + compatible = "fsl-usb2-dr"; + reg = <23000 1000>; + #address-cells = <1>; +@@ -119,11 +126,11 @@ + }; + + mdio@24520 { +- device_type = "mdio"; +- compatible = "gianfar"; +- reg = <24520 20>; + #address-cells = <1>; + #size-cells = <0>; ++ compatible = "fsl,gianfar-mdio"; ++ reg = <24520 20>; ++ + phy0: ethernet-phy@0 { + interrupt-parent = < &ipic >; + interrupts = <11 8>; +@@ -138,17 +145,12 @@ + }; + }; + +- ethernet@24000 { ++ enet0: ethernet@24000 { ++ cell-index = <0>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; + reg = <24000 1000>; +- /* +- * address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <20 8 21 8 22 8>; + interrupt-parent = < &ipic >; +@@ -156,19 +158,12 @@ + linux,network-index = <0>; + }; + +- ethernet@25000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet1: ethernet@25000 { ++ cell-index = <1>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; + reg = <25000 1000>; +- /* +- * address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <23 8 24 8 25 8>; + interrupt-parent = < &ipic >; +@@ -176,7 +171,8 @@ + linux,network-index = <1>; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; +@@ -185,7 +181,8 @@ + interrupt-parent = < &ipic >; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; +@@ -225,7 +222,8 @@ + }; + }; + +- pci@e0008500 { ++ pci0: pci@e0008500 { ++ cell-index = <1>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + +@@ -285,7 +283,8 @@ + device_type = "pci"; + }; + +- pci@e0008600 { ++ pci1: pci@e0008600 { ++ cell-index = <2>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc836x_mds.dts powerpc.git/arch/powerpc/boot/dts/mpc836x_mds.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc836x_mds.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc836x_mds.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -20,6 +20,14 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -64,7 +72,7 @@ + i2c@3000 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "i2c"; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <e 8>; +@@ -80,7 +88,7 @@ + i2c@3100 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "i2c"; ++ cell-index = <1>; + compatible = "fsl-i2c"; + reg = <3100 100>; + interrupts = <f 8>; +@@ -88,7 +96,8 @@ + dfsrr; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; +@@ -97,7 +106,8 @@ + interrupt-parent = < &ipic >; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; +@@ -231,7 +241,6 @@ + }; + + usb@6c0 { +- device_type = "usb"; + compatible = "qe_udc"; + reg = <6c0 40 8B00 100>; + interrupts = <b>; +@@ -239,45 +248,35 @@ + mode = "slave"; + }; + +- ucc@2000 { ++ enet0: ucc@2000 { + device_type = "network"; + compatible = "ucc_geth"; + model = "UCC"; ++ cell-index = <1>; + device-id = <1>; + reg = <2000 200>; + interrupts = <20>; + interrupt-parent = < &qeic >; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; +- rx-clock = <0>; +- tx-clock = <19>; ++ rx-clock-name = "none"; ++ tx-clock-name = "clk9"; + phy-handle = < &phy0 >; + phy-connection-type = "rgmii-id"; + pio-handle = < &pio1 >; + }; + +- ucc@3000 { ++ enet1: ucc@3000 { + device_type = "network"; + compatible = "ucc_geth"; + model = "UCC"; ++ cell-index = <2>; + device-id = <2>; + reg = <3000 200>; + interrupts = <21>; + interrupt-parent = < &qeic >; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; +- rx-clock = <0>; +- tx-clock = <14>; ++ rx-clock-name = "none"; ++ tx-clock-name = "clk4"; + phy-handle = < &phy1 >; + phy-connection-type = "rgmii-id"; + pio-handle = < &pio2 >; +@@ -316,7 +315,8 @@ + }; + }; + +- pci@e0008500 { ++ pci0: pci@e0008500 { ++ cell-index = <1>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8377_mds.dts powerpc.git/arch/powerpc/boot/dts/mpc8377_mds.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8377_mds.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8377_mds.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,279 @@ ++/* ++ * MPC8377E MDS Device Tree Source ++ * ++ * Copyright 2007 Freescale Semiconductor Inc. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++/dts-v1/; ++ ++/ { ++ model = "fsl,mpc8377emds"; ++ compatible = "fsl,mpc8377emds","fsl,mpc837xmds"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ PowerPC,8377@0 { ++ device_type = "cpu"; ++ reg = <0>; ++ d-cache-line-size = <0x20>; ++ i-cache-line-size = <0x20>; ++ d-cache-size = <0x8000>; // L1, 32K ++ i-cache-size = <0x8000>; // L1, 32K ++ timebase-frequency = <0>; ++ bus-frequency = <0>; ++ clock-frequency = <0>; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <0x00000000 0x20000000>; // 512MB at 0 ++ }; ++ ++ soc@e0000000 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ device_type = "soc"; ++ ranges = <0x0 0xe0000000 0x00100000>; ++ reg = <0xe0000000 0x00000200>; ++ bus-frequency = <0>; ++ ++ wdt@200 { ++ compatible = "mpc83xx_wdt"; ++ reg = <0x200 0x100>; ++ }; ++ ++ i2c@3000 { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; ++ compatible = "fsl-i2c"; ++ reg = <0x3000 0x100>; ++ interrupts = <0xe 0x8>; ++ interrupt-parent = < &ipic >; ++ dfsrr; ++ }; ++ ++ i2c@3100 { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <1>; ++ compatible = "fsl-i2c"; ++ reg = <0x3100 0x100>; ++ interrupts = <0xf 0x8>; ++ interrupt-parent = < &ipic >; ++ dfsrr; ++ }; ++ ++ spi@7000 { ++ compatible = "fsl_spi"; ++ reg = <0x7000 0x1000>; ++ interrupts = <0x10 0x8>; ++ interrupt-parent = < &ipic >; ++ mode = "cpu"; ++ }; ++ ++ /* phy type (ULPI, UTMI, UTMI_WIDE, SERIAL) */ ++ usb@23000 { ++ compatible = "fsl-usb2-dr"; ++ reg = <0x23000 0x1000>; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ interrupt-parent = < &ipic >; ++ interrupts = <0x26 0x8>; ++ phy_type = "utmi_wide"; ++ }; ++ ++ mdio@24520 { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ compatible = "fsl,gianfar-mdio"; ++ reg = <0x24520 0x20>; ++ phy2: ethernet-phy@2 { ++ interrupt-parent = < &ipic >; ++ interrupts = <0x11 0x8>; ++ reg = <2>; ++ device_type = "ethernet-phy"; ++ }; ++ phy3: ethernet-phy@3 { ++ interrupt-parent = < &ipic >; ++ interrupts = <0x12 0x8>; ++ reg = <3>; ++ device_type = "ethernet-phy"; ++ }; ++ }; ++ ++ enet0: ethernet@24000 { ++ cell-index = <0>; ++ device_type = "network"; ++ model = "eTSEC"; ++ compatible = "gianfar"; ++ reg = <0x24000 0x1000>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ interrupts = <0x20 0x8 0x21 0x8 0x22 0x8>; ++ phy-connection-type = "mii"; ++ interrupt-parent = < &ipic >; ++ phy-handle = < &phy2 >; ++ }; ++ ++ enet1: ethernet@25000 { ++ cell-index = <1>; ++ device_type = "network"; ++ model = "eTSEC"; ++ compatible = "gianfar"; ++ reg = <0x25000 0x1000>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ interrupts = <0x23 0x8 0x24 0x8 0x25 0x8>; ++ phy-connection-type = "mii"; ++ interrupt-parent = < &ipic >; ++ phy-handle = < &phy3 >; ++ }; ++ ++ serial0: serial@4500 { ++ cell-index = <0>; ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <0x4500 0x100>; ++ clock-frequency = <0>; ++ interrupts = <0x9 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ serial1: serial@4600 { ++ cell-index = <1>; ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <0x4600 0x100>; ++ clock-frequency = <0>; ++ interrupts = <0xa 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ crypto@30000 { ++ model = "SEC3"; ++ compatible = "talitos"; ++ reg = <0x30000 0x10000>; ++ interrupts = <0xb 0x8>; ++ interrupt-parent = < &ipic >; ++ /* Rev. 3.0 geometry */ ++ num-channels = <4>; ++ channel-fifo-len = <0x18>; ++ exec-units-mask = <0x000001fe>; ++ descriptor-types-mask = <0x03ab0ebf>; ++ }; ++ ++ sdhc@2e000 { ++ model = "eSDHC"; ++ compatible = "fsl,esdhc"; ++ reg = <0x2e000 0x1000>; ++ interrupts = <0x2a 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ sata@18000 { ++ compatible = "fsl,mpc8379-sata"; ++ reg = <0x18000 0x1000>; ++ interrupts = <0x2c 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ sata@19000 { ++ compatible = "fsl,mpc8379-sata"; ++ reg = <0x19000 0x1000>; ++ interrupts = <0x2d 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ /* IPIC ++ * interrupts cell = <intr #, sense> ++ * sense values match linux IORESOURCE_IRQ_* defines: ++ * sense == 8: Level, low assertion ++ * sense == 2: Edge, high-to-low change ++ */ ++ ipic: pic@700 { ++ compatible = "fsl,ipic"; ++ interrupt-controller; ++ #address-cells = <0>; ++ #interrupt-cells = <2>; ++ reg = <0x700 0x100>; ++ }; ++ }; ++ ++ pci0: pci@e0008500 { ++ cell-index = <0>; ++ interrupt-map-mask = <0xf800 0x0 0x0 0x7>; ++ interrupt-map = < ++ ++ /* IDSEL 0x11 */ ++ 0x8800 0x0 0x0 0x1 &ipic 0x14 0x8 ++ 0x8800 0x0 0x0 0x2 &ipic 0x15 0x8 ++ 0x8800 0x0 0x0 0x3 &ipic 0x16 0x8 ++ 0x8800 0x0 0x0 0x4 &ipic 0x17 0x8 ++ ++ /* IDSEL 0x12 */ ++ 0x9000 0x0 0x0 0x1 &ipic 0x16 0x8 ++ 0x9000 0x0 0x0 0x2 &ipic 0x17 0x8 ++ 0x9000 0x0 0x0 0x3 &ipic 0x14 0x8 ++ 0x9000 0x0 0x0 0x4 &ipic 0x15 0x8 ++ ++ /* IDSEL 0x13 */ ++ 0x9800 0x0 0x0 0x1 &ipic 0x17 0x8 ++ 0x9800 0x0 0x0 0x2 &ipic 0x14 0x8 ++ 0x9800 0x0 0x0 0x3 &ipic 0x15 0x8 ++ 0x9800 0x0 0x0 0x4 &ipic 0x16 0x8 ++ ++ /* IDSEL 0x15 */ ++ 0xa800 0x0 0x0 0x1 &ipic 0x14 0x8 ++ 0xa800 0x0 0x0 0x2 &ipic 0x15 0x8 ++ 0xa800 0x0 0x0 0x3 &ipic 0x16 0x8 ++ 0xa800 0x0 0x0 0x4 &ipic 0x17 0x8 ++ ++ /* IDSEL 0x16 */ ++ 0xb000 0x0 0x0 0x1 &ipic 0x17 0x8 ++ 0xb000 0x0 0x0 0x2 &ipic 0x14 0x8 ++ 0xb000 0x0 0x0 0x3 &ipic 0x15 0x8 ++ 0xb000 0x0 0x0 0x4 &ipic 0x16 0x8 ++ ++ /* IDSEL 0x17 */ ++ 0xb800 0x0 0x0 0x1 &ipic 0x16 0x8 ++ 0xb800 0x0 0x0 0x2 &ipic 0x17 0x8 ++ 0xb800 0x0 0x0 0x3 &ipic 0x14 0x8 ++ 0xb800 0x0 0x0 0x4 &ipic 0x15 0x8 ++ ++ /* IDSEL 0x18 */ ++ 0xc000 0x0 0x0 0x1 &ipic 0x15 0x8 ++ 0xc000 0x0 0x0 0x2 &ipic 0x16 0x8 ++ 0xc000 0x0 0x0 0x3 &ipic 0x17 0x8 ++ 0xc000 0x0 0x0 0x4 &ipic 0x14 0x8>; ++ interrupt-parent = < &ipic >; ++ interrupts = <0x42 0x8>; ++ bus-range = <0 0>; ++ ranges = <0x02000000 0x0 0x90000000 0x90000000 0x0 0x10000000 ++ 0x42000000 0x0 0x80000000 0x80000000 0x0 0x10000000 ++ 0x01000000 0x0 0x00000000 0xe0300000 0x0 0x00100000>; ++ clock-frequency = <0>; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ reg = <0xe0008500 0x100>; ++ compatible = "fsl,mpc8349-pci"; ++ device_type = "pci"; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8378_mds.dts powerpc.git/arch/powerpc/boot/dts/mpc8378_mds.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8378_mds.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8378_mds.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,265 @@ ++/* ++ * MPC8378E MDS Device Tree Source ++ * ++ * Copyright 2007 Freescale Semiconductor Inc. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++/dts-v1/; ++ ++/ { ++ model = "fsl,mpc8378emds"; ++ compatible = "fsl,mpc8378emds","fsl,mpc837xmds"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ PowerPC,8378@0 { ++ device_type = "cpu"; ++ reg = <0>; ++ d-cache-line-size = <0x20>; ++ i-cache-line-size = <0x20>; ++ d-cache-size = <0x8000>; // L1, 32K ++ i-cache-size = <0x8000>; // L1, 32K ++ timebase-frequency = <0>; ++ bus-frequency = <0>; ++ clock-frequency = <0>; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <0x00000000 0x20000000>; // 512MB at 0 ++ }; ++ ++ soc@e0000000 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ device_type = "soc"; ++ ranges = <0x0 0xe0000000 0x00100000>; ++ reg = <0xe0000000 0x00000200>; ++ bus-frequency = <0>; ++ ++ wdt@200 { ++ compatible = "mpc83xx_wdt"; ++ reg = <0x200 0x100>; ++ }; ++ ++ i2c@3000 { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; ++ compatible = "fsl-i2c"; ++ reg = <0x3000 0x100>; ++ interrupts = <0xe 0x8>; ++ interrupt-parent = < &ipic >; ++ dfsrr; ++ }; ++ ++ i2c@3100 { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <1>; ++ compatible = "fsl-i2c"; ++ reg = <0x3100 0x100>; ++ interrupts = <0xf 0x8>; ++ interrupt-parent = < &ipic >; ++ dfsrr; ++ }; ++ ++ spi@7000 { ++ compatible = "fsl_spi"; ++ reg = <0x7000 0x1000>; ++ interrupts = <0x10 0x8>; ++ interrupt-parent = < &ipic >; ++ mode = "cpu"; ++ }; ++ ++ /* phy type (ULPI, UTMI, UTMI_WIDE, SERIAL) */ ++ usb@23000 { ++ compatible = "fsl-usb2-dr"; ++ reg = <0x23000 0x1000>; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ interrupt-parent = < &ipic >; ++ interrupts = <0x26 0x8>; ++ phy_type = "utmi_wide"; ++ }; ++ ++ mdio@24520 { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ compatible = "fsl,gianfar-mdio"; ++ reg = <0x24520 0x20>; ++ phy2: ethernet-phy@2 { ++ interrupt-parent = < &ipic >; ++ interrupts = <0x11 0x8>; ++ reg = <2>; ++ device_type = "ethernet-phy"; ++ }; ++ phy3: ethernet-phy@3 { ++ interrupt-parent = < &ipic >; ++ interrupts = <0x12 0x8>; ++ reg = <3>; ++ device_type = "ethernet-phy"; ++ }; ++ }; ++ ++ enet0: ethernet@24000 { ++ cell-index = <0>; ++ device_type = "network"; ++ model = "eTSEC"; ++ compatible = "gianfar"; ++ reg = <0x24000 0x1000>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ interrupts = <0x20 0x8 0x21 0x8 0x22 0x8>; ++ phy-connection-type = "mii"; ++ interrupt-parent = < &ipic >; ++ phy-handle = < &phy2 >; ++ }; ++ ++ enet1: ethernet@25000 { ++ cell-index = <1>; ++ device_type = "network"; ++ model = "eTSEC"; ++ compatible = "gianfar"; ++ reg = <0x25000 0x1000>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ interrupts = <0x23 0x8 0x24 0x8 0x25 0x8>; ++ phy-connection-type = "mii"; ++ interrupt-parent = < &ipic >; ++ phy-handle = < &phy3 >; ++ }; ++ ++ serial0: serial@4500 { ++ cell-index = <0>; ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <0x4500 0x100>; ++ clock-frequency = <0>; ++ interrupts = <0x9 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ serial1: serial@4600 { ++ cell-index = <1>; ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <0x4600 0x100>; ++ clock-frequency = <0>; ++ interrupts = <0xa 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ crypto@30000 { ++ model = "SEC3"; ++ compatible = "talitos"; ++ reg = <0x30000 0x10000>; ++ interrupts = <0xb 0x8>; ++ interrupt-parent = < &ipic >; ++ /* Rev. 3.0 geometry */ ++ num-channels = <4>; ++ channel-fifo-len = <0x18>; ++ exec-units-mask = <0x000001fe>; ++ descriptor-types-mask = <0x03ab0ebf>; ++ }; ++ ++ sdhc@2e000 { ++ model = "eSDHC"; ++ compatible = "fsl,esdhc"; ++ reg = <0x2e000 0x1000>; ++ interrupts = <0x2a 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ /* IPIC ++ * interrupts cell = <intr #, sense> ++ * sense values match linux IORESOURCE_IRQ_* defines: ++ * sense == 8: Level, low assertion ++ * sense == 2: Edge, high-to-low change ++ */ ++ ipic: pic@700 { ++ compatible = "fsl,ipic"; ++ interrupt-controller; ++ #address-cells = <0>; ++ #interrupt-cells = <2>; ++ reg = <0x700 0x100>; ++ }; ++ }; ++ ++ pci0: pci@e0008500 { ++ cell-index = <0>; ++ interrupt-map-mask = <0xf800 0x0 0x0 0x7>; ++ interrupt-map = < ++ ++ /* IDSEL 0x11 */ ++ 0x8800 0x0 0x0 0x1 &ipic 0x14 0x8 ++ 0x8800 0x0 0x0 0x2 &ipic 0x15 0x8 ++ 0x8800 0x0 0x0 0x3 &ipic 0x16 0x8 ++ 0x8800 0x0 0x0 0x4 &ipic 0x17 0x8 ++ ++ /* IDSEL 0x12 */ ++ 0x9000 0x0 0x0 0x1 &ipic 0x16 0x8 ++ 0x9000 0x0 0x0 0x2 &ipic 0x17 0x8 ++ 0x9000 0x0 0x0 0x3 &ipic 0x14 0x8 ++ 0x9000 0x0 0x0 0x4 &ipic 0x15 0x8 ++ ++ /* IDSEL 0x13 */ ++ 0x9800 0x0 0x0 0x1 &ipic 0x17 0x8 ++ 0x9800 0x0 0x0 0x2 &ipic 0x14 0x8 ++ 0x9800 0x0 0x0 0x3 &ipic 0x15 0x8 ++ 0x9800 0x0 0x0 0x4 &ipic 0x16 0x8 ++ ++ /* IDSEL 0x15 */ ++ 0xa800 0x0 0x0 0x1 &ipic 0x14 0x8 ++ 0xa800 0x0 0x0 0x2 &ipic 0x15 0x8 ++ 0xa800 0x0 0x0 0x3 &ipic 0x16 0x8 ++ 0xa800 0x0 0x0 0x4 &ipic 0x17 0x8 ++ ++ /* IDSEL 0x16 */ ++ 0xb000 0x0 0x0 0x1 &ipic 0x17 0x8 ++ 0xb000 0x0 0x0 0x2 &ipic 0x14 0x8 ++ 0xb000 0x0 0x0 0x3 &ipic 0x15 0x8 ++ 0xb000 0x0 0x0 0x4 &ipic 0x16 0x8 ++ ++ /* IDSEL 0x17 */ ++ 0xb800 0x0 0x0 0x1 &ipic 0x16 0x8 ++ 0xb800 0x0 0x0 0x2 &ipic 0x17 0x8 ++ 0xb800 0x0 0x0 0x3 &ipic 0x14 0x8 ++ 0xb800 0x0 0x0 0x4 &ipic 0x15 0x8 ++ ++ /* IDSEL 0x18 */ ++ 0xc000 0x0 0x0 0x1 &ipic 0x15 0x8 ++ 0xc000 0x0 0x0 0x2 &ipic 0x16 0x8 ++ 0xc000 0x0 0x0 0x3 &ipic 0x17 0x8 ++ 0xc000 0x0 0x0 0x4 &ipic 0x14 0x8>; ++ interrupt-parent = < &ipic >; ++ interrupts = <0x42 0x8>; ++ bus-range = <0 0>; ++ ranges = <0x02000000 0x0 0x90000000 0x90000000 0x0 0x10000000 ++ 0x42000000 0x0 0x80000000 0x80000000 0x0 0x10000000 ++ 0x01000000 0x0 0x00000000 0xe0300000 0x0 0x00100000>; ++ clock-frequency = <0>; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ reg = <0xe0008500 0x100>; ++ compatible = "fsl,mpc8349-pci"; ++ device_type = "pci"; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8379_mds.dts powerpc.git/arch/powerpc/boot/dts/mpc8379_mds.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8379_mds.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8379_mds.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,293 @@ ++/* ++ * MPC8379E MDS Device Tree Source ++ * ++ * Copyright 2007 Freescale Semiconductor Inc. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++/dts-v1/; ++ ++/ { ++ model = "fsl,mpc8379emds"; ++ compatible = "fsl,mpc8379emds","fsl,mpc837xmds"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ PowerPC,8379@0 { ++ device_type = "cpu"; ++ reg = <0>; ++ d-cache-line-size = <0x20>; ++ i-cache-line-size = <0x20>; ++ d-cache-size = <0x8000>; // L1, 32K ++ i-cache-size = <0x8000>; // L1, 32K ++ timebase-frequency = <0>; ++ bus-frequency = <0>; ++ clock-frequency = <0>; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <0x00000000 0x20000000>; // 512MB at 0 ++ }; ++ ++ soc@e0000000 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ device_type = "soc"; ++ ranges = <0x0 0xe0000000 0x00100000>; ++ reg = <0xe0000000 0x00000200>; ++ bus-frequency = <0>; ++ ++ wdt@200 { ++ compatible = "mpc83xx_wdt"; ++ reg = <0x200 0x100>; ++ }; ++ ++ i2c@3000 { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; ++ compatible = "fsl-i2c"; ++ reg = <0x3000 0x100>; ++ interrupts = <0xe 0x8>; ++ interrupt-parent = < &ipic >; ++ dfsrr; ++ }; ++ ++ i2c@3100 { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <1>; ++ compatible = "fsl-i2c"; ++ reg = <0x3100 0x100>; ++ interrupts = <0xf 0x8>; ++ interrupt-parent = < &ipic >; ++ dfsrr; ++ }; ++ ++ spi@7000 { ++ compatible = "fsl_spi"; ++ reg = <0x7000 0x1000>; ++ interrupts = <0x10 0x8>; ++ interrupt-parent = < &ipic >; ++ mode = "cpu"; ++ }; ++ ++ /* phy type (ULPI, UTMI, UTMI_WIDE, SERIAL) */ ++ usb@23000 { ++ compatible = "fsl-usb2-dr"; ++ reg = <0x23000 0x1000>; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ interrupt-parent = < &ipic >; ++ interrupts = <0x26 0x8>; ++ phy_type = "utmi_wide"; ++ }; ++ ++ mdio@24520 { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ compatible = "fsl,gianfar-mdio"; ++ reg = <0x24520 0x20>; ++ phy2: ethernet-phy@2 { ++ interrupt-parent = < &ipic >; ++ interrupts = <0x11 0x8>; ++ reg = <2>; ++ device_type = "ethernet-phy"; ++ }; ++ phy3: ethernet-phy@3 { ++ interrupt-parent = < &ipic >; ++ interrupts = <0x12 0x8>; ++ reg = <3>; ++ device_type = "ethernet-phy"; ++ }; ++ }; ++ ++ enet0: ethernet@24000 { ++ cell-index = <0>; ++ device_type = "network"; ++ model = "eTSEC"; ++ compatible = "gianfar"; ++ reg = <0x24000 0x1000>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ interrupts = <0x20 0x8 0x21 0x8 0x22 0x8>; ++ phy-connection-type = "mii"; ++ interrupt-parent = < &ipic >; ++ phy-handle = < &phy2 >; ++ }; ++ ++ enet1: ethernet@25000 { ++ cell-index = <1>; ++ device_type = "network"; ++ model = "eTSEC"; ++ compatible = "gianfar"; ++ reg = <0x25000 0x1000>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ interrupts = <0x23 0x8 0x24 0x8 0x25 0x8>; ++ phy-connection-type = "mii"; ++ interrupt-parent = < &ipic >; ++ phy-handle = < &phy3 >; ++ }; ++ ++ serial0: serial@4500 { ++ cell-index = <0>; ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <0x4500 0x100>; ++ clock-frequency = <0>; ++ interrupts = <0x9 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ serial1: serial@4600 { ++ cell-index = <1>; ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <0x4600 0x100>; ++ clock-frequency = <0>; ++ interrupts = <0xa 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ crypto@30000 { ++ model = "SEC3"; ++ compatible = "talitos"; ++ reg = <0x30000 0x10000>; ++ interrupts = <0xb 0x8>; ++ interrupt-parent = < &ipic >; ++ /* Rev. 3.0 geometry */ ++ num-channels = <4>; ++ channel-fifo-len = <0x18>; ++ exec-units-mask = <0x000001fe>; ++ descriptor-types-mask = <0x03ab0ebf>; ++ }; ++ ++ sdhc@2e000 { ++ model = "eSDHC"; ++ compatible = "fsl,esdhc"; ++ reg = <0x2e000 0x1000>; ++ interrupts = <0x2a 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ sata@18000 { ++ compatible = "fsl,mpc8379-sata"; ++ reg = <0x18000 0x1000>; ++ interrupts = <0x2c 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ sata@19000 { ++ compatible = "fsl,mpc8379-sata"; ++ reg = <0x19000 0x1000>; ++ interrupts = <0x2d 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ sata@1a000 { ++ compatible = "fsl,mpc8379-sata"; ++ reg = <0x1a000 0x1000>; ++ interrupts = <0x2e 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ sata@1b000 { ++ compatible = "fsl,mpc8379-sata"; ++ reg = <0x1b000 0x1000>; ++ interrupts = <0x2f 0x8>; ++ interrupt-parent = < &ipic >; ++ }; ++ ++ /* IPIC ++ * interrupts cell = <intr #, sense> ++ * sense values match linux IORESOURCE_IRQ_* defines: ++ * sense == 8: Level, low assertion ++ * sense == 2: Edge, high-to-low change ++ */ ++ ipic: pic@700 { ++ compatible = "fsl,ipic"; ++ interrupt-controller; ++ #address-cells = <0>; ++ #interrupt-cells = <2>; ++ reg = <0x700 0x100>; ++ }; ++ }; ++ ++ pci0: pci@e0008500 { ++ cell-index = <0>; ++ interrupt-map-mask = <0xf800 0x0 0x0 0x7>; ++ interrupt-map = < ++ ++ /* IDSEL 0x11 */ ++ 0x8800 0x0 0x0 0x1 &ipic 0x14 0x8 ++ 0x8800 0x0 0x0 0x2 &ipic 0x15 0x8 ++ 0x8800 0x0 0x0 0x3 &ipic 0x16 0x8 ++ 0x8800 0x0 0x0 0x4 &ipic 0x17 0x8 ++ ++ /* IDSEL 0x12 */ ++ 0x9000 0x0 0x0 0x1 &ipic 0x16 0x8 ++ 0x9000 0x0 0x0 0x2 &ipic 0x17 0x8 ++ 0x9000 0x0 0x0 0x3 &ipic 0x14 0x8 ++ 0x9000 0x0 0x0 0x4 &ipic 0x15 0x8 ++ ++ /* IDSEL 0x13 */ ++ 0x9800 0x0 0x0 0x1 &ipic 0x17 0x8 ++ 0x9800 0x0 0x0 0x2 &ipic 0x14 0x8 ++ 0x9800 0x0 0x0 0x3 &ipic 0x15 0x8 ++ 0x9800 0x0 0x0 0x4 &ipic 0x16 0x8 ++ ++ /* IDSEL 0x15 */ ++ 0xa800 0x0 0x0 0x1 &ipic 0x14 0x8 ++ 0xa800 0x0 0x0 0x2 &ipic 0x15 0x8 ++ 0xa800 0x0 0x0 0x3 &ipic 0x16 0x8 ++ 0xa800 0x0 0x0 0x4 &ipic 0x17 0x8 ++ ++ /* IDSEL 0x16 */ ++ 0xb000 0x0 0x0 0x1 &ipic 0x17 0x8 ++ 0xb000 0x0 0x0 0x2 &ipic 0x14 0x8 ++ 0xb000 0x0 0x0 0x3 &ipic 0x15 0x8 ++ 0xb000 0x0 0x0 0x4 &ipic 0x16 0x8 ++ ++ /* IDSEL 0x17 */ ++ 0xb800 0x0 0x0 0x1 &ipic 0x16 0x8 ++ 0xb800 0x0 0x0 0x2 &ipic 0x17 0x8 ++ 0xb800 0x0 0x0 0x3 &ipic 0x14 0x8 ++ 0xb800 0x0 0x0 0x4 &ipic 0x15 0x8 ++ ++ /* IDSEL 0x18 */ ++ 0xc000 0x0 0x0 0x1 &ipic 0x15 0x8 ++ 0xc000 0x0 0x0 0x2 &ipic 0x16 0x8 ++ 0xc000 0x0 0x0 0x3 &ipic 0x17 0x8 ++ 0xc000 0x0 0x0 0x4 &ipic 0x14 0x8>; ++ interrupt-parent = < &ipic >; ++ interrupts = <0x42 0x8>; ++ bus-range = <0 0>; ++ ranges = <0x02000000 0x0 0x90000000 0x90000000 0x0 0x10000000 ++ 0x42000000 0x0 0x80000000 0x80000000 0x0 0x10000000 ++ 0x01000000 0x0 0x00000000 0xe0300000 0x0 0x00100000>; ++ clock-frequency = <0>; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ reg = <0xe0008500 0x100>; ++ compatible = "fsl,mpc8349-pci"; ++ device_type = "pci"; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8540ads.dts powerpc.git/arch/powerpc/boot/dts/mpc8540ads.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8540ads.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8540ads.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -16,6 +16,15 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ ethernet2 = &enet2; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -63,7 +72,9 @@ + }; + + i2c@3000 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <2b 2>; +@@ -74,9 +85,9 @@ + mdio@24520 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "mdio"; +- compatible = "gianfar"; ++ compatible = "fsl,gianfar-mdio"; + reg = <24520 20>; ++ + phy0: ethernet-phy@0 { + interrupt-parent = <&mpic>; + interrupts = <5 1>; +@@ -97,64 +108,44 @@ + }; + }; + +- ethernet@24000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet0: ethernet@24000 { ++ cell-index = <0>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; + reg = <24000 1000>; +- /* +- * address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <1d 2 1e 2 22 2>; + interrupt-parent = <&mpic>; + phy-handle = <&phy0>; + }; + +- ethernet@25000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet1: ethernet@25000 { ++ cell-index = <1>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; + reg = <25000 1000>; +- /* +- * address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <23 2 24 2 28 2>; + interrupt-parent = <&mpic>; + phy-handle = <&phy1>; + }; + +- ethernet@26000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet2: ethernet@26000 { ++ cell-index = <2>; + device_type = "network"; + model = "FEC"; + compatible = "gianfar"; + reg = <26000 1000>; +- /* +- * address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <29 2>; + interrupt-parent = <&mpic>; + phy-handle = <&phy3>; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; // reg base, size +@@ -163,7 +154,8 @@ + interrupt-parent = <&mpic>; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; // reg base, size +@@ -183,7 +175,8 @@ + }; + }; + +- pci@e0008000 { ++ pci0: pci@e0008000 { ++ cell-index = <0>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8541cds.dts powerpc.git/arch/powerpc/boot/dts/mpc8541cds.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8541cds.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8541cds.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -16,6 +16,15 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ pci1 = &pci1; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -63,7 +72,9 @@ + }; + + i2c@3000 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <2b 2>; +@@ -74,9 +85,9 @@ + mdio@24520 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "mdio"; +- compatible = "gianfar"; ++ compatible = "fsl,gianfar-mdio"; + reg = <24520 20>; ++ + phy0: ethernet-phy@0 { + interrupt-parent = <&mpic>; + interrupts = <5 1>; +@@ -91,9 +102,8 @@ + }; + }; + +- ethernet@24000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet0: ethernet@24000 { ++ cell-index = <0>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; +@@ -104,9 +114,8 @@ + phy-handle = <&phy0>; + }; + +- ethernet@25000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet1: ethernet@25000 { ++ cell-index = <1>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; +@@ -117,7 +126,8 @@ + phy-handle = <&phy1>; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; // reg base, size +@@ -126,7 +136,8 @@ + interrupt-parent = <&mpic>; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; // reg base, size +@@ -183,7 +194,8 @@ + }; + }; + +- pci1: pci@e0008000 { ++ pci0: pci@e0008000 { ++ cell-index = <0>; + interrupt-map-mask = <1f800 0 0 7>; + interrupt-map = < + +@@ -250,11 +262,12 @@ + #interrupt-cells = <2>; + compatible = "chrp,iic"; + interrupts = <1>; +- interrupt-parent = <&pci1>; ++ interrupt-parent = <&pci0>; + }; + }; + +- pci@e0009000 { ++ pci1: pci@e0009000 { ++ cell-index = <1>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8544ds.dts powerpc.git/arch/powerpc/boot/dts/mpc8544ds.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8544ds.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8544ds.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -15,6 +15,17 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ pci1 = &pci1; ++ pci2 = &pci2; ++ pci3 = &pci3; ++ }; ++ + cpus { + #cpus = <1>; + #address-cells = <1>; +@@ -64,7 +75,9 @@ + }; + + i2c@3000 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <2b 2>; +@@ -72,12 +85,23 @@ + dfsrr; + }; + ++ i2c@3100 { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <1>; ++ compatible = "fsl-i2c"; ++ reg = <3100 100>; ++ interrupts = <2b 2>; ++ interrupt-parent = <&mpic>; ++ dfsrr; ++ }; ++ + mdio@24520 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "mdio"; +- compatible = "gianfar"; ++ compatible = "fsl,gianfar-mdio"; + reg = <24520 20>; ++ + phy0: ethernet-phy@0 { + interrupt-parent = <&mpic>; + interrupts = <a 1>; +@@ -92,9 +116,8 @@ + }; + }; + +- ethernet@24000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet0: ethernet@24000 { ++ cell-index = <0>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; +@@ -106,9 +129,8 @@ + phy-connection-type = "rgmii-id"; + }; + +- ethernet@26000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet1: ethernet@26000 { ++ cell-index = <1>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; +@@ -120,7 +142,8 @@ + phy-connection-type = "rgmii-id"; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; +@@ -129,7 +152,8 @@ + interrupt-parent = <&mpic>; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; +@@ -156,7 +180,8 @@ + }; + }; + +- pci@e0008000 { ++ pci0: pci@e0008000 { ++ cell-index = <0>; + compatible = "fsl,mpc8540-pci"; + device_type = "pci"; + interrupt-map-mask = <f800 0 0 7>; +@@ -187,7 +212,8 @@ + reg = <e0008000 1000>; + }; + +- pcie@e0009000 { ++ pci1: pcie@e0009000 { ++ cell-index = <1>; + compatible = "fsl,mpc8548-pcie"; + device_type = "pci"; + #interrupt-cells = <1>; +@@ -223,7 +249,8 @@ + }; + }; + +- pcie@e000a000 { ++ pci2: pcie@e000a000 { ++ cell-index = <2>; + compatible = "fsl,mpc8548-pcie"; + device_type = "pci"; + #interrupt-cells = <1>; +@@ -259,7 +286,8 @@ + }; + }; + +- pcie@e000b000 { ++ pci3: pcie@e000b000 { ++ cell-index = <3>; + compatible = "fsl,mpc8548-pcie"; + device_type = "pci"; + #interrupt-cells = <1>; +@@ -276,9 +304,9 @@ + interrupt-map = < + // IDSEL 0x1c USB + e000 0 0 1 &i8259 c 2 +- e100 0 0 1 &i8259 9 2 +- e200 0 0 1 &i8259 a 2 +- e300 0 0 1 &i8259 b 2 ++ e100 0 0 2 &i8259 9 2 ++ e200 0 0 3 &i8259 a 2 ++ e300 0 0 4 &i8259 b 2 + + // IDSEL 0x1d Audio + e800 0 0 1 &i8259 6 2 +@@ -369,6 +397,5 @@ + }; + }; + }; +- + }; + }; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8548cds.dts powerpc.git/arch/powerpc/boot/dts/mpc8548cds.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8548cds.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8548cds.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -16,6 +16,20 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++/* ++ ethernet2 = &enet2; ++ ethernet3 = &enet3; ++*/ ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ pci1 = &pci1; ++ pci2 = &pci2; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -63,7 +77,9 @@ + }; + + i2c@3000 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <2b 2>; +@@ -71,12 +87,23 @@ + dfsrr; + }; + ++ i2c@3100 { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <1>; ++ compatible = "fsl-i2c"; ++ reg = <3100 100>; ++ interrupts = <2b 2>; ++ interrupt-parent = <&mpic>; ++ dfsrr; ++ }; ++ + mdio@24520 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "mdio"; +- compatible = "gianfar"; ++ compatible = "fsl,gianfar-mdio"; + reg = <24520 20>; ++ + phy0: ethernet-phy@0 { + interrupt-parent = <&mpic>; + interrupts = <5 1>; +@@ -103,9 +130,8 @@ + }; + }; + +- ethernet@24000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet0: ethernet@24000 { ++ cell-index = <0>; + device_type = "network"; + model = "eTSEC"; + compatible = "gianfar"; +@@ -116,9 +142,8 @@ + phy-handle = <&phy0>; + }; + +- ethernet@25000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet1: ethernet@25000 { ++ cell-index = <1>; + device_type = "network"; + model = "eTSEC"; + compatible = "gianfar"; +@@ -130,9 +155,8 @@ + }; + + /* eTSEC 3/4 are currently broken +- ethernet@26000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet2: ethernet@26000 { ++ cell-index = <2>; + device_type = "network"; + model = "eTSEC"; + compatible = "gianfar"; +@@ -143,9 +167,8 @@ + phy-handle = <&phy2>; + }; + +- ethernet@27000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet3: ethernet@27000 { ++ cell-index = <3>; + device_type = "network"; + model = "eTSEC"; + compatible = "gianfar"; +@@ -157,7 +180,8 @@ + }; + */ + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; // reg base, size +@@ -166,7 +190,8 @@ + interrupt-parent = <&mpic>; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; // reg base, size +@@ -193,7 +218,8 @@ + }; + }; + +- pci@e0008000 { ++ pci0: pci@e0008000 { ++ cell-index = <0>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + /* IDSEL 0x4 (PCIX Slot 2) */ +@@ -342,7 +368,8 @@ + }; + }; + +- pci@e0009000 { ++ pci1: pci@e0009000 { ++ cell-index = <1>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + +@@ -366,7 +393,8 @@ + device_type = "pci"; + }; + +- pcie@e000a000 { ++ pci2: pcie@e000a000 { ++ cell-index = <2>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8555cds.dts powerpc.git/arch/powerpc/boot/dts/mpc8555cds.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8555cds.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8555cds.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -16,6 +16,15 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ pci1 = &pci1; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -63,7 +72,9 @@ + }; + + i2c@3000 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <2b 2>; +@@ -74,9 +85,9 @@ + mdio@24520 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "mdio"; +- compatible = "gianfar"; ++ compatible = "fsl,gianfar-mdio"; + reg = <24520 20>; ++ + phy0: ethernet-phy@0 { + interrupt-parent = <&mpic>; + interrupts = <5 1>; +@@ -91,9 +102,8 @@ + }; + }; + +- ethernet@24000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet0: ethernet@24000 { ++ cell-index = <0>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; +@@ -104,9 +114,8 @@ + phy-handle = <&phy0>; + }; + +- ethernet@25000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet1: ethernet@25000 { ++ cell-index = <1>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; +@@ -117,7 +126,8 @@ + phy-handle = <&phy1>; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; // reg base, size +@@ -126,7 +136,8 @@ + interrupt-parent = <&mpic>; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; // reg base, size +@@ -183,7 +194,8 @@ + }; + }; + +- pci1: pci@e0008000 { ++ pci0: pci@e0008000 { ++ cell-index = <0>; + interrupt-map-mask = <1f800 0 0 7>; + interrupt-map = < + +@@ -250,11 +262,12 @@ + #interrupt-cells = <2>; + compatible = "chrp,iic"; + interrupts = <1>; +- interrupt-parent = <&pci1>; ++ interrupt-parent = <&pci0>; + }; + }; + +- pci@e0009000 { ++ pci1: pci@e0009000 { ++ cell-index = <1>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8560ads.dts powerpc.git/arch/powerpc/boot/dts/mpc8560ads.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8560ads.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8560ads.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -16,6 +16,16 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ ethernet2 = &enet2; ++ ethernet3 = &enet3; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -63,11 +73,11 @@ + }; + + mdio@24520 { +- device_type = "mdio"; +- compatible = "gianfar"; +- reg = <24520 20>; + #address-cells = <1>; + #size-cells = <0>; ++ compatible = "fsl,gianfar-mdio"; ++ reg = <24520 20>; ++ + phy0: ethernet-phy@0 { + interrupt-parent = <&mpic>; + interrupts = <5 1>; +@@ -94,36 +104,24 @@ + }; + }; + +- ethernet@24000 { ++ enet0: ethernet@24000 { ++ cell-index = <0>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; + reg = <24000 1000>; +- /* +- * address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <1d 2 1e 2 22 2>; + interrupt-parent = <&mpic>; + phy-handle = <&phy0>; + }; + +- ethernet@25000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet1: ethernet@25000 { ++ cell-index = <1>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; + reg = <25000 1000>; +- /* +- * address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <23 2 24 2 28 2>; + interrupt-parent = <&mpic>; +@@ -174,7 +172,7 @@ + compatible = "fsl,mpc8560-cpm-pic", "fsl,cpm2-pic"; + }; + +- serial@91a00 { ++ serial0: serial@91a00 { + device_type = "serial"; + compatible = "fsl,mpc8560-scc-uart", + "fsl,cpm2-scc-uart"; +@@ -186,7 +184,7 @@ + interrupt-parent = <&cpmpic>; + }; + +- serial@91a20 { ++ serial1: serial@91a20 { + device_type = "serial"; + compatible = "fsl,mpc8560-scc-uart", + "fsl,cpm2-scc-uart"; +@@ -198,17 +196,11 @@ + interrupt-parent = <&cpmpic>; + }; + +- ethernet@91320 { ++ enet2: ethernet@91320 { + device_type = "network"; + compatible = "fsl,mpc8560-fcc-enet", + "fsl,cpm2-fcc-enet"; + reg = <91320 20 88500 100 913b0 1>; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + fsl,cpm-command = <16200300>; + interrupts = <21 8>; +@@ -216,17 +208,11 @@ + phy-handle = <&phy2>; + }; + +- ethernet@91340 { ++ enet3: ethernet@91340 { + device_type = "network"; + compatible = "fsl,mpc8560-fcc-enet", + "fsl,cpm2-fcc-enet"; + reg = <91340 20 88600 100 913d0 1>; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + fsl,cpm-command = <1a400300>; + interrupts = <22 8>; +@@ -236,7 +222,8 @@ + }; + }; + +- pci@e0008000 { ++ pci0: pci@e0008000 { ++ cell-index = <0>; + #interrupt-cells = <1>; + #size-cells = <2>; + #address-cells = <3>; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8568mds.dts powerpc.git/arch/powerpc/boot/dts/mpc8568mds.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8568mds.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8568mds.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -20,6 +20,17 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ ethernet2 = &enet2; ++ ethernet3 = &enet3; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ pci1 = &pci1; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -74,7 +85,7 @@ + i2c@3000 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "i2c"; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <2b 2>; +@@ -90,7 +101,7 @@ + i2c@3100 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "i2c"; ++ cell-index = <1>; + compatible = "fsl-i2c"; + reg = <3100 100>; + interrupts = <2b 2>; +@@ -101,9 +112,9 @@ + mdio@24520 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "mdio"; +- compatible = "gianfar"; ++ compatible = "fsl,gianfar-mdio"; + reg = <24520 20>; ++ + phy0: ethernet-phy@7 { + interrupt-parent = <&mpic>; + interrupts = <1 1>; +@@ -130,45 +141,32 @@ + }; + }; + +- ethernet@24000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet0: ethernet@24000 { ++ cell-index = <0>; + device_type = "network"; + model = "eTSEC"; + compatible = "gianfar"; + reg = <24000 1000>; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <1d 2 1e 2 22 2>; + interrupt-parent = <&mpic>; + phy-handle = <&phy2>; + }; + +- ethernet@25000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet1: ethernet@25000 { ++ cell-index = <1>; + device_type = "network"; + model = "eTSEC"; + compatible = "gianfar"; + reg = <25000 1000>; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <23 2 24 2 28 2>; + interrupt-parent = <&mpic>; + phy-handle = <&phy3>; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; +@@ -183,7 +181,8 @@ + fsl,has-rstcr; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; +@@ -318,45 +317,35 @@ + mode = "cpu"; + }; + +- ucc@2000 { ++ enet2: ucc@2000 { + device_type = "network"; + compatible = "ucc_geth"; + model = "UCC"; ++ cell-index = <1>; + device-id = <1>; + reg = <2000 200>; + interrupts = <20>; + interrupt-parent = <&qeic>; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; +- rx-clock = <0>; +- tx-clock = <20>; ++ rx-clock-name = "none"; ++ tx-clock-name = "clk16"; + pio-handle = <&pio1>; + phy-handle = <&phy0>; + phy-connection-type = "rgmii-id"; + }; + +- ucc@3000 { ++ enet3: ucc@3000 { + device_type = "network"; + compatible = "ucc_geth"; + model = "UCC"; ++ cell-index = <2>; + device-id = <2>; + reg = <3000 200>; + interrupts = <21>; + interrupt-parent = <&qeic>; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; +- rx-clock = <0>; +- tx-clock = <20>; ++ rx-clock-name = "none"; ++ tx-clock-name = "clk16"; + pio-handle = <&pio2>; + phy-handle = <&phy1>; + phy-connection-type = "rgmii-id"; +@@ -366,7 +355,6 @@ + #address-cells = <1>; + #size-cells = <0>; + reg = <2120 18>; +- device_type = "mdio"; + compatible = "ucc_geth_phy"; + + /* These are the same PHYs as on +@@ -410,7 +398,8 @@ + + }; + +- pci@e0008000 { ++ pci0: pci@e0008000 { ++ cell-index = <0>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + /* IDSEL 0x12 AD18 */ +@@ -440,7 +429,8 @@ + }; + + /* PCI Express */ +- pcie@e000a000 { ++ pci1: pcie@e000a000 { ++ cell-index = <2>; + interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8572ds.dts powerpc.git/arch/powerpc/boot/dts/mpc8572ds.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8572ds.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8572ds.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -15,6 +15,18 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ ethernet2 = &enet2; ++ ethernet3 = &enet3; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ pci1 = &pci1; ++ pci2 = &pci2; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -69,7 +81,9 @@ + }; + + i2c@3000 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <2b 2>; +@@ -78,7 +92,9 @@ + }; + + i2c@3100 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <1>; + compatible = "fsl-i2c"; + reg = <3100 100>; + interrupts = <2b 2>; +@@ -89,9 +105,9 @@ + mdio@24520 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "mdio"; +- compatible = "gianfar"; ++ compatible = "fsl,gianfar-mdio"; + reg = <24520 20>; ++ + phy0: ethernet-phy@0 { + interrupt-parent = <&mpic>; + interrupts = <a 1>; +@@ -114,9 +130,8 @@ + }; + }; + +- ethernet@24000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet0: ethernet@24000 { ++ cell-index = <0>; + device_type = "network"; + model = "eTSEC"; + compatible = "gianfar"; +@@ -128,9 +143,8 @@ + phy-connection-type = "rgmii-id"; + }; + +- ethernet@25000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet1: ethernet@25000 { ++ cell-index = <1>; + device_type = "network"; + model = "eTSEC"; + compatible = "gianfar"; +@@ -142,9 +156,8 @@ + phy-connection-type = "rgmii-id"; + }; + +- ethernet@26000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet2: ethernet@26000 { ++ cell-index = <2>; + device_type = "network"; + model = "eTSEC"; + compatible = "gianfar"; +@@ -156,9 +169,8 @@ + phy-connection-type = "rgmii-id"; + }; + +- ethernet@27000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet3: ethernet@27000 { ++ cell-index = <3>; + device_type = "network"; + model = "eTSEC"; + compatible = "gianfar"; +@@ -170,7 +182,8 @@ + phy-connection-type = "rgmii-id"; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; +@@ -179,7 +192,8 @@ + interrupt-parent = <&mpic>; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; +@@ -206,7 +220,8 @@ + }; + }; + +- pcie@ffe08000 { ++ pci0: pcie@ffe08000 { ++ cell-index = <0>; + compatible = "fsl,mpc8548-pcie"; + device_type = "pci"; + #interrupt-cells = <1>; +@@ -319,9 +334,9 @@ + + // IDSEL 0x1c USB + e000 0 0 1 &i8259 c 2 +- e100 0 0 1 &i8259 9 2 +- e200 0 0 1 &i8259 a 2 +- e300 0 0 1 &i8259 b 2 ++ e100 0 0 2 &i8259 9 2 ++ e200 0 0 3 &i8259 a 2 ++ e300 0 0 4 &i8259 b 2 + + // IDSEL 0x1d Audio + e800 0 0 1 &i8259 6 2 +@@ -415,7 +430,8 @@ + + }; + +- pcie@ffe09000 { ++ pci1: pcie@ffe09000 { ++ cell-index = <1>; + compatible = "fsl,mpc8548-pcie"; + device_type = "pci"; + #interrupt-cells = <1>; +@@ -451,7 +467,8 @@ + }; + }; + +- pcie@ffe0a000 { ++ pci2: pcie@ffe0a000 { ++ cell-index = <2>; + compatible = "fsl,mpc8548-pcie"; + device_type = "pci"; + #interrupt-cells = <1>; +@@ -464,6 +481,7 @@ + clock-frequency = <1fca055>; + interrupt-parent = <&mpic>; + interrupts = <1b 2>; ++ interrupt-map-mask = <f800 0 0 7>; + interrupt-map = < + /* IDSEL 0x0 */ + 0000 0 0 1 &mpic 0 1 +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8610_hpcd.dts powerpc.git/arch/powerpc/boot/dts/mpc8610_hpcd.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8610_hpcd.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8610_hpcd.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -1,7 +1,7 @@ + /* + * MPC8610 HPCD Device Tree Source + * +- * Copyright 2007 Freescale Semiconductor Inc. ++ * Copyright 2007-2008 Freescale Semiconductor Inc. + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License Version 2 as published +@@ -15,6 +15,13 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ pci1 = &pci1; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -42,33 +49,42 @@ + #size-cells = <1>; + #interrupt-cells = <2>; + device_type = "soc"; ++ compatible = "fsl,mpc8610-immr", "simple-bus"; + ranges = <0 e0000000 00100000>; + reg = <e0000000 1000>; + bus-frequency = <0>; + + i2c@3000 { +- device_type = "i2c"; +- compatible = "fsl-i2c"; + #address-cells = <1>; + #size-cells = <0>; ++ cell-index = <0>; ++ compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <2b 2>; + interrupt-parent = <&mpic>; + dfsrr; ++ ++ cs4270:codec@4f { ++ compatible = "cirrus,cs4270"; ++ reg = <4f>; ++ /* MCLK source is a stand-alone oscillator */ ++ clock-frequency = <bb8000>; ++ }; + }; + + i2c@3100 { +- device_type = "i2c"; +- compatible = "fsl-i2c"; + #address-cells = <1>; + #size-cells = <0>; ++ cell-index = <1>; ++ compatible = "fsl-i2c"; + reg = <3100 100>; + interrupts = <2b 2>; + interrupt-parent = <&mpic>; + dfsrr; + }; + +- serial@4500 { ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; +@@ -77,7 +93,8 @@ + interrupt-parent = <&mpic>; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; +@@ -86,7 +103,6 @@ + interrupt-parent = <&mpic>; + }; + +- + mpic: interrupt-controller@40000 { + clock-frequency = <0>; + interrupt-controller; +@@ -103,9 +119,113 @@ + reg = <e0000 1000>; + fsl,has-rstcr; + }; ++ ++ i2s@16000 { ++ compatible = "fsl,mpc8610-ssi"; ++ cell-index = <0>; ++ reg = <16000 100>; ++ interrupt-parent = <&mpic>; ++ interrupts = <3e 2>; ++ fsl,mode = "i2s-slave"; ++ codec-handle = <&cs4270>; ++ }; ++ ++ ssi@16100 { ++ compatible = "fsl,mpc8610-ssi"; ++ cell-index = <1>; ++ reg = <16100 100>; ++ interrupt-parent = <&mpic>; ++ interrupts = <3f 2>; ++ }; ++ ++ dma@21300 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ compatible = "fsl,mpc8610-dma", "fsl,eloplus-dma"; ++ cell-index = <0>; ++ reg = <21300 4>; /* DMA general status register */ ++ ranges = <0 21100 200>; ++ ++ dma-channel@0 { ++ compatible = "fsl,mpc8610-dma-channel", ++ "fsl,eloplus-dma-channel"; ++ cell-index = <0>; ++ reg = <0 80>; ++ interrupt-parent = <&mpic>; ++ interrupts = <14 2>; ++ }; ++ dma-channel@1 { ++ compatible = "fsl,mpc8610-dma-channel", ++ "fsl,eloplus-dma-channel"; ++ cell-index = <1>; ++ reg = <80 80>; ++ interrupt-parent = <&mpic>; ++ interrupts = <15 2>; ++ }; ++ dma-channel@2 { ++ compatible = "fsl,mpc8610-dma-channel", ++ "fsl,eloplus-dma-channel"; ++ cell-index = <2>; ++ reg = <100 80>; ++ interrupt-parent = <&mpic>; ++ interrupts = <16 2>; ++ }; ++ dma-channel@3 { ++ compatible = "fsl,mpc8610-dma-channel", ++ "fsl,eloplus-dma-channel"; ++ cell-index = <3>; ++ reg = <180 80>; ++ interrupt-parent = <&mpic>; ++ interrupts = <17 2>; ++ }; ++ }; ++ ++ dma@c300 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ compatible = "fsl,mpc8610-dma", "fsl,mpc8540-dma"; ++ cell-index = <1>; ++ reg = <c300 4>; /* DMA general status register */ ++ ranges = <0 c100 200>; ++ ++ dma-channel@0 { ++ compatible = "fsl,mpc8610-dma-channel", ++ "fsl,mpc8540-dma-channel"; ++ cell-index = <0>; ++ reg = <0 80>; ++ interrupt-parent = <&mpic>; ++ interrupts = <3c 2>; ++ }; ++ dma-channel@1 { ++ compatible = "fsl,mpc8610-dma-channel", ++ "fsl,mpc8540-dma-channel"; ++ cell-index = <1>; ++ reg = <80 80>; ++ interrupt-parent = <&mpic>; ++ interrupts = <3d 2>; ++ }; ++ dma-channel@2 { ++ compatible = "fsl,mpc8610-dma-channel", ++ "fsl,mpc8540-dma-channel"; ++ cell-index = <2>; ++ reg = <100 80>; ++ interrupt-parent = <&mpic>; ++ interrupts = <3e 2>; ++ }; ++ dma-channel@3 { ++ compatible = "fsl,mpc8610-dma-channel", ++ "fsl,mpc8540-dma-channel"; ++ cell-index = <3>; ++ reg = <180 80>; ++ interrupt-parent = <&mpic>; ++ interrupts = <3f 2>; ++ }; ++ }; ++ + }; + +- pci@e0008000 { ++ pci0: pci@e0008000 { ++ cell-index = <0>; + compatible = "fsl,mpc8610-pci"; + device_type = "pci"; + #interrupt-cells = <1>; +@@ -134,7 +254,8 @@ + >; + }; + +- pcie@e000a000 { ++ pci1: pcie@e000a000 { ++ cell-index = <1>; + compatible = "fsl,mpc8641-pcie"; + device_type = "pci"; + #interrupt-cells = <1>; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc8641_hpcn.dts powerpc.git/arch/powerpc/boot/dts/mpc8641_hpcn.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc8641_hpcn.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc8641_hpcn.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -16,6 +16,17 @@ + #address-cells = <1>; + #size-cells = <1>; + ++ aliases { ++ ethernet0 = &enet0; ++ ethernet1 = &enet1; ++ ethernet2 = &enet2; ++ ethernet3 = &enet3; ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ pci1 = &pci1; ++ }; ++ + cpus { + #address-cells = <1>; + #size-cells = <0>; +@@ -49,16 +60,60 @@ + reg = <00000000 40000000>; // 1G at 0x0 + }; + ++ localbus@f8005000 { ++ #address-cells = <2>; ++ #size-cells = <1>; ++ compatible = "fsl,mpc8641-localbus", "simple-bus"; ++ reg = <f8005000 1000>; ++ interrupts = <13 2>; ++ interrupt-parent = <&mpic>; ++ ++ ranges = <0 0 ff800000 00800000 ++ 1 0 fe000000 01000000 ++ 2 0 f8200000 00100000 ++ 3 0 f8100000 00100000>; ++ ++ flash@0,0 { ++ compatible = "cfi-flash"; ++ reg = <0 0 00800000>; ++ bank-width = <2>; ++ device-width = <2>; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ partition@0 { ++ label = "kernel"; ++ reg = <00000000 00300000>; ++ }; ++ partition@300000 { ++ label = "firmware b"; ++ reg = <00300000 00100000>; ++ read-only; ++ }; ++ partition@400000 { ++ label = "fs"; ++ reg = <00400000 00300000>; ++ }; ++ partition@700000 { ++ label = "firmware a"; ++ reg = <00700000 00100000>; ++ read-only; ++ }; ++ }; ++ }; ++ + soc8641@f8000000 { + #address-cells = <1>; + #size-cells = <1>; + device_type = "soc"; ++ compatible = "simple-bus"; + ranges = <00000000 f8000000 00100000>; + reg = <f8000000 00001000>; // CCSRBAR + bus-frequency = <0>; + + i2c@3000 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <0>; + compatible = "fsl-i2c"; + reg = <3000 100>; + interrupts = <2b 2>; +@@ -67,7 +122,9 @@ + }; + + i2c@3100 { +- device_type = "i2c"; ++ #address-cells = <1>; ++ #size-cells = <0>; ++ cell-index = <1>; + compatible = "fsl-i2c"; + reg = <3100 100>; + interrupts = <2b 2>; +@@ -78,9 +135,9 @@ + mdio@24520 { + #address-cells = <1>; + #size-cells = <0>; +- device_type = "mdio"; +- compatible = "gianfar"; ++ compatible = "fsl,gianfar-mdio"; + reg = <24520 20>; ++ + phy0: ethernet-phy@0 { + interrupt-parent = <&mpic>; + interrupts = <a 1>; +@@ -107,19 +164,12 @@ + }; + }; + +- ethernet@24000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet0: ethernet@24000 { ++ cell-index = <0>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; + reg = <24000 1000>; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <1d 2 1e 2 22 2>; + interrupt-parent = <&mpic>; +@@ -127,19 +177,12 @@ + phy-connection-type = "rgmii-id"; + }; + +- ethernet@25000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet1: ethernet@25000 { ++ cell-index = <1>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; + reg = <25000 1000>; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <23 2 24 2 28 2>; + interrupt-parent = <&mpic>; +@@ -147,19 +190,12 @@ + phy-connection-type = "rgmii-id"; + }; + +- ethernet@26000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet2: ethernet@26000 { ++ cell-index = <2>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; + reg = <26000 1000>; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <1F 2 20 2 21 2>; + interrupt-parent = <&mpic>; +@@ -167,26 +203,21 @@ + phy-connection-type = "rgmii-id"; + }; + +- ethernet@27000 { +- #address-cells = <1>; +- #size-cells = <0>; ++ enet3: ethernet@27000 { ++ cell-index = <3>; + device_type = "network"; + model = "TSEC"; + compatible = "gianfar"; + reg = <27000 1000>; +- /* +- * mac-address is deprecated and will be removed +- * in 2.6.25. Only recent versions of +- * U-Boot support local-mac-address, however. +- */ +- mac-address = [ 00 00 00 00 00 00 ]; + local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <25 2 26 2 27 2>; + interrupt-parent = <&mpic>; + phy-handle = <&phy3>; + phy-connection-type = "rgmii-id"; + }; +- serial@4500 { ++ ++ serial0: serial@4500 { ++ cell-index = <0>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4500 100>; +@@ -195,7 +226,8 @@ + interrupt-parent = <&mpic>; + }; + +- serial@4600 { ++ serial1: serial@4600 { ++ cell-index = <1>; + device_type = "serial"; + compatible = "ns16550"; + reg = <4600 100>; +@@ -222,7 +254,8 @@ + }; + }; + +- pcie@f8008000 { ++ pci0: pcie@f8008000 { ++ cell-index = <0>; + compatible = "fsl,mpc8641-pcie"; + device_type = "pci"; + #interrupt-cells = <1>; +@@ -335,9 +368,9 @@ + + // IDSEL 0x1c USB + e000 0 0 1 &i8259 c 2 +- e100 0 0 1 &i8259 9 2 +- e200 0 0 1 &i8259 a 2 +- e300 0 0 1 &i8259 b 2 ++ e100 0 0 2 &i8259 9 2 ++ e200 0 0 3 &i8259 a 2 ++ e300 0 0 4 &i8259 b 2 + + // IDSEL 0x1d Audio + e800 0 0 1 &i8259 6 2 +@@ -430,7 +463,8 @@ + + }; + +- pcie@f8009000 { ++ pci1: pcie@f8009000 { ++ cell-index = <1>; + compatible = "fsl,mpc8641-pcie"; + device_type = "pci"; + #interrupt-cells = <1>; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/mpc866ads.dts powerpc.git/arch/powerpc/boot/dts/mpc866ads.dts +--- linux-2.6.24/arch/powerpc/boot/dts/mpc866ads.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/mpc866ads.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -12,7 +12,7 @@ + + / { + model = "MPC866ADS"; +- compatible = "mpc8xx"; ++ compatible = "fsl,mpc866ads"; + #address-cells = <1>; + #size-cells = <1>; + +@@ -23,15 +23,15 @@ + PowerPC,866@0 { + device_type = "cpu"; + reg = <0>; +- d-cache-line-size = <20>; // 32 bytes +- i-cache-line-size = <20>; // 32 bytes ++ d-cache-line-size = <10>; // 16 bytes ++ i-cache-line-size = <10>; // 16 bytes + d-cache-size = <2000>; // L1, 8K + i-cache-size = <4000>; // L1, 16K + timebase-frequency = <0>; + bus-frequency = <0>; + clock-frequency = <0>; + interrupts = <f 2>; // decrementer interrupt +- interrupt-parent = <&Mpc8xx_pic>; ++ interrupt-parent = <&PIC>; + }; + }; + +@@ -40,107 +40,139 @@ + reg = <00000000 800000>; + }; + +- soc866@ff000000 { ++ localbus@ff000100 { ++ compatible = "fsl,mpc866-localbus", "fsl,pq1-localbus"; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ reg = <ff000100 40>; ++ ++ ranges = < ++ 1 0 ff080000 00008000 ++ 5 0 ff0a0000 00008000 ++ >; ++ ++ board-control@1,0 { ++ reg = <1 0 20 5 300 4>; ++ compatible = "fsl,mpc866ads-bcsr"; ++ }; ++ }; ++ ++ soc@ff000000 { + #address-cells = <1>; + #size-cells = <1>; + device_type = "soc"; + ranges = <0 ff000000 00100000>; + reg = <ff000000 00000200>; + bus-frequency = <0>; +- mdio@e80 { +- device_type = "mdio"; +- compatible = "fs_enet"; +- reg = <e80 8>; ++ ++ mdio@e00 { ++ compatible = "fsl,mpc866-fec-mdio", "fsl,pq1-fec-mdio"; ++ reg = <e00 188>; + #address-cells = <1>; + #size-cells = <0>; +- phy: ethernet-phy@f { ++ PHY: ethernet-phy@f { + reg = <f>; + device_type = "ethernet-phy"; + }; + }; + +- fec@e00 { ++ ethernet@e00 { + device_type = "network"; +- compatible = "fs_enet"; +- model = "FEC"; +- device-id = <1>; ++ compatible = "fsl,mpc866-fec-enet", ++ "fsl,pq1-fec-enet"; + reg = <e00 188>; +- mac-address = [ 00 00 0C 00 01 FD ]; ++ local-mac-address = [ 00 00 00 00 00 00 ]; + interrupts = <3 1>; +- interrupt-parent = <&Mpc8xx_pic>; +- phy-handle = <&Phy>; ++ interrupt-parent = <&PIC>; ++ phy-handle = <&PHY>; ++ linux,network-index = <0>; + }; + +- mpc8xx_pic: pic@ff000000 { ++ PIC: pic@0 { + interrupt-controller; +- #address-cells = <0>; + #interrupt-cells = <2>; + reg = <0 24>; +- device_type = "mpc8xx-pic"; +- compatible = "CPM"; ++ compatible = "fsl,mpc866-pic", "fsl,pq1-pic"; + }; + +- cpm@ff000000 { ++ cpm@9c0 { + #address-cells = <1>; + #size-cells = <1>; +- device_type = "cpm"; +- model = "CPM"; +- ranges = <0 0 4000>; +- reg = <860 f0>; +- command-proc = <9c0>; ++ compatible = "fsl,mpc866-cpm", "fsl,cpm1"; ++ ranges; ++ reg = <9c0 40>; + brg-frequency = <0>; + interrupts = <0 2>; // cpm error interrupt +- interrupt-parent = <&Cpm_pic>; ++ interrupt-parent = <&CPM_PIC>; + +- cpm_pic: pic@930 { ++ muram@2000 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges = <0 2000 2000>; ++ ++ data@0 { ++ compatible = "fsl,cpm-muram-data"; ++ reg = <0 1c00>; ++ }; ++ }; ++ ++ brg@9f0 { ++ compatible = "fsl,mpc866-brg", ++ "fsl,cpm1-brg", ++ "fsl,cpm-brg"; ++ reg = <9f0 10>; ++ clock-frequency = <0>; ++ }; ++ ++ CPM_PIC: pic@930 { + interrupt-controller; + #address-cells = <0>; +- #interrupt-cells = <2>; ++ #interrupt-cells = <1>; + interrupts = <5 2 0 2>; +- interrupt-parent = <&Mpc8xx_pic>; ++ interrupt-parent = <&PIC>; + reg = <930 20>; +- device_type = "cpm-pic"; +- compatible = "CPM"; ++ compatible = "fsl,mpc866-cpm-pic", ++ "fsl,cpm1-pic"; + }; + +- smc@a80 { ++ ++ serial@a80 { + device_type = "serial"; +- compatible = "cpm_uart"; +- model = "SMC"; +- device-id = <1>; ++ compatible = "fsl,mpc866-smc-uart", ++ "fsl,cpm1-smc-uart"; + reg = <a80 10 3e80 40>; +- clock-setup = <00ffffff 0>; +- rx-clock = <1>; +- tx-clock = <1>; +- current-speed = <0>; +- interrupts = <4 3>; +- interrupt-parent = <&Cpm_pic>; ++ interrupts = <4>; ++ interrupt-parent = <&CPM_PIC>; ++ fsl,cpm-brg = <1>; ++ fsl,cpm-command = <0090>; + }; + +- smc@a90 { ++ serial@a90 { + device_type = "serial"; +- compatible = "cpm_uart"; +- model = "SMC"; +- device-id = <2>; +- reg = <a90 20 3f80 40>; +- clock-setup = <ff00ffff 90000>; +- rx-clock = <2>; +- tx-clock = <2>; +- current-speed = <0>; +- interrupts = <3 3>; +- interrupt-parent = <&Cpm_pic>; ++ compatible = "fsl,mpc866-smc-uart", ++ "fsl,cpm1-smc-uart"; ++ reg = <a90 10 3f80 40>; ++ interrupts = <3>; ++ interrupt-parent = <&CPM_PIC>; ++ fsl,cpm-brg = <2>; ++ fsl,cpm-command = <00d0>; + }; + +- scc@a00 { ++ ethernet@a00 { + device_type = "network"; +- compatible = "fs_enet"; +- model = "SCC"; +- device-id = <1>; +- reg = <a00 18 3c00 80>; +- mac-address = [ 00 00 0C 00 03 FD ]; +- interrupts = <1e 3>; +- interrupt-parent = <&Cpm_pic>; ++ compatible = "fsl,mpc866-scc-enet", ++ "fsl,cpm1-scc-enet"; ++ reg = <a00 18 3c00 100>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; ++ interrupts = <1e>; ++ interrupt-parent = <&CPM_PIC>; ++ fsl,cpm-command = <0000>; ++ linux,network-index = <1>; + }; + }; + }; ++ ++ chosen { ++ linux,stdout-path = "/soc/cpm/serial@a80"; ++ }; + }; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/rainier.dts powerpc.git/arch/powerpc/boot/dts/rainier.dts +--- linux-2.6.24/arch/powerpc/boot/dts/rainier.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/rainier.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,353 @@ ++/* ++ * Device Tree Source for AMCC Rainier ++ * ++ * Based on Sequoia code ++ * Copyright (c) 2007 MontaVista Software, Inc. ++ * ++ * FIXME: Draft only! ++ * ++ * This file is licensed under the terms of the GNU General Public ++ * License version 2. This program is licensed "as is" without ++ * any warranty of any kind, whether express or implied. ++ * ++ */ ++ ++/ { ++ #address-cells = <2>; ++ #size-cells = <1>; ++ model = "amcc,rainier"; ++ compatible = "amcc,rainier"; ++ dcr-parent = <&/cpus/cpu@0>; ++ ++ aliases { ++ ethernet0 = &EMAC0; ++ ethernet1 = &EMAC1; ++ serial0 = &UART0; ++ serial1 = &UART1; ++ serial2 = &UART2; ++ serial3 = &UART3; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ cpu@0 { ++ device_type = "cpu"; ++ model = "PowerPC,440GRx"; ++ reg = <0>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ timebase-frequency = <0>; /* Filled in by zImage */ ++ i-cache-line-size = <20>; ++ d-cache-line-size = <20>; ++ i-cache-size = <8000>; ++ d-cache-size = <8000>; ++ dcr-controller; ++ dcr-access-method = "native"; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <0 0 0>; /* Filled in by zImage */ ++ }; ++ ++ UIC0: interrupt-controller0 { ++ compatible = "ibm,uic-440grx","ibm,uic"; ++ interrupt-controller; ++ cell-index = <0>; ++ dcr-reg = <0c0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ }; ++ ++ UIC1: interrupt-controller1 { ++ compatible = "ibm,uic-440grx","ibm,uic"; ++ interrupt-controller; ++ cell-index = <1>; ++ dcr-reg = <0d0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ interrupts = <1e 4 1f 4>; /* cascade */ ++ interrupt-parent = <&UIC0>; ++ }; ++ ++ UIC2: interrupt-controller2 { ++ compatible = "ibm,uic-440grx","ibm,uic"; ++ interrupt-controller; ++ cell-index = <2>; ++ dcr-reg = <0e0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ interrupts = <1c 4 1d 4>; /* cascade */ ++ interrupt-parent = <&UIC0>; ++ }; ++ ++ SDR0: sdr { ++ compatible = "ibm,sdr-440grx", "ibm,sdr-440ep"; ++ dcr-reg = <00e 002>; ++ }; ++ ++ CPR0: cpr { ++ compatible = "ibm,cpr-440grx", "ibm,cpr-440ep"; ++ dcr-reg = <00c 002>; ++ }; ++ ++ plb { ++ compatible = "ibm,plb-440grx", "ibm,plb4"; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ ranges; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ ++ SDRAM0: sdram { ++ compatible = "ibm,sdram-440grx", "ibm,sdram-44x-ddr2denali"; ++ dcr-reg = <010 2>; ++ }; ++ ++ DMA0: dma { ++ compatible = "ibm,dma-440grx", "ibm,dma-4xx"; ++ dcr-reg = <100 027>; ++ }; ++ ++ MAL0: mcmal { ++ compatible = "ibm,mcmal-440grx", "ibm,mcmal2"; ++ dcr-reg = <180 62>; ++ num-tx-chans = <2>; ++ num-rx-chans = <2>; ++ interrupt-parent = <&MAL0>; ++ interrupts = <0 1 2 3 4>; ++ #interrupt-cells = <1>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ interrupt-map = </*TXEOB*/ 0 &UIC0 a 4 ++ /*RXEOB*/ 1 &UIC0 b 4 ++ /*SERR*/ 2 &UIC1 0 4 ++ /*TXDE*/ 3 &UIC1 1 4 ++ /*RXDE*/ 4 &UIC1 2 4>; ++ interrupt-map-mask = <ffffffff>; ++ }; ++ ++ POB0: opb { ++ compatible = "ibm,opb-440grx", "ibm,opb"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges = <00000000 1 00000000 80000000 ++ 80000000 1 80000000 80000000>; ++ interrupt-parent = <&UIC1>; ++ interrupts = <7 4>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ ++ EBC0: ebc { ++ compatible = "ibm,ebc-440grx", "ibm,ebc"; ++ dcr-reg = <012 2>; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ interrupts = <5 1>; ++ interrupt-parent = <&UIC1>; ++ ++ nor_flash@0,0 { ++ compatible = "amd,s29gl256n", "cfi-flash"; ++ bank-width = <2>; ++ reg = <0 000000 4000000>; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ partition@0 { ++ label = "Kernel"; ++ reg = <0 180000>; ++ }; ++ partition@180000 { ++ label = "ramdisk"; ++ reg = <180000 200000>; ++ }; ++ partition@380000 { ++ label = "file system"; ++ reg = <380000 3aa0000>; ++ }; ++ partition@3e20000 { ++ label = "kozio"; ++ reg = <3e20000 140000>; ++ }; ++ partition@3f60000 { ++ label = "env"; ++ reg = <3f60000 40000>; ++ }; ++ partition@3fa0000 { ++ label = "u-boot"; ++ reg = <3fa0000 60000>; ++ }; ++ }; ++ ++ }; ++ ++ UART0: serial@ef600300 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <ef600300 8>; ++ virtual-reg = <ef600300>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ current-speed = <1c200>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <0 4>; ++ }; ++ ++ UART1: serial@ef600400 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <ef600400 8>; ++ virtual-reg = <ef600400>; ++ clock-frequency = <0>; ++ current-speed = <0>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <1 4>; ++ }; ++ ++ UART2: serial@ef600500 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <ef600500 8>; ++ virtual-reg = <ef600500>; ++ clock-frequency = <0>; ++ current-speed = <0>; ++ interrupt-parent = <&UIC1>; ++ interrupts = <3 4>; ++ }; ++ ++ UART3: serial@ef600600 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <ef600600 8>; ++ virtual-reg = <ef600600>; ++ clock-frequency = <0>; ++ current-speed = <0>; ++ interrupt-parent = <&UIC1>; ++ interrupts = <4 4>; ++ }; ++ ++ IIC0: i2c@ef600700 { ++ device_type = "i2c"; ++ compatible = "ibm,iic-440grx", "ibm,iic"; ++ reg = <ef600700 14>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <2 4>; ++ }; ++ ++ IIC1: i2c@ef600800 { ++ device_type = "i2c"; ++ compatible = "ibm,iic-440grx", "ibm,iic"; ++ reg = <ef600800 14>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <7 4>; ++ }; ++ ++ ZMII0: emac-zmii@ef600d00 { ++ device_type = "zmii-interface"; ++ compatible = "ibm,zmii-440grx", "ibm,zmii"; ++ reg = <ef600d00 c>; ++ }; ++ ++ RGMII0: emac-rgmii@ef601000 { ++ device_type = "rgmii-interface"; ++ compatible = "ibm,rgmii-440grx", "ibm,rgmii"; ++ reg = <ef601000 8>; ++ has-mdio; ++ }; ++ ++ EMAC0: ethernet@ef600e00 { ++ linux,network-index = <0>; ++ device_type = "network"; ++ compatible = "ibm,emac-440grx", "ibm,emac-440epx", "ibm,emac4"; ++ interrupt-parent = <&EMAC0>; ++ interrupts = <0 1>; ++ #interrupt-cells = <1>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ interrupt-map = </*Status*/ 0 &UIC0 18 4 ++ /*Wake*/ 1 &UIC1 1d 4>; ++ reg = <ef600e00 70>; ++ local-mac-address = [000000000000]; ++ mal-device = <&MAL0>; ++ mal-tx-channel = <0>; ++ mal-rx-channel = <0>; ++ cell-index = <0>; ++ max-frame-size = <5dc>; ++ rx-fifo-size = <1000>; ++ tx-fifo-size = <800>; ++ phy-mode = "rgmii"; ++ phy-map = <00000000>; ++ zmii-device = <&ZMII0>; ++ zmii-channel = <0>; ++ rgmii-device = <&RGMII0>; ++ rgmii-channel = <0>; ++ has-inverted-stacr-oc; ++ has-new-stacr-staopc; ++ }; ++ ++ EMAC1: ethernet@ef600f00 { ++ linux,network-index = <1>; ++ device_type = "network"; ++ compatible = "ibm,emac-440grx", "ibm,emac-440epx", "ibm,emac4"; ++ interrupt-parent = <&EMAC1>; ++ interrupts = <0 1>; ++ #interrupt-cells = <1>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ interrupt-map = </*Status*/ 0 &UIC0 19 4 ++ /*Wake*/ 1 &UIC1 1f 4>; ++ reg = <ef600f00 70>; ++ local-mac-address = [000000000000]; ++ mal-device = <&MAL0>; ++ mal-tx-channel = <1>; ++ mal-rx-channel = <1>; ++ cell-index = <1>; ++ max-frame-size = <5dc>; ++ rx-fifo-size = <1000>; ++ tx-fifo-size = <800>; ++ phy-mode = "rgmii"; ++ phy-map = <00000000>; ++ zmii-device = <&ZMII0>; ++ zmii-channel = <1>; ++ rgmii-device = <&RGMII0>; ++ rgmii-channel = <1>; ++ has-inverted-stacr-oc; ++ has-new-stacr-staopc; ++ }; ++ }; ++ ++ PCI0: pci@1ec000000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb440grx-pci", "ibm,plb-pci"; ++ primary; ++ reg = <1 eec00000 8 /* Config space access */ ++ 1 eed00000 4 /* IACK */ ++ 1 eed00000 4 /* Special cycle */ ++ 1 ef400000 40>; /* Internal registers */ ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed. Chip supports a second ++ * IO range but we don't use it for now ++ */ ++ ranges = <02000000 0 80000000 1 80000000 0 10000000 ++ 01000000 0 00000000 1 e8000000 0 00100000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 0 80000000>; ++ ++ /* All PCI interrupts are routed to IRQ 67 */ ++ interrupt-map-mask = <0000 0 0 0>; ++ interrupt-map = < 0000 0 0 0 &UIC2 3 8 >; ++ }; ++ }; ++ ++ chosen { ++ linux,stdout-path = "/plb/opb/serial@ef600300"; ++ bootargs = "console=ttyS0,115200"; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/sequoia.dts powerpc.git/arch/powerpc/boot/dts/sequoia.dts +--- linux-2.6.24/arch/powerpc/boot/dts/sequoia.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/sequoia.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -17,14 +17,24 @@ + #size-cells = <1>; + model = "amcc,sequoia"; + compatible = "amcc,sequoia"; +- dcr-parent = <&/cpus/PowerPC,440EPx@0>; ++ dcr-parent = <&/cpus/cpu@0>; ++ ++ aliases { ++ ethernet0 = &EMAC0; ++ ethernet1 = &EMAC1; ++ serial0 = &UART0; ++ serial1 = &UART1; ++ serial2 = &UART2; ++ serial3 = &UART3; ++ }; + + cpus { + #address-cells = <1>; + #size-cells = <0>; + +- PowerPC,440EPx@0 { ++ cpu@0 { + device_type = "cpu"; ++ model = "PowerPC,440EPx"; + reg = <0>; + clock-frequency = <0>; /* Filled in by zImage */ + timebase-frequency = <0>; /* Filled in by zImage */ +@@ -94,7 +104,6 @@ + clock-frequency = <0>; /* Filled in by zImage */ + + SDRAM0: sdram { +- device_type = "memory-controller"; + compatible = "ibm,sdram-440epx", "ibm,sdram-44x-ddr2denali"; + dcr-reg = <010 2>; + }; +@@ -122,6 +131,13 @@ + interrupt-map-mask = <ffffffff>; + }; + ++ USB1: usb@e0000400 { ++ compatible = "ohci-be"; ++ reg = <0 e0000400 60>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <15 8>; ++ }; ++ + POB0: opb { + compatible = "ibm,opb-440epx", "ibm,opb"; + #address-cells = <1>; +@@ -308,6 +324,33 @@ + has-new-stacr-staopc; + }; + }; ++ ++ PCI0: pci@1ec000000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb440epx-pci", "ibm,plb-pci"; ++ primary; ++ reg = <1 eec00000 8 /* Config space access */ ++ 1 eed00000 4 /* IACK */ ++ 1 eed00000 4 /* Special cycle */ ++ 1 ef400000 40>; /* Internal registers */ ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed. Chip supports a second ++ * IO range but we don't use it for now ++ */ ++ ranges = <02000000 0 80000000 1 80000000 0 10000000 ++ 01000000 0 00000000 1 e8000000 0 00100000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 0 80000000>; ++ ++ /* All PCI interrupts are routed to IRQ 67 */ ++ interrupt-map-mask = <0000 0 0 0>; ++ interrupt-map = < 0000 0 0 0 &UIC2 3 8 >; ++ }; + }; + + chosen { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/storcenter.dts powerpc.git/arch/powerpc/boot/dts/storcenter.dts +--- linux-2.6.24/arch/powerpc/boot/dts/storcenter.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/storcenter.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,138 @@ ++/* ++ * Device Tree Source for IOMEGA StorCenter ++ * ++ * Copyright 2007 Oyvind Repvik ++ * Copyright 2007 Jon Loeliger ++ * ++ * Based on the Kurobox DTS by G. Liakhovetski <g.liakhovetski@gmx.de> ++ * ++ * This file is licensed under the terms of the GNU General Public ++ * License version 2. This program is licensed "as is" without any ++ * warranty of any kind, whether express or implied. ++ */ ++ ++/ { ++ model = "StorCenter"; ++ compatible = "storcenter"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ++ aliases { ++ serial0 = &serial0; ++ serial1 = &serial1; ++ pci0 = &pci0; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ PowerPC,8241@0 { ++ device_type = "cpu"; ++ reg = <0>; ++ clock-frequency = <d# 200000000>; /* Hz */ ++ timebase-frequency = <d# 25000000>; /* Hz */ ++ bus-frequency = <0>; /* from bootwrapper */ ++ i-cache-line-size = <d# 32>; /* bytes */ ++ d-cache-line-size = <d# 32>; /* bytes */ ++ i-cache-size = <4000>; ++ d-cache-size = <4000>; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <00000000 04000000>; /* 64MB @ 0x0 */ ++ }; ++ ++ soc@fc000000 { ++ #address-cells = <1>; ++ #size-cells = <1>; ++ device_type = "soc"; ++ compatible = "fsl,mpc8241", "mpc10x"; ++ store-gathering = <0>; /* 0 == off, !0 == on */ ++ ranges = <0 fc000000 100000>; ++ reg = <fc000000 100000>; /* EUMB */ ++ bus-frequency = <0>; /* fixed by loader */ ++ ++ i2c@3000 { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ compatible = "fsl-i2c"; ++ reg = <3000 100>; ++ interrupts = <5 2>; ++ interrupt-parent = <&mpic>; ++ ++ rtc@68 { ++ compatible = "dallas,ds1337"; ++ reg = <68>; ++ }; ++ }; ++ ++ serial0: serial@4500 { ++ cell-index = <0>; ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <4500 20>; ++ clock-frequency = <d# 97553800>; /* Hz */ ++ current-speed = <d# 115200>; ++ interrupts = <9 2>; ++ interrupt-parent = <&mpic>; ++ }; ++ ++ serial1: serial@4600 { ++ cell-index = <1>; ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <4600 20>; ++ clock-frequency = <d# 97553800>; /* Hz */ ++ current-speed = <d# 9600>; ++ interrupts = <a 2>; ++ interrupt-parent = <&mpic>; ++ }; ++ ++ mpic: interrupt-controller@40000 { ++ #interrupt-cells = <2>; ++ device_type = "open-pic"; ++ compatible = "chrp,open-pic"; ++ interrupt-controller; ++ reg = <40000 40000>; ++ }; ++ ++ }; ++ ++ pci0: pci@fe800000 { ++ #address-cells = <3>; ++ #size-cells = <2>; ++ #interrupt-cells = <1>; ++ device_type = "pci"; ++ compatible = "mpc10x-pci"; ++ reg = <fe800000 1000>; ++ ranges = <01000000 0 0 fe000000 0 00c00000 ++ 02000000 0 80000000 80000000 0 70000000>; ++ bus-range = <0 ff>; ++ clock-frequency = <d# 97553800>; /* Hz */ ++ interrupt-parent = <&mpic>; ++ interrupt-map-mask = <f800 0 0 7>; ++ interrupt-map = < ++ /* IDSEL 13 - IDE */ ++ 6800 0 0 1 &mpic 0 1 ++ 6800 0 0 2 &mpic 0 1 ++ 6800 0 0 3 &mpic 0 1 ++ /* IDSEL 14 - USB */ ++ 7000 0 0 1 &mpic 0 1 ++ 7000 0 0 2 &mpic 0 1 ++ 7000 0 0 3 &mpic 0 1 ++ 7000 0 0 4 &mpic 0 1 ++ /* IDSEL 15 - ETH */ ++ 7800 0 0 1 &mpic 0 1 ++ 7800 0 0 2 &mpic 0 1 ++ 7800 0 0 3 &mpic 0 1 ++ 7800 0 0 4 &mpic 0 1 ++ >; ++ }; ++ ++ chosen { ++ linux,stdout-path = "/soc/serial@4500"; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/taishan.dts powerpc.git/arch/powerpc/boot/dts/taishan.dts +--- linux-2.6.24/arch/powerpc/boot/dts/taishan.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/taishan.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,383 @@ ++/* ++ * Device Tree Source for IBM/AMCC Taishan ++ * ++ * Copyright 2007 IBM Corp. ++ * Hugh Blemings <hugh@au.ibm.com> based off code by ++ * Josh Boyer <jwboyer@linux.vnet.ibm.com>, David Gibson <dwg@au1.ibm.com> ++ * ++ * This file is licensed under the terms of the GNU General Public ++ * License version 2. This program is licensed "as is" without ++ * any warranty of any kind, whether express or implied. ++ */ ++ ++/ { ++ #address-cells = <2>; ++ #size-cells = <1>; ++ model = "amcc,taishan"; ++ compatible = "amcc,taishan"; ++ dcr-parent = <&/cpus/cpu@0>; ++ ++ aliases { ++ ethernet0 = &EMAC2; ++ ethernet1 = &EMAC3; ++ serial0 = &UART0; ++ serial1 = &UART1; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ cpu@0 { ++ device_type = "cpu"; ++ model = "PowerPC,440GX"; ++ reg = <0>; ++ clock-frequency = <2FAF0800>; // 800MHz ++ timebase-frequency = <0>; // Filled in by zImage ++ i-cache-line-size = <32>; ++ d-cache-line-size = <32>; ++ i-cache-size = <8000>; /* 32 kB */ ++ d-cache-size = <8000>; /* 32 kB */ ++ dcr-controller; ++ dcr-access-method = "native"; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <0 0 0>; // Filled in by zImage ++ }; ++ ++ ++ UICB0: interrupt-controller-base { ++ compatible = "ibm,uic-440gx", "ibm,uic"; ++ interrupt-controller; ++ cell-index = <3>; ++ dcr-reg = <200 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ }; ++ ++ ++ UIC0: interrupt-controller0 { ++ compatible = "ibm,uic-440gx", "ibm,uic"; ++ interrupt-controller; ++ cell-index = <0>; ++ dcr-reg = <0c0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ interrupts = <01 4 00 4>; /* cascade - first non-critical */ ++ interrupt-parent = <&UICB0>; ++ ++ }; ++ ++ UIC1: interrupt-controller1 { ++ compatible = "ibm,uic-440gx", "ibm,uic"; ++ interrupt-controller; ++ cell-index = <1>; ++ dcr-reg = <0d0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ interrupts = <03 4 02 4>; /* cascade */ ++ interrupt-parent = <&UICB0>; ++ }; ++ ++ UIC2: interrupt-controller2 { ++ compatible = "ibm,uic-440gx", "ibm,uic"; ++ interrupt-controller; ++ cell-index = <2>; /* was 1 */ ++ dcr-reg = <210 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ interrupts = <05 4 04 4>; /* cascade */ ++ interrupt-parent = <&UICB0>; ++ }; ++ ++ ++ CPC0: cpc { ++ compatible = "ibm,cpc-440gp"; ++ dcr-reg = <0b0 003 0e0 010>; ++ // FIXME: anything else? ++ }; ++ ++ plb { ++ compatible = "ibm,plb-440gx", "ibm,plb4"; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ ranges; ++ clock-frequency = <9896800>; // 160MHz ++ ++ SDRAM0: memory-controller { ++ compatible = "ibm,sdram-440gp"; ++ dcr-reg = <010 2>; ++ // FIXME: anything else? ++ }; ++ ++ SRAM0: sram { ++ compatible = "ibm,sram-440gp"; ++ dcr-reg = <020 8 00a 1>; ++ }; ++ ++ DMA0: dma { ++ // FIXME: ??? ++ compatible = "ibm,dma-440gp"; ++ dcr-reg = <100 027>; ++ }; ++ ++ MAL0: mcmal { ++ compatible = "ibm,mcmal-440gx", "ibm,mcmal2"; ++ dcr-reg = <180 62>; ++ num-tx-chans = <4>; ++ num-rx-chans = <4>; ++ interrupt-parent = <&MAL0>; ++ interrupts = <0 1 2 3 4>; ++ #interrupt-cells = <1>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ interrupt-map = </*TXEOB*/ 0 &UIC0 a 4 ++ /*RXEOB*/ 1 &UIC0 b 4 ++ /*SERR*/ 2 &UIC1 0 4 ++ /*TXDE*/ 3 &UIC1 1 4 ++ /*RXDE*/ 4 &UIC1 2 4>; ++ interrupt-map-mask = <ffffffff>; ++ }; ++ ++ POB0: opb { ++ compatible = "ibm,opb-440gx", "ibm,opb"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ /* Wish there was a nicer way of specifying a full 32-bit ++ range */ ++ ranges = <00000000 1 00000000 80000000 ++ 80000000 1 80000000 80000000>; ++ dcr-reg = <090 00b>; ++ interrupt-parent = <&UIC1>; ++ interrupts = <7 4>; ++ clock-frequency = <4C4B400>; // 80MHz ++ ++ ++ EBC0: ebc { ++ compatible = "ibm,ebc-440gx", "ibm,ebc"; ++ dcr-reg = <012 2>; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ clock-frequency = <4C4B400>; // 80MHz ++ ++ /* ranges property is supplied by zImage ++ * based on firmware's configuration of the ++ * EBC bridge */ ++ ++ interrupts = <5 4>; ++ interrupt-parent = <&UIC1>; ++ ++ /* TODO: Add other EBC devices */ ++ }; ++ ++ ++ ++ UART0: serial@40000200 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <40000200 8>; ++ virtual-reg = <e0000200>; ++ clock-frequency = <A8C000>; ++ current-speed = <1C200>; /* 115200 */ ++ interrupt-parent = <&UIC0>; ++ interrupts = <0 4>; ++ }; ++ ++ UART1: serial@40000300 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <40000300 8>; ++ virtual-reg = <e0000300>; ++ clock-frequency = <A8C000>; ++ current-speed = <1C200>; /* 115200 */ ++ interrupt-parent = <&UIC0>; ++ interrupts = <1 4>; ++ }; ++ ++ IIC0: i2c@40000400 { ++ /* FIXME */ ++ device_type = "i2c"; ++ compatible = "ibm,iic-440gp", "ibm,iic"; ++ reg = <40000400 14>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <2 4>; ++ }; ++ IIC1: i2c@40000500 { ++ /* FIXME */ ++ device_type = "i2c"; ++ compatible = "ibm,iic-440gp", "ibm,iic"; ++ reg = <40000500 14>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <3 4>; ++ }; ++ ++ GPIO0: gpio@40000700 { ++ /* FIXME */ ++ compatible = "ibm,gpio-440gp"; ++ reg = <40000700 20>; ++ }; ++ ++ ZMII0: emac-zmii@40000780 { ++ device_type = "zgmii-interface"; ++ compatible = "ibm,zmii-440gx", "ibm,zmii"; ++ reg = <40000780 c>; ++ }; ++ ++ RGMII0: emac-rgmii@40000790 { ++ device_type = "rgmii-interface"; ++ compatible = "ibm,rgmii"; ++ reg = <40000790 8>; ++ }; ++ ++ ++ EMAC0: ethernet@40000800 { ++ unused = <1>; ++ linux,network-index = <2>; ++ device_type = "network"; ++ compatible = "ibm,emac-440gx", "ibm,emac4"; ++ interrupt-parent = <&UIC1>; ++ interrupts = <1c 4 1d 4>; ++ reg = <40000800 70>; ++ local-mac-address = [000000000000]; // Filled in by zImage ++ mal-device = <&MAL0>; ++ mal-tx-channel = <0>; ++ mal-rx-channel = <0>; ++ cell-index = <0>; ++ max-frame-size = <5dc>; ++ rx-fifo-size = <1000>; ++ tx-fifo-size = <800>; ++ phy-mode = "rmii"; ++ phy-map = <00000001>; ++ zmii-device = <&ZMII0>; ++ zmii-channel = <0>; ++ }; ++ EMAC1: ethernet@40000900 { ++ unused = <1>; ++ linux,network-index = <3>; ++ device_type = "network"; ++ compatible = "ibm,emac-440gx", "ibm,emac4"; ++ interrupt-parent = <&UIC1>; ++ interrupts = <1e 4 1f 4>; ++ reg = <40000900 70>; ++ local-mac-address = [000000000000]; // Filled in by zImage ++ mal-device = <&MAL0>; ++ mal-tx-channel = <1>; ++ mal-rx-channel = <1>; ++ cell-index = <1>; ++ max-frame-size = <5dc>; ++ rx-fifo-size = <1000>; ++ tx-fifo-size = <800>; ++ phy-mode = "rmii"; ++ phy-map = <00000001>; ++ zmii-device = <&ZMII0>; ++ zmii-channel = <1>; ++ }; ++ ++ EMAC2: ethernet@40000c00 { ++ linux,network-index = <0>; ++ device_type = "network"; ++ compatible = "ibm,emac-440gx", "ibm,emac4"; ++ interrupt-parent = <&UIC2>; ++ interrupts = <0 4 1 4>; ++ reg = <40000c00 70>; ++ local-mac-address = [000000000000]; // Filled in by zImage ++ mal-device = <&MAL0>; ++ mal-tx-channel = <2>; ++ mal-rx-channel = <2>; ++ cell-index = <2>; ++ max-frame-size = <5dc>; ++ rx-fifo-size = <1000>; ++ tx-fifo-size = <800>; ++ phy-mode = "rgmii"; ++ phy-map = <00000001>; ++ rgmii-device = <&RGMII0>; ++ rgmii-channel = <0>; ++ zmii-device = <&ZMII0>; ++ zmii-channel = <2>; ++ }; ++ ++ EMAC3: ethernet@40000e00 { ++ linux,network-index = <1>; ++ device_type = "network"; ++ compatible = "ibm,emac-440gx", "ibm,emac4"; ++ interrupt-parent = <&UIC2>; ++ interrupts = <2 4 3 4>; ++ reg = <40000e00 70>; ++ local-mac-address = [000000000000]; // Filled in by zImage ++ mal-device = <&MAL0>; ++ mal-tx-channel = <3>; ++ mal-rx-channel = <3>; ++ cell-index = <3>; ++ max-frame-size = <5dc>; ++ rx-fifo-size = <1000>; ++ tx-fifo-size = <800>; ++ phy-mode = "rgmii"; ++ phy-map = <00000003>; ++ rgmii-device = <&RGMII0>; ++ rgmii-channel = <1>; ++ zmii-device = <&ZMII0>; ++ zmii-channel = <3>; ++ }; ++ ++ ++ GPT0: gpt@40000a00 { ++ /* FIXME */ ++ reg = <40000a00 d4>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <12 4 13 4 14 4 15 4 16 4>; ++ }; ++ ++ }; ++ ++ PCIX0: pci@20ec00000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb440gp-pcix", "ibm,plb-pcix"; ++ primary; ++ large-inbound-windows; ++ enable-msi-hole; ++ reg = <2 0ec00000 8 /* Config space access */ ++ 0 0 0 /* no IACK cycles */ ++ 2 0ed00000 4 /* Special cycles */ ++ 2 0ec80000 100 /* Internal registers */ ++ 2 0ec80100 fc>; /* Internal messaging registers */ ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed ++ */ ++ ranges = <02000000 0 80000000 00000003 80000000 0 80000000 ++ 01000000 0 00000000 00000002 08000000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 0 80000000>; ++ ++ interrupt-map-mask = <f800 0 0 7>; ++ interrupt-map = < ++ /* IDSEL 1 */ ++ 0800 0 0 1 &UIC0 17 8 ++ 0800 0 0 2 &UIC0 18 8 ++ 0800 0 0 3 &UIC0 19 8 ++ 0800 0 0 4 &UIC0 1a 8 ++ ++ /* IDSEL 2 */ ++ 1000 0 0 1 &UIC0 18 8 ++ 1000 0 0 2 &UIC0 19 8 ++ 1000 0 0 3 &UIC0 1a 8 ++ 1000 0 0 4 &UIC0 17 8 ++ >; ++ }; ++ }; ++ ++ chosen { ++ linux,stdout-path = "/plb/opb/serial@40000300"; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/tqm5200.dts powerpc.git/arch/powerpc/boot/dts/tqm5200.dts +--- linux-2.6.24/arch/powerpc/boot/dts/tqm5200.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/tqm5200.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,184 @@ ++/* ++ * TQM5200 board Device Tree Source ++ * ++ * Copyright (C) 2007 Semihalf ++ * Marian Balakowicz <m8@semihalf.com> ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++/* ++ * WARNING: Do not depend on this tree layout remaining static just yet. ++ * The MPC5200 device tree conventions are still in flux ++ * Keep an eye on the linuxppc-dev mailing list for more details ++ */ ++ ++/ { ++ model = "tqc,tqm5200"; ++ compatible = "tqc,tqm5200"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ PowerPC,5200@0 { ++ device_type = "cpu"; ++ reg = <0>; ++ d-cache-line-size = <20>; ++ i-cache-line-size = <20>; ++ d-cache-size = <4000>; // L1, 16K ++ i-cache-size = <4000>; // L1, 16K ++ timebase-frequency = <0>; // from bootloader ++ bus-frequency = <0>; // from bootloader ++ clock-frequency = <0>; // from bootloader ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <00000000 04000000>; // 64MB ++ }; ++ ++ soc5200@f0000000 { ++ model = "fsl,mpc5200"; ++ compatible = "fsl,mpc5200"; ++ revision = ""; // from bootloader ++ device_type = "soc"; ++ ranges = <0 f0000000 0000c000>; ++ reg = <f0000000 00000100>; ++ bus-frequency = <0>; // from bootloader ++ system-frequency = <0>; // from bootloader ++ ++ cdm@200 { ++ compatible = "mpc5200-cdm"; ++ reg = <200 38>; ++ }; ++ ++ mpc5200_pic: pic@500 { ++ // 5200 interrupts are encoded into two levels; ++ interrupt-controller; ++ #interrupt-cells = <3>; ++ compatible = "mpc5200-pic"; ++ reg = <500 80>; ++ }; ++ ++ gpt@600 { // General Purpose Timer ++ compatible = "fsl,mpc5200-gpt"; ++ reg = <600 10>; ++ interrupts = <1 9 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ fsl,has-wdt; ++ }; ++ ++ gpio@b00 { ++ compatible = "mpc5200-gpio"; ++ reg = <b00 40>; ++ interrupts = <1 7 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ usb@1000 { ++ compatible = "mpc5200-ohci","ohci-be"; ++ reg = <1000 ff>; ++ interrupts = <2 6 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ dma-controller@1200 { ++ compatible = "mpc5200-bestcomm"; ++ reg = <1200 80>; ++ interrupts = <3 0 0 3 1 0 3 2 0 3 3 0 ++ 3 4 0 3 5 0 3 6 0 3 7 0 ++ 3 8 0 3 9 0 3 a 0 3 b 0 ++ 3 c 0 3 d 0 3 e 0 3 f 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ xlb@1f00 { ++ compatible = "mpc5200-xlb"; ++ reg = <1f00 100>; ++ }; ++ ++ serial@2000 { // PSC1 ++ device_type = "serial"; ++ compatible = "mpc5200-psc-uart"; ++ port-number = <0>; // Logical port assignment ++ reg = <2000 100>; ++ interrupts = <2 1 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ serial@2200 { // PSC2 ++ device_type = "serial"; ++ compatible = "mpc5200-psc-uart"; ++ port-number = <1>; // Logical port assignment ++ reg = <2200 100>; ++ interrupts = <2 2 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ serial@2400 { // PSC3 ++ device_type = "serial"; ++ compatible = "mpc5200-psc-uart"; ++ port-number = <2>; // Logical port assignment ++ reg = <2400 100>; ++ interrupts = <2 3 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ ethernet@3000 { ++ device_type = "network"; ++ compatible = "mpc5200-fec"; ++ reg = <3000 800>; ++ local-mac-address = [ 00 00 00 00 00 00 ]; /* Filled in by U-Boot */ ++ interrupts = <2 5 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ ata@3a00 { ++ compatible = "mpc5200-ata"; ++ reg = <3a00 100>; ++ interrupts = <2 7 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ }; ++ ++ i2c@3d40 { ++ compatible = "mpc5200-i2c","fsl-i2c"; ++ reg = <3d40 40>; ++ interrupts = <2 10 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ fsl5200-clocking; ++ }; ++ ++ sram@8000 { ++ compatible = "mpc5200-sram"; ++ reg = <8000 4000>; ++ }; ++ }; ++ ++ pci@f0000d00 { ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ device_type = "pci"; ++ compatible = "fsl,mpc5200-pci"; ++ reg = <f0000d00 100>; ++ interrupt-map-mask = <f800 0 0 7>; ++ interrupt-map = <c000 0 0 1 &mpc5200_pic 0 0 3 ++ c000 0 0 2 &mpc5200_pic 0 0 3 ++ c000 0 0 3 &mpc5200_pic 0 0 3 ++ c000 0 0 4 &mpc5200_pic 0 0 3>; ++ clock-frequency = <0>; // From boot loader ++ interrupts = <2 8 0 2 9 0 2 a 0>; ++ interrupt-parent = <&mpc5200_pic>; ++ bus-range = <0 0>; ++ ranges = <42000000 0 80000000 80000000 0 10000000 ++ 02000000 0 90000000 90000000 0 10000000 ++ 01000000 0 00000000 a0000000 0 01000000>; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/walnut.dts powerpc.git/arch/powerpc/boot/dts/walnut.dts +--- linux-2.6.24/arch/powerpc/boot/dts/walnut.dts 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/walnut.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -14,14 +14,21 @@ + #size-cells = <1>; + model = "ibm,walnut"; + compatible = "ibm,walnut"; +- dcr-parent = <&/cpus/PowerPC,405GP@0>; ++ dcr-parent = <&/cpus/cpu@0>; ++ ++ aliases { ++ ethernet0 = &EMAC; ++ serial0 = &UART0; ++ serial1 = &UART1; ++ }; + + cpus { + #address-cells = <1>; + #size-cells = <0>; + +- PowerPC,405GP@0 { ++ cpu@0 { + device_type = "cpu"; ++ model = "PowerPC,405GP"; + reg = <0>; + clock-frequency = <bebc200>; /* Filled in by zImage */ + timebase-frequency = <0>; /* Filled in by zImage */ +@@ -168,9 +175,10 @@ + }; + }; + +- ds1743@1,0 { ++ nvram@1,0 { + /* NVRAM and RTC */ +- compatible = "ds1743"; ++ compatible = "ds1743-nvram"; ++ #bytes = <2000>; + reg = <1 0 2000>; + }; + +@@ -190,6 +198,45 @@ + virtual-reg = <f0300005>; + }; + }; ++ ++ PCI0: pci@ec000000 { ++ device_type = "pci"; ++ #interrupt-cells = <1>; ++ #size-cells = <2>; ++ #address-cells = <3>; ++ compatible = "ibm,plb405gp-pci", "ibm,plb-pci"; ++ primary; ++ reg = <eec00000 8 /* Config space access */ ++ eed80000 4 /* IACK */ ++ eed80000 4 /* Special cycle */ ++ ef480000 40>; /* Internal registers */ ++ ++ /* Outbound ranges, one memory and one IO, ++ * later cannot be changed. Chip supports a second ++ * IO range but we don't use it for now ++ */ ++ ranges = <02000000 0 80000000 80000000 0 20000000 ++ 01000000 0 00000000 e8000000 0 00010000>; ++ ++ /* Inbound 2GB range starting at 0 */ ++ dma-ranges = <42000000 0 0 0 0 80000000>; ++ ++ /* Walnut has all 4 IRQ pins tied together per slot */ ++ interrupt-map-mask = <f800 0 0 0>; ++ interrupt-map = < ++ /* IDSEL 1 */ ++ 0800 0 0 0 &UIC0 1c 8 ++ ++ /* IDSEL 2 */ ++ 1000 0 0 0 &UIC0 1d 8 ++ ++ /* IDSEL 3 */ ++ 1800 0 0 0 &UIC0 1e 8 ++ ++ /* IDSEL 4 */ ++ 2000 0 0 0 &UIC0 1f 8 ++ >; ++ }; + }; + + chosen { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/dts/warp.dts powerpc.git/arch/powerpc/boot/dts/warp.dts +--- linux-2.6.24/arch/powerpc/boot/dts/warp.dts 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/dts/warp.dts 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,239 @@ ++/* ++ * Device Tree Source for PIKA Warp ++ * ++ * Copyright (c) 2008 PIKA Technologies ++ * Sean MacLennan <smaclennan@pikatech.com> ++ * ++ * This file is licensed under the terms of the GNU General Public ++ * License version 2. This program is licensed "as is" without ++ * any warranty of any kind, whether express or implied. ++ */ ++ ++/ { ++ #address-cells = <2>; ++ #size-cells = <1>; ++ model = "pika,warp"; ++ compatible = "pika,warp"; ++ dcr-parent = <&/cpus/cpu@0>; ++ ++ aliases { ++ ethernet0 = &EMAC0; ++ serial0 = &UART0; ++ }; ++ ++ cpus { ++ #address-cells = <1>; ++ #size-cells = <0>; ++ ++ cpu@0 { ++ device_type = "cpu"; ++ model = "PowerPC,440EP"; ++ reg = <0>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ timebase-frequency = <0>; /* Filled in by zImage */ ++ i-cache-line-size = <20>; ++ d-cache-line-size = <20>; ++ i-cache-size = <8000>; ++ d-cache-size = <8000>; ++ dcr-controller; ++ dcr-access-method = "native"; ++ }; ++ }; ++ ++ memory { ++ device_type = "memory"; ++ reg = <0 0 0>; /* Filled in by zImage */ ++ }; ++ ++ UIC0: interrupt-controller0 { ++ compatible = "ibm,uic-440ep","ibm,uic"; ++ interrupt-controller; ++ cell-index = <0>; ++ dcr-reg = <0c0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ }; ++ ++ UIC1: interrupt-controller1 { ++ compatible = "ibm,uic-440ep","ibm,uic"; ++ interrupt-controller; ++ cell-index = <1>; ++ dcr-reg = <0d0 009>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ #interrupt-cells = <2>; ++ interrupts = <1e 4 1f 4>; /* cascade */ ++ interrupt-parent = <&UIC0>; ++ }; ++ ++ SDR0: sdr { ++ compatible = "ibm,sdr-440ep"; ++ dcr-reg = <00e 002>; ++ }; ++ ++ CPR0: cpr { ++ compatible = "ibm,cpr-440ep"; ++ dcr-reg = <00c 002>; ++ }; ++ ++ plb { ++ compatible = "ibm,plb-440ep", "ibm,plb-440gp", "ibm,plb4"; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ ranges; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ ++ SDRAM0: sdram { ++ compatible = "ibm,sdram-440ep", "ibm,sdram-405gp"; ++ dcr-reg = <010 2>; ++ }; ++ ++ DMA0: dma { ++ compatible = "ibm,dma-440ep", "ibm,dma-440gp"; ++ dcr-reg = <100 027>; ++ }; ++ ++ MAL0: mcmal { ++ compatible = "ibm,mcmal-440ep", "ibm,mcmal-440gp", "ibm,mcmal"; ++ dcr-reg = <180 62>; ++ num-tx-chans = <4>; ++ num-rx-chans = <2>; ++ interrupt-parent = <&MAL0>; ++ interrupts = <0 1 2 3 4>; ++ #interrupt-cells = <1>; ++ #address-cells = <0>; ++ #size-cells = <0>; ++ interrupt-map = </*TXEOB*/ 0 &UIC0 a 4 ++ /*RXEOB*/ 1 &UIC0 b 4 ++ /*SERR*/ 2 &UIC1 0 4 ++ /*TXDE*/ 3 &UIC1 1 4 ++ /*RXDE*/ 4 &UIC1 2 4>; ++ }; ++ ++ POB0: opb { ++ compatible = "ibm,opb-440ep", "ibm,opb-440gp", "ibm,opb"; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ ranges = <00000000 0 00000000 80000000 ++ 80000000 0 80000000 80000000>; ++ interrupt-parent = <&UIC1>; ++ interrupts = <7 4>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ ++ EBC0: ebc { ++ compatible = "ibm,ebc-440ep", "ibm,ebc-440gp", "ibm,ebc"; ++ dcr-reg = <012 2>; ++ #address-cells = <2>; ++ #size-cells = <1>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ interrupts = <5 1>; ++ interrupt-parent = <&UIC1>; ++ ++ fpga@2,0 { ++ compatible = "pika,fpga"; ++ reg = <2 0 2200>; ++ interrupts = <18 8>; ++ interrupt-parent = <&UIC0>; ++ }; ++ ++ nor_flash@0,0 { ++ compatible = "amd,s29gl512n", "cfi-flash"; ++ bank-width = <2>; ++ reg = <0 0 4000000>; ++ #address-cells = <1>; ++ #size-cells = <1>; ++ partition@0 { ++ label = "kernel"; ++ reg = <0 180000>; ++ }; ++ partition@180000 { ++ label = "root"; ++ reg = <180000 3480000>; ++ }; ++ partition@3600000 { ++ label = "user"; ++ reg = <3600000 900000>; ++ }; ++ partition@3f00000 { ++ label = "fpga"; ++ reg = <3f00000 40000>; ++ }; ++ partition@3f40000 { ++ label = "env"; ++ reg = <3f40000 40000>; ++ }; ++ partition@3f80000 { ++ label = "u-boot"; ++ reg = <3f80000 80000>; ++ }; ++ }; ++ }; ++ ++ UART0: serial@ef600300 { ++ device_type = "serial"; ++ compatible = "ns16550"; ++ reg = <ef600300 8>; ++ virtual-reg = <ef600300>; ++ clock-frequency = <0>; /* Filled in by zImage */ ++ current-speed = <1c200>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <0 4>; ++ }; ++ ++ IIC0: i2c@ef600700 { ++ compatible = "ibm,iic-440ep", "ibm,iic-440gp", "ibm,iic"; ++ reg = <ef600700 14>; ++ interrupt-parent = <&UIC0>; ++ interrupts = <2 4>; ++ }; ++ ++ GPIO0: gpio@ef600b00 { ++ compatible = "ibm,gpio-440ep"; ++ reg = <ef600b00 48>; ++ }; ++ ++ GPIO1: gpio@ef600c00 { ++ compatible = "ibm,gpio-440ep"; ++ reg = <ef600c00 48>; ++ }; ++ ++ ZMII0: emac-zmii@ef600d00 { ++ compatible = "ibm,zmii-440ep", "ibm,zmii-440gp", "ibm,zmii"; ++ reg = <ef600d00 c>; ++ }; ++ ++ EMAC0: ethernet@ef600e00 { ++ linux,network-index = <0>; ++ device_type = "network"; ++ compatible = "ibm,emac-440ep", "ibm,emac-440gp", "ibm,emac"; ++ interrupt-parent = <&UIC1>; ++ interrupts = <1c 4 1d 4>; ++ reg = <ef600e00 70>; ++ local-mac-address = [000000000000]; ++ mal-device = <&MAL0>; ++ mal-tx-channel = <0 1>; ++ mal-rx-channel = <0>; ++ cell-index = <0>; ++ max-frame-size = <5dc>; ++ rx-fifo-size = <1000>; ++ tx-fifo-size = <800>; ++ phy-mode = "rmii"; ++ phy-map = <00000000>; ++ zmii-device = <&ZMII0>; ++ zmii-channel = <0>; ++ }; ++ ++ usb@ef601000 { ++ compatible = "ohci-be"; ++ reg = <ef601000 80>; ++ interrupts = <8 1 9 1>; ++ interrupt-parent = < &UIC1 >; ++ }; ++ }; ++ }; ++ ++ chosen { ++ linux,stdout-path = "/plb/opb/serial@ef600300"; ++ }; ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/ebony.c powerpc.git/arch/powerpc/boot/ebony.c +--- linux-2.6.24/arch/powerpc/boot/ebony.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/ebony.c 2008-01-28 20:25:49.000000000 +0100 +@@ -31,66 +31,6 @@ + + static u8 *ebony_mac0, *ebony_mac1; + +-/* Calculate 440GP clocks */ +-void ibm440gp_fixup_clocks(unsigned int sysclk, unsigned int ser_clk) +-{ +- u32 sys0 = mfdcr(DCRN_CPC0_SYS0); +- u32 cr0 = mfdcr(DCRN_CPC0_CR0); +- u32 cpu, plb, opb, ebc, tb, uart0, uart1, m; +- u32 opdv = CPC0_SYS0_OPDV(sys0); +- u32 epdv = CPC0_SYS0_EPDV(sys0); +- +- if (sys0 & CPC0_SYS0_BYPASS) { +- /* Bypass system PLL */ +- cpu = plb = sysclk; +- } else { +- if (sys0 & CPC0_SYS0_EXTSL) +- /* PerClk */ +- m = CPC0_SYS0_FWDVB(sys0) * opdv * epdv; +- else +- /* CPU clock */ +- m = CPC0_SYS0_FBDV(sys0) * CPC0_SYS0_FWDVA(sys0); +- cpu = sysclk * m / CPC0_SYS0_FWDVA(sys0); +- plb = sysclk * m / CPC0_SYS0_FWDVB(sys0); +- } +- +- opb = plb / opdv; +- ebc = opb / epdv; +- +- /* FIXME: Check if this is for all 440GP, or just Ebony */ +- if ((mfpvr() & 0xf0000fff) == 0x40000440) +- /* Rev. B 440GP, use external system clock */ +- tb = sysclk; +- else +- /* Rev. C 440GP, errata force us to use internal clock */ +- tb = cpu; +- +- if (cr0 & CPC0_CR0_U0EC) +- /* External UART clock */ +- uart0 = ser_clk; +- else +- /* Internal UART clock */ +- uart0 = plb / CPC0_CR0_UDIV(cr0); +- +- if (cr0 & CPC0_CR0_U1EC) +- /* External UART clock */ +- uart1 = ser_clk; +- else +- /* Internal UART clock */ +- uart1 = plb / CPC0_CR0_UDIV(cr0); +- +- printf("PPC440GP: SysClk = %dMHz (%x)\n\r", +- (sysclk + 500000) / 1000000, sysclk); +- +- dt_fixup_cpu_clocks(cpu, tb, 0); +- +- dt_fixup_clock("/plb", plb); +- dt_fixup_clock("/plb/opb", opb); +- dt_fixup_clock("/plb/opb/ebc", ebc); +- dt_fixup_clock("/plb/opb/serial@40000200", uart0); +- dt_fixup_clock("/plb/opb/serial@40000300", uart1); +-} +- + #define EBONY_FPGA_PATH "/plb/opb/ebc/fpga" + #define EBONY_FPGA_FLASH_SEL 0x01 + #define EBONY_SMALL_FLASH_PATH "/plb/opb/ebc/small-flash" +@@ -134,7 +74,7 @@ + unsigned long sysclk = 33000000; + + ibm440gp_fixup_clocks(sysclk, 6 * 1843200); +- ibm4xx_fixup_memsize(); ++ ibm4xx_sdram_fixup_memsize(); + dt_fixup_mac_addresses(ebony_mac0, ebony_mac1); + ibm4xx_fixup_ebc_ranges("/plb/opb/ebc"); + ebony_flashsel_fixup(); +@@ -146,6 +86,6 @@ + platform_ops.exit = ibm44x_dbcr_reset; + ebony_mac0 = mac0; + ebony_mac1 = mac1; +- ft_init(_dtb_start, _dtb_end - _dtb_start, 32); ++ fdt_init(_dtb_start); + serial_console_init(); + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/ep405.c powerpc.git/arch/powerpc/boot/ep405.c +--- linux-2.6.24/arch/powerpc/boot/ep405.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/ep405.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,74 @@ ++/* ++ * Embedded Planet EP405 with PlanetCore firmware ++ * ++ * (c) Benjamin Herrenschmidt <benh@kernel.crashing.org>, IBM Corp,\ ++ * ++ * Based on ep88xc.c by ++ * ++ * Scott Wood <scottwood@freescale.com> ++ * ++ * Copyright (c) 2007 Freescale Semiconductor, Inc. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 as published ++ * by the Free Software Foundation. ++ */ ++ ++#include "ops.h" ++#include "stdio.h" ++#include "planetcore.h" ++#include "dcr.h" ++#include "4xx.h" ++#include "io.h" ++ ++static char *table; ++static u64 mem_size; ++ ++static void platform_fixups(void) ++{ ++ u64 val; ++ void *nvrtc; ++ ++ dt_fixup_memory(0, mem_size); ++ planetcore_set_mac_addrs(table); ++ ++ if (!planetcore_get_decimal(table, PLANETCORE_KEY_CRYSTAL_HZ, &val)) { ++ printf("No PlanetCore crystal frequency key.\r\n"); ++ return; ++ } ++ ibm405gp_fixup_clocks(val, 0xa8c000); ++ ibm4xx_quiesce_eth((u32 *)0xef600800, NULL); ++ ibm4xx_fixup_ebc_ranges("/plb/ebc"); ++ ++ if (!planetcore_get_decimal(table, PLANETCORE_KEY_KB_NVRAM, &val)) { ++ printf("No PlanetCore NVRAM size key.\r\n"); ++ return; ++ } ++ nvrtc = finddevice("/plb/ebc/nvrtc@4,200000"); ++ if (nvrtc != NULL) { ++ u32 reg[3] = { 4, 0x200000, 0}; ++ getprop(nvrtc, "reg", reg, 3); ++ reg[2] = (val << 10) & 0xffffffff; ++ setprop(nvrtc, "reg", reg, 3); ++ } ++} ++ ++void platform_init(unsigned long r3, unsigned long r4, unsigned long r5, ++ unsigned long r6, unsigned long r7) ++{ ++ table = (char *)r3; ++ planetcore_prepare_table(table); ++ ++ if (!planetcore_get_decimal(table, PLANETCORE_KEY_MB_RAM, &mem_size)) ++ return; ++ ++ mem_size *= 1024 * 1024; ++ simple_alloc_init(_end, mem_size - (unsigned long)_end, 32, 64); ++ ++ fdt_init(_dtb_start); ++ ++ planetcore_set_stdout_path(table); ++ ++ serial_console_init(); ++ platform_ops.fixups = platform_fixups; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/ep8248e.c powerpc.git/arch/powerpc/boot/ep8248e.c +--- linux-2.6.24/arch/powerpc/boot/ep8248e.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/ep8248e.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,55 @@ ++/* ++ * Embedded Planet EP8248E with PlanetCore firmware ++ * ++ * Author: Scott Wood <scottwood@freescale.com> ++ * ++ * Copyright (c) 2007 Freescale Semiconductor, Inc. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 as published ++ * by the Free Software Foundation. ++ */ ++ ++#include "ops.h" ++#include "stdio.h" ++#include "planetcore.h" ++#include "pq2.h" ++ ++static char *table; ++static u64 mem_size; ++ ++#include <io.h> ++ ++static void platform_fixups(void) ++{ ++ u64 val; ++ ++ dt_fixup_memory(0, mem_size); ++ planetcore_set_mac_addrs(table); ++ ++ if (!planetcore_get_decimal(table, PLANETCORE_KEY_CRYSTAL_HZ, &val)) { ++ printf("No PlanetCore crystal frequency key.\r\n"); ++ return; ++ } ++ ++ pq2_fixup_clocks(val); ++} ++ ++void platform_init(unsigned long r3, unsigned long r4, unsigned long r5, ++ unsigned long r6, unsigned long r7) ++{ ++ table = (char *)r3; ++ planetcore_prepare_table(table); ++ ++ if (!planetcore_get_decimal(table, PLANETCORE_KEY_MB_RAM, &mem_size)) ++ return; ++ ++ mem_size *= 1024 * 1024; ++ simple_alloc_init(_end, mem_size - (unsigned long)_end, 32, 64); ++ ++ fdt_init(_dtb_start); ++ ++ planetcore_set_stdout_path(table); ++ serial_console_init(); ++ platform_ops.fixups = platform_fixups; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/ep88xc.c powerpc.git/arch/powerpc/boot/ep88xc.c +--- linux-2.6.24/arch/powerpc/boot/ep88xc.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/ep88xc.c 2008-01-28 20:25:49.000000000 +0100 +@@ -45,7 +45,7 @@ + mem_size *= 1024 * 1024; + simple_alloc_init(_end, mem_size - (unsigned long)_end, 32, 64); + +- ft_init(_dtb_start, _dtb_end - _dtb_start, 32); ++ fdt_init(_dtb_start); + + planetcore_set_stdout_path(table); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/flatdevtree.c powerpc.git/arch/powerpc/boot/flatdevtree.c +--- linux-2.6.24/arch/powerpc/boot/flatdevtree.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/flatdevtree.c 1970-01-01 01:00:00.000000000 +0100 +@@ -1,1036 +0,0 @@ +-/* +- * This program is free software; you can redistribute it and/or modify +- * it under the terms of the GNU General Public License as published by +- * the Free Software Foundation; either version 2 of the License, or +- * (at your option) any later version. +- * +- * This program is distributed in the hope that it will be useful, +- * but WITHOUT ANY WARRANTY; without even the implied warranty of +- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +- * GNU General Public License for more details. +- * +- * You should have received a copy of the GNU General Public License +- * along with this program; if not, write to the Free Software +- * Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +- * +- * Copyright Pantelis Antoniou 2006 +- * Copyright (C) IBM Corporation 2006 +- * +- * Authors: Pantelis Antoniou <pantelis@embeddedalley.com> +- * Hollis Blanchard <hollisb@us.ibm.com> +- * Mark A. Greer <mgreer@mvista.com> +- * Paul Mackerras <paulus@samba.org> +- */ +- +-#include <string.h> +-#include <stddef.h> +-#include "flatdevtree.h" +-#include "flatdevtree_env.h" +- +-#define _ALIGN(x, al) (((x) + (al) - 1) & ~((al) - 1)) +- +-static char *ft_root_node(struct ft_cxt *cxt) +-{ +- return cxt->rgn[FT_STRUCT].start; +-} +- +-/* Routines for keeping node ptrs returned by ft_find_device current */ +-/* First entry not used b/c it would return 0 and be taken as NULL/error */ +-static void *ft_get_phandle(struct ft_cxt *cxt, char *node) +-{ +- unsigned int i; +- +- if (!node) +- return NULL; +- +- for (i = 1; i < cxt->nodes_used; i++) /* already there? */ +- if (cxt->node_tbl[i] == node) +- return (void *)i; +- +- if (cxt->nodes_used < cxt->node_max) { +- cxt->node_tbl[cxt->nodes_used] = node; +- return (void *)cxt->nodes_used++; +- } +- +- return NULL; +-} +- +-static char *ft_node_ph2node(struct ft_cxt *cxt, const void *phandle) +-{ +- unsigned int i = (unsigned int)phandle; +- +- if (i < cxt->nodes_used) +- return cxt->node_tbl[i]; +- return NULL; +-} +- +-static void ft_node_update_before(struct ft_cxt *cxt, char *addr, int shift) +-{ +- unsigned int i; +- +- if (shift == 0) +- return; +- +- for (i = 1; i < cxt->nodes_used; i++) +- if (cxt->node_tbl[i] < addr) +- cxt->node_tbl[i] += shift; +-} +- +-static void ft_node_update_after(struct ft_cxt *cxt, char *addr, int shift) +-{ +- unsigned int i; +- +- if (shift == 0) +- return; +- +- for (i = 1; i < cxt->nodes_used; i++) +- if (cxt->node_tbl[i] >= addr) +- cxt->node_tbl[i] += shift; +-} +- +-/* Struct used to return info from ft_next() */ +-struct ft_atom { +- u32 tag; +- const char *name; +- void *data; +- u32 size; +-}; +- +-/* Set ptrs to current one's info; return addr of next one */ +-static char *ft_next(struct ft_cxt *cxt, char *p, struct ft_atom *ret) +-{ +- u32 sz; +- +- if (p >= cxt->rgn[FT_STRUCT].start + cxt->rgn[FT_STRUCT].size) +- return NULL; +- +- ret->tag = be32_to_cpu(*(u32 *) p); +- p += 4; +- +- switch (ret->tag) { /* Tag */ +- case OF_DT_BEGIN_NODE: +- ret->name = p; +- ret->data = (void *)(p - 4); /* start of node */ +- p += _ALIGN(strlen(p) + 1, 4); +- break; +- case OF_DT_PROP: +- ret->size = sz = be32_to_cpu(*(u32 *) p); +- ret->name = cxt->str_anchor + be32_to_cpu(*(u32 *) (p + 4)); +- ret->data = (void *)(p + 8); +- p += 8 + _ALIGN(sz, 4); +- break; +- case OF_DT_END_NODE: +- case OF_DT_NOP: +- break; +- case OF_DT_END: +- default: +- p = NULL; +- break; +- } +- +- return p; +-} +- +-#define HDR_SIZE _ALIGN(sizeof(struct boot_param_header), 8) +-#define EXPAND_INCR 1024 /* alloc this much extra when expanding */ +- +-/* Copy the tree to a newly-allocated region and put things in order */ +-static int ft_reorder(struct ft_cxt *cxt, int nextra) +-{ +- unsigned long tot; +- enum ft_rgn_id r; +- char *p, *pend; +- int stroff; +- +- tot = HDR_SIZE + EXPAND_INCR; +- for (r = FT_RSVMAP; r <= FT_STRINGS; ++r) +- tot += cxt->rgn[r].size; +- if (nextra > 0) +- tot += nextra; +- tot = _ALIGN(tot, 8); +- +- if (!cxt->realloc) +- return 0; +- p = cxt->realloc(NULL, tot); +- if (!p) +- return 0; +- +- memcpy(p, cxt->bph, sizeof(struct boot_param_header)); +- /* offsets get fixed up later */ +- +- cxt->bph = (struct boot_param_header *)p; +- cxt->max_size = tot; +- pend = p + tot; +- p += HDR_SIZE; +- +- memcpy(p, cxt->rgn[FT_RSVMAP].start, cxt->rgn[FT_RSVMAP].size); +- cxt->rgn[FT_RSVMAP].start = p; +- p += cxt->rgn[FT_RSVMAP].size; +- +- memcpy(p, cxt->rgn[FT_STRUCT].start, cxt->rgn[FT_STRUCT].size); +- ft_node_update_after(cxt, cxt->rgn[FT_STRUCT].start, +- p - cxt->rgn[FT_STRUCT].start); +- cxt->p += p - cxt->rgn[FT_STRUCT].start; +- cxt->rgn[FT_STRUCT].start = p; +- +- p = pend - cxt->rgn[FT_STRINGS].size; +- memcpy(p, cxt->rgn[FT_STRINGS].start, cxt->rgn[FT_STRINGS].size); +- stroff = cxt->str_anchor - cxt->rgn[FT_STRINGS].start; +- cxt->rgn[FT_STRINGS].start = p; +- cxt->str_anchor = p + stroff; +- +- cxt->isordered = 1; +- return 1; +-} +- +-static inline char *prev_end(struct ft_cxt *cxt, enum ft_rgn_id r) +-{ +- if (r > FT_RSVMAP) +- return cxt->rgn[r - 1].start + cxt->rgn[r - 1].size; +- return (char *)cxt->bph + HDR_SIZE; +-} +- +-static inline char *next_start(struct ft_cxt *cxt, enum ft_rgn_id r) +-{ +- if (r < FT_STRINGS) +- return cxt->rgn[r + 1].start; +- return (char *)cxt->bph + cxt->max_size; +-} +- +-/* +- * See if we can expand region rgn by nextra bytes by using up +- * free space after or before the region. +- */ +-static int ft_shuffle(struct ft_cxt *cxt, char **pp, enum ft_rgn_id rgn, +- int nextra) +-{ +- char *p = *pp; +- char *rgn_start, *rgn_end; +- +- rgn_start = cxt->rgn[rgn].start; +- rgn_end = rgn_start + cxt->rgn[rgn].size; +- if (nextra <= 0 || rgn_end + nextra <= next_start(cxt, rgn)) { +- /* move following stuff */ +- if (p < rgn_end) { +- if (nextra < 0) +- memmove(p, p - nextra, rgn_end - p + nextra); +- else +- memmove(p + nextra, p, rgn_end - p); +- if (rgn == FT_STRUCT) +- ft_node_update_after(cxt, p, nextra); +- } +- cxt->rgn[rgn].size += nextra; +- if (rgn == FT_STRINGS) +- /* assumes strings only added at beginning */ +- cxt->str_anchor += nextra; +- return 1; +- } +- if (prev_end(cxt, rgn) <= rgn_start - nextra) { +- /* move preceding stuff */ +- if (p > rgn_start) { +- memmove(rgn_start - nextra, rgn_start, p - rgn_start); +- if (rgn == FT_STRUCT) +- ft_node_update_before(cxt, p, -nextra); +- } +- *pp -= nextra; +- cxt->rgn[rgn].start -= nextra; +- cxt->rgn[rgn].size += nextra; +- return 1; +- } +- return 0; +-} +- +-static int ft_make_space(struct ft_cxt *cxt, char **pp, enum ft_rgn_id rgn, +- int nextra) +-{ +- unsigned long size, ssize, tot; +- char *str, *next; +- enum ft_rgn_id r; +- +- if (!cxt->isordered) { +- unsigned long rgn_off = *pp - cxt->rgn[rgn].start; +- +- if (!ft_reorder(cxt, nextra)) +- return 0; +- +- *pp = cxt->rgn[rgn].start + rgn_off; +- } +- if (ft_shuffle(cxt, pp, rgn, nextra)) +- return 1; +- +- /* See if there is space after the strings section */ +- ssize = cxt->rgn[FT_STRINGS].size; +- if (cxt->rgn[FT_STRINGS].start + ssize +- < (char *)cxt->bph + cxt->max_size) { +- /* move strings up as far as possible */ +- str = (char *)cxt->bph + cxt->max_size - ssize; +- cxt->str_anchor += str - cxt->rgn[FT_STRINGS].start; +- memmove(str, cxt->rgn[FT_STRINGS].start, ssize); +- cxt->rgn[FT_STRINGS].start = str; +- /* enough space now? */ +- if (rgn >= FT_STRUCT && ft_shuffle(cxt, pp, rgn, nextra)) +- return 1; +- } +- +- /* how much total free space is there following this region? */ +- tot = 0; +- for (r = rgn; r < FT_STRINGS; ++r) { +- char *r_end = cxt->rgn[r].start + cxt->rgn[r].size; +- tot += next_start(cxt, rgn) - r_end; +- } +- +- /* cast is to shut gcc up; we know nextra >= 0 */ +- if (tot < (unsigned int)nextra) { +- /* have to reallocate */ +- char *newp, *new_start; +- int shift; +- +- if (!cxt->realloc) +- return 0; +- size = _ALIGN(cxt->max_size + (nextra - tot) + EXPAND_INCR, 8); +- newp = cxt->realloc(cxt->bph, size); +- if (!newp) +- return 0; +- cxt->max_size = size; +- shift = newp - (char *)cxt->bph; +- +- if (shift) { /* realloc can return same addr */ +- cxt->bph = (struct boot_param_header *)newp; +- ft_node_update_after(cxt, cxt->rgn[FT_STRUCT].start, +- shift); +- for (r = FT_RSVMAP; r <= FT_STRINGS; ++r) { +- new_start = cxt->rgn[r].start + shift; +- cxt->rgn[r].start = new_start; +- } +- *pp += shift; +- cxt->str_anchor += shift; +- } +- +- /* move strings up to the end */ +- str = newp + size - ssize; +- cxt->str_anchor += str - cxt->rgn[FT_STRINGS].start; +- memmove(str, cxt->rgn[FT_STRINGS].start, ssize); +- cxt->rgn[FT_STRINGS].start = str; +- +- if (ft_shuffle(cxt, pp, rgn, nextra)) +- return 1; +- } +- +- /* must be FT_RSVMAP and we need to move FT_STRUCT up */ +- if (rgn == FT_RSVMAP) { +- next = cxt->rgn[FT_RSVMAP].start + cxt->rgn[FT_RSVMAP].size +- + nextra; +- ssize = cxt->rgn[FT_STRUCT].size; +- if (next + ssize >= cxt->rgn[FT_STRINGS].start) +- return 0; /* "can't happen" */ +- memmove(next, cxt->rgn[FT_STRUCT].start, ssize); +- ft_node_update_after(cxt, cxt->rgn[FT_STRUCT].start, nextra); +- cxt->rgn[FT_STRUCT].start = next; +- +- if (ft_shuffle(cxt, pp, rgn, nextra)) +- return 1; +- } +- +- return 0; /* "can't happen" */ +-} +- +-static void ft_put_word(struct ft_cxt *cxt, u32 v) +-{ +- *(u32 *) cxt->p = cpu_to_be32(v); +- cxt->p += 4; +-} +- +-static void ft_put_bin(struct ft_cxt *cxt, const void *data, unsigned int sz) +-{ +- unsigned long sza = _ALIGN(sz, 4); +- +- /* zero out the alignment gap if necessary */ +- if (sz < sza) +- *(u32 *) (cxt->p + sza - 4) = 0; +- +- /* copy in the data */ +- memcpy(cxt->p, data, sz); +- +- cxt->p += sza; +-} +- +-char *ft_begin_node(struct ft_cxt *cxt, const char *name) +-{ +- unsigned long nlen = strlen(name) + 1; +- unsigned long len = 8 + _ALIGN(nlen, 4); +- char *ret; +- +- if (!ft_make_space(cxt, &cxt->p, FT_STRUCT, len)) +- return NULL; +- +- ret = cxt->p; +- +- ft_put_word(cxt, OF_DT_BEGIN_NODE); +- ft_put_bin(cxt, name, strlen(name) + 1); +- +- return ret; +-} +- +-void ft_end_node(struct ft_cxt *cxt) +-{ +- ft_put_word(cxt, OF_DT_END_NODE); +-} +- +-void ft_nop(struct ft_cxt *cxt) +-{ +- if (ft_make_space(cxt, &cxt->p, FT_STRUCT, 4)) +- ft_put_word(cxt, OF_DT_NOP); +-} +- +-#define NO_STRING 0x7fffffff +- +-static int lookup_string(struct ft_cxt *cxt, const char *name) +-{ +- char *p, *end; +- +- p = cxt->rgn[FT_STRINGS].start; +- end = p + cxt->rgn[FT_STRINGS].size; +- while (p < end) { +- if (strcmp(p, (char *)name) == 0) +- return p - cxt->str_anchor; +- p += strlen(p) + 1; +- } +- +- return NO_STRING; +-} +- +-/* lookup string and insert if not found */ +-static int map_string(struct ft_cxt *cxt, const char *name) +-{ +- int off; +- char *p; +- +- off = lookup_string(cxt, name); +- if (off != NO_STRING) +- return off; +- p = cxt->rgn[FT_STRINGS].start; +- if (!ft_make_space(cxt, &p, FT_STRINGS, strlen(name) + 1)) +- return NO_STRING; +- strcpy(p, name); +- return p - cxt->str_anchor; +-} +- +-int ft_prop(struct ft_cxt *cxt, const char *name, const void *data, +- unsigned int sz) +-{ +- int off, len; +- +- off = map_string(cxt, name); +- if (off == NO_STRING) +- return -1; +- +- len = 12 + _ALIGN(sz, 4); +- if (!ft_make_space(cxt, &cxt->p, FT_STRUCT, len)) +- return -1; +- +- ft_put_word(cxt, OF_DT_PROP); +- ft_put_word(cxt, sz); +- ft_put_word(cxt, off); +- ft_put_bin(cxt, data, sz); +- return 0; +-} +- +-int ft_prop_str(struct ft_cxt *cxt, const char *name, const char *str) +-{ +- return ft_prop(cxt, name, str, strlen(str) + 1); +-} +- +-int ft_prop_int(struct ft_cxt *cxt, const char *name, unsigned int val) +-{ +- u32 v = cpu_to_be32((u32) val); +- +- return ft_prop(cxt, name, &v, 4); +-} +- +-/* Calculate the size of the reserved map */ +-static unsigned long rsvmap_size(struct ft_cxt *cxt) +-{ +- struct ft_reserve *res; +- +- res = (struct ft_reserve *)cxt->rgn[FT_RSVMAP].start; +- while (res->start || res->len) +- ++res; +- return (char *)(res + 1) - cxt->rgn[FT_RSVMAP].start; +-} +- +-/* Calculate the size of the struct region by stepping through it */ +-static unsigned long struct_size(struct ft_cxt *cxt) +-{ +- char *p = cxt->rgn[FT_STRUCT].start; +- char *next; +- struct ft_atom atom; +- +- /* make check in ft_next happy */ +- if (cxt->rgn[FT_STRUCT].size == 0) +- cxt->rgn[FT_STRUCT].size = 0xfffffffful - (unsigned long)p; +- +- while ((next = ft_next(cxt, p, &atom)) != NULL) +- p = next; +- return p + 4 - cxt->rgn[FT_STRUCT].start; +-} +- +-/* add `adj' on to all string offset values in the struct area */ +-static void adjust_string_offsets(struct ft_cxt *cxt, int adj) +-{ +- char *p = cxt->rgn[FT_STRUCT].start; +- char *next; +- struct ft_atom atom; +- int off; +- +- while ((next = ft_next(cxt, p, &atom)) != NULL) { +- if (atom.tag == OF_DT_PROP) { +- off = be32_to_cpu(*(u32 *) (p + 8)); +- *(u32 *) (p + 8) = cpu_to_be32(off + adj); +- } +- p = next; +- } +-} +- +-/* start construction of the flat OF tree from scratch */ +-void ft_begin(struct ft_cxt *cxt, void *blob, unsigned int max_size, +- void *(*realloc_fn) (void *, unsigned long)) +-{ +- struct boot_param_header *bph = blob; +- char *p; +- struct ft_reserve *pres; +- +- /* clear the cxt */ +- memset(cxt, 0, sizeof(*cxt)); +- +- cxt->bph = bph; +- cxt->max_size = max_size; +- cxt->realloc = realloc_fn; +- cxt->isordered = 1; +- +- /* zero everything in the header area */ +- memset(bph, 0, sizeof(*bph)); +- +- bph->magic = cpu_to_be32(OF_DT_HEADER); +- bph->version = cpu_to_be32(0x10); +- bph->last_comp_version = cpu_to_be32(0x10); +- +- /* start pointers */ +- cxt->rgn[FT_RSVMAP].start = p = blob + HDR_SIZE; +- cxt->rgn[FT_RSVMAP].size = sizeof(struct ft_reserve); +- pres = (struct ft_reserve *)p; +- cxt->rgn[FT_STRUCT].start = p += sizeof(struct ft_reserve); +- cxt->rgn[FT_STRUCT].size = 4; +- cxt->rgn[FT_STRINGS].start = blob + max_size; +- cxt->rgn[FT_STRINGS].size = 0; +- +- /* init rsvmap and struct */ +- pres->start = 0; +- pres->len = 0; +- *(u32 *) p = cpu_to_be32(OF_DT_END); +- +- cxt->str_anchor = blob; +-} +- +-/* open up an existing blob to be examined or modified */ +-int ft_open(struct ft_cxt *cxt, void *blob, unsigned int max_size, +- unsigned int max_find_device, +- void *(*realloc_fn) (void *, unsigned long)) +-{ +- struct boot_param_header *bph = blob; +- +- /* can't cope with version < 16 */ +- if (be32_to_cpu(bph->version) < 16) +- return -1; +- +- /* clear the cxt */ +- memset(cxt, 0, sizeof(*cxt)); +- +- /* alloc node_tbl to track node ptrs returned by ft_find_device */ +- ++max_find_device; +- cxt->node_tbl = realloc_fn(NULL, max_find_device * sizeof(char *)); +- if (!cxt->node_tbl) +- return -1; +- memset(cxt->node_tbl, 0, max_find_device * sizeof(char *)); +- cxt->node_max = max_find_device; +- cxt->nodes_used = 1; /* don't use idx 0 b/c looks like NULL */ +- +- cxt->bph = bph; +- cxt->max_size = max_size; +- cxt->realloc = realloc_fn; +- +- cxt->rgn[FT_RSVMAP].start = blob + be32_to_cpu(bph->off_mem_rsvmap); +- cxt->rgn[FT_RSVMAP].size = rsvmap_size(cxt); +- cxt->rgn[FT_STRUCT].start = blob + be32_to_cpu(bph->off_dt_struct); +- cxt->rgn[FT_STRUCT].size = struct_size(cxt); +- cxt->rgn[FT_STRINGS].start = blob + be32_to_cpu(bph->off_dt_strings); +- cxt->rgn[FT_STRINGS].size = be32_to_cpu(bph->dt_strings_size); +- +- cxt->p = cxt->rgn[FT_STRUCT].start; +- cxt->str_anchor = cxt->rgn[FT_STRINGS].start; +- +- return 0; +-} +- +-/* add a reserver physical area to the rsvmap */ +-int ft_add_rsvmap(struct ft_cxt *cxt, u64 physaddr, u64 size) +-{ +- char *p; +- struct ft_reserve *pres; +- +- p = cxt->rgn[FT_RSVMAP].start + cxt->rgn[FT_RSVMAP].size +- - sizeof(struct ft_reserve); +- if (!ft_make_space(cxt, &p, FT_RSVMAP, sizeof(struct ft_reserve))) +- return -1; +- +- pres = (struct ft_reserve *)p; +- pres->start = cpu_to_be64(physaddr); +- pres->len = cpu_to_be64(size); +- +- return 0; +-} +- +-void ft_begin_tree(struct ft_cxt *cxt) +-{ +- cxt->p = ft_root_node(cxt); +-} +- +-void ft_end_tree(struct ft_cxt *cxt) +-{ +- struct boot_param_header *bph = cxt->bph; +- char *p, *oldstr, *str, *endp; +- unsigned long ssize; +- int adj; +- +- if (!cxt->isordered) +- return; /* we haven't touched anything */ +- +- /* adjust string offsets */ +- oldstr = cxt->rgn[FT_STRINGS].start; +- adj = cxt->str_anchor - oldstr; +- if (adj) +- adjust_string_offsets(cxt, adj); +- +- /* make strings end on 8-byte boundary */ +- ssize = cxt->rgn[FT_STRINGS].size; +- endp = (char *)_ALIGN((unsigned long)cxt->rgn[FT_STRUCT].start +- + cxt->rgn[FT_STRUCT].size + ssize, 8); +- str = endp - ssize; +- +- /* move strings down to end of structs */ +- memmove(str, oldstr, ssize); +- cxt->str_anchor = str; +- cxt->rgn[FT_STRINGS].start = str; +- +- /* fill in header fields */ +- p = (char *)bph; +- bph->totalsize = cpu_to_be32(endp - p); +- bph->off_mem_rsvmap = cpu_to_be32(cxt->rgn[FT_RSVMAP].start - p); +- bph->off_dt_struct = cpu_to_be32(cxt->rgn[FT_STRUCT].start - p); +- bph->off_dt_strings = cpu_to_be32(cxt->rgn[FT_STRINGS].start - p); +- bph->dt_strings_size = cpu_to_be32(ssize); +-} +- +-void *ft_find_device(struct ft_cxt *cxt, const void *top, const char *srch_path) +-{ +- char *node; +- +- if (top) { +- node = ft_node_ph2node(cxt, top); +- if (node == NULL) +- return NULL; +- } else { +- node = ft_root_node(cxt); +- } +- +- node = ft_find_descendent(cxt, node, srch_path); +- return ft_get_phandle(cxt, node); +-} +- +-void *ft_find_descendent(struct ft_cxt *cxt, void *top, const char *srch_path) +-{ +- struct ft_atom atom; +- char *p; +- const char *cp, *q; +- int cl; +- int depth = -1; +- int dmatch = 0; +- const char *path_comp[FT_MAX_DEPTH]; +- +- cp = srch_path; +- cl = 0; +- p = top; +- +- while ((p = ft_next(cxt, p, &atom)) != NULL) { +- switch (atom.tag) { +- case OF_DT_BEGIN_NODE: +- ++depth; +- if (depth != dmatch) +- break; +- cxt->genealogy[depth] = atom.data; +- cxt->genealogy[depth + 1] = NULL; +- if (depth && !(strncmp(atom.name, cp, cl) == 0 +- && (atom.name[cl] == '/' +- || atom.name[cl] == '\0' +- || atom.name[cl] == '@'))) +- break; +- path_comp[dmatch] = cp; +- /* it matches so far, advance to next path component */ +- cp += cl; +- /* skip slashes */ +- while (*cp == '/') +- ++cp; +- /* we're done if this is the end of the string */ +- if (*cp == 0) +- return atom.data; +- /* look for end of this component */ +- q = strchr(cp, '/'); +- if (q) +- cl = q - cp; +- else +- cl = strlen(cp); +- ++dmatch; +- break; +- case OF_DT_END_NODE: +- if (depth == 0) +- return NULL; +- if (dmatch > depth) { +- --dmatch; +- cl = cp - path_comp[dmatch] - 1; +- cp = path_comp[dmatch]; +- while (cl > 0 && cp[cl - 1] == '/') +- --cl; +- } +- --depth; +- break; +- } +- } +- return NULL; +-} +- +-void *__ft_get_parent(struct ft_cxt *cxt, void *node) +-{ +- int d; +- struct ft_atom atom; +- char *p; +- +- for (d = 0; cxt->genealogy[d] != NULL; ++d) +- if (cxt->genealogy[d] == node) +- return d > 0 ? cxt->genealogy[d - 1] : NULL; +- +- /* have to do it the hard way... */ +- p = ft_root_node(cxt); +- d = 0; +- while ((p = ft_next(cxt, p, &atom)) != NULL) { +- switch (atom.tag) { +- case OF_DT_BEGIN_NODE: +- cxt->genealogy[d] = atom.data; +- if (node == atom.data) { +- /* found it */ +- cxt->genealogy[d + 1] = NULL; +- return d > 0 ? cxt->genealogy[d - 1] : NULL; +- } +- ++d; +- break; +- case OF_DT_END_NODE: +- --d; +- break; +- } +- } +- return NULL; +-} +- +-void *ft_get_parent(struct ft_cxt *cxt, const void *phandle) +-{ +- void *node = ft_node_ph2node(cxt, phandle); +- if (node == NULL) +- return NULL; +- +- node = __ft_get_parent(cxt, node); +- return ft_get_phandle(cxt, node); +-} +- +-static const void *__ft_get_prop(struct ft_cxt *cxt, void *node, +- const char *propname, unsigned int *len) +-{ +- struct ft_atom atom; +- int depth = 0; +- +- while ((node = ft_next(cxt, node, &atom)) != NULL) { +- switch (atom.tag) { +- case OF_DT_BEGIN_NODE: +- ++depth; +- break; +- +- case OF_DT_PROP: +- if (depth != 1 || strcmp(atom.name, propname)) +- break; +- +- if (len) +- *len = atom.size; +- +- return atom.data; +- +- case OF_DT_END_NODE: +- if (--depth <= 0) +- return NULL; +- } +- } +- +- return NULL; +-} +- +-int ft_get_prop(struct ft_cxt *cxt, const void *phandle, const char *propname, +- void *buf, const unsigned int buflen) +-{ +- const void *data; +- unsigned int size; +- +- void *node = ft_node_ph2node(cxt, phandle); +- if (!node) +- return -1; +- +- data = __ft_get_prop(cxt, node, propname, &size); +- if (data) { +- unsigned int clipped_size = min(size, buflen); +- memcpy(buf, data, clipped_size); +- return size; +- } +- +- return -1; +-} +- +-void *__ft_find_node_by_prop_value(struct ft_cxt *cxt, void *prev, +- const char *propname, const char *propval, +- unsigned int proplen) +-{ +- struct ft_atom atom; +- char *p = ft_root_node(cxt); +- char *next; +- int past_prev = prev ? 0 : 1; +- int depth = -1; +- +- while ((next = ft_next(cxt, p, &atom)) != NULL) { +- const void *data; +- unsigned int size; +- +- switch (atom.tag) { +- case OF_DT_BEGIN_NODE: +- depth++; +- +- if (prev == p) { +- past_prev = 1; +- break; +- } +- +- if (!past_prev || depth < 1) +- break; +- +- data = __ft_get_prop(cxt, p, propname, &size); +- if (!data || size != proplen) +- break; +- if (memcmp(data, propval, size)) +- break; +- +- return p; +- +- case OF_DT_END_NODE: +- if (depth-- == 0) +- return NULL; +- +- break; +- } +- +- p = next; +- } +- +- return NULL; +-} +- +-void *ft_find_node_by_prop_value(struct ft_cxt *cxt, const void *prev, +- const char *propname, const char *propval, +- int proplen) +-{ +- void *node = NULL; +- +- if (prev) { +- node = ft_node_ph2node(cxt, prev); +- +- if (!node) +- return NULL; +- } +- +- node = __ft_find_node_by_prop_value(cxt, node, propname, +- propval, proplen); +- return ft_get_phandle(cxt, node); +-} +- +-int ft_set_prop(struct ft_cxt *cxt, const void *phandle, const char *propname, +- const void *buf, const unsigned int buflen) +-{ +- struct ft_atom atom; +- void *node; +- char *p, *next; +- int nextra; +- +- node = ft_node_ph2node(cxt, phandle); +- if (node == NULL) +- return -1; +- +- next = ft_next(cxt, node, &atom); +- if (atom.tag != OF_DT_BEGIN_NODE) +- /* phandle didn't point to a node */ +- return -1; +- p = next; +- +- while ((next = ft_next(cxt, p, &atom)) != NULL) { +- switch (atom.tag) { +- case OF_DT_BEGIN_NODE: /* properties must go before subnodes */ +- case OF_DT_END_NODE: +- /* haven't found the property, insert here */ +- cxt->p = p; +- return ft_prop(cxt, propname, buf, buflen); +- case OF_DT_PROP: +- if (strcmp(atom.name, propname)) +- break; +- /* found an existing property, overwrite it */ +- nextra = _ALIGN(buflen, 4) - _ALIGN(atom.size, 4); +- cxt->p = atom.data; +- if (nextra && !ft_make_space(cxt, &cxt->p, FT_STRUCT, +- nextra)) +- return -1; +- *(u32 *) (cxt->p - 8) = cpu_to_be32(buflen); +- ft_put_bin(cxt, buf, buflen); +- return 0; +- } +- p = next; +- } +- return -1; +-} +- +-int ft_del_prop(struct ft_cxt *cxt, const void *phandle, const char *propname) +-{ +- struct ft_atom atom; +- void *node; +- char *p, *next; +- int size; +- +- node = ft_node_ph2node(cxt, phandle); +- if (node == NULL) +- return -1; +- +- p = node; +- while ((next = ft_next(cxt, p, &atom)) != NULL) { +- switch (atom.tag) { +- case OF_DT_BEGIN_NODE: +- case OF_DT_END_NODE: +- return -1; +- case OF_DT_PROP: +- if (strcmp(atom.name, propname)) +- break; +- /* found the property, remove it */ +- size = 12 + -_ALIGN(atom.size, 4); +- cxt->p = p; +- if (!ft_make_space(cxt, &cxt->p, FT_STRUCT, -size)) +- return -1; +- return 0; +- } +- p = next; +- } +- return -1; +-} +- +-void *ft_create_node(struct ft_cxt *cxt, const void *parent, const char *name) +-{ +- struct ft_atom atom; +- char *p, *next, *ret; +- int depth = 0; +- +- if (parent) { +- p = ft_node_ph2node(cxt, parent); +- if (!p) +- return NULL; +- } else { +- p = ft_root_node(cxt); +- } +- +- while ((next = ft_next(cxt, p, &atom)) != NULL) { +- switch (atom.tag) { +- case OF_DT_BEGIN_NODE: +- ++depth; +- if (depth == 1 && strcmp(atom.name, name) == 0) +- /* duplicate node name, return error */ +- return NULL; +- break; +- case OF_DT_END_NODE: +- --depth; +- if (depth > 0) +- break; +- /* end of node, insert here */ +- cxt->p = p; +- ret = ft_begin_node(cxt, name); +- ft_end_node(cxt); +- return ft_get_phandle(cxt, ret); +- } +- p = next; +- } +- return NULL; +-} +- +-/* Returns the start of the path within the provided buffer, or NULL on +- * error. +- */ +-char *ft_get_path(struct ft_cxt *cxt, const void *phandle, +- char *buf, int len) +-{ +- const char *path_comp[FT_MAX_DEPTH]; +- struct ft_atom atom; +- char *p, *next, *pos; +- int depth = 0, i; +- void *node; +- +- node = ft_node_ph2node(cxt, phandle); +- if (node == NULL) +- return NULL; +- +- p = ft_root_node(cxt); +- +- while ((next = ft_next(cxt, p, &atom)) != NULL) { +- switch (atom.tag) { +- case OF_DT_BEGIN_NODE: +- path_comp[depth++] = atom.name; +- if (p == node) +- goto found; +- +- break; +- +- case OF_DT_END_NODE: +- if (--depth == 0) +- return NULL; +- } +- +- p = next; +- } +- +-found: +- pos = buf; +- for (i = 1; i < depth; i++) { +- int this_len; +- +- if (len <= 1) +- return NULL; +- +- *pos++ = '/'; +- len--; +- +- strncpy(pos, path_comp[i], len); +- +- if (pos[len - 1] != 0) +- return NULL; +- +- this_len = strlen(pos); +- len -= this_len; +- pos += this_len; +- } +- +- return buf; +-} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/flatdevtree.h powerpc.git/arch/powerpc/boot/flatdevtree.h +--- linux-2.6.24/arch/powerpc/boot/flatdevtree.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/flatdevtree.h 1970-01-01 01:00:00.000000000 +0100 +@@ -1,113 +0,0 @@ +-/* +- * This program is free software; you can redistribute it and/or modify +- * it under the terms of the GNU General Public License as published by +- * the Free Software Foundation; either version 2 of the License, or +- * (at your option) any later version. +- * +- * This program is distributed in the hope that it will be useful, +- * but WITHOUT ANY WARRANTY; without even the implied warranty of +- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +- * GNU General Public License for more details. +- * +- * You should have received a copy of the GNU General Public License +- * along with this program; if not, write to the Free Software +- * Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +- */ +- +-#ifndef FLATDEVTREE_H +-#define FLATDEVTREE_H +- +-#include "flatdevtree_env.h" +- +-/* Definitions used by the flattened device tree */ +-#define OF_DT_HEADER 0xd00dfeed /* marker */ +-#define OF_DT_BEGIN_NODE 0x1 /* Start of node, full name */ +-#define OF_DT_END_NODE 0x2 /* End node */ +-#define OF_DT_PROP 0x3 /* Property: name off, size, content */ +-#define OF_DT_NOP 0x4 /* nop */ +-#define OF_DT_END 0x9 +- +-#define OF_DT_VERSION 0x10 +- +-struct boot_param_header { +- u32 magic; /* magic word OF_DT_HEADER */ +- u32 totalsize; /* total size of DT block */ +- u32 off_dt_struct; /* offset to structure */ +- u32 off_dt_strings; /* offset to strings */ +- u32 off_mem_rsvmap; /* offset to memory reserve map */ +- u32 version; /* format version */ +- u32 last_comp_version; /* last compatible version */ +- /* version 2 fields below */ +- u32 boot_cpuid_phys; /* Physical CPU id we're booting on */ +- /* version 3 fields below */ +- u32 dt_strings_size; /* size of the DT strings block */ +-}; +- +-struct ft_reserve { +- u64 start; +- u64 len; +-}; +- +-struct ft_region { +- char *start; +- unsigned long size; +-}; +- +-enum ft_rgn_id { +- FT_RSVMAP, +- FT_STRUCT, +- FT_STRINGS, +- FT_N_REGION +-}; +- +-#define FT_MAX_DEPTH 50 +- +-struct ft_cxt { +- struct boot_param_header *bph; +- int max_size; /* maximum size of tree */ +- int isordered; /* everything in standard order */ +- void *(*realloc)(void *, unsigned long); +- char *str_anchor; +- char *p; /* current insertion point in structs */ +- struct ft_region rgn[FT_N_REGION]; +- void *genealogy[FT_MAX_DEPTH+1]; +- char **node_tbl; +- unsigned int node_max; +- unsigned int nodes_used; +-}; +- +-char *ft_begin_node(struct ft_cxt *cxt, const char *name); +-void ft_end_node(struct ft_cxt *cxt); +- +-void ft_begin_tree(struct ft_cxt *cxt); +-void ft_end_tree(struct ft_cxt *cxt); +- +-void ft_nop(struct ft_cxt *cxt); +-int ft_prop(struct ft_cxt *cxt, const char *name, +- const void *data, unsigned int sz); +-int ft_prop_str(struct ft_cxt *cxt, const char *name, const char *str); +-int ft_prop_int(struct ft_cxt *cxt, const char *name, unsigned int val); +-void ft_begin(struct ft_cxt *cxt, void *blob, unsigned int max_size, +- void *(*realloc_fn)(void *, unsigned long)); +-int ft_open(struct ft_cxt *cxt, void *blob, unsigned int max_size, +- unsigned int max_find_device, +- void *(*realloc_fn)(void *, unsigned long)); +-int ft_add_rsvmap(struct ft_cxt *cxt, u64 physaddr, u64 size); +- +-void ft_dump_blob(const void *bphp); +-void ft_merge_blob(struct ft_cxt *cxt, void *blob); +-void *ft_find_device(struct ft_cxt *cxt, const void *top, +- const char *srch_path); +-void *ft_find_descendent(struct ft_cxt *cxt, void *top, const char *srch_path); +-int ft_get_prop(struct ft_cxt *cxt, const void *phandle, const char *propname, +- void *buf, const unsigned int buflen); +-int ft_set_prop(struct ft_cxt *cxt, const void *phandle, const char *propname, +- const void *buf, const unsigned int buflen); +-void *ft_get_parent(struct ft_cxt *cxt, const void *phandle); +-void *ft_find_node_by_prop_value(struct ft_cxt *cxt, const void *prev, +- const char *propname, const char *propval, +- int proplen); +-void *ft_create_node(struct ft_cxt *cxt, const void *parent, const char *name); +-char *ft_get_path(struct ft_cxt *cxt, const void *phandle, char *buf, int len); +- +-#endif /* FLATDEVTREE_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/flatdevtree_misc.c powerpc.git/arch/powerpc/boot/flatdevtree_misc.c +--- linux-2.6.24/arch/powerpc/boot/flatdevtree_misc.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/flatdevtree_misc.c 1970-01-01 01:00:00.000000000 +0100 +@@ -1,79 +0,0 @@ +-/* +- * This file does the necessary interface mapping between the bootwrapper +- * device tree operations and the interface provided by shared source +- * files flatdevicetree.[ch]. +- * +- * Author: Mark A. Greer <mgreer@mvista.com> +- * +- * 2006 (c) MontaVista Software, Inc. This file is licensed under +- * the terms of the GNU General Public License version 2. This program +- * is licensed "as is" without any warranty of any kind, whether express +- * or implied. +- */ +-#include <stddef.h> +-#include "flatdevtree.h" +-#include "ops.h" +- +-static struct ft_cxt cxt; +- +-static void *fdtm_finddevice(const char *name) +-{ +- return ft_find_device(&cxt, NULL, name); +-} +- +-static int fdtm_getprop(const void *phandle, const char *propname, +- void *buf, const int buflen) +-{ +- return ft_get_prop(&cxt, phandle, propname, buf, buflen); +-} +- +-static int fdtm_setprop(const void *phandle, const char *propname, +- const void *buf, const int buflen) +-{ +- return ft_set_prop(&cxt, phandle, propname, buf, buflen); +-} +- +-static void *fdtm_get_parent(const void *phandle) +-{ +- return ft_get_parent(&cxt, phandle); +-} +- +-static void *fdtm_create_node(const void *phandle, const char *name) +-{ +- return ft_create_node(&cxt, phandle, name); +-} +- +-static void *fdtm_find_node_by_prop_value(const void *prev, +- const char *propname, +- const char *propval, +- int proplen) +-{ +- return ft_find_node_by_prop_value(&cxt, prev, propname, +- propval, proplen); +-} +- +-static unsigned long fdtm_finalize(void) +-{ +- ft_end_tree(&cxt); +- return (unsigned long)cxt.bph; +-} +- +-static char *fdtm_get_path(const void *phandle, char *buf, int len) +-{ +- return ft_get_path(&cxt, phandle, buf, len); +-} +- +-int ft_init(void *dt_blob, unsigned int max_size, unsigned int max_find_device) +-{ +- dt_ops.finddevice = fdtm_finddevice; +- dt_ops.getprop = fdtm_getprop; +- dt_ops.setprop = fdtm_setprop; +- dt_ops.get_parent = fdtm_get_parent; +- dt_ops.create_node = fdtm_create_node; +- dt_ops.find_node_by_prop_value = fdtm_find_node_by_prop_value; +- dt_ops.finalize = fdtm_finalize; +- dt_ops.get_path = fdtm_get_path; +- +- return ft_open(&cxt, dt_blob, max_size, max_find_device, +- platform_ops.realloc); +-} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/holly.c powerpc.git/arch/powerpc/boot/holly.c +--- linux-2.6.24/arch/powerpc/boot/holly.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/holly.c 2008-01-28 20:25:49.000000000 +0100 +@@ -28,6 +28,6 @@ + u32 heapsize = 0x8000000 - (u32)_end; /* 128M */ + + simple_alloc_init(_end, heapsize, 32, 64); +- ft_init(_dtb_start, 0, 4); ++ fdt_init(_dtb_start); + serial_console_init(); + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/libfdt/Makefile.libfdt powerpc.git/arch/powerpc/boot/libfdt/Makefile.libfdt +--- linux-2.6.24/arch/powerpc/boot/libfdt/Makefile.libfdt 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/libfdt/Makefile.libfdt 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,14 @@ ++# Makefile.libfdt ++# ++# This is not a complete Makefile of itself. Instead, it is designed to ++# be easily embeddable into other systems of Makefiles. ++# ++LIBFDT_SRCS = fdt.c fdt_ro.c fdt_wip.c fdt_sw.c fdt_rw.c fdt_strerror.c ++LIBFDT_INCLUDES = fdt.h libfdt.h ++LIBFDT_EXTRA = libfdt_internal.h ++LIBFDT_LIB = libfdt/libfdt.a ++ ++LIBFDT_OBJS = $(LIBFDT_SRCS:%.c=%.o) ++ ++$(LIBFDT_objdir)/$(LIBFDT_LIB): $(addprefix $(LIBFDT_objdir)/,$(LIBFDT_OBJS)) ++ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/libfdt/fdt.c powerpc.git/arch/powerpc/boot/libfdt/fdt.c +--- linux-2.6.24/arch/powerpc/boot/libfdt/fdt.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/libfdt/fdt.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,156 @@ ++/* ++ * libfdt - Flat Device Tree manipulation ++ * Copyright (C) 2006 David Gibson, IBM Corporation. ++ * ++ * libfdt is dual licensed: you can use it either under the terms of ++ * the GPL, or the BSD license, at your option. ++ * ++ * a) This library is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This library is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public ++ * License along with this library; if not, write to the Free ++ * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, ++ * MA 02110-1301 USA ++ * ++ * Alternatively, ++ * ++ * b) Redistribution and use in source and binary forms, with or ++ * without modification, are permitted provided that the following ++ * conditions are met: ++ * ++ * 1. Redistributions of source code must retain the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer. ++ * 2. Redistributions in binary form must reproduce the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer in the documentation and/or other materials ++ * provided with the distribution. ++ * ++ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND ++ * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, ++ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF ++ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE ++ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR ++ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, ++ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT ++ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; ++ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ++ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN ++ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR ++ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, ++ * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ++ */ ++#include "libfdt_env.h" ++ ++#include <fdt.h> ++#include <libfdt.h> ++ ++#include "libfdt_internal.h" ++ ++int fdt_check_header(const void *fdt) ++{ ++ if (fdt_magic(fdt) == FDT_MAGIC) { ++ /* Complete tree */ ++ if (fdt_version(fdt) < FDT_FIRST_SUPPORTED_VERSION) ++ return -FDT_ERR_BADVERSION; ++ if (fdt_last_comp_version(fdt) > FDT_LAST_SUPPORTED_VERSION) ++ return -FDT_ERR_BADVERSION; ++ } else if (fdt_magic(fdt) == SW_MAGIC) { ++ /* Unfinished sequential-write blob */ ++ if (fdt_size_dt_struct(fdt) == 0) ++ return -FDT_ERR_BADSTATE; ++ } else { ++ return -FDT_ERR_BADMAGIC; ++ } ++ ++ return 0; ++} ++ ++const void *fdt_offset_ptr(const void *fdt, int offset, int len) ++{ ++ const void *p; ++ ++ if (fdt_version(fdt) >= 0x11) ++ if (((offset + len) < offset) ++ || ((offset + len) > fdt_size_dt_struct(fdt))) ++ return NULL; ++ ++ p = _fdt_offset_ptr(fdt, offset); ++ ++ if (p + len < p) ++ return NULL; ++ return p; ++} ++ ++uint32_t fdt_next_tag(const void *fdt, int offset, int *nextoffset) ++{ ++ const uint32_t *tagp, *lenp; ++ uint32_t tag; ++ const char *p; ++ ++ if (offset % FDT_TAGSIZE) ++ return -1; ++ ++ tagp = fdt_offset_ptr(fdt, offset, FDT_TAGSIZE); ++ if (! tagp) ++ return FDT_END; /* premature end */ ++ tag = fdt32_to_cpu(*tagp); ++ offset += FDT_TAGSIZE; ++ ++ switch (tag) { ++ case FDT_BEGIN_NODE: ++ /* skip name */ ++ do { ++ p = fdt_offset_ptr(fdt, offset++, 1); ++ } while (p && (*p != '\0')); ++ if (! p) ++ return FDT_END; ++ break; ++ case FDT_PROP: ++ lenp = fdt_offset_ptr(fdt, offset, sizeof(*lenp)); ++ if (! lenp) ++ return FDT_END; ++ /* skip name offset, length and value */ ++ offset += 2*FDT_TAGSIZE + fdt32_to_cpu(*lenp); ++ break; ++ } ++ ++ if (nextoffset) ++ *nextoffset = ALIGN(offset, FDT_TAGSIZE); ++ ++ return tag; ++} ++ ++const char *_fdt_find_string(const char *strtab, int tabsize, const char *s) ++{ ++ int len = strlen(s) + 1; ++ const char *last = strtab + tabsize - len; ++ const char *p; ++ ++ for (p = strtab; p <= last; p++) ++ if (memeq(p, s, len)) ++ return p; ++ return NULL; ++} ++ ++int fdt_move(const void *fdt, void *buf, int bufsize) ++{ ++ int err = fdt_check_header(fdt); ++ ++ if (err) ++ return err; ++ ++ if (fdt_totalsize(fdt) > bufsize) ++ return -FDT_ERR_NOSPACE; ++ ++ memmove(buf, fdt, fdt_totalsize(fdt)); ++ return 0; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/libfdt/fdt.h powerpc.git/arch/powerpc/boot/libfdt/fdt.h +--- linux-2.6.24/arch/powerpc/boot/libfdt/fdt.h 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/libfdt/fdt.h 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,60 @@ ++#ifndef _FDT_H ++#define _FDT_H ++ ++#ifndef __ASSEMBLY__ ++ ++struct fdt_header { ++ uint32_t magic; /* magic word FDT_MAGIC */ ++ uint32_t totalsize; /* total size of DT block */ ++ uint32_t off_dt_struct; /* offset to structure */ ++ uint32_t off_dt_strings; /* offset to strings */ ++ uint32_t off_mem_rsvmap; /* offset to memory reserve map */ ++ uint32_t version; /* format version */ ++ uint32_t last_comp_version; /* last compatible version */ ++ ++ /* version 2 fields below */ ++ uint32_t boot_cpuid_phys; /* Which physical CPU id we're ++ booting on */ ++ /* version 3 fields below */ ++ uint32_t size_dt_strings; /* size of the strings block */ ++ ++ /* version 17 fields below */ ++ uint32_t size_dt_struct; /* size of the structure block */ ++}; ++ ++struct fdt_reserve_entry { ++ uint64_t address; ++ uint64_t size; ++}; ++ ++struct fdt_node_header { ++ uint32_t tag; ++ char name[0]; ++}; ++ ++struct fdt_property { ++ uint32_t tag; ++ uint32_t len; ++ uint32_t nameoff; ++ char data[0]; ++}; ++ ++#endif /* !__ASSEMBLY */ ++ ++#define FDT_MAGIC 0xd00dfeed /* 4: version, 4: total size */ ++#define FDT_TAGSIZE sizeof(uint32_t) ++ ++#define FDT_BEGIN_NODE 0x1 /* Start node: full name */ ++#define FDT_END_NODE 0x2 /* End node */ ++#define FDT_PROP 0x3 /* Property: name off, ++ size, content */ ++#define FDT_NOP 0x4 /* nop */ ++#define FDT_END 0x9 ++ ++#define FDT_V1_SIZE (7*sizeof(uint32_t)) ++#define FDT_V2_SIZE (FDT_V1_SIZE + sizeof(uint32_t)) ++#define FDT_V3_SIZE (FDT_V2_SIZE + sizeof(uint32_t)) ++#define FDT_V16_SIZE FDT_V3_SIZE ++#define FDT_V17_SIZE (FDT_V16_SIZE + sizeof(uint32_t)) ++ ++#endif /* _FDT_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/libfdt/fdt_ro.c powerpc.git/arch/powerpc/boot/libfdt/fdt_ro.c +--- linux-2.6.24/arch/powerpc/boot/libfdt/fdt_ro.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/libfdt/fdt_ro.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,583 @@ ++/* ++ * libfdt - Flat Device Tree manipulation ++ * Copyright (C) 2006 David Gibson, IBM Corporation. ++ * ++ * libfdt is dual licensed: you can use it either under the terms of ++ * the GPL, or the BSD license, at your option. ++ * ++ * a) This library is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This library is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public ++ * License along with this library; if not, write to the Free ++ * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, ++ * MA 02110-1301 USA ++ * ++ * Alternatively, ++ * ++ * b) Redistribution and use in source and binary forms, with or ++ * without modification, are permitted provided that the following ++ * conditions are met: ++ * ++ * 1. Redistributions of source code must retain the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer. ++ * 2. Redistributions in binary form must reproduce the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer in the documentation and/or other materials ++ * provided with the distribution. ++ * ++ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND ++ * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, ++ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF ++ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE ++ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR ++ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, ++ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT ++ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; ++ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ++ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN ++ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR ++ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, ++ * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ++ */ ++#include "libfdt_env.h" ++ ++#include <fdt.h> ++#include <libfdt.h> ++ ++#include "libfdt_internal.h" ++ ++#define CHECK_HEADER(fdt) \ ++ { \ ++ int err; \ ++ if ((err = fdt_check_header(fdt)) != 0) \ ++ return err; \ ++ } ++ ++static int nodename_eq(const void *fdt, int offset, ++ const char *s, int len) ++{ ++ const char *p = fdt_offset_ptr(fdt, offset, len+1); ++ ++ if (! p) ++ /* short match */ ++ return 0; ++ ++ if (memcmp(p, s, len) != 0) ++ return 0; ++ ++ if (p[len] == '\0') ++ return 1; ++ else if (!memchr(s, '@', len) && (p[len] == '@')) ++ return 1; ++ else ++ return 0; ++} ++ ++const char *fdt_string(const void *fdt, int stroffset) ++{ ++ return (char *)fdt + fdt_off_dt_strings(fdt) + stroffset; ++} ++ ++int fdt_get_mem_rsv(const void *fdt, int n, uint64_t *address, uint64_t *size) ++{ ++ CHECK_HEADER(fdt); ++ *address = fdt64_to_cpu(_fdt_mem_rsv(fdt, n)->address); ++ *size = fdt64_to_cpu(_fdt_mem_rsv(fdt, n)->size); ++ return 0; ++} ++ ++int fdt_num_mem_rsv(const void *fdt) ++{ ++ int i = 0; ++ ++ while (fdt64_to_cpu(_fdt_mem_rsv(fdt, i)->size) != 0) ++ i++; ++ return i; ++} ++ ++int fdt_subnode_offset_namelen(const void *fdt, int parentoffset, ++ const char *name, int namelen) ++{ ++ int level = 0; ++ uint32_t tag; ++ int offset, nextoffset; ++ ++ CHECK_HEADER(fdt); ++ ++ tag = fdt_next_tag(fdt, parentoffset, &nextoffset); ++ if (tag != FDT_BEGIN_NODE) ++ return -FDT_ERR_BADOFFSET; ++ ++ do { ++ offset = nextoffset; ++ tag = fdt_next_tag(fdt, offset, &nextoffset); ++ ++ switch (tag) { ++ case FDT_END: ++ return -FDT_ERR_TRUNCATED; ++ ++ case FDT_BEGIN_NODE: ++ level++; ++ if (level != 1) ++ continue; ++ if (nodename_eq(fdt, offset+FDT_TAGSIZE, name, namelen)) ++ /* Found it! */ ++ return offset; ++ break; ++ ++ case FDT_END_NODE: ++ level--; ++ break; ++ ++ case FDT_PROP: ++ case FDT_NOP: ++ break; ++ ++ default: ++ return -FDT_ERR_BADSTRUCTURE; ++ } ++ } while (level >= 0); ++ ++ return -FDT_ERR_NOTFOUND; ++} ++ ++int fdt_subnode_offset(const void *fdt, int parentoffset, ++ const char *name) ++{ ++ return fdt_subnode_offset_namelen(fdt, parentoffset, name, strlen(name)); ++} ++ ++int fdt_path_offset(const void *fdt, const char *path) ++{ ++ const char *end = path + strlen(path); ++ const char *p = path; ++ int offset = 0; ++ ++ CHECK_HEADER(fdt); ++ ++ if (*path != '/') ++ return -FDT_ERR_BADPATH; ++ ++ while (*p) { ++ const char *q; ++ ++ while (*p == '/') ++ p++; ++ if (! *p) ++ return offset; ++ q = strchr(p, '/'); ++ if (! q) ++ q = end; ++ ++ offset = fdt_subnode_offset_namelen(fdt, offset, p, q-p); ++ if (offset < 0) ++ return offset; ++ ++ p = q; ++ } ++ ++ return offset; ++} ++ ++const char *fdt_get_name(const void *fdt, int nodeoffset, int *len) ++{ ++ const struct fdt_node_header *nh; ++ int err; ++ ++ if ((err = fdt_check_header(fdt)) != 0) ++ goto fail; ++ ++ err = -FDT_ERR_BADOFFSET; ++ nh = fdt_offset_ptr(fdt, nodeoffset, sizeof(*nh)); ++ if (!nh || (fdt32_to_cpu(nh->tag) != FDT_BEGIN_NODE)) ++ goto fail; ++ ++ if (len) ++ *len = strlen(nh->name); ++ ++ return nh->name; ++ ++ fail: ++ if (len) ++ *len = err; ++ return NULL; ++} ++ ++const struct fdt_property *fdt_get_property(const void *fdt, ++ int nodeoffset, ++ const char *name, int *lenp) ++{ ++ uint32_t tag; ++ const struct fdt_property *prop; ++ int namestroff; ++ int offset, nextoffset; ++ int err; ++ ++ if ((err = fdt_check_header(fdt)) != 0) ++ goto fail; ++ ++ err = -FDT_ERR_BADOFFSET; ++ if (nodeoffset % FDT_TAGSIZE) ++ goto fail; ++ ++ tag = fdt_next_tag(fdt, nodeoffset, &nextoffset); ++ if (tag != FDT_BEGIN_NODE) ++ goto fail; ++ ++ do { ++ offset = nextoffset; ++ ++ tag = fdt_next_tag(fdt, offset, &nextoffset); ++ switch (tag) { ++ case FDT_END: ++ err = -FDT_ERR_TRUNCATED; ++ goto fail; ++ ++ case FDT_BEGIN_NODE: ++ case FDT_END_NODE: ++ case FDT_NOP: ++ break; ++ ++ case FDT_PROP: ++ err = -FDT_ERR_BADSTRUCTURE; ++ prop = fdt_offset_ptr(fdt, offset, sizeof(*prop)); ++ if (! prop) ++ goto fail; ++ namestroff = fdt32_to_cpu(prop->nameoff); ++ if (streq(fdt_string(fdt, namestroff), name)) { ++ /* Found it! */ ++ int len = fdt32_to_cpu(prop->len); ++ prop = fdt_offset_ptr(fdt, offset, ++ sizeof(*prop)+len); ++ if (! prop) ++ goto fail; ++ ++ if (lenp) ++ *lenp = len; ++ ++ return prop; ++ } ++ break; ++ ++ default: ++ err = -FDT_ERR_BADSTRUCTURE; ++ goto fail; ++ } ++ } while ((tag != FDT_BEGIN_NODE) && (tag != FDT_END_NODE)); ++ ++ err = -FDT_ERR_NOTFOUND; ++ fail: ++ if (lenp) ++ *lenp = err; ++ return NULL; ++} ++ ++const void *fdt_getprop(const void *fdt, int nodeoffset, ++ const char *name, int *lenp) ++{ ++ const struct fdt_property *prop; ++ ++ prop = fdt_get_property(fdt, nodeoffset, name, lenp); ++ if (! prop) ++ return NULL; ++ ++ return prop->data; ++} ++ ++uint32_t fdt_get_phandle(const void *fdt, int nodeoffset) ++{ ++ const uint32_t *php; ++ int len; ++ ++ php = fdt_getprop(fdt, nodeoffset, "linux,phandle", &len); ++ if (!php || (len != sizeof(*php))) ++ return 0; ++ ++ return fdt32_to_cpu(*php); ++} ++ ++int fdt_get_path(const void *fdt, int nodeoffset, char *buf, int buflen) ++{ ++ uint32_t tag; ++ int p = 0, overflow = 0; ++ int offset, nextoffset, namelen; ++ const char *name; ++ ++ CHECK_HEADER(fdt); ++ ++ tag = fdt_next_tag(fdt, 0, &nextoffset); ++ if (tag != FDT_BEGIN_NODE) ++ return -FDT_ERR_BADSTRUCTURE; ++ ++ if (buflen < 2) ++ return -FDT_ERR_NOSPACE; ++ buf[0] = '/'; ++ p = 1; ++ ++ while (nextoffset <= nodeoffset) { ++ offset = nextoffset; ++ tag = fdt_next_tag(fdt, offset, &nextoffset); ++ switch (tag) { ++ case FDT_END: ++ return -FDT_ERR_BADOFFSET; ++ ++ case FDT_BEGIN_NODE: ++ name = fdt_get_name(fdt, offset, &namelen); ++ if (!name) ++ return namelen; ++ if (overflow || ((p + namelen + 1) > buflen)) { ++ overflow++; ++ break; ++ } ++ memcpy(buf + p, name, namelen); ++ p += namelen; ++ buf[p++] = '/'; ++ break; ++ ++ case FDT_END_NODE: ++ if (overflow) { ++ overflow--; ++ break; ++ } ++ do { ++ p--; ++ } while (buf[p-1] != '/'); ++ break; ++ ++ case FDT_PROP: ++ case FDT_NOP: ++ break; ++ ++ default: ++ return -FDT_ERR_BADSTRUCTURE; ++ } ++ } ++ ++ if (overflow) ++ return -FDT_ERR_NOSPACE; ++ ++ if (p > 1) /* special case so that root path is "/", not "" */ ++ p--; ++ buf[p] = '\0'; ++ return p; ++} ++ ++int fdt_supernode_atdepth_offset(const void *fdt, int nodeoffset, ++ int supernodedepth, int *nodedepth) ++{ ++ int level = -1; ++ uint32_t tag; ++ int offset, nextoffset = 0; ++ int supernodeoffset = -FDT_ERR_INTERNAL; ++ ++ CHECK_HEADER(fdt); ++ ++ if (supernodedepth < 0) ++ return -FDT_ERR_NOTFOUND; ++ ++ do { ++ offset = nextoffset; ++ tag = fdt_next_tag(fdt, offset, &nextoffset); ++ switch (tag) { ++ case FDT_END: ++ return -FDT_ERR_BADOFFSET; ++ ++ case FDT_BEGIN_NODE: ++ level++; ++ if (level == supernodedepth) ++ supernodeoffset = offset; ++ break; ++ ++ case FDT_END_NODE: ++ level--; ++ break; ++ ++ case FDT_PROP: ++ case FDT_NOP: ++ break; ++ ++ default: ++ return -FDT_ERR_BADSTRUCTURE; ++ } ++ } while (offset < nodeoffset); ++ ++ if (nodedepth) ++ *nodedepth = level; ++ ++ if (supernodedepth > level) ++ return -FDT_ERR_NOTFOUND; ++ return supernodeoffset; ++} ++ ++int fdt_node_depth(const void *fdt, int nodeoffset) ++{ ++ int nodedepth; ++ int err; ++ ++ err = fdt_supernode_atdepth_offset(fdt, nodeoffset, 0, &nodedepth); ++ if (err) ++ return (err < 0) ? err : -FDT_ERR_INTERNAL; ++ return nodedepth; ++} ++ ++int fdt_parent_offset(const void *fdt, int nodeoffset) ++{ ++ int nodedepth = fdt_node_depth(fdt, nodeoffset); ++ ++ if (nodedepth < 0) ++ return nodedepth; ++ return fdt_supernode_atdepth_offset(fdt, nodeoffset, ++ nodedepth - 1, NULL); ++} ++ ++int fdt_node_offset_by_prop_value(const void *fdt, int startoffset, ++ const char *propname, ++ const void *propval, int proplen) ++{ ++ uint32_t tag; ++ int offset, nextoffset; ++ const void *val; ++ int len; ++ ++ CHECK_HEADER(fdt); ++ ++ if (startoffset >= 0) { ++ tag = fdt_next_tag(fdt, startoffset, &nextoffset); ++ if (tag != FDT_BEGIN_NODE) ++ return -FDT_ERR_BADOFFSET; ++ } else { ++ nextoffset = 0; ++ } ++ ++ /* FIXME: The algorithm here is pretty horrible: we scan each ++ * property of a node in fdt_getprop(), then if that didn't ++ * find what we want, we scan over them again making our way ++ * to the next node. Still it's the easiest to implement ++ * approach; performance can come later. */ ++ do { ++ offset = nextoffset; ++ tag = fdt_next_tag(fdt, offset, &nextoffset); ++ ++ switch (tag) { ++ case FDT_BEGIN_NODE: ++ val = fdt_getprop(fdt, offset, propname, &len); ++ if (val ++ && (len == proplen) ++ && (memcmp(val, propval, len) == 0)) ++ return offset; ++ break; ++ ++ case FDT_PROP: ++ case FDT_END: ++ case FDT_END_NODE: ++ case FDT_NOP: ++ break; ++ ++ default: ++ return -FDT_ERR_BADSTRUCTURE; ++ } ++ } while (tag != FDT_END); ++ ++ return -FDT_ERR_NOTFOUND; ++} ++ ++int fdt_node_offset_by_phandle(const void *fdt, uint32_t phandle) ++{ ++ if ((phandle == 0) || (phandle == -1)) ++ return -FDT_ERR_BADPHANDLE; ++ phandle = cpu_to_fdt32(phandle); ++ return fdt_node_offset_by_prop_value(fdt, -1, "linux,phandle", ++ &phandle, sizeof(phandle)); ++} ++ ++int _stringlist_contains(const void *strlist, int listlen, const char *str) ++{ ++ int len = strlen(str); ++ const void *p; ++ ++ while (listlen >= len) { ++ if (memcmp(str, strlist, len+1) == 0) ++ return 1; ++ p = memchr(strlist, '\0', listlen); ++ if (!p) ++ return 0; /* malformed strlist.. */ ++ listlen -= (p-strlist) + 1; ++ strlist = p + 1; ++ } ++ return 0; ++} ++ ++int fdt_node_check_compatible(const void *fdt, int nodeoffset, ++ const char *compatible) ++{ ++ const void *prop; ++ int len; ++ ++ prop = fdt_getprop(fdt, nodeoffset, "compatible", &len); ++ if (!prop) ++ return len; ++ if (_stringlist_contains(prop, len, compatible)) ++ return 0; ++ else ++ return 1; ++} ++ ++int fdt_node_offset_by_compatible(const void *fdt, int startoffset, ++ const char *compatible) ++{ ++ uint32_t tag; ++ int offset, nextoffset; ++ int err; ++ ++ CHECK_HEADER(fdt); ++ ++ if (startoffset >= 0) { ++ tag = fdt_next_tag(fdt, startoffset, &nextoffset); ++ if (tag != FDT_BEGIN_NODE) ++ return -FDT_ERR_BADOFFSET; ++ } else { ++ nextoffset = 0; ++ } ++ ++ /* FIXME: The algorithm here is pretty horrible: we scan each ++ * property of a node in fdt_node_check_compatible(), then if ++ * that didn't find what we want, we scan over them again ++ * making our way to the next node. Still it's the easiest to ++ * implement approach; performance can come later. */ ++ do { ++ offset = nextoffset; ++ tag = fdt_next_tag(fdt, offset, &nextoffset); ++ ++ switch (tag) { ++ case FDT_BEGIN_NODE: ++ err = fdt_node_check_compatible(fdt, offset, ++ compatible); ++ if ((err < 0) ++ && (err != -FDT_ERR_NOTFOUND)) ++ return err; ++ else if (err == 0) ++ return offset; ++ break; ++ ++ case FDT_PROP: ++ case FDT_END: ++ case FDT_END_NODE: ++ case FDT_NOP: ++ break; ++ ++ default: ++ return -FDT_ERR_BADSTRUCTURE; ++ } ++ } while (tag != FDT_END); ++ ++ return -FDT_ERR_NOTFOUND; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/libfdt/fdt_rw.c powerpc.git/arch/powerpc/boot/libfdt/fdt_rw.c +--- linux-2.6.24/arch/powerpc/boot/libfdt/fdt_rw.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/libfdt/fdt_rw.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,447 @@ ++/* ++ * libfdt - Flat Device Tree manipulation ++ * Copyright (C) 2006 David Gibson, IBM Corporation. ++ * ++ * libfdt is dual licensed: you can use it either under the terms of ++ * the GPL, or the BSD license, at your option. ++ * ++ * a) This library is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This library is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public ++ * License along with this library; if not, write to the Free ++ * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, ++ * MA 02110-1301 USA ++ * ++ * Alternatively, ++ * ++ * b) Redistribution and use in source and binary forms, with or ++ * without modification, are permitted provided that the following ++ * conditions are met: ++ * ++ * 1. Redistributions of source code must retain the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer. ++ * 2. Redistributions in binary form must reproduce the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer in the documentation and/or other materials ++ * provided with the distribution. ++ * ++ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND ++ * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, ++ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF ++ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE ++ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR ++ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, ++ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT ++ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; ++ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ++ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN ++ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR ++ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, ++ * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ++ */ ++#include "libfdt_env.h" ++ ++#include <fdt.h> ++#include <libfdt.h> ++ ++#include "libfdt_internal.h" ++ ++static int _blocks_misordered(const void *fdt, ++ int mem_rsv_size, int struct_size) ++{ ++ return (fdt_off_mem_rsvmap(fdt) < ALIGN(sizeof(struct fdt_header), 8)) ++ || (fdt_off_dt_struct(fdt) < ++ (fdt_off_mem_rsvmap(fdt) + mem_rsv_size)) ++ || (fdt_off_dt_strings(fdt) < ++ (fdt_off_dt_struct(fdt) + struct_size)) ++ || (fdt_totalsize(fdt) < ++ (fdt_off_dt_strings(fdt) + fdt_size_dt_strings(fdt))); ++} ++ ++static int rw_check_header(void *fdt) ++{ ++ int err; ++ ++ if ((err = fdt_check_header(fdt))) ++ return err; ++ if (fdt_version(fdt) < 17) ++ return -FDT_ERR_BADVERSION; ++ if (_blocks_misordered(fdt, sizeof(struct fdt_reserve_entry), ++ fdt_size_dt_struct(fdt))) ++ return -FDT_ERR_BADLAYOUT; ++ if (fdt_version(fdt) > 17) ++ fdt_set_version(fdt, 17); ++ ++ return 0; ++} ++ ++#define RW_CHECK_HEADER(fdt) \ ++ { \ ++ int err; \ ++ if ((err = rw_check_header(fdt)) != 0) \ ++ return err; \ ++ } ++ ++static inline int _blob_data_size(void *fdt) ++{ ++ return fdt_off_dt_strings(fdt) + fdt_size_dt_strings(fdt); ++} ++ ++static int _blob_splice(void *fdt, void *p, int oldlen, int newlen) ++{ ++ void *end = fdt + _blob_data_size(fdt); ++ ++ if (((p + oldlen) < p) || ((p + oldlen) > end)) ++ return -FDT_ERR_BADOFFSET; ++ if ((end - oldlen + newlen) > (fdt + fdt_totalsize(fdt))) ++ return -FDT_ERR_NOSPACE; ++ memmove(p + newlen, p + oldlen, end - p - oldlen); ++ return 0; ++} ++ ++static int _blob_splice_mem_rsv(void *fdt, struct fdt_reserve_entry *p, ++ int oldn, int newn) ++{ ++ int delta = (newn - oldn) * sizeof(*p); ++ int err; ++ err = _blob_splice(fdt, p, oldn * sizeof(*p), newn * sizeof(*p)); ++ if (err) ++ return err; ++ fdt_set_off_dt_struct(fdt, fdt_off_dt_struct(fdt) + delta); ++ fdt_set_off_dt_strings(fdt, fdt_off_dt_strings(fdt) + delta); ++ return 0; ++} ++ ++static int _blob_splice_struct(void *fdt, void *p, ++ int oldlen, int newlen) ++{ ++ int delta = newlen - oldlen; ++ int err; ++ ++ if ((err = _blob_splice(fdt, p, oldlen, newlen))) ++ return err; ++ ++ fdt_set_size_dt_struct(fdt, fdt_size_dt_struct(fdt) + delta); ++ fdt_set_off_dt_strings(fdt, fdt_off_dt_strings(fdt) + delta); ++ return 0; ++} ++ ++static int _blob_splice_string(void *fdt, int newlen) ++{ ++ void *p = fdt + fdt_off_dt_strings(fdt) + fdt_size_dt_strings(fdt); ++ int err; ++ ++ if ((err = _blob_splice(fdt, p, 0, newlen))) ++ return err; ++ ++ fdt_set_size_dt_strings(fdt, fdt_size_dt_strings(fdt) + newlen); ++ return 0; ++} ++ ++static int _find_add_string(void *fdt, const char *s) ++{ ++ char *strtab = (char *)fdt + fdt_off_dt_strings(fdt); ++ const char *p; ++ char *new; ++ int len = strlen(s) + 1; ++ int err; ++ ++ p = _fdt_find_string(strtab, fdt_size_dt_strings(fdt), s); ++ if (p) ++ /* found it */ ++ return (p - strtab); ++ ++ new = strtab + fdt_size_dt_strings(fdt); ++ err = _blob_splice_string(fdt, len); ++ if (err) ++ return err; ++ ++ memcpy(new, s, len); ++ return (new - strtab); ++} ++ ++int fdt_add_mem_rsv(void *fdt, uint64_t address, uint64_t size) ++{ ++ struct fdt_reserve_entry *re; ++ int err; ++ ++ if ((err = rw_check_header(fdt))) ++ return err; ++ ++ re = _fdt_mem_rsv_w(fdt, fdt_num_mem_rsv(fdt)); ++ err = _blob_splice_mem_rsv(fdt, re, 0, 1); ++ if (err) ++ return err; ++ ++ re->address = cpu_to_fdt64(address); ++ re->size = cpu_to_fdt64(size); ++ return 0; ++} ++ ++int fdt_del_mem_rsv(void *fdt, int n) ++{ ++ struct fdt_reserve_entry *re = _fdt_mem_rsv_w(fdt, n); ++ int err; ++ ++ if ((err = rw_check_header(fdt))) ++ return err; ++ if (n >= fdt_num_mem_rsv(fdt)) ++ return -FDT_ERR_NOTFOUND; ++ ++ err = _blob_splice_mem_rsv(fdt, re, 1, 0); ++ if (err) ++ return err; ++ return 0; ++} ++ ++static int _resize_property(void *fdt, int nodeoffset, const char *name, int len, ++ struct fdt_property **prop) ++{ ++ int oldlen; ++ int err; ++ ++ *prop = fdt_get_property_w(fdt, nodeoffset, name, &oldlen); ++ if (! (*prop)) ++ return oldlen; ++ ++ if ((err = _blob_splice_struct(fdt, (*prop)->data, ++ ALIGN(oldlen, FDT_TAGSIZE), ++ ALIGN(len, FDT_TAGSIZE)))) ++ return err; ++ ++ (*prop)->len = cpu_to_fdt32(len); ++ return 0; ++} ++ ++static int _add_property(void *fdt, int nodeoffset, const char *name, int len, ++ struct fdt_property **prop) ++{ ++ uint32_t tag; ++ int proplen; ++ int nextoffset; ++ int namestroff; ++ int err; ++ ++ tag = fdt_next_tag(fdt, nodeoffset, &nextoffset); ++ if (tag != FDT_BEGIN_NODE) ++ return -FDT_ERR_BADOFFSET; ++ ++ namestroff = _find_add_string(fdt, name); ++ if (namestroff < 0) ++ return namestroff; ++ ++ *prop = _fdt_offset_ptr_w(fdt, nextoffset); ++ proplen = sizeof(**prop) + ALIGN(len, FDT_TAGSIZE); ++ ++ err = _blob_splice_struct(fdt, *prop, 0, proplen); ++ if (err) ++ return err; ++ ++ (*prop)->tag = cpu_to_fdt32(FDT_PROP); ++ (*prop)->nameoff = cpu_to_fdt32(namestroff); ++ (*prop)->len = cpu_to_fdt32(len); ++ return 0; ++} ++ ++int fdt_setprop(void *fdt, int nodeoffset, const char *name, ++ const void *val, int len) ++{ ++ struct fdt_property *prop; ++ int err; ++ ++ if ((err = rw_check_header(fdt))) ++ return err; ++ ++ err = _resize_property(fdt, nodeoffset, name, len, &prop); ++ if (err == -FDT_ERR_NOTFOUND) ++ err = _add_property(fdt, nodeoffset, name, len, &prop); ++ if (err) ++ return err; ++ ++ memcpy(prop->data, val, len); ++ return 0; ++} ++ ++int fdt_delprop(void *fdt, int nodeoffset, const char *name) ++{ ++ struct fdt_property *prop; ++ int len, proplen; ++ ++ RW_CHECK_HEADER(fdt); ++ ++ prop = fdt_get_property_w(fdt, nodeoffset, name, &len); ++ if (! prop) ++ return len; ++ ++ proplen = sizeof(*prop) + ALIGN(len, FDT_TAGSIZE); ++ return _blob_splice_struct(fdt, prop, proplen, 0); ++} ++ ++int fdt_add_subnode_namelen(void *fdt, int parentoffset, ++ const char *name, int namelen) ++{ ++ struct fdt_node_header *nh; ++ int offset, nextoffset; ++ int nodelen; ++ int err; ++ uint32_t tag; ++ uint32_t *endtag; ++ ++ RW_CHECK_HEADER(fdt); ++ ++ offset = fdt_subnode_offset_namelen(fdt, parentoffset, name, namelen); ++ if (offset >= 0) ++ return -FDT_ERR_EXISTS; ++ else if (offset != -FDT_ERR_NOTFOUND) ++ return offset; ++ ++ /* Try to place the new node after the parent's properties */ ++ fdt_next_tag(fdt, parentoffset, &nextoffset); /* skip the BEGIN_NODE */ ++ do { ++ offset = nextoffset; ++ tag = fdt_next_tag(fdt, offset, &nextoffset); ++ } while (tag == FDT_PROP); ++ ++ nh = _fdt_offset_ptr_w(fdt, offset); ++ nodelen = sizeof(*nh) + ALIGN(namelen+1, FDT_TAGSIZE) + FDT_TAGSIZE; ++ ++ err = _blob_splice_struct(fdt, nh, 0, nodelen); ++ if (err) ++ return err; ++ ++ nh->tag = cpu_to_fdt32(FDT_BEGIN_NODE); ++ memset(nh->name, 0, ALIGN(namelen+1, FDT_TAGSIZE)); ++ memcpy(nh->name, name, namelen); ++ endtag = (uint32_t *)((void *)nh + nodelen - FDT_TAGSIZE); ++ *endtag = cpu_to_fdt32(FDT_END_NODE); ++ ++ return offset; ++} ++ ++int fdt_add_subnode(void *fdt, int parentoffset, const char *name) ++{ ++ return fdt_add_subnode_namelen(fdt, parentoffset, name, strlen(name)); ++} ++ ++int fdt_del_node(void *fdt, int nodeoffset) ++{ ++ int endoffset; ++ ++ RW_CHECK_HEADER(fdt); ++ ++ endoffset = _fdt_node_end_offset(fdt, nodeoffset); ++ if (endoffset < 0) ++ return endoffset; ++ ++ return _blob_splice_struct(fdt, _fdt_offset_ptr_w(fdt, nodeoffset), ++ endoffset - nodeoffset, 0); ++} ++ ++static void _packblocks(const void *fdt, void *buf, ++ int mem_rsv_size, int struct_size) ++{ ++ int mem_rsv_off, struct_off, strings_off; ++ ++ mem_rsv_off = ALIGN(sizeof(struct fdt_header), 8); ++ struct_off = mem_rsv_off + mem_rsv_size; ++ strings_off = struct_off + struct_size; ++ ++ memmove(buf + mem_rsv_off, fdt + fdt_off_mem_rsvmap(fdt), mem_rsv_size); ++ fdt_set_off_mem_rsvmap(buf, mem_rsv_off); ++ ++ memmove(buf + struct_off, fdt + fdt_off_dt_struct(fdt), struct_size); ++ fdt_set_off_dt_struct(buf, struct_off); ++ fdt_set_size_dt_struct(buf, struct_size); ++ ++ memmove(buf + strings_off, fdt + fdt_off_dt_strings(fdt), ++ fdt_size_dt_strings(fdt)); ++ fdt_set_off_dt_strings(buf, strings_off); ++ fdt_set_size_dt_strings(buf, fdt_size_dt_strings(fdt)); ++} ++ ++int fdt_open_into(const void *fdt, void *buf, int bufsize) ++{ ++ int err; ++ int mem_rsv_size, struct_size; ++ int newsize; ++ void *tmp; ++ ++ err = fdt_check_header(fdt); ++ if (err) ++ return err; ++ ++ mem_rsv_size = (fdt_num_mem_rsv(fdt)+1) ++ * sizeof(struct fdt_reserve_entry); ++ ++ if (fdt_version(fdt) >= 17) { ++ struct_size = fdt_size_dt_struct(fdt); ++ } else { ++ struct_size = 0; ++ while (fdt_next_tag(fdt, struct_size, &struct_size) != FDT_END) ++ ; ++ } ++ ++ if (!_blocks_misordered(fdt, mem_rsv_size, struct_size)) { ++ /* no further work necessary */ ++ err = fdt_move(fdt, buf, bufsize); ++ if (err) ++ return err; ++ fdt_set_version(buf, 17); ++ fdt_set_size_dt_struct(buf, struct_size); ++ fdt_set_totalsize(buf, bufsize); ++ return 0; ++ } ++ ++ /* Need to reorder */ ++ newsize = ALIGN(sizeof(struct fdt_header), 8) + mem_rsv_size ++ + struct_size + fdt_size_dt_strings(fdt); ++ ++ if (bufsize < newsize) ++ return -FDT_ERR_NOSPACE; ++ ++ if (((buf + newsize) <= fdt) ++ || (buf >= (fdt + fdt_totalsize(fdt)))) { ++ tmp = buf; ++ } else { ++ tmp = (void *)fdt + fdt_totalsize(fdt); ++ if ((tmp + newsize) > (buf + bufsize)) ++ return -FDT_ERR_NOSPACE; ++ } ++ ++ _packblocks(fdt, tmp, mem_rsv_size, struct_size); ++ memmove(buf, tmp, newsize); ++ ++ fdt_set_magic(buf, FDT_MAGIC); ++ fdt_set_totalsize(buf, bufsize); ++ fdt_set_version(buf, 17); ++ fdt_set_last_comp_version(buf, 16); ++ fdt_set_boot_cpuid_phys(buf, fdt_boot_cpuid_phys(fdt)); ++ ++ return 0; ++} ++ ++int fdt_pack(void *fdt) ++{ ++ int mem_rsv_size; ++ int err; ++ ++ err = rw_check_header(fdt); ++ if (err) ++ return err; ++ ++ mem_rsv_size = (fdt_num_mem_rsv(fdt)+1) ++ * sizeof(struct fdt_reserve_entry); ++ _packblocks(fdt, fdt, mem_rsv_size, fdt_size_dt_struct(fdt)); ++ fdt_set_totalsize(fdt, _blob_data_size(fdt)); ++ ++ return 0; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/libfdt/fdt_strerror.c powerpc.git/arch/powerpc/boot/libfdt/fdt_strerror.c +--- linux-2.6.24/arch/powerpc/boot/libfdt/fdt_strerror.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/libfdt/fdt_strerror.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,96 @@ ++/* ++ * libfdt - Flat Device Tree manipulation ++ * Copyright (C) 2006 David Gibson, IBM Corporation. ++ * ++ * libfdt is dual licensed: you can use it either under the terms of ++ * the GPL, or the BSD license, at your option. ++ * ++ * a) This library is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This library is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public ++ * License along with this library; if not, write to the Free ++ * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, ++ * MA 02110-1301 USA ++ * ++ * Alternatively, ++ * ++ * b) Redistribution and use in source and binary forms, with or ++ * without modification, are permitted provided that the following ++ * conditions are met: ++ * ++ * 1. Redistributions of source code must retain the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer. ++ * 2. Redistributions in binary form must reproduce the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer in the documentation and/or other materials ++ * provided with the distribution. ++ * ++ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND ++ * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, ++ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF ++ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE ++ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR ++ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, ++ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT ++ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; ++ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ++ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN ++ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR ++ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, ++ * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ++ */ ++#include "libfdt_env.h" ++ ++#include <fdt.h> ++#include <libfdt.h> ++ ++#include "libfdt_internal.h" ++ ++struct errtabent { ++ const char *str; ++}; ++ ++#define ERRTABENT(val) \ ++ [(val)] = { .str = #val, } ++ ++static struct errtabent errtable[] = { ++ ERRTABENT(FDT_ERR_NOTFOUND), ++ ERRTABENT(FDT_ERR_EXISTS), ++ ERRTABENT(FDT_ERR_NOSPACE), ++ ++ ERRTABENT(FDT_ERR_BADOFFSET), ++ ERRTABENT(FDT_ERR_BADPATH), ++ ERRTABENT(FDT_ERR_BADSTATE), ++ ++ ERRTABENT(FDT_ERR_TRUNCATED), ++ ERRTABENT(FDT_ERR_BADMAGIC), ++ ERRTABENT(FDT_ERR_BADVERSION), ++ ERRTABENT(FDT_ERR_BADSTRUCTURE), ++ ERRTABENT(FDT_ERR_BADLAYOUT), ++}; ++#define ERRTABSIZE (sizeof(errtable) / sizeof(errtable[0])) ++ ++const char *fdt_strerror(int errval) ++{ ++ if (errval > 0) ++ return "<valid offset/length>"; ++ else if (errval == 0) ++ return "<no error>"; ++ else if (errval > -ERRTABSIZE) { ++ const char *s = errtable[-errval].str; ++ ++ if (s) ++ return s; ++ } ++ ++ return "<unknown error>"; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/libfdt/fdt_sw.c powerpc.git/arch/powerpc/boot/libfdt/fdt_sw.c +--- linux-2.6.24/arch/powerpc/boot/libfdt/fdt_sw.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/libfdt/fdt_sw.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,258 @@ ++/* ++ * libfdt - Flat Device Tree manipulation ++ * Copyright (C) 2006 David Gibson, IBM Corporation. ++ * ++ * libfdt is dual licensed: you can use it either under the terms of ++ * the GPL, or the BSD license, at your option. ++ * ++ * a) This library is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This library is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public ++ * License along with this library; if not, write to the Free ++ * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, ++ * MA 02110-1301 USA ++ * ++ * Alternatively, ++ * ++ * b) Redistribution and use in source and binary forms, with or ++ * without modification, are permitted provided that the following ++ * conditions are met: ++ * ++ * 1. Redistributions of source code must retain the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer. ++ * 2. Redistributions in binary form must reproduce the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer in the documentation and/or other materials ++ * provided with the distribution. ++ * ++ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND ++ * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, ++ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF ++ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE ++ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR ++ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, ++ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT ++ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; ++ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ++ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN ++ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR ++ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, ++ * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ++ */ ++#include "libfdt_env.h" ++ ++#include <fdt.h> ++#include <libfdt.h> ++ ++#include "libfdt_internal.h" ++ ++static int check_header_sw(void *fdt) ++{ ++ if (fdt_magic(fdt) != SW_MAGIC) ++ return -FDT_ERR_BADMAGIC; ++ return 0; ++} ++ ++static void *grab_space(void *fdt, int len) ++{ ++ int offset = fdt_size_dt_struct(fdt); ++ int spaceleft; ++ ++ spaceleft = fdt_totalsize(fdt) - fdt_off_dt_struct(fdt) ++ - fdt_size_dt_strings(fdt); ++ ++ if ((offset + len < offset) || (offset + len > spaceleft)) ++ return NULL; ++ ++ fdt_set_size_dt_struct(fdt, offset + len); ++ return fdt_offset_ptr_w(fdt, offset, len); ++} ++ ++int fdt_create(void *buf, int bufsize) ++{ ++ void *fdt = buf; ++ ++ if (bufsize < sizeof(struct fdt_header)) ++ return -FDT_ERR_NOSPACE; ++ ++ memset(buf, 0, bufsize); ++ ++ fdt_set_magic(fdt, SW_MAGIC); ++ fdt_set_version(fdt, FDT_LAST_SUPPORTED_VERSION); ++ fdt_set_last_comp_version(fdt, FDT_FIRST_SUPPORTED_VERSION); ++ fdt_set_totalsize(fdt, bufsize); ++ ++ fdt_set_off_mem_rsvmap(fdt, ALIGN(sizeof(struct fdt_header), ++ sizeof(struct fdt_reserve_entry))); ++ fdt_set_off_dt_struct(fdt, fdt_off_mem_rsvmap(fdt)); ++ fdt_set_off_dt_strings(fdt, bufsize); ++ ++ return 0; ++} ++ ++int fdt_add_reservemap_entry(void *fdt, uint64_t addr, uint64_t size) ++{ ++ struct fdt_reserve_entry *re; ++ int err = check_header_sw(fdt); ++ int offset; ++ ++ if (err) ++ return err; ++ if (fdt_size_dt_struct(fdt)) ++ return -FDT_ERR_BADSTATE; ++ ++ offset = fdt_off_dt_struct(fdt); ++ if ((offset + sizeof(*re)) > fdt_totalsize(fdt)) ++ return -FDT_ERR_NOSPACE; ++ ++ re = (struct fdt_reserve_entry *)(fdt + offset); ++ re->address = cpu_to_fdt64(addr); ++ re->size = cpu_to_fdt64(size); ++ ++ fdt_set_off_dt_struct(fdt, offset + sizeof(*re)); ++ ++ return 0; ++} ++ ++int fdt_finish_reservemap(void *fdt) ++{ ++ return fdt_add_reservemap_entry(fdt, 0, 0); ++} ++ ++int fdt_begin_node(void *fdt, const char *name) ++{ ++ struct fdt_node_header *nh; ++ int err = check_header_sw(fdt); ++ int namelen = strlen(name) + 1; ++ ++ if (err) ++ return err; ++ ++ nh = grab_space(fdt, sizeof(*nh) + ALIGN(namelen, FDT_TAGSIZE)); ++ if (! nh) ++ return -FDT_ERR_NOSPACE; ++ ++ nh->tag = cpu_to_fdt32(FDT_BEGIN_NODE); ++ memcpy(nh->name, name, namelen); ++ return 0; ++} ++ ++int fdt_end_node(void *fdt) ++{ ++ uint32_t *en; ++ int err = check_header_sw(fdt); ++ ++ if (err) ++ return err; ++ ++ en = grab_space(fdt, FDT_TAGSIZE); ++ if (! en) ++ return -FDT_ERR_NOSPACE; ++ ++ *en = cpu_to_fdt32(FDT_END_NODE); ++ return 0; ++} ++ ++static int find_add_string(void *fdt, const char *s) ++{ ++ char *strtab = (char *)fdt + fdt_totalsize(fdt); ++ const char *p; ++ int strtabsize = fdt_size_dt_strings(fdt); ++ int len = strlen(s) + 1; ++ int struct_top, offset; ++ ++ p = _fdt_find_string(strtab - strtabsize, strtabsize, s); ++ if (p) ++ return p - strtab; ++ ++ /* Add it */ ++ offset = -strtabsize - len; ++ struct_top = fdt_off_dt_struct(fdt) + fdt_size_dt_struct(fdt); ++ if (fdt_totalsize(fdt) + offset < struct_top) ++ return 0; /* no more room :( */ ++ ++ memcpy(strtab + offset, s, len); ++ fdt_set_size_dt_strings(fdt, strtabsize + len); ++ return offset; ++} ++ ++int fdt_property(void *fdt, const char *name, const void *val, int len) ++{ ++ struct fdt_property *prop; ++ int err = check_header_sw(fdt); ++ int nameoff; ++ ++ if (err) ++ return err; ++ ++ nameoff = find_add_string(fdt, name); ++ if (nameoff == 0) ++ return -FDT_ERR_NOSPACE; ++ ++ prop = grab_space(fdt, sizeof(*prop) + ALIGN(len, FDT_TAGSIZE)); ++ if (! prop) ++ return -FDT_ERR_NOSPACE; ++ ++ prop->tag = cpu_to_fdt32(FDT_PROP); ++ prop->nameoff = cpu_to_fdt32(nameoff); ++ prop->len = cpu_to_fdt32(len); ++ memcpy(prop->data, val, len); ++ return 0; ++} ++ ++int fdt_finish(void *fdt) ++{ ++ int err = check_header_sw(fdt); ++ char *p = (char *)fdt; ++ uint32_t *end; ++ int oldstroffset, newstroffset; ++ uint32_t tag; ++ int offset, nextoffset; ++ ++ if (err) ++ return err; ++ ++ /* Add terminator */ ++ end = grab_space(fdt, sizeof(*end)); ++ if (! end) ++ return -FDT_ERR_NOSPACE; ++ *end = cpu_to_fdt32(FDT_END); ++ ++ /* Relocate the string table */ ++ oldstroffset = fdt_totalsize(fdt) - fdt_size_dt_strings(fdt); ++ newstroffset = fdt_off_dt_struct(fdt) + fdt_size_dt_struct(fdt); ++ memmove(p + newstroffset, p + oldstroffset, fdt_size_dt_strings(fdt)); ++ fdt_set_off_dt_strings(fdt, newstroffset); ++ ++ /* Walk the structure, correcting string offsets */ ++ offset = 0; ++ while ((tag = fdt_next_tag(fdt, offset, &nextoffset)) != FDT_END) { ++ if (tag == FDT_PROP) { ++ struct fdt_property *prop = ++ fdt_offset_ptr_w(fdt, offset, sizeof(*prop)); ++ int nameoff; ++ ++ if (! prop) ++ return -FDT_ERR_BADSTRUCTURE; ++ ++ nameoff = fdt32_to_cpu(prop->nameoff); ++ nameoff += fdt_size_dt_strings(fdt); ++ prop->nameoff = cpu_to_fdt32(nameoff); ++ } ++ offset = nextoffset; ++ } ++ ++ /* Finally, adjust the header */ ++ fdt_set_totalsize(fdt, newstroffset + fdt_size_dt_strings(fdt)); ++ fdt_set_magic(fdt, FDT_MAGIC); ++ return 0; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/libfdt/fdt_wip.c powerpc.git/arch/powerpc/boot/libfdt/fdt_wip.c +--- linux-2.6.24/arch/powerpc/boot/libfdt/fdt_wip.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/libfdt/fdt_wip.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,144 @@ ++/* ++ * libfdt - Flat Device Tree manipulation ++ * Copyright (C) 2006 David Gibson, IBM Corporation. ++ * ++ * libfdt is dual licensed: you can use it either under the terms of ++ * the GPL, or the BSD license, at your option. ++ * ++ * a) This library is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This library is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public ++ * License along with this library; if not, write to the Free ++ * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, ++ * MA 02110-1301 USA ++ * ++ * Alternatively, ++ * ++ * b) Redistribution and use in source and binary forms, with or ++ * without modification, are permitted provided that the following ++ * conditions are met: ++ * ++ * 1. Redistributions of source code must retain the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer. ++ * 2. Redistributions in binary form must reproduce the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer in the documentation and/or other materials ++ * provided with the distribution. ++ * ++ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND ++ * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, ++ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF ++ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE ++ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR ++ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, ++ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT ++ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; ++ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ++ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN ++ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR ++ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, ++ * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ++ */ ++#include "libfdt_env.h" ++ ++#include <fdt.h> ++#include <libfdt.h> ++ ++#include "libfdt_internal.h" ++ ++int fdt_setprop_inplace(void *fdt, int nodeoffset, const char *name, ++ const void *val, int len) ++{ ++ void *propval; ++ int proplen; ++ ++ propval = fdt_getprop_w(fdt, nodeoffset, name, &proplen); ++ if (! propval) ++ return proplen; ++ ++ if (proplen != len) ++ return -FDT_ERR_NOSPACE; ++ ++ memcpy(propval, val, len); ++ return 0; ++} ++ ++static void nop_region(void *start, int len) ++{ ++ uint32_t *p; ++ ++ for (p = start; (void *)p < (start + len); p++) ++ *p = cpu_to_fdt32(FDT_NOP); ++} ++ ++int fdt_nop_property(void *fdt, int nodeoffset, const char *name) ++{ ++ struct fdt_property *prop; ++ int len; ++ ++ prop = fdt_get_property_w(fdt, nodeoffset, name, &len); ++ if (! prop) ++ return len; ++ ++ nop_region(prop, len + sizeof(*prop)); ++ ++ return 0; ++} ++ ++int _fdt_node_end_offset(void *fdt, int nodeoffset) ++{ ++ int level = 0; ++ uint32_t tag; ++ int offset, nextoffset; ++ ++ tag = fdt_next_tag(fdt, nodeoffset, &nextoffset); ++ if (tag != FDT_BEGIN_NODE) ++ return -FDT_ERR_BADOFFSET; ++ do { ++ offset = nextoffset; ++ tag = fdt_next_tag(fdt, offset, &nextoffset); ++ ++ switch (tag) { ++ case FDT_END: ++ return offset; ++ ++ case FDT_BEGIN_NODE: ++ level++; ++ break; ++ ++ case FDT_END_NODE: ++ level--; ++ break; ++ ++ case FDT_PROP: ++ case FDT_NOP: ++ break; ++ ++ default: ++ return -FDT_ERR_BADSTRUCTURE; ++ } ++ } while (level >= 0); ++ ++ return nextoffset; ++} ++ ++int fdt_nop_node(void *fdt, int nodeoffset) ++{ ++ int endoffset; ++ ++ endoffset = _fdt_node_end_offset(fdt, nodeoffset); ++ if (endoffset < 0) ++ return endoffset; ++ ++ nop_region(fdt_offset_ptr_w(fdt, nodeoffset, 0), endoffset - nodeoffset); ++ return 0; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/libfdt/libfdt.h powerpc.git/arch/powerpc/boot/libfdt/libfdt.h +--- linux-2.6.24/arch/powerpc/boot/libfdt/libfdt.h 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/libfdt/libfdt.h 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,721 @@ ++#ifndef _LIBFDT_H ++#define _LIBFDT_H ++/* ++ * libfdt - Flat Device Tree manipulation ++ * Copyright (C) 2006 David Gibson, IBM Corporation. ++ * ++ * libfdt is dual licensed: you can use it either under the terms of ++ * the GPL, or the BSD license, at your option. ++ * ++ * a) This library is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This library is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public ++ * License along with this library; if not, write to the Free ++ * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, ++ * MA 02110-1301 USA ++ * ++ * Alternatively, ++ * ++ * b) Redistribution and use in source and binary forms, with or ++ * without modification, are permitted provided that the following ++ * conditions are met: ++ * ++ * 1. Redistributions of source code must retain the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer. ++ * 2. Redistributions in binary form must reproduce the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer in the documentation and/or other materials ++ * provided with the distribution. ++ * ++ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND ++ * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, ++ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF ++ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE ++ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR ++ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, ++ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT ++ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; ++ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ++ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN ++ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR ++ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, ++ * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ++ */ ++ ++#include <libfdt_env.h> ++#include <fdt.h> ++ ++#define FDT_FIRST_SUPPORTED_VERSION 0x10 ++#define FDT_LAST_SUPPORTED_VERSION 0x11 ++ ++/* Error codes: informative error codes */ ++#define FDT_ERR_NOTFOUND 1 ++ /* FDT_ERR_NOTFOUND: The requested node or property does not exist */ ++#define FDT_ERR_EXISTS 2 ++ /* FDT_ERR_EXISTS: Attemped to create a node or property which ++ * already exists */ ++#define FDT_ERR_NOSPACE 3 ++ /* FDT_ERR_NOSPACE: Operation needed to expand the device ++ * tree, but its buffer did not have sufficient space to ++ * contain the expanded tree. Use fdt_open_into() to move the ++ * device tree to a buffer with more space. */ ++ ++/* Error codes: codes for bad parameters */ ++#define FDT_ERR_BADOFFSET 4 ++ /* FDT_ERR_BADOFFSET: Function was passed a structure block ++ * offset which is out-of-bounds, or which points to an ++ * unsuitable part of the structure for the operation. */ ++#define FDT_ERR_BADPATH 5 ++ /* FDT_ERR_BADPATH: Function was passed a badly formatted path ++ * (e.g. missing a leading / for a function which requires an ++ * absolute path) */ ++#define FDT_ERR_BADPHANDLE 6 ++ /* FDT_ERR_BADPHANDLE: Function was passed an invalid phandle ++ * value. phandle values of 0 and -1 are not permitted. */ ++#define FDT_ERR_BADSTATE 7 ++ /* FDT_ERR_BADSTATE: Function was passed an incomplete device ++ * tree created by the sequential-write functions, which is ++ * not sufficiently complete for the requested operation. */ ++ ++/* Error codes: codes for bad device tree blobs */ ++#define FDT_ERR_TRUNCATED 8 ++ /* FDT_ERR_TRUNCATED: Structure block of the given device tree ++ * ends without an FDT_END tag. */ ++#define FDT_ERR_BADMAGIC 9 ++ /* FDT_ERR_BADMAGIC: Given "device tree" appears not to be a ++ * device tree at all - it is missing the flattened device ++ * tree magic number. */ ++#define FDT_ERR_BADVERSION 10 ++ /* FDT_ERR_BADVERSION: Given device tree has a version which ++ * can't be handled by the requested operation. For ++ * read-write functions, this may mean that fdt_open_into() is ++ * required to convert the tree to the expected version. */ ++#define FDT_ERR_BADSTRUCTURE 11 ++ /* FDT_ERR_BADSTRUCTURE: Given device tree has a corrupt ++ * structure block or other serious error (e.g. misnested ++ * nodes, or subnodes preceding properties). */ ++#define FDT_ERR_BADLAYOUT 12 ++ /* FDT_ERR_BADLAYOUT: For read-write functions, the given ++ * device tree has it's sub-blocks in an order that the ++ * function can't handle (memory reserve map, then structure, ++ * then strings). Use fdt_open_into() to reorganize the tree ++ * into a form suitable for the read-write operations. */ ++ ++/* "Can't happen" error indicating a bug in libfdt */ ++#define FDT_ERR_INTERNAL 13 ++ /* FDT_ERR_INTERNAL: libfdt has failed an internal assertion. ++ * Should never be returned, if it is, it indicates a bug in ++ * libfdt itself. */ ++ ++#define FDT_ERR_MAX 13 ++ ++/**********************************************************************/ ++/* Low-level functions (you probably don't need these) */ ++/**********************************************************************/ ++ ++const void *fdt_offset_ptr(const void *fdt, int offset, int checklen); ++static inline void *fdt_offset_ptr_w(void *fdt, int offset, int checklen) ++{ ++ return (void *)fdt_offset_ptr(fdt, offset, checklen); ++} ++ ++uint32_t fdt_next_tag(const void *fdt, int offset, int *nextoffset); ++ ++/**********************************************************************/ ++/* General functions */ ++/**********************************************************************/ ++ ++#define fdt_get_header(fdt, field) \ ++ (fdt32_to_cpu(((const struct fdt_header *)(fdt))->field)) ++#define fdt_magic(fdt) (fdt_get_header(fdt, magic)) ++#define fdt_totalsize(fdt) (fdt_get_header(fdt, totalsize)) ++#define fdt_off_dt_struct(fdt) (fdt_get_header(fdt, off_dt_struct)) ++#define fdt_off_dt_strings(fdt) (fdt_get_header(fdt, off_dt_strings)) ++#define fdt_off_mem_rsvmap(fdt) (fdt_get_header(fdt, off_mem_rsvmap)) ++#define fdt_version(fdt) (fdt_get_header(fdt, version)) ++#define fdt_last_comp_version(fdt) (fdt_get_header(fdt, last_comp_version)) ++#define fdt_boot_cpuid_phys(fdt) (fdt_get_header(fdt, boot_cpuid_phys)) ++#define fdt_size_dt_strings(fdt) (fdt_get_header(fdt, size_dt_strings)) ++#define fdt_size_dt_struct(fdt) (fdt_get_header(fdt, size_dt_struct)) ++ ++#define __fdt_set_hdr(name) \ ++ static inline void fdt_set_##name(void *fdt, uint32_t val) \ ++ { \ ++ struct fdt_header *fdth = fdt; \ ++ fdth->name = cpu_to_fdt32(val); \ ++ } ++__fdt_set_hdr(magic); ++__fdt_set_hdr(totalsize); ++__fdt_set_hdr(off_dt_struct); ++__fdt_set_hdr(off_dt_strings); ++__fdt_set_hdr(off_mem_rsvmap); ++__fdt_set_hdr(version); ++__fdt_set_hdr(last_comp_version); ++__fdt_set_hdr(boot_cpuid_phys); ++__fdt_set_hdr(size_dt_strings); ++__fdt_set_hdr(size_dt_struct); ++#undef __fdt_set_hdr ++ ++/** ++ * fdt_check_header - sanity check a device tree or possible device tree ++ * @fdt: pointer to data which might be a flattened device tree ++ * ++ * fdt_check_header() checks that the given buffer contains what ++ * appears to be a flattened device tree with sane information in its ++ * header. ++ * ++ * returns: ++ * 0, if the buffer appears to contain a valid device tree ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, standard meanings, as above ++ */ ++int fdt_check_header(const void *fdt); ++ ++/** ++ * fdt_move - move a device tree around in memory ++ * @fdt: pointer to the device tree to move ++ * @buf: pointer to memory where the device is to be moved ++ * @bufsize: size of the memory space at buf ++ * ++ * fdt_move() relocates, if possible, the device tree blob located at ++ * fdt to the buffer at buf of size bufsize. The buffer may overlap ++ * with the existing device tree blob at fdt. Therefore, ++ * fdt_move(fdt, fdt, fdt_totalsize(fdt)) ++ * should always succeed. ++ * ++ * returns: ++ * 0, on success ++ * -FDT_ERR_NOSPACE, bufsize is insufficient to contain the device tree ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, standard meanings ++ */ ++int fdt_move(const void *fdt, void *buf, int bufsize); ++ ++/**********************************************************************/ ++/* Read-only functions */ ++/**********************************************************************/ ++ ++/** ++ * fdt_string - retreive a string from the strings block of a device tree ++ * @fdt: pointer to the device tree blob ++ * @stroffset: offset of the string within the strings block (native endian) ++ * ++ * fdt_string() retrieves a pointer to a single string from the ++ * strings block of the device tree blob at fdt. ++ * ++ * returns: ++ * a pointer to the string, on success ++ * NULL, if stroffset is out of bounds ++ */ ++const char *fdt_string(const void *fdt, int stroffset); ++ ++/** ++ * fdt_num_mem_rsv - retreive the number of memory reserve map entries ++ * @fdt: pointer to the device tree blob ++ * ++ * Returns the number of entries in the device tree blob's memory ++ * reservation map. This does not include the terminating 0,0 entry ++ * or any other (0,0) entries reserved for expansion. ++ * ++ * returns: ++ * the number of entries ++ */ ++int fdt_num_mem_rsv(const void *fdt); ++ ++/** ++ * fdt_get_mem_rsv - retreive one memory reserve map entry ++ * @fdt: pointer to the device tree blob ++ * @address, @size: pointers to 64-bit variables ++ * ++ * On success, *address and *size will contain the address and size of ++ * the n-th reserve map entry from the device tree blob, in ++ * native-endian format. ++ * ++ * returns: ++ * 0, on success ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, standard meanings ++ */ ++int fdt_get_mem_rsv(const void *fdt, int n, uint64_t *address, uint64_t *size); ++ ++/** ++ * fdt_subnode_offset_namelen - find a subnode based on substring ++ * @fdt: pointer to the device tree blob ++ * @parentoffset: structure block offset of a node ++ * @name: name of the subnode to locate ++ * @namelen: number of characters of name to consider ++ * ++ * Identical to fdt_subnode_offset(), but only examine the first ++ * namelen characters of name for matching the subnode name. This is ++ * useful for finding subnodes based on a portion of a larger string, ++ * such as a full path. ++ */ ++int fdt_subnode_offset_namelen(const void *fdt, int parentoffset, ++ const char *name, int namelen); ++/** ++ * fdt_subnode_offset - find a subnode of a given node ++ * @fdt: pointer to the device tree blob ++ * @parentoffset: structure block offset of a node ++ * @name: name of the subnode to locate ++ * ++ * fdt_subnode_offset() finds a subnode of the node at structure block ++ * offset parentoffset with the given name. name may include a unit ++ * address, in which case fdt_subnode_offset() will find the subnode ++ * with that unit address, or the unit address may be omitted, in ++ * which case fdt_subnode_offset() will find an arbitrary subnode ++ * whose name excluding unit address matches the given name. ++ * ++ * returns: ++ * structure block offset of the requested subnode (>=0), on success ++ * -FDT_ERR_NOTFOUND, if the requested subnode does not exist ++ * -FDT_ERR_BADOFFSET, if parentoffset did not point to an FDT_BEGIN_NODE tag ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, ++ * -FDT_ERR_BADSTRUCTURE, ++ * -FDT_ERR_TRUNCATED, standard meanings. ++ */ ++int fdt_subnode_offset(const void *fdt, int parentoffset, const char *name); ++ ++/** ++ * fdt_path_offset - find a tree node by its full path ++ * @fdt: pointer to the device tree blob ++ * @path: full path of the node to locate ++ * ++ * fdt_path_offset() finds a node of a given path in the device tree. ++ * Each path component may omit the unit address portion, but the ++ * results of this are undefined if any such path component is ++ * ambiguous (that is if there are multiple nodes at the relevant ++ * level matching the given component, differentiated only by unit ++ * address). ++ * ++ * returns: ++ * structure block offset of the node with the requested path (>=0), on success ++ * -FDT_ERR_BADPATH, given path does not begin with '/' or is invalid ++ * -FDT_ERR_NOTFOUND, if the requested node does not exist ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, ++ * -FDT_ERR_BADSTRUCTURE, ++ * -FDT_ERR_TRUNCATED, standard meanings. ++ */ ++int fdt_path_offset(const void *fdt, const char *path); ++ ++/** ++ * fdt_get_name - retreive the name of a given node ++ * @fdt: pointer to the device tree blob ++ * @nodeoffset: structure block offset of the starting node ++ * @lenp: pointer to an integer variable (will be overwritten) or NULL ++ * ++ * fdt_get_name() retrieves the name (including unit address) of the ++ * device tree node at structure block offset nodeoffset. If lenp is ++ * non-NULL, the length of this name is also returned, in the integer ++ * pointed to by lenp. ++ * ++ * returns: ++ * pointer to the node's name, on success ++ * If lenp is non-NULL, *lenp contains the length of that name (>=0) ++ * NULL, on error ++ * if lenp is non-NULL *lenp contains an error code (<0): ++ * -FDT_ERR_BADOFFSET, nodeoffset did not point to FDT_BEGIN_NODE tag ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, standard meanings ++ */ ++const char *fdt_get_name(const void *fdt, int nodeoffset, int *lenp); ++ ++/** ++ * fdt_get_property - find a given property in a given node ++ * @fdt: pointer to the device tree blob ++ * @nodeoffset: offset of the node whose property to find ++ * @name: name of the property to find ++ * @lenp: pointer to an integer variable (will be overwritten) or NULL ++ * ++ * fdt_get_property() retrieves a pointer to the fdt_property ++ * structure within the device tree blob corresponding to the property ++ * named 'name' of the node at offset nodeoffset. If lenp is ++ * non-NULL, the length of the property value also returned, in the ++ * integer pointed to by lenp. ++ * ++ * returns: ++ * pointer to the structure representing the property ++ * if lenp is non-NULL, *lenp contains the length of the property ++ * value (>=0) ++ * NULL, on error ++ * if lenp is non-NULL, *lenp contains an error code (<0): ++ * -FDT_ERR_NOTFOUND, node does not have named property ++ * -FDT_ERR_BADOFFSET, nodeoffset did not point to FDT_BEGIN_NODE tag ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, ++ * -FDT_ERR_BADSTRUCTURE, ++ * -FDT_ERR_TRUNCATED, standard meanings ++ */ ++const struct fdt_property *fdt_get_property(const void *fdt, int nodeoffset, ++ const char *name, int *lenp); ++static inline struct fdt_property *fdt_get_property_w(void *fdt, int nodeoffset, ++ const char *name, ++ int *lenp) ++{ ++ return (struct fdt_property *)fdt_get_property(fdt, nodeoffset, ++ name, lenp); ++} ++ ++/** ++ * fdt_getprop - retrieve the value of a given property ++ * @fdt: pointer to the device tree blob ++ * @nodeoffset: offset of the node whose property to find ++ * @name: name of the property to find ++ * @lenp: pointer to an integer variable (will be overwritten) or NULL ++ * ++ * fdt_getprop() retrieves a pointer to the value of the property ++ * named 'name' of the node at offset nodeoffset (this will be a ++ * pointer to within the device blob itself, not a copy of the value). ++ * If lenp is non-NULL, the length of the property value also ++ * returned, in the integer pointed to by lenp. ++ * ++ * returns: ++ * pointer to the property's value ++ * if lenp is non-NULL, *lenp contains the length of the property ++ * value (>=0) ++ * NULL, on error ++ * if lenp is non-NULL, *lenp contains an error code (<0): ++ * -FDT_ERR_NOTFOUND, node does not have named property ++ * -FDT_ERR_BADOFFSET, nodeoffset did not point to FDT_BEGIN_NODE tag ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, ++ * -FDT_ERR_BADSTRUCTURE, ++ * -FDT_ERR_TRUNCATED, standard meanings ++ */ ++const void *fdt_getprop(const void *fdt, int nodeoffset, ++ const char *name, int *lenp); ++static inline void *fdt_getprop_w(void *fdt, int nodeoffset, ++ const char *name, int *lenp) ++{ ++ return (void *)fdt_getprop(fdt, nodeoffset, name, lenp); ++} ++ ++/** ++ * fdt_get_phandle - retreive the phandle of a given node ++ * @fdt: pointer to the device tree blob ++ * @nodeoffset: structure block offset of the node ++ * ++ * fdt_get_phandle() retrieves the phandle of the device tree node at ++ * structure block offset nodeoffset. ++ * ++ * returns: ++ * the phandle of the node at nodeoffset, on succes (!= 0, != -1) ++ * 0, if the node has no phandle, or another error occurs ++ */ ++uint32_t fdt_get_phandle(const void *fdt, int nodeoffset); ++ ++/** ++ * fdt_get_path - determine the full path of a node ++ * @fdt: pointer to the device tree blob ++ * @nodeoffset: offset of the node whose path to find ++ * @buf: character buffer to contain the returned path (will be overwritten) ++ * @buflen: size of the character buffer at buf ++ * ++ * fdt_get_path() computes the full path of the node at offset ++ * nodeoffset, and records that path in the buffer at buf. ++ * ++ * NOTE: This function is expensive, as it must scan the device tree ++ * structure from the start to nodeoffset. ++ * ++ * returns: ++ * 0, on success ++ * buf contains the absolute path of the node at ++ * nodeoffset, as a NUL-terminated string. ++ * -FDT_ERR_BADOFFSET, nodeoffset does not refer to a BEGIN_NODE tag ++ * -FDT_ERR_NOSPACE, the path of the given node is longer than (bufsize-1) ++ * characters and will not fit in the given buffer. ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, ++ * -FDT_ERR_BADSTRUCTURE, standard meanings ++ */ ++int fdt_get_path(const void *fdt, int nodeoffset, char *buf, int buflen); ++ ++/** ++ * fdt_supernode_atdepth_offset - find a specific ancestor of a node ++ * @fdt: pointer to the device tree blob ++ * @nodeoffset: offset of the node whose parent to find ++ * @supernodedepth: depth of the ancestor to find ++ * @nodedepth: pointer to an integer variable (will be overwritten) or NULL ++ * ++ * fdt_supernode_atdepth_offset() finds an ancestor of the given node ++ * at a specific depth from the root (where the root itself has depth ++ * 0, its immediate subnodes depth 1 and so forth). So ++ * fdt_supernode_atdepth_offset(fdt, nodeoffset, 0, NULL); ++ * will always return 0, the offset of the root node. If the node at ++ * nodeoffset has depth D, then: ++ * fdt_supernode_atdepth_offset(fdt, nodeoffset, D, NULL); ++ * will return nodeoffset itself. ++ * ++ * NOTE: This function is expensive, as it must scan the device tree ++ * structure from the start to nodeoffset. ++ * ++ * returns: ++ ++ * structure block offset of the node at node offset's ancestor ++ * of depth supernodedepth (>=0), on success ++ * -FDT_ERR_BADOFFSET, nodeoffset does not refer to a BEGIN_NODE tag ++* -FDT_ERR_NOTFOUND, supernodedepth was greater than the depth of nodeoffset ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, ++ * -FDT_ERR_BADSTRUCTURE, standard meanings ++ */ ++int fdt_supernode_atdepth_offset(const void *fdt, int nodeoffset, ++ int supernodedepth, int *nodedepth); ++ ++/** ++ * fdt_node_depth - find the depth of a given node ++ * @fdt: pointer to the device tree blob ++ * @nodeoffset: offset of the node whose parent to find ++ * ++ * fdt_node_depth() finds the depth of a given node. The root node ++ * has depth 0, its immediate subnodes depth 1 and so forth. ++ * ++ * NOTE: This function is expensive, as it must scan the device tree ++ * structure from the start to nodeoffset. ++ * ++ * returns: ++ * depth of the node at nodeoffset (>=0), on success ++ * -FDT_ERR_BADOFFSET, nodeoffset does not refer to a BEGIN_NODE tag ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, ++ * -FDT_ERR_BADSTRUCTURE, standard meanings ++ */ ++int fdt_node_depth(const void *fdt, int nodeoffset); ++ ++/** ++ * fdt_parent_offset - find the parent of a given node ++ * @fdt: pointer to the device tree blob ++ * @nodeoffset: offset of the node whose parent to find ++ * ++ * fdt_parent_offset() locates the parent node of a given node (that ++ * is, it finds the offset of the node which contains the node at ++ * nodeoffset as a subnode). ++ * ++ * NOTE: This function is expensive, as it must scan the device tree ++ * structure from the start to nodeoffset, *twice*. ++ * ++ * returns: ++ * stucture block offset of the parent of the node at nodeoffset ++ * (>=0), on success ++ * -FDT_ERR_BADOFFSET, nodeoffset does not refer to a BEGIN_NODE tag ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, ++ * -FDT_ERR_BADSTRUCTURE, standard meanings ++ */ ++int fdt_parent_offset(const void *fdt, int nodeoffset); ++ ++/** ++ * fdt_node_offset_by_prop_value - find nodes with a given property value ++ * @fdt: pointer to the device tree blob ++ * @startoffset: only find nodes after this offset ++ * @propname: property name to check ++ * @propval: property value to search for ++ * @proplen: length of the value in propval ++ * ++ * fdt_node_offset_by_prop_value() returns the offset of the first ++ * node after startoffset, which has a property named propname whose ++ * value is of length proplen and has value equal to propval; or if ++ * startoffset is -1, the very first such node in the tree. ++ * ++ * To iterate through all nodes matching the criterion, the following ++ * idiom can be used: ++ * offset = fdt_node_offset_by_prop_value(fdt, -1, propname, ++ * propval, proplen); ++ * while (offset != -FDT_ERR_NOTFOUND) { ++ * // other code here ++ * offset = fdt_node_offset_by_prop_value(fdt, offset, propname, ++ * propval, proplen); ++ * } ++ * ++ * Note the -1 in the first call to the function, if 0 is used here ++ * instead, the function will never locate the root node, even if it ++ * matches the criterion. ++ * ++ * returns: ++ * structure block offset of the located node (>= 0, >startoffset), ++ * on success ++ * -FDT_ERR_NOTFOUND, no node matching the criterion exists in the ++ * tree after startoffset ++ * -FDT_ERR_BADOFFSET, nodeoffset does not refer to a BEGIN_NODE tag ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, ++ * -FDT_ERR_BADSTRUCTURE, standard meanings ++ */ ++int fdt_node_offset_by_prop_value(const void *fdt, int startoffset, ++ const char *propname, ++ const void *propval, int proplen); ++ ++/** ++ * fdt_node_offset_by_phandle - find the node with a given phandle ++ * @fdt: pointer to the device tree blob ++ * @phandle: phandle value ++ * ++ * fdt_node_offset_by_prop_value() returns the offset of the node ++ * which has the given phandle value. If there is more than one node ++ * in the tree with the given phandle (an invalid tree), results are ++ * undefined. ++ * ++ * returns: ++ * structure block offset of the located node (>= 0), on success ++ * -FDT_ERR_NOTFOUND, no node with that phandle exists ++ * -FDT_ERR_BADPHANDLE, given phandle value was invalid (0 or -1) ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, ++ * -FDT_ERR_BADSTRUCTURE, standard meanings ++ */ ++int fdt_node_offset_by_phandle(const void *fdt, uint32_t phandle); ++ ++/** ++ * fdt_node_check_compatible: check a node's compatible property ++ * @fdt: pointer to the device tree blob ++ * @nodeoffset: offset of a tree node ++ * @compatible: string to match against ++ * ++ * ++ * fdt_node_check_compatible() returns 0 if the given node contains a ++ * 'compatible' property with the given string as one of its elements, ++ * it returns non-zero otherwise, or on error. ++ * ++ * returns: ++ * 0, if the node has a 'compatible' property listing the given string ++ * 1, if the node has a 'compatible' property, but it does not list ++ * the given string ++ * -FDT_ERR_NOTFOUND, if the given node has no 'compatible' property ++ * -FDT_ERR_BADOFFSET, if nodeoffset does not refer to a BEGIN_NODE tag ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, ++ * -FDT_ERR_BADSTRUCTURE, standard meanings ++ */ ++int fdt_node_check_compatible(const void *fdt, int nodeoffset, ++ const char *compatible); ++ ++/** ++ * fdt_node_offset_by_compatible - find nodes with a given 'compatible' value ++ * @fdt: pointer to the device tree blob ++ * @startoffset: only find nodes after this offset ++ * @compatible: 'compatible' string to match against ++ * ++ * fdt_node_offset_by_compatible() returns the offset of the first ++ * node after startoffset, which has a 'compatible' property which ++ * lists the given compatible string; or if startoffset is -1, the ++ * very first such node in the tree. ++ * ++ * To iterate through all nodes matching the criterion, the following ++ * idiom can be used: ++ * offset = fdt_node_offset_by_compatible(fdt, -1, compatible); ++ * while (offset != -FDT_ERR_NOTFOUND) { ++ * // other code here ++ * offset = fdt_node_offset_by_compatible(fdt, offset, compatible); ++ * } ++ * ++ * Note the -1 in the first call to the function, if 0 is used here ++ * instead, the function will never locate the root node, even if it ++ * matches the criterion. ++ * ++ * returns: ++ * structure block offset of the located node (>= 0, >startoffset), ++ * on success ++ * -FDT_ERR_NOTFOUND, no node matching the criterion exists in the ++ * tree after startoffset ++ * -FDT_ERR_BADOFFSET, nodeoffset does not refer to a BEGIN_NODE tag ++ * -FDT_ERR_BADMAGIC, ++ * -FDT_ERR_BADVERSION, ++ * -FDT_ERR_BADSTATE, ++ * -FDT_ERR_BADSTRUCTURE, standard meanings ++ */ ++int fdt_node_offset_by_compatible(const void *fdt, int startoffset, ++ const char *compatible); ++ ++/**********************************************************************/ ++/* Write-in-place functions */ ++/**********************************************************************/ ++ ++int fdt_setprop_inplace(void *fdt, int nodeoffset, const char *name, ++ const void *val, int len); ++static inline int fdt_setprop_inplace_cell(void *fdt, int nodeoffset, ++ const char *name, uint32_t val) ++{ ++ val = cpu_to_fdt32(val); ++ return fdt_setprop_inplace(fdt, nodeoffset, name, &val, sizeof(val)); ++} ++ ++int fdt_nop_property(void *fdt, int nodeoffset, const char *name); ++int fdt_nop_node(void *fdt, int nodeoffset); ++ ++/**********************************************************************/ ++/* Sequential write functions */ ++/**********************************************************************/ ++ ++int fdt_create(void *buf, int bufsize); ++int fdt_add_reservemap_entry(void *fdt, uint64_t addr, uint64_t size); ++int fdt_finish_reservemap(void *fdt); ++int fdt_begin_node(void *fdt, const char *name); ++int fdt_property(void *fdt, const char *name, const void *val, int len); ++static inline int fdt_property_cell(void *fdt, const char *name, uint32_t val) ++{ ++ val = cpu_to_fdt32(val); ++ return fdt_property(fdt, name, &val, sizeof(val)); ++} ++#define fdt_property_string(fdt, name, str) \ ++ fdt_property(fdt, name, str, strlen(str)+1) ++int fdt_end_node(void *fdt); ++int fdt_finish(void *fdt); ++ ++/**********************************************************************/ ++/* Read-write functions */ ++/**********************************************************************/ ++ ++int fdt_open_into(const void *fdt, void *buf, int bufsize); ++int fdt_pack(void *fdt); ++ ++int fdt_add_mem_rsv(void *fdt, uint64_t address, uint64_t size); ++int fdt_del_mem_rsv(void *fdt, int n); ++ ++int fdt_setprop(void *fdt, int nodeoffset, const char *name, ++ const void *val, int len); ++static inline int fdt_setprop_cell(void *fdt, int nodeoffset, const char *name, ++ uint32_t val) ++{ ++ val = cpu_to_fdt32(val); ++ return fdt_setprop(fdt, nodeoffset, name, &val, sizeof(val)); ++} ++#define fdt_setprop_string(fdt, nodeoffset, name, str) \ ++ fdt_setprop((fdt), (nodeoffset), (name), (str), strlen(str)+1) ++int fdt_delprop(void *fdt, int nodeoffset, const char *name); ++int fdt_add_subnode_namelen(void *fdt, int parentoffset, ++ const char *name, int namelen); ++int fdt_add_subnode(void *fdt, int parentoffset, const char *name); ++int fdt_del_node(void *fdt, int nodeoffset); ++ ++/**********************************************************************/ ++/* Debugging / informational functions */ ++/**********************************************************************/ ++ ++const char *fdt_strerror(int errval); ++ ++#endif /* _LIBFDT_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/libfdt/libfdt_internal.h powerpc.git/arch/powerpc/boot/libfdt/libfdt_internal.h +--- linux-2.6.24/arch/powerpc/boot/libfdt/libfdt_internal.h 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/libfdt/libfdt_internal.h 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,89 @@ ++#ifndef _LIBFDT_INTERNAL_H ++#define _LIBFDT_INTERNAL_H ++/* ++ * libfdt - Flat Device Tree manipulation ++ * Copyright (C) 2006 David Gibson, IBM Corporation. ++ * ++ * libfdt is dual licensed: you can use it either under the terms of ++ * the GPL, or the BSD license, at your option. ++ * ++ * a) This library is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This library is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public ++ * License along with this library; if not, write to the Free ++ * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, ++ * MA 02110-1301 USA ++ * ++ * Alternatively, ++ * ++ * b) Redistribution and use in source and binary forms, with or ++ * without modification, are permitted provided that the following ++ * conditions are met: ++ * ++ * 1. Redistributions of source code must retain the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer. ++ * 2. Redistributions in binary form must reproduce the above ++ * copyright notice, this list of conditions and the following ++ * disclaimer in the documentation and/or other materials ++ * provided with the distribution. ++ * ++ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND ++ * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, ++ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF ++ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE ++ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR ++ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, ++ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT ++ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; ++ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ++ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN ++ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR ++ * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, ++ * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ++ */ ++#include <fdt.h> ++ ++#define ALIGN(x, a) (((x) + (a) - 1) & ~((a) - 1)) ++#define PALIGN(p, a) ((void *)ALIGN((unsigned long)(p), (a))) ++ ++#define memeq(p, q, n) (memcmp((p), (q), (n)) == 0) ++#define streq(p, q) (strcmp((p), (q)) == 0) ++ ++uint32_t _fdt_next_tag(const void *fdt, int startoffset, int *nextoffset); ++const char *_fdt_find_string(const char *strtab, int tabsize, const char *s); ++int _fdt_node_end_offset(void *fdt, int nodeoffset); ++ ++static inline const void *_fdt_offset_ptr(const void *fdt, int offset) ++{ ++ return fdt + fdt_off_dt_struct(fdt) + offset; ++} ++ ++static inline void *_fdt_offset_ptr_w(void *fdt, int offset) ++{ ++ return (void *)_fdt_offset_ptr(fdt, offset); ++} ++ ++static inline const struct fdt_reserve_entry *_fdt_mem_rsv(const void *fdt, int n) ++{ ++ const struct fdt_reserve_entry *rsv_table = ++ fdt + fdt_off_mem_rsvmap(fdt); ++ ++ return rsv_table + n; ++} ++static inline struct fdt_reserve_entry *_fdt_mem_rsv_w(void *fdt, int n) ++{ ++ return (void *)_fdt_mem_rsv(fdt, n); ++} ++ ++#define SW_MAGIC (~FDT_MAGIC) ++ ++#endif /* _LIBFDT_INTERNAL_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/libfdt-wrapper.c powerpc.git/arch/powerpc/boot/libfdt-wrapper.c +--- linux-2.6.24/arch/powerpc/boot/libfdt-wrapper.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/libfdt-wrapper.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,184 @@ ++/* ++ * This file does the necessary interface mapping between the bootwrapper ++ * device tree operations and the interface provided by shared source ++ * files flatdevicetree.[ch]. ++ * ++ * Copyright 2007 David Gibson, IBM Corporation. ++ * ++ * This library is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License as ++ * published by the Free Software Foundation; either version 2 of the ++ * License, or (at your option) any later version. ++ * ++ * This library is distributed in the hope that it will be useful, but ++ * WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ * General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this library; if not, write to the Free Software ++ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA ++ * 02110-1301 USA ++ */ ++ ++#include <stddef.h> ++#include <stdio.h> ++#include <page.h> ++#include <libfdt.h> ++#include "ops.h" ++ ++#define DEBUG 0 ++#define BAD_ERROR(err) (((err) < 0) \ ++ && ((err) != -FDT_ERR_NOTFOUND) \ ++ && ((err) != -FDT_ERR_EXISTS)) ++ ++#define check_err(err) \ ++ ({ \ ++ if (BAD_ERROR(err) || ((err < 0) && DEBUG)) \ ++ printf("%s():%d %s\n\r", __FUNCTION__, __LINE__, \ ++ fdt_strerror(err)); \ ++ if (BAD_ERROR(err)) \ ++ exit(); \ ++ (err < 0) ? -1 : 0; \ ++ }) ++ ++#define offset_devp(off) \ ++ ({ \ ++ int _offset = (off); \ ++ check_err(_offset) ? NULL : (void *)(_offset+1); \ ++ }) ++ ++#define devp_offset_find(devp) (((int)(devp))-1) ++#define devp_offset(devp) (devp ? ((int)(devp))-1 : 0) ++ ++static void *fdt; ++static void *buf; /* = NULL */ ++ ++#define EXPAND_GRANULARITY 1024 ++ ++static void expand_buf(int minexpand) ++{ ++ int size = fdt_totalsize(fdt); ++ int rc; ++ ++ size = _ALIGN(size + minexpand, EXPAND_GRANULARITY); ++ buf = platform_ops.realloc(buf, size); ++ if (!buf) ++ fatal("Couldn't find %d bytes to expand device tree\n\r", size); ++ rc = fdt_open_into(fdt, buf, size); ++ if (rc != 0) ++ fatal("Couldn't expand fdt into new buffer: %s\n\r", ++ fdt_strerror(rc)); ++ ++ fdt = buf; ++} ++ ++static void *fdt_wrapper_finddevice(const char *path) ++{ ++ return offset_devp(fdt_path_offset(fdt, path)); ++} ++ ++static int fdt_wrapper_getprop(const void *devp, const char *name, ++ void *buf, const int buflen) ++{ ++ const void *p; ++ int len; ++ ++ p = fdt_getprop(fdt, devp_offset(devp), name, &len); ++ if (!p) ++ return check_err(len); ++ memcpy(buf, p, min(len, buflen)); ++ return len; ++} ++ ++static int fdt_wrapper_setprop(const void *devp, const char *name, ++ const void *buf, const int len) ++{ ++ int rc; ++ ++ rc = fdt_setprop(fdt, devp_offset(devp), name, buf, len); ++ if (rc == -FDT_ERR_NOSPACE) { ++ expand_buf(len + 16); ++ rc = fdt_setprop(fdt, devp_offset(devp), name, buf, len); ++ } ++ ++ return check_err(rc); ++} ++ ++static void *fdt_wrapper_get_parent(const void *devp) ++{ ++ return offset_devp(fdt_parent_offset(fdt, devp_offset(devp))); ++} ++ ++static void *fdt_wrapper_create_node(const void *devp, const char *name) ++{ ++ int offset; ++ ++ offset = fdt_add_subnode(fdt, devp_offset(devp), name); ++ if (offset == -FDT_ERR_NOSPACE) { ++ expand_buf(strlen(name) + 16); ++ offset = fdt_add_subnode(fdt, devp_offset(devp), name); ++ } ++ ++ return offset_devp(offset); ++} ++ ++static void *fdt_wrapper_find_node_by_prop_value(const void *prev, ++ const char *name, ++ const char *val, ++ int len) ++{ ++ int offset = fdt_node_offset_by_prop_value(fdt, devp_offset_find(prev), ++ name, val, len); ++ return offset_devp(offset); ++} ++ ++static char *fdt_wrapper_get_path(const void *devp, char *buf, int len) ++{ ++ int rc; ++ ++ rc = fdt_get_path(fdt, devp_offset(devp), buf, len); ++ if (check_err(rc)) ++ return NULL; ++ return buf; ++} ++ ++static unsigned long fdt_wrapper_finalize(void) ++{ ++ int rc; ++ ++ rc = fdt_pack(fdt); ++ if (rc != 0) ++ fatal("Couldn't pack flat tree: %s\n\r", ++ fdt_strerror(rc)); ++ return (unsigned long)fdt; ++} ++ ++void fdt_init(void *blob) ++{ ++ int err; ++ ++ dt_ops.finddevice = fdt_wrapper_finddevice; ++ dt_ops.getprop = fdt_wrapper_getprop; ++ dt_ops.setprop = fdt_wrapper_setprop; ++ dt_ops.get_parent = fdt_wrapper_get_parent; ++ dt_ops.create_node = fdt_wrapper_create_node; ++ dt_ops.find_node_by_prop_value = fdt_wrapper_find_node_by_prop_value; ++ dt_ops.get_path = fdt_wrapper_get_path; ++ dt_ops.finalize = fdt_wrapper_finalize; ++ ++ /* Make sure the dt blob is the right version and so forth */ ++ fdt = blob; ++ err = fdt_open_into(fdt, fdt, fdt_totalsize(blob)); ++ if (err == -FDT_ERR_NOSPACE) { ++ int bufsize = fdt_totalsize(fdt) + 4; ++ buf = malloc(bufsize); ++ err = fdt_open_into(fdt, buf, bufsize); ++ } ++ ++ if (err != 0) ++ fatal("fdt_init(): %s\n\r", fdt_strerror(err)); ++ ++ if (buf) ++ fdt = buf; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/libfdt_env.h powerpc.git/arch/powerpc/boot/libfdt_env.h +--- linux-2.6.24/arch/powerpc/boot/libfdt_env.h 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/libfdt_env.h 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,17 @@ ++#ifndef _ARCH_POWERPC_BOOT_LIBFDT_ENV_H ++#define _ARCH_POWERPC_BOOT_LIBFDT_ENV_H ++ ++#include <types.h> ++#include <string.h> ++ ++typedef u32 uint32_t; ++typedef u64 uint64_t; ++ ++#define fdt16_to_cpu(x) (x) ++#define cpu_to_fdt16(x) (x) ++#define fdt32_to_cpu(x) (x) ++#define cpu_to_fdt32(x) (x) ++#define fdt64_to_cpu(x) (x) ++#define cpu_to_fdt64(x) (x) ++ ++#endif /* _ARCH_POWERPC_BOOT_LIBFDT_ENV_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/main.c powerpc.git/arch/powerpc/boot/main.c +--- linux-2.6.24/arch/powerpc/boot/main.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/main.c 2008-01-28 20:25:49.000000000 +0100 +@@ -16,7 +16,6 @@ + #include "stdio.h" + #include "ops.h" + #include "gunzip_util.h" +-#include "flatdevtree.h" + #include "reg.h" + + static struct gunzip_state gzstate; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/ops.h powerpc.git/arch/powerpc/boot/ops.h +--- linux-2.6.24/arch/powerpc/boot/ops.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/ops.h 2008-01-28 20:25:49.000000000 +0100 +@@ -79,7 +79,7 @@ + extern struct loader_info loader_info; + + void start(void); +-int ft_init(void *dt_blob, unsigned int max_size, unsigned int max_find_device); ++void fdt_init(void *blob); + int serial_console_init(void); + int ns16550_console_init(void *devp, struct serial_console_data *scdp); + int mpsc_console_init(void *devp, struct serial_console_data *scdp); +@@ -159,9 +159,23 @@ + return find_node_by_prop_value_str(prev, "device_type", type); + } + ++static inline void *find_node_by_alias(const char *alias) ++{ ++ void *devp = finddevice("/aliases"); ++ ++ if (devp) { ++ char path[MAX_PATH_LEN]; ++ if (getprop(devp, alias, path, MAX_PATH_LEN) > 0) ++ return finddevice(path); ++ } ++ ++ return NULL; ++} ++ + void dt_fixup_memory(u64 start, u64 size); + void dt_fixup_cpu_clocks(u32 cpufreq, u32 tbfreq, u32 busfreq); + void dt_fixup_clock(const char *path, u32 freq); ++void dt_fixup_mac_address_by_alias(const char *alias, const u8 *addr); + void dt_fixup_mac_address(u32 index, const u8 *addr); + void __dt_fixup_mac_addresses(u32 startindex, ...); + #define dt_fixup_mac_addresses(...) \ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/prpmc2800.c powerpc.git/arch/powerpc/boot/prpmc2800.c +--- linux-2.6.24/arch/powerpc/boot/prpmc2800.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/prpmc2800.c 2008-01-28 20:25:49.000000000 +0100 +@@ -547,8 +547,7 @@ + if (!dtb) + exit(); + memmove(dtb, _dtb_start, dt_size); +- if (ft_init(dtb, dt_size, 16)) +- exit(); ++ fdt_init(dtb); + + bridge_base = mv64x60_get_bridge_base(); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/ps3.c powerpc.git/arch/powerpc/boot/ps3.c +--- linux-2.6.24/arch/powerpc/boot/ps3.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/ps3.c 2008-01-28 20:25:49.000000000 +0100 +@@ -131,7 +131,7 @@ + printf("\n-- PS3 bootwrapper --\n"); + + simple_alloc_init(_end, heapsize, 32, 64); +- ft_init(_dtb_start, 0, 4); ++ fdt_init(_dtb_start); + + chosen = finddevice("/chosen"); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/redboot-8xx.c powerpc.git/arch/powerpc/boot/redboot-8xx.c +--- linux-2.6.24/arch/powerpc/boot/redboot-8xx.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/redboot-8xx.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,58 @@ ++/* ++ * RedBoot firmware support ++ * ++ * Author: Scott Wood <scottwood@freescale.com> ++ * ++ * Copyright (c) 2007 Freescale Semiconductor, Inc. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License version 2 as published ++ * by the Free Software Foundation. ++ */ ++ ++#include "ops.h" ++#include "stdio.h" ++#include "redboot.h" ++#include "fsl-soc.h" ++#include "io.h" ++ ++static bd_t bd; ++BSS_STACK(4096); ++ ++#define MHZ(x) ((x + 500000) / 1000000) ++ ++static void platform_fixups(void) ++{ ++ void *node; ++ ++ dt_fixup_memory(bd.bi_memstart, bd.bi_memsize); ++ dt_fixup_mac_addresses(bd.bi_enetaddr); ++ dt_fixup_cpu_clocks(bd.bi_intfreq, bd.bi_busfreq / 16, bd.bi_busfreq); ++ ++ node = finddevice("/soc/cpm/brg"); ++ if (node) { ++ printf("BRG clock-frequency <- 0x%x (%dMHz)\r\n", ++ bd.bi_busfreq, MHZ(bd.bi_busfreq)); ++ setprop(node, "clock-frequency", &bd.bi_busfreq, 4); ++ } ++} ++ ++void platform_init(unsigned long r3, unsigned long r4, unsigned long r5, ++ unsigned long r6, unsigned long r7) ++{ ++ memcpy(&bd, (char *)r3, sizeof(bd)); ++ ++ if (bd.bi_tag != 0x42444944) ++ return; ++ ++ simple_alloc_init(_end, ++ bd.bi_memstart + bd.bi_memsize - (unsigned long)_end, ++ 32, 64); ++ ++ fdt_init(_dtb_start); ++ serial_console_init(); ++ platform_ops.fixups = platform_fixups; ++ ++ loader_info.cmdline = (char *)bd.bi_cmdline; ++ loader_info.cmdline_len = strlen((char *)bd.bi_cmdline); ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/redboot.h powerpc.git/arch/powerpc/boot/redboot.h +--- linux-2.6.24/arch/powerpc/boot/redboot.h 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/redboot.h 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,56 @@ ++#ifndef _PPC_REDBOOT_H ++#define _PPC_REDBOOT_H ++ ++//========================================================================= ++// include/asm-ppc/redboot.h ++// Copyright (c) 2002, 2003 Gary Thomas (<gary@mlbassoc.com> ++// Copyright (c) 1997 Dan Malek (dmalek@jlc.net) ++ ++// ++// Board specific details, as provided by RedBoot ++// ++ ++/* A Board Information structure that is given to a program when ++ * RedBoot starts it up. Note: not all fields make sense for all ++ * architectures and it's up to the platform specific code to fill ++ * in the details. ++ */ ++typedef struct bd_info { ++ unsigned int bi_tag; /* Should be 0x42444944 "BDID" */ ++ unsigned int bi_size; /* Size of this structure */ ++ unsigned int bi_revision; /* revision of this structure */ ++ unsigned int bi_bdate; /* bootstrap date, i.e. 0x19971106 */ ++ unsigned int bi_memstart; /* Memory start address */ ++ unsigned int bi_memsize; /* Memory (end) size in bytes */ ++ unsigned int bi_intfreq; /* Internal Freq, in Hz */ ++ unsigned int bi_busfreq; /* Bus Freq, in Hz */ ++ unsigned int bi_cpmfreq; /* CPM Freq, in Hz */ ++ unsigned int bi_brgfreq; /* BRG Freq, in Hz */ ++ unsigned int bi_vco; /* VCO Out from PLL */ ++ unsigned int bi_pci_freq; /* PCI Freq, in Hz */ ++ unsigned int bi_baudrate; /* Default console baud rate */ ++ unsigned int bi_immr; /* IMMR when called from boot rom */ ++ unsigned char bi_enetaddr[6]; ++ unsigned int bi_flashbase; /* Physical address of FLASH memory */ ++ unsigned int bi_flashsize; /* Length of FLASH memory */ ++ int bi_flashwidth; /* Width (8,16,32,64) */ ++ unsigned char *bi_cmdline; /* Pointer to command line */ ++ unsigned char bi_esa[3][6]; /* Ethernet station addresses */ ++ unsigned int bi_ramdisk_begin, bi_ramdisk_end; ++ struct { /* Information about [main] video screen */ ++ short x_res; /* Horizontal resolution in pixels */ ++ short y_res; /* Vertical resolution in pixels */ ++ short bpp; /* Bits/pixel */ ++ short mode; /* Type of pixels (packed, indexed) */ ++ unsigned long fb; /* Pointer to frame buffer (pixel) memory */ ++ } bi_video; ++ void (*bi_cputc)(char); /* Write a character to the RedBoot console */ ++ char (*bi_cgetc)(void); /* Read a character from the RedBoot console */ ++ int (*bi_ctstc)(void); /* Test for input on the RedBoot console */ ++} bd_t; ++ ++#define BI_REV 0x0102 /* Version 1.02 */ ++ ++#define bi_pci_busfreq bi_pci_freq ++#define bi_immr_base bi_immr ++#endif +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/reg.h powerpc.git/arch/powerpc/boot/reg.h +--- linux-2.6.24/arch/powerpc/boot/reg.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/reg.h 2008-01-28 20:25:49.000000000 +0100 +@@ -16,6 +16,14 @@ + return pvr; + } + ++#define __stringify_1(x) #x ++#define __stringify(x) __stringify_1(x) ++ ++#define mfspr(rn) ({unsigned long rval; \ ++ asm volatile("mfspr %0," __stringify(rn) \ ++ : "=r" (rval)); rval; }) ++#define mtspr(rn, v) asm volatile("mtspr " __stringify(rn) ",%0" : : "r" (v)) ++ + register void *__stack_pointer asm("r1"); + #define get_sp() (__stack_pointer) + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/serial.c powerpc.git/arch/powerpc/boot/serial.c +--- linux-2.6.24/arch/powerpc/boot/serial.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/serial.c 2008-01-28 20:25:49.000000000 +0100 +@@ -128,7 +128,8 @@ + rc = cpm_console_init(devp, &serial_cd); + else if (dt_is_compatible(devp, "mpc5200-psc-uart")) + rc = mpc5200_psc_console_init(devp, &serial_cd); +- else if (dt_is_compatible(devp, "xilinx,uartlite")) ++ else if (dt_is_compatible(devp, "xlnx,opb-uartlite-1.00.b") || ++ dt_is_compatible(devp, "xlnx,xps-uartlite-1.00.a")) + rc = uartlite_console_init(devp, &serial_cd); + + /* Add other serial console driver calls here */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/treeboot-walnut.c powerpc.git/arch/powerpc/boot/treeboot-walnut.c +--- linux-2.6.24/arch/powerpc/boot/treeboot-walnut.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/treeboot-walnut.c 2008-01-28 20:25:49.000000000 +0100 +@@ -20,55 +20,6 @@ + + BSS_STACK(4096); + +-void ibm405gp_fixup_clocks(unsigned int sysclk, unsigned int ser_clk) +-{ +- u32 pllmr = mfdcr(DCRN_CPC0_PLLMR); +- u32 cpc0_cr0 = mfdcr(DCRN_405_CPC0_CR0); +- u32 cpc0_cr1 = mfdcr(DCRN_405_CPC0_CR1); +- u32 cpu, plb, opb, ebc, tb, uart0, uart1, m; +- u32 fwdv, fbdv, cbdv, opdv, epdv, udiv; +- +- fwdv = (8 - ((pllmr & 0xe0000000) >> 29)); +- fbdv = (pllmr & 0x1e000000) >> 25; +- cbdv = ((pllmr & 0x00060000) >> 17) + 1; +- opdv = ((pllmr & 0x00018000) >> 15) + 1; +- epdv = ((pllmr & 0x00001800) >> 13) + 2; +- udiv = ((cpc0_cr0 & 0x3e) >> 1) + 1; +- +- m = fwdv * fbdv * cbdv; +- +- cpu = sysclk * m / fwdv; +- plb = cpu / cbdv; +- opb = plb / opdv; +- ebc = plb / epdv; +- +- if (cpc0_cr0 & 0x80) { +- /* uart0 uses the external clock */ +- uart0 = ser_clk; +- } else { +- uart0 = cpu / udiv; +- } +- +- if (cpc0_cr0 & 0x40) { +- /* uart1 uses the external clock */ +- uart1 = ser_clk; +- } else { +- uart1 = cpu / udiv; +- } +- +- /* setup the timebase clock to tick at the cpu frequency */ +- cpc0_cr1 = cpc0_cr1 & ~0x00800000; +- mtdcr(DCRN_405_CPC0_CR1, cpc0_cr1); +- tb = cpu; +- +- dt_fixup_cpu_clocks(cpu, tb, 0); +- dt_fixup_clock("/plb", plb); +- dt_fixup_clock("/plb/opb", opb); +- dt_fixup_clock("/plb/ebc", ebc); +- dt_fixup_clock("/plb/opb/serial@ef600300", uart0); +- dt_fixup_clock("/plb/opb/serial@ef600400", uart1); +-} +- + static void walnut_flashsel_fixup(void) + { + void *devp, *sram; +@@ -112,7 +63,7 @@ + #define WALNUT_OPENBIOS_MAC_OFF 0xfffffe0b + static void walnut_fixups(void) + { +- ibm4xx_fixup_memsize(); ++ ibm4xx_sdram_fixup_memsize(); + ibm405gp_fixup_clocks(33330000, 0xa8c000); + ibm4xx_quiesce_eth((u32 *)0xef600800, NULL); + ibm4xx_fixup_ebc_ranges("/plb/ebc"); +@@ -128,6 +79,6 @@ + simple_alloc_init(_end, avail_ram, 32, 32); + platform_ops.fixups = walnut_fixups; + platform_ops.exit = ibm40x_dbcr_reset; +- ft_init(_dtb_start, _dtb_end - _dtb_start, 32); ++ fdt_init(_dtb_start); + serial_console_init(); + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/boot/wrapper powerpc.git/arch/powerpc/boot/wrapper +--- linux-2.6.24/arch/powerpc/boot/wrapper 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/boot/wrapper 2008-01-28 20:25:49.000000000 +0100 +@@ -45,6 +45,7 @@ + + # directory for object and other files used by this script + object=arch/powerpc/boot ++objbin=$object + + # directory for working files + tmpdir=. +@@ -95,6 +96,7 @@ + shift + [ "$#" -gt 0 ] || usage + object="$1" ++ objbin="$1" + ;; + -W) + shift +@@ -116,10 +118,13 @@ + done + + if [ -n "$dts" ]; then ++ if [ ! -r "$dts" -a -r "$object/dts/$dts" ]; then ++ dts="$object/dts/$dts" ++ fi + if [ -z "$dtb" ]; then + dtb="$platform.dtb" + fi +- dtc -O dtb -o "$dtb" -b 0 -V 16 "$dts" ++ $object/dtc -O dtb -o "$dtb" -b 0 "$dts" + fi + + if [ -z "$kernel" ]; then +@@ -163,7 +168,7 @@ + ksection=.kernel:vmlinux.bin + isection=.kernel:initrd + ;; +-ep88xc) ++ep88xc|ep405|redboot*|ep8248e) + platformo="$object/fixed-head.o $object/$platform.o" + binary=y + ;; +@@ -246,11 +251,11 @@ + # post-processing needed for some platforms + case "$platform" in + pseries|chrp) +- $object/addnote "$ofile" ++ $objbin/addnote "$ofile" + ;; + coff) + ${CROSS}objcopy -O aixcoff-rs6000 --set-start "$entry" "$ofile" +- $object/hack-coff "$ofile" ++ $objbin/hack-coff "$ofile" + ;; + cuboot*) + gzip -f -9 "$ofile" +@@ -259,7 +264,7 @@ + ;; + treeboot*) + mv "$ofile" "$ofile.elf" +- $object/mktree "$ofile.elf" "$ofile" "$base" "$entry" ++ $objbin/mktree "$ofile.elf" "$ofile" "$base" "$entry" + if [ -z "$cacheit" ]; then + rm -f "$ofile.elf" + fi +@@ -287,8 +292,6 @@ + overlay_dest="256" + overlay_size="256" + +- rm -f "$object/otheros.bld" +- + ${CROSS}objcopy -O binary "$ofile" "$ofile.bin" + + dd if="$ofile.bin" of="$ofile.bin" conv=notrunc \ +@@ -299,6 +302,8 @@ + skip=$system_reset_overlay seek=$overlay_dest \ + count=$overlay_size bs=1 + +- gzip --force -9 --stdout "$ofile.bin" > "$object/otheros.bld" ++ odir="$(dirname "$ofile.bin")" ++ rm -f "$odir/otheros.bld" ++ gzip --force -9 --stdout "$ofile.bin" > "$odir/otheros.bld" + ;; + esac +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/adder875-redboot_defconfig powerpc.git/arch/powerpc/configs/adder875-redboot_defconfig +--- linux-2.6.24/arch/powerpc/configs/adder875-redboot_defconfig 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/adder875-redboot_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,798 @@ ++# ++# Automatically generated make config: don't edit ++# Linux kernel version: 2.6.24-rc6 ++# Thu Jan 17 16:17:38 2008 ++# ++# CONFIG_PPC64 is not set ++ ++# ++# Processor support ++# ++# CONFIG_6xx is not set ++# CONFIG_PPC_85xx is not set ++CONFIG_PPC_8xx=y ++# CONFIG_40x is not set ++# CONFIG_44x is not set ++# CONFIG_E200 is not set ++CONFIG_8xx=y ++# CONFIG_PPC_MM_SLICES is not set ++CONFIG_NOT_COHERENT_CACHE=y ++CONFIG_PPC32=y ++CONFIG_WORD_SIZE=32 ++CONFIG_PPC_MERGE=y ++CONFIG_MMU=y ++CONFIG_GENERIC_CMOS_UPDATE=y ++CONFIG_GENERIC_TIME=y ++CONFIG_GENERIC_TIME_VSYSCALL=y ++CONFIG_GENERIC_CLOCKEVENTS=y ++CONFIG_GENERIC_HARDIRQS=y ++CONFIG_IRQ_PER_CPU=y ++CONFIG_RWSEM_XCHGADD_ALGORITHM=y ++CONFIG_ARCH_HAS_ILOG2_U32=y ++CONFIG_GENERIC_HWEIGHT=y ++CONFIG_GENERIC_CALIBRATE_DELAY=y ++CONFIG_GENERIC_FIND_NEXT_BIT=y ++# CONFIG_ARCH_NO_VIRT_TO_BUS is not set ++CONFIG_PPC=y ++CONFIG_EARLY_PRINTK=y ++CONFIG_GENERIC_NVRAM=y ++CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y ++CONFIG_ARCH_MAY_HAVE_PC_FDC=y ++CONFIG_PPC_OF=y ++CONFIG_OF=y ++# CONFIG_PPC_UDBG_16550 is not set ++# CONFIG_GENERIC_TBSYNC is not set ++CONFIG_AUDIT_ARCH=y ++CONFIG_GENERIC_BUG=y ++# CONFIG_DEFAULT_UIMAGE is not set ++CONFIG_REDBOOT=y ++# CONFIG_PPC_DCR_NATIVE is not set ++# CONFIG_PPC_DCR_MMIO is not set ++CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" ++ ++# ++# General setup ++# ++CONFIG_EXPERIMENTAL=y ++CONFIG_BROKEN_ON_SMP=y ++CONFIG_INIT_ENV_ARG_LIMIT=32 ++CONFIG_LOCALVERSION="" ++CONFIG_LOCALVERSION_AUTO=y ++# CONFIG_SWAP is not set ++CONFIG_SYSVIPC=y ++CONFIG_SYSVIPC_SYSCTL=y ++# CONFIG_POSIX_MQUEUE is not set ++# CONFIG_BSD_PROCESS_ACCT is not set ++# CONFIG_TASKSTATS is not set ++# CONFIG_USER_NS is not set ++# CONFIG_PID_NS is not set ++# CONFIG_AUDIT is not set ++# CONFIG_IKCONFIG is not set ++CONFIG_LOG_BUF_SHIFT=14 ++# CONFIG_CGROUPS is not set ++CONFIG_FAIR_GROUP_SCHED=y ++CONFIG_FAIR_USER_SCHED=y ++# CONFIG_FAIR_CGROUP_SCHED is not set ++CONFIG_SYSFS_DEPRECATED=y ++# CONFIG_RELAY is not set ++# CONFIG_BLK_DEV_INITRD is not set ++# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set ++CONFIG_SYSCTL=y ++CONFIG_EMBEDDED=y ++# CONFIG_SYSCTL_SYSCALL is not set ++CONFIG_KALLSYMS=y ++# CONFIG_KALLSYMS_ALL is not set ++# CONFIG_KALLSYMS_EXTRA_PASS is not set ++CONFIG_HOTPLUG=y ++CONFIG_PRINTK=y ++CONFIG_BUG=y ++# CONFIG_ELF_CORE is not set ++# CONFIG_BASE_FULL is not set ++# CONFIG_FUTEX is not set ++CONFIG_ANON_INODES=y ++CONFIG_EPOLL=y ++CONFIG_SIGNALFD=y ++CONFIG_EVENTFD=y ++CONFIG_SHMEM=y ++# CONFIG_VM_EVENT_COUNTERS is not set ++CONFIG_SLUB_DEBUG=y ++# CONFIG_SLAB is not set ++CONFIG_SLUB=y ++# CONFIG_SLOB is not set ++# CONFIG_TINY_SHMEM is not set ++CONFIG_BASE_SMALL=1 ++# CONFIG_MODULES is not set ++CONFIG_BLOCK=y ++# CONFIG_LBD is not set ++# CONFIG_BLK_DEV_IO_TRACE is not set ++# CONFIG_LSF is not set ++# CONFIG_BLK_DEV_BSG is not set ++ ++# ++# IO Schedulers ++# ++CONFIG_IOSCHED_NOOP=y ++# CONFIG_IOSCHED_AS is not set ++CONFIG_IOSCHED_DEADLINE=y ++# CONFIG_IOSCHED_CFQ is not set ++# CONFIG_DEFAULT_AS is not set ++CONFIG_DEFAULT_DEADLINE=y ++# CONFIG_DEFAULT_CFQ is not set ++# CONFIG_DEFAULT_NOOP is not set ++CONFIG_DEFAULT_IOSCHED="deadline" ++ ++# ++# Platform support ++# ++# CONFIG_PPC_MPC52xx is not set ++# CONFIG_PPC_MPC5200 is not set ++# CONFIG_PPC_CELL is not set ++# CONFIG_PPC_CELL_NATIVE is not set ++CONFIG_CPM1=y ++# CONFIG_MPC8XXFADS is not set ++# CONFIG_MPC86XADS is not set ++# CONFIG_MPC885ADS is not set ++# CONFIG_PPC_EP88XC is not set ++CONFIG_PPC_ADDER875=y ++ ++# ++# MPC8xx CPM Options ++# ++ ++# ++# Generic MPC8xx Options ++# ++CONFIG_8xx_COPYBACK=y ++# CONFIG_8xx_CPU6 is not set ++CONFIG_8xx_CPU15=y ++CONFIG_NO_UCODE_PATCH=y ++# CONFIG_USB_SOF_UCODE_PATCH is not set ++# CONFIG_I2C_SPI_UCODE_PATCH is not set ++# CONFIG_I2C_SPI_SMC1_UCODE_PATCH is not set ++# CONFIG_PQ2ADS is not set ++# CONFIG_MPIC is not set ++# CONFIG_MPIC_WEIRD is not set ++# CONFIG_PPC_I8259 is not set ++# CONFIG_PPC_RTAS is not set ++# CONFIG_MMIO_NVRAM is not set ++# CONFIG_PPC_MPC106 is not set ++# CONFIG_PPC_970_NAP is not set ++# CONFIG_PPC_INDIRECT_IO is not set ++# CONFIG_GENERIC_IOMAP is not set ++# CONFIG_CPU_FREQ is not set ++# CONFIG_CPM2 is not set ++CONFIG_PPC_CPM_NEW_BINDING=y ++# CONFIG_FSL_ULI1575 is not set ++CONFIG_CPM=y ++ ++# ++# Kernel options ++# ++# CONFIG_HIGHMEM is not set ++# CONFIG_TICK_ONESHOT is not set ++# CONFIG_NO_HZ is not set ++# CONFIG_HIGH_RES_TIMERS is not set ++CONFIG_GENERIC_CLOCKEVENTS_BUILD=y ++# CONFIG_HZ_100 is not set ++# CONFIG_HZ_250 is not set ++# CONFIG_HZ_300 is not set ++CONFIG_HZ_1000=y ++CONFIG_HZ=1000 ++CONFIG_PREEMPT_NONE=y ++# CONFIG_PREEMPT_VOLUNTARY is not set ++# CONFIG_PREEMPT is not set ++CONFIG_BINFMT_ELF=y ++# CONFIG_BINFMT_MISC is not set ++# CONFIG_MATH_EMULATION is not set ++# CONFIG_8XX_MINIMAL_FPEMU is not set ++CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y ++CONFIG_ARCH_FLATMEM_ENABLE=y ++CONFIG_ARCH_POPULATES_NODE_MAP=y ++CONFIG_SELECT_MEMORY_MODEL=y ++CONFIG_FLATMEM_MANUAL=y ++# CONFIG_DISCONTIGMEM_MANUAL is not set ++# CONFIG_SPARSEMEM_MANUAL is not set ++CONFIG_FLATMEM=y ++CONFIG_FLAT_NODE_MEM_MAP=y ++# CONFIG_SPARSEMEM_STATIC is not set ++# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set ++CONFIG_SPLIT_PTLOCK_CPUS=4 ++# CONFIG_RESOURCES_64BIT is not set ++CONFIG_ZONE_DMA_FLAG=1 ++CONFIG_BOUNCE=y ++CONFIG_VIRT_TO_BUS=y ++# CONFIG_PROC_DEVICETREE is not set ++# CONFIG_CMDLINE_BOOL is not set ++# CONFIG_PM is not set ++CONFIG_SUSPEND_UP_POSSIBLE=y ++CONFIG_HIBERNATION_UP_POSSIBLE=y ++# CONFIG_SECCOMP is not set ++CONFIG_WANT_DEVICE_TREE=y ++CONFIG_DEVICE_TREE="adder875-redboot.dts" ++CONFIG_ISA_DMA_API=y ++ ++# ++# Bus options ++# ++CONFIG_ZONE_DMA=y ++CONFIG_FSL_SOC=y ++# CONFIG_PCI is not set ++# CONFIG_PCI_DOMAINS is not set ++# CONFIG_PCI_SYSCALL is not set ++# CONFIG_PCI_QSPAN is not set ++# CONFIG_ARCH_SUPPORTS_MSI is not set ++# CONFIG_PCCARD is not set ++ ++# ++# Advanced setup ++# ++# CONFIG_ADVANCED_OPTIONS is not set ++ ++# ++# Default settings for advanced configuration options are used ++# ++CONFIG_HIGHMEM_START=0xfe000000 ++CONFIG_LOWMEM_SIZE=0x30000000 ++CONFIG_KERNEL_START=0xc0000000 ++CONFIG_TASK_SIZE=0x80000000 ++CONFIG_CONSISTENT_START=0xfd000000 ++CONFIG_CONSISTENT_SIZE=0x00200000 ++CONFIG_BOOT_LOAD=0x00400000 ++ ++# ++# Networking ++# ++CONFIG_NET=y ++ ++# ++# Networking options ++# ++CONFIG_PACKET=y ++# CONFIG_PACKET_MMAP is not set ++CONFIG_UNIX=y ++# CONFIG_NET_KEY is not set ++CONFIG_INET=y ++CONFIG_IP_MULTICAST=y ++# CONFIG_IP_ADVANCED_ROUTER is not set ++CONFIG_IP_FIB_HASH=y ++CONFIG_IP_PNP=y ++# CONFIG_IP_PNP_DHCP is not set ++# CONFIG_IP_PNP_BOOTP is not set ++# CONFIG_IP_PNP_RARP is not set ++# CONFIG_NET_IPIP is not set ++# CONFIG_NET_IPGRE is not set ++# CONFIG_IP_MROUTE is not set ++# CONFIG_ARPD is not set ++CONFIG_SYN_COOKIES=y ++# CONFIG_INET_AH is not set ++# CONFIG_INET_ESP is not set ++# CONFIG_INET_IPCOMP is not set ++# CONFIG_INET_XFRM_TUNNEL is not set ++# CONFIG_INET_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_TRANSPORT is not set ++# CONFIG_INET_XFRM_MODE_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_BEET is not set ++# CONFIG_INET_LRO is not set ++CONFIG_INET_DIAG=y ++CONFIG_INET_TCP_DIAG=y ++# CONFIG_TCP_CONG_ADVANCED is not set ++CONFIG_TCP_CONG_CUBIC=y ++CONFIG_DEFAULT_TCP_CONG="cubic" ++# CONFIG_TCP_MD5SIG is not set ++# CONFIG_IPV6 is not set ++# CONFIG_INET6_XFRM_TUNNEL is not set ++# CONFIG_INET6_TUNNEL is not set ++# CONFIG_NETWORK_SECMARK is not set ++# CONFIG_NETFILTER is not set ++# CONFIG_IP_DCCP is not set ++# CONFIG_IP_SCTP is not set ++# CONFIG_TIPC is not set ++# CONFIG_ATM is not set ++# CONFIG_BRIDGE is not set ++# CONFIG_VLAN_8021Q is not set ++# CONFIG_DECNET is not set ++# CONFIG_LLC2 is not set ++# CONFIG_IPX is not set ++# CONFIG_ATALK is not set ++# CONFIG_X25 is not set ++# CONFIG_LAPB is not set ++# CONFIG_ECONET is not set ++# CONFIG_WAN_ROUTER is not set ++# CONFIG_NET_SCHED is not set ++ ++# ++# Network testing ++# ++# CONFIG_NET_PKTGEN is not set ++# CONFIG_HAMRADIO is not set ++# CONFIG_IRDA is not set ++# CONFIG_BT is not set ++# CONFIG_AF_RXRPC is not set ++ ++# ++# Wireless ++# ++# CONFIG_CFG80211 is not set ++# CONFIG_WIRELESS_EXT is not set ++# CONFIG_MAC80211 is not set ++# CONFIG_IEEE80211 is not set ++# CONFIG_RFKILL is not set ++# CONFIG_NET_9P is not set ++ ++# ++# Device Drivers ++# ++ ++# ++# Generic Driver Options ++# ++CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" ++CONFIG_STANDALONE=y ++CONFIG_PREVENT_FIRMWARE_BUILD=y ++# CONFIG_FW_LOADER is not set ++# CONFIG_DEBUG_DRIVER is not set ++# CONFIG_DEBUG_DEVRES is not set ++# CONFIG_SYS_HYPERVISOR is not set ++# CONFIG_CONNECTOR is not set ++CONFIG_MTD=y ++# CONFIG_MTD_DEBUG is not set ++# CONFIG_MTD_CONCAT is not set ++# CONFIG_MTD_PARTITIONS is not set ++ ++# ++# User Modules And Translation Layers ++# ++CONFIG_MTD_CHAR=y ++CONFIG_MTD_BLKDEVS=y ++CONFIG_MTD_BLOCK=y ++# CONFIG_FTL is not set ++# CONFIG_NFTL is not set ++# CONFIG_INFTL is not set ++# CONFIG_RFD_FTL is not set ++# CONFIG_SSFDC is not set ++# CONFIG_MTD_OOPS is not set ++ ++# ++# RAM/ROM/Flash chip drivers ++# ++CONFIG_MTD_CFI=y ++# CONFIG_MTD_JEDECPROBE is not set ++CONFIG_MTD_GEN_PROBE=y ++# CONFIG_MTD_CFI_ADV_OPTIONS is not set ++CONFIG_MTD_MAP_BANK_WIDTH_1=y ++CONFIG_MTD_MAP_BANK_WIDTH_2=y ++CONFIG_MTD_MAP_BANK_WIDTH_4=y ++# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set ++CONFIG_MTD_CFI_I1=y ++CONFIG_MTD_CFI_I2=y ++# CONFIG_MTD_CFI_I4 is not set ++# CONFIG_MTD_CFI_I8 is not set ++# CONFIG_MTD_CFI_INTELEXT is not set ++CONFIG_MTD_CFI_AMDSTD=y ++# CONFIG_MTD_CFI_STAA is not set ++CONFIG_MTD_CFI_UTIL=y ++# CONFIG_MTD_RAM is not set ++# CONFIG_MTD_ROM is not set ++# CONFIG_MTD_ABSENT is not set ++ ++# ++# Mapping drivers for chip access ++# ++# CONFIG_MTD_COMPLEX_MAPPINGS is not set ++# CONFIG_MTD_PHYSMAP is not set ++CONFIG_MTD_PHYSMAP_OF=y ++# CONFIG_MTD_CFI_FLAGADM is not set ++# CONFIG_MTD_PLATRAM is not set ++ ++# ++# Self-contained MTD device drivers ++# ++# CONFIG_MTD_SLRAM is not set ++# CONFIG_MTD_PHRAM is not set ++# CONFIG_MTD_MTDRAM is not set ++# CONFIG_MTD_BLOCK2MTD is not set ++ ++# ++# Disk-On-Chip Device Drivers ++# ++# CONFIG_MTD_DOC2000 is not set ++# CONFIG_MTD_DOC2001 is not set ++# CONFIG_MTD_DOC2001PLUS is not set ++# CONFIG_MTD_NAND is not set ++# CONFIG_MTD_ONENAND is not set ++ ++# ++# UBI - Unsorted block images ++# ++# CONFIG_MTD_UBI is not set ++CONFIG_OF_DEVICE=y ++# CONFIG_PARPORT is not set ++# CONFIG_BLK_DEV is not set ++# CONFIG_MISC_DEVICES is not set ++# CONFIG_IDE is not set ++ ++# ++# SCSI device support ++# ++# CONFIG_RAID_ATTRS is not set ++# CONFIG_SCSI is not set ++# CONFIG_SCSI_DMA is not set ++# CONFIG_SCSI_NETLINK is not set ++# CONFIG_ATA is not set ++# CONFIG_MD is not set ++# CONFIG_MACINTOSH_DRIVERS is not set ++CONFIG_NETDEVICES=y ++# CONFIG_NETDEVICES_MULTIQUEUE is not set ++# CONFIG_DUMMY is not set ++# CONFIG_BONDING is not set ++# CONFIG_MACVLAN is not set ++# CONFIG_EQUALIZER is not set ++# CONFIG_TUN is not set ++# CONFIG_VETH is not set ++CONFIG_PHYLIB=y ++ ++# ++# MII PHY device drivers ++# ++# CONFIG_MARVELL_PHY is not set ++CONFIG_DAVICOM_PHY=y ++# CONFIG_QSEMI_PHY is not set ++# CONFIG_LXT_PHY is not set ++# CONFIG_CICADA_PHY is not set ++# CONFIG_VITESSE_PHY is not set ++# CONFIG_SMSC_PHY is not set ++# CONFIG_BROADCOM_PHY is not set ++# CONFIG_ICPLUS_PHY is not set ++# CONFIG_FIXED_PHY is not set ++# CONFIG_MDIO_BITBANG is not set ++CONFIG_NET_ETHERNET=y ++CONFIG_MII=y ++# CONFIG_IBM_NEW_EMAC_ZMII is not set ++# CONFIG_IBM_NEW_EMAC_RGMII is not set ++# CONFIG_IBM_NEW_EMAC_TAH is not set ++# CONFIG_IBM_NEW_EMAC_EMAC4 is not set ++# CONFIG_B44 is not set ++CONFIG_FS_ENET=y ++# CONFIG_FS_ENET_HAS_SCC is not set ++CONFIG_FS_ENET_HAS_FEC=y ++CONFIG_FS_ENET_MDIO_FEC=y ++# CONFIG_NETDEV_1000 is not set ++# CONFIG_NETDEV_10000 is not set ++ ++# ++# Wireless LAN ++# ++# CONFIG_WLAN_PRE80211 is not set ++# CONFIG_WLAN_80211 is not set ++# CONFIG_WAN is not set ++# CONFIG_PPP is not set ++# CONFIG_SLIP is not set ++# CONFIG_SHAPER is not set ++# CONFIG_NETCONSOLE is not set ++# CONFIG_NETPOLL is not set ++# CONFIG_NET_POLL_CONTROLLER is not set ++# CONFIG_ISDN is not set ++# CONFIG_PHONE is not set ++ ++# ++# Input device support ++# ++CONFIG_INPUT=y ++# CONFIG_INPUT_FF_MEMLESS is not set ++# CONFIG_INPUT_POLLDEV is not set ++ ++# ++# Userland interfaces ++# ++CONFIG_INPUT_MOUSEDEV=y ++CONFIG_INPUT_MOUSEDEV_PSAUX=y ++CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 ++CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 ++# CONFIG_INPUT_JOYDEV is not set ++# CONFIG_INPUT_EVDEV is not set ++# CONFIG_INPUT_EVBUG is not set ++ ++# ++# Input Device Drivers ++# ++CONFIG_INPUT_KEYBOARD=y ++CONFIG_KEYBOARD_ATKBD=y ++# CONFIG_KEYBOARD_SUNKBD is not set ++# CONFIG_KEYBOARD_LKKBD is not set ++# CONFIG_KEYBOARD_XTKBD is not set ++# CONFIG_KEYBOARD_NEWTON is not set ++# CONFIG_KEYBOARD_STOWAWAY is not set ++CONFIG_INPUT_MOUSE=y ++CONFIG_MOUSE_PS2=y ++CONFIG_MOUSE_PS2_ALPS=y ++CONFIG_MOUSE_PS2_LOGIPS2PP=y ++CONFIG_MOUSE_PS2_SYNAPTICS=y ++CONFIG_MOUSE_PS2_LIFEBOOK=y ++CONFIG_MOUSE_PS2_TRACKPOINT=y ++# CONFIG_MOUSE_PS2_TOUCHKIT is not set ++# CONFIG_MOUSE_SERIAL is not set ++# CONFIG_MOUSE_VSXXXAA is not set ++# CONFIG_INPUT_JOYSTICK is not set ++# CONFIG_INPUT_TABLET is not set ++# CONFIG_INPUT_TOUCHSCREEN is not set ++# CONFIG_INPUT_MISC is not set ++ ++# ++# Hardware I/O ports ++# ++CONFIG_SERIO=y ++CONFIG_SERIO_I8042=y ++CONFIG_SERIO_SERPORT=y ++CONFIG_SERIO_LIBPS2=y ++# CONFIG_SERIO_RAW is not set ++# CONFIG_GAMEPORT is not set ++ ++# ++# Character devices ++# ++# CONFIG_VT is not set ++# CONFIG_SERIAL_NONSTANDARD is not set ++ ++# ++# Serial drivers ++# ++# CONFIG_SERIAL_8250 is not set ++ ++# ++# Non-8250 serial port support ++# ++# CONFIG_SERIAL_UARTLITE is not set ++CONFIG_SERIAL_CORE=y ++CONFIG_SERIAL_CORE_CONSOLE=y ++CONFIG_SERIAL_CPM=y ++CONFIG_SERIAL_CPM_CONSOLE=y ++# CONFIG_SERIAL_CPM_SCC1 is not set ++# CONFIG_SERIAL_CPM_SCC2 is not set ++# CONFIG_SERIAL_CPM_SCC3 is not set ++# CONFIG_SERIAL_CPM_SCC4 is not set ++CONFIG_SERIAL_CPM_SMC1=y ++CONFIG_SERIAL_CPM_SMC2=y ++CONFIG_UNIX98_PTYS=y ++# CONFIG_LEGACY_PTYS is not set ++# CONFIG_IPMI_HANDLER is not set ++CONFIG_HW_RANDOM=y ++# CONFIG_NVRAM is not set ++CONFIG_GEN_RTC=y ++# CONFIG_GEN_RTC_X is not set ++# CONFIG_R3964 is not set ++# CONFIG_RAW_DRIVER is not set ++# CONFIG_TCG_TPM is not set ++# CONFIG_I2C is not set ++ ++# ++# SPI support ++# ++# CONFIG_SPI is not set ++# CONFIG_SPI_MASTER is not set ++# CONFIG_W1 is not set ++# CONFIG_POWER_SUPPLY is not set ++# CONFIG_HWMON is not set ++# CONFIG_WATCHDOG is not set ++ ++# ++# Sonics Silicon Backplane ++# ++CONFIG_SSB_POSSIBLE=y ++# CONFIG_SSB is not set ++ ++# ++# Multifunction device drivers ++# ++# CONFIG_MFD_SM501 is not set ++ ++# ++# Multimedia devices ++# ++# CONFIG_VIDEO_DEV is not set ++# CONFIG_DVB_CORE is not set ++CONFIG_DAB=y ++ ++# ++# Graphics support ++# ++# CONFIG_VGASTATE is not set ++CONFIG_VIDEO_OUTPUT_CONTROL=y ++# CONFIG_FB is not set ++# CONFIG_BACKLIGHT_LCD_SUPPORT is not set ++ ++# ++# Display device support ++# ++# CONFIG_DISPLAY_SUPPORT is not set ++ ++# ++# Sound ++# ++# CONFIG_SOUND is not set ++# CONFIG_HID_SUPPORT is not set ++# CONFIG_USB_SUPPORT is not set ++# CONFIG_MMC is not set ++# CONFIG_NEW_LEDS is not set ++# CONFIG_EDAC is not set ++# CONFIG_RTC_CLASS is not set ++ ++# ++# Userspace I/O ++# ++# CONFIG_UIO is not set ++ ++# ++# File systems ++# ++# CONFIG_EXT2_FS is not set ++# CONFIG_EXT3_FS is not set ++# CONFIG_EXT4DEV_FS is not set ++# CONFIG_REISERFS_FS is not set ++# CONFIG_JFS_FS is not set ++# CONFIG_FS_POSIX_ACL is not set ++# CONFIG_XFS_FS is not set ++# CONFIG_GFS2_FS is not set ++# CONFIG_OCFS2_FS is not set ++# CONFIG_MINIX_FS is not set ++# CONFIG_ROMFS_FS is not set ++# CONFIG_INOTIFY is not set ++# CONFIG_QUOTA is not set ++# CONFIG_DNOTIFY is not set ++# CONFIG_AUTOFS_FS is not set ++# CONFIG_AUTOFS4_FS is not set ++# CONFIG_FUSE_FS is not set ++ ++# ++# CD-ROM/DVD Filesystems ++# ++# CONFIG_ISO9660_FS is not set ++# CONFIG_UDF_FS is not set ++ ++# ++# DOS/FAT/NT Filesystems ++# ++# CONFIG_MSDOS_FS is not set ++# CONFIG_VFAT_FS is not set ++# CONFIG_NTFS_FS is not set ++ ++# ++# Pseudo filesystems ++# ++CONFIG_PROC_FS=y ++# CONFIG_PROC_KCORE is not set ++CONFIG_PROC_SYSCTL=y ++CONFIG_SYSFS=y ++CONFIG_TMPFS=y ++# CONFIG_TMPFS_POSIX_ACL is not set ++# CONFIG_HUGETLB_PAGE is not set ++# CONFIG_CONFIGFS_FS is not set ++ ++# ++# Miscellaneous filesystems ++# ++# CONFIG_ADFS_FS is not set ++# CONFIG_AFFS_FS is not set ++# CONFIG_HFS_FS is not set ++# CONFIG_HFSPLUS_FS is not set ++# CONFIG_BEFS_FS is not set ++# CONFIG_BFS_FS is not set ++# CONFIG_EFS_FS is not set ++# CONFIG_JFFS2_FS is not set ++CONFIG_CRAMFS=y ++# CONFIG_VXFS_FS is not set ++# CONFIG_HPFS_FS is not set ++# CONFIG_QNX4FS_FS is not set ++# CONFIG_SYSV_FS is not set ++# CONFIG_UFS_FS is not set ++CONFIG_NETWORK_FILESYSTEMS=y ++CONFIG_NFS_FS=y ++CONFIG_NFS_V3=y ++# CONFIG_NFS_V3_ACL is not set ++# CONFIG_NFS_V4 is not set ++# CONFIG_NFS_DIRECTIO is not set ++# CONFIG_NFSD is not set ++CONFIG_ROOT_NFS=y ++CONFIG_LOCKD=y ++CONFIG_LOCKD_V4=y ++CONFIG_NFS_COMMON=y ++CONFIG_SUNRPC=y ++# CONFIG_SUNRPC_BIND34 is not set ++# CONFIG_RPCSEC_GSS_KRB5 is not set ++# CONFIG_RPCSEC_GSS_SPKM3 is not set ++# CONFIG_SMB_FS is not set ++# CONFIG_CIFS is not set ++# CONFIG_NCP_FS is not set ++# CONFIG_CODA_FS is not set ++# CONFIG_AFS_FS is not set ++ ++# ++# Partition Types ++# ++CONFIG_PARTITION_ADVANCED=y ++# CONFIG_ACORN_PARTITION is not set ++# CONFIG_OSF_PARTITION is not set ++# CONFIG_AMIGA_PARTITION is not set ++# CONFIG_ATARI_PARTITION is not set ++# CONFIG_MAC_PARTITION is not set ++CONFIG_MSDOS_PARTITION=y ++# CONFIG_BSD_DISKLABEL is not set ++# CONFIG_MINIX_SUBPARTITION is not set ++# CONFIG_SOLARIS_X86_PARTITION is not set ++# CONFIG_UNIXWARE_DISKLABEL is not set ++# CONFIG_LDM_PARTITION is not set ++# CONFIG_SGI_PARTITION is not set ++# CONFIG_ULTRIX_PARTITION is not set ++# CONFIG_SUN_PARTITION is not set ++# CONFIG_KARMA_PARTITION is not set ++# CONFIG_EFI_PARTITION is not set ++# CONFIG_SYSV68_PARTITION is not set ++# CONFIG_NLS is not set ++# CONFIG_DLM is not set ++# CONFIG_UCC_SLOW is not set ++ ++# ++# Library routines ++# ++# CONFIG_CRC_CCITT is not set ++# CONFIG_CRC16 is not set ++# CONFIG_CRC_ITU_T is not set ++# CONFIG_CRC32 is not set ++# CONFIG_CRC7 is not set ++# CONFIG_LIBCRC32C is not set ++CONFIG_ZLIB_INFLATE=y ++CONFIG_HAS_IOMEM=y ++CONFIG_HAS_IOPORT=y ++CONFIG_HAS_DMA=y ++CONFIG_INSTRUMENTATION=y ++# CONFIG_PROFILING is not set ++# CONFIG_MARKERS is not set ++ ++# ++# Kernel hacking ++# ++# CONFIG_PRINTK_TIME is not set ++CONFIG_ENABLE_WARN_DEPRECATED=y ++CONFIG_ENABLE_MUST_CHECK=y ++CONFIG_MAGIC_SYSRQ=y ++# CONFIG_UNUSED_SYMBOLS is not set ++# CONFIG_DEBUG_FS is not set ++# CONFIG_HEADERS_CHECK is not set ++CONFIG_DEBUG_KERNEL=y ++# CONFIG_DEBUG_SHIRQ is not set ++CONFIG_DETECT_SOFTLOCKUP=y ++CONFIG_SCHED_DEBUG=y ++# CONFIG_SCHEDSTATS is not set ++# CONFIG_TIMER_STATS is not set ++# CONFIG_SLUB_DEBUG_ON is not set ++# CONFIG_DEBUG_SPINLOCK is not set ++# CONFIG_DEBUG_MUTEXES is not set ++# CONFIG_DEBUG_SPINLOCK_SLEEP is not set ++# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set ++# CONFIG_DEBUG_KOBJECT is not set ++CONFIG_DEBUG_BUGVERBOSE=y ++CONFIG_DEBUG_INFO=y ++# CONFIG_DEBUG_VM is not set ++# CONFIG_DEBUG_LIST is not set ++# CONFIG_DEBUG_SG is not set ++CONFIG_FORCED_INLINING=y ++# CONFIG_BOOT_PRINTK_DELAY is not set ++# CONFIG_FAULT_INJECTION is not set ++# CONFIG_SAMPLES is not set ++# CONFIG_DEBUG_STACKOVERFLOW is not set ++# CONFIG_DEBUG_STACK_USAGE is not set ++# CONFIG_DEBUG_PAGEALLOC is not set ++# CONFIG_DEBUGGER is not set ++# CONFIG_BDI_SWITCH is not set ++# CONFIG_PPC_EARLY_DEBUG is not set ++ ++# ++# Security options ++# ++# CONFIG_KEYS is not set ++# CONFIG_SECURITY is not set ++# CONFIG_SECURITY_FILE_CAPABILITIES is not set ++# CONFIG_CRYPTO is not set ++# CONFIG_PPC_CLOCK is not set ++CONFIG_PPC_LIB_RHEAP=y +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/adder875-uboot_defconfig powerpc.git/arch/powerpc/configs/adder875-uboot_defconfig +--- linux-2.6.24/arch/powerpc/configs/adder875-uboot_defconfig 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/adder875-uboot_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,798 @@ ++# ++# Automatically generated make config: don't edit ++# Linux kernel version: 2.6.24-rc6 ++# Thu Jan 17 16:17:18 2008 ++# ++# CONFIG_PPC64 is not set ++ ++# ++# Processor support ++# ++# CONFIG_6xx is not set ++# CONFIG_PPC_85xx is not set ++CONFIG_PPC_8xx=y ++# CONFIG_40x is not set ++# CONFIG_44x is not set ++# CONFIG_E200 is not set ++CONFIG_8xx=y ++# CONFIG_PPC_MM_SLICES is not set ++CONFIG_NOT_COHERENT_CACHE=y ++CONFIG_PPC32=y ++CONFIG_WORD_SIZE=32 ++CONFIG_PPC_MERGE=y ++CONFIG_MMU=y ++CONFIG_GENERIC_CMOS_UPDATE=y ++CONFIG_GENERIC_TIME=y ++CONFIG_GENERIC_TIME_VSYSCALL=y ++CONFIG_GENERIC_CLOCKEVENTS=y ++CONFIG_GENERIC_HARDIRQS=y ++CONFIG_IRQ_PER_CPU=y ++CONFIG_RWSEM_XCHGADD_ALGORITHM=y ++CONFIG_ARCH_HAS_ILOG2_U32=y ++CONFIG_GENERIC_HWEIGHT=y ++CONFIG_GENERIC_CALIBRATE_DELAY=y ++CONFIG_GENERIC_FIND_NEXT_BIT=y ++# CONFIG_ARCH_NO_VIRT_TO_BUS is not set ++CONFIG_PPC=y ++CONFIG_EARLY_PRINTK=y ++CONFIG_GENERIC_NVRAM=y ++CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y ++CONFIG_ARCH_MAY_HAVE_PC_FDC=y ++CONFIG_PPC_OF=y ++CONFIG_OF=y ++# CONFIG_PPC_UDBG_16550 is not set ++# CONFIG_GENERIC_TBSYNC is not set ++CONFIG_AUDIT_ARCH=y ++CONFIG_GENERIC_BUG=y ++# CONFIG_DEFAULT_UIMAGE is not set ++CONFIG_REDBOOT=y ++# CONFIG_PPC_DCR_NATIVE is not set ++# CONFIG_PPC_DCR_MMIO is not set ++CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" ++ ++# ++# General setup ++# ++CONFIG_EXPERIMENTAL=y ++CONFIG_BROKEN_ON_SMP=y ++CONFIG_INIT_ENV_ARG_LIMIT=32 ++CONFIG_LOCALVERSION="" ++CONFIG_LOCALVERSION_AUTO=y ++# CONFIG_SWAP is not set ++CONFIG_SYSVIPC=y ++CONFIG_SYSVIPC_SYSCTL=y ++# CONFIG_POSIX_MQUEUE is not set ++# CONFIG_BSD_PROCESS_ACCT is not set ++# CONFIG_TASKSTATS is not set ++# CONFIG_USER_NS is not set ++# CONFIG_PID_NS is not set ++# CONFIG_AUDIT is not set ++# CONFIG_IKCONFIG is not set ++CONFIG_LOG_BUF_SHIFT=14 ++# CONFIG_CGROUPS is not set ++CONFIG_FAIR_GROUP_SCHED=y ++CONFIG_FAIR_USER_SCHED=y ++# CONFIG_FAIR_CGROUP_SCHED is not set ++CONFIG_SYSFS_DEPRECATED=y ++# CONFIG_RELAY is not set ++# CONFIG_BLK_DEV_INITRD is not set ++# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set ++CONFIG_SYSCTL=y ++CONFIG_EMBEDDED=y ++# CONFIG_SYSCTL_SYSCALL is not set ++CONFIG_KALLSYMS=y ++# CONFIG_KALLSYMS_ALL is not set ++# CONFIG_KALLSYMS_EXTRA_PASS is not set ++CONFIG_HOTPLUG=y ++CONFIG_PRINTK=y ++CONFIG_BUG=y ++# CONFIG_ELF_CORE is not set ++# CONFIG_BASE_FULL is not set ++# CONFIG_FUTEX is not set ++CONFIG_ANON_INODES=y ++CONFIG_EPOLL=y ++CONFIG_SIGNALFD=y ++CONFIG_EVENTFD=y ++CONFIG_SHMEM=y ++# CONFIG_VM_EVENT_COUNTERS is not set ++CONFIG_SLUB_DEBUG=y ++# CONFIG_SLAB is not set ++CONFIG_SLUB=y ++# CONFIG_SLOB is not set ++# CONFIG_TINY_SHMEM is not set ++CONFIG_BASE_SMALL=1 ++# CONFIG_MODULES is not set ++CONFIG_BLOCK=y ++# CONFIG_LBD is not set ++# CONFIG_BLK_DEV_IO_TRACE is not set ++# CONFIG_LSF is not set ++# CONFIG_BLK_DEV_BSG is not set ++ ++# ++# IO Schedulers ++# ++CONFIG_IOSCHED_NOOP=y ++# CONFIG_IOSCHED_AS is not set ++CONFIG_IOSCHED_DEADLINE=y ++# CONFIG_IOSCHED_CFQ is not set ++# CONFIG_DEFAULT_AS is not set ++CONFIG_DEFAULT_DEADLINE=y ++# CONFIG_DEFAULT_CFQ is not set ++# CONFIG_DEFAULT_NOOP is not set ++CONFIG_DEFAULT_IOSCHED="deadline" ++ ++# ++# Platform support ++# ++# CONFIG_PPC_MPC52xx is not set ++# CONFIG_PPC_MPC5200 is not set ++# CONFIG_PPC_CELL is not set ++# CONFIG_PPC_CELL_NATIVE is not set ++CONFIG_CPM1=y ++# CONFIG_MPC8XXFADS is not set ++# CONFIG_MPC86XADS is not set ++# CONFIG_MPC885ADS is not set ++# CONFIG_PPC_EP88XC is not set ++CONFIG_PPC_ADDER875=y ++ ++# ++# MPC8xx CPM Options ++# ++ ++# ++# Generic MPC8xx Options ++# ++CONFIG_8xx_COPYBACK=y ++# CONFIG_8xx_CPU6 is not set ++CONFIG_8xx_CPU15=y ++CONFIG_NO_UCODE_PATCH=y ++# CONFIG_USB_SOF_UCODE_PATCH is not set ++# CONFIG_I2C_SPI_UCODE_PATCH is not set ++# CONFIG_I2C_SPI_SMC1_UCODE_PATCH is not set ++# CONFIG_PQ2ADS is not set ++# CONFIG_MPIC is not set ++# CONFIG_MPIC_WEIRD is not set ++# CONFIG_PPC_I8259 is not set ++# CONFIG_PPC_RTAS is not set ++# CONFIG_MMIO_NVRAM is not set ++# CONFIG_PPC_MPC106 is not set ++# CONFIG_PPC_970_NAP is not set ++# CONFIG_PPC_INDIRECT_IO is not set ++# CONFIG_GENERIC_IOMAP is not set ++# CONFIG_CPU_FREQ is not set ++# CONFIG_CPM2 is not set ++CONFIG_PPC_CPM_NEW_BINDING=y ++# CONFIG_FSL_ULI1575 is not set ++CONFIG_CPM=y ++ ++# ++# Kernel options ++# ++# CONFIG_HIGHMEM is not set ++# CONFIG_TICK_ONESHOT is not set ++# CONFIG_NO_HZ is not set ++# CONFIG_HIGH_RES_TIMERS is not set ++CONFIG_GENERIC_CLOCKEVENTS_BUILD=y ++# CONFIG_HZ_100 is not set ++# CONFIG_HZ_250 is not set ++# CONFIG_HZ_300 is not set ++CONFIG_HZ_1000=y ++CONFIG_HZ=1000 ++CONFIG_PREEMPT_NONE=y ++# CONFIG_PREEMPT_VOLUNTARY is not set ++# CONFIG_PREEMPT is not set ++CONFIG_BINFMT_ELF=y ++# CONFIG_BINFMT_MISC is not set ++# CONFIG_MATH_EMULATION is not set ++# CONFIG_8XX_MINIMAL_FPEMU is not set ++CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y ++CONFIG_ARCH_FLATMEM_ENABLE=y ++CONFIG_ARCH_POPULATES_NODE_MAP=y ++CONFIG_SELECT_MEMORY_MODEL=y ++CONFIG_FLATMEM_MANUAL=y ++# CONFIG_DISCONTIGMEM_MANUAL is not set ++# CONFIG_SPARSEMEM_MANUAL is not set ++CONFIG_FLATMEM=y ++CONFIG_FLAT_NODE_MEM_MAP=y ++# CONFIG_SPARSEMEM_STATIC is not set ++# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set ++CONFIG_SPLIT_PTLOCK_CPUS=4 ++# CONFIG_RESOURCES_64BIT is not set ++CONFIG_ZONE_DMA_FLAG=1 ++CONFIG_BOUNCE=y ++CONFIG_VIRT_TO_BUS=y ++# CONFIG_PROC_DEVICETREE is not set ++# CONFIG_CMDLINE_BOOL is not set ++# CONFIG_PM is not set ++CONFIG_SUSPEND_UP_POSSIBLE=y ++CONFIG_HIBERNATION_UP_POSSIBLE=y ++# CONFIG_SECCOMP is not set ++CONFIG_WANT_DEVICE_TREE=y ++CONFIG_DEVICE_TREE="adder875-uboot.dts" ++CONFIG_ISA_DMA_API=y ++ ++# ++# Bus options ++# ++CONFIG_ZONE_DMA=y ++CONFIG_FSL_SOC=y ++# CONFIG_PCI is not set ++# CONFIG_PCI_DOMAINS is not set ++# CONFIG_PCI_SYSCALL is not set ++# CONFIG_PCI_QSPAN is not set ++# CONFIG_ARCH_SUPPORTS_MSI is not set ++# CONFIG_PCCARD is not set ++ ++# ++# Advanced setup ++# ++# CONFIG_ADVANCED_OPTIONS is not set ++ ++# ++# Default settings for advanced configuration options are used ++# ++CONFIG_HIGHMEM_START=0xfe000000 ++CONFIG_LOWMEM_SIZE=0x30000000 ++CONFIG_KERNEL_START=0xc0000000 ++CONFIG_TASK_SIZE=0x80000000 ++CONFIG_CONSISTENT_START=0xfd000000 ++CONFIG_CONSISTENT_SIZE=0x00200000 ++CONFIG_BOOT_LOAD=0x00400000 ++ ++# ++# Networking ++# ++CONFIG_NET=y ++ ++# ++# Networking options ++# ++CONFIG_PACKET=y ++# CONFIG_PACKET_MMAP is not set ++CONFIG_UNIX=y ++# CONFIG_NET_KEY is not set ++CONFIG_INET=y ++CONFIG_IP_MULTICAST=y ++# CONFIG_IP_ADVANCED_ROUTER is not set ++CONFIG_IP_FIB_HASH=y ++CONFIG_IP_PNP=y ++# CONFIG_IP_PNP_DHCP is not set ++# CONFIG_IP_PNP_BOOTP is not set ++# CONFIG_IP_PNP_RARP is not set ++# CONFIG_NET_IPIP is not set ++# CONFIG_NET_IPGRE is not set ++# CONFIG_IP_MROUTE is not set ++# CONFIG_ARPD is not set ++CONFIG_SYN_COOKIES=y ++# CONFIG_INET_AH is not set ++# CONFIG_INET_ESP is not set ++# CONFIG_INET_IPCOMP is not set ++# CONFIG_INET_XFRM_TUNNEL is not set ++# CONFIG_INET_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_TRANSPORT is not set ++# CONFIG_INET_XFRM_MODE_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_BEET is not set ++# CONFIG_INET_LRO is not set ++CONFIG_INET_DIAG=y ++CONFIG_INET_TCP_DIAG=y ++# CONFIG_TCP_CONG_ADVANCED is not set ++CONFIG_TCP_CONG_CUBIC=y ++CONFIG_DEFAULT_TCP_CONG="cubic" ++# CONFIG_TCP_MD5SIG is not set ++# CONFIG_IPV6 is not set ++# CONFIG_INET6_XFRM_TUNNEL is not set ++# CONFIG_INET6_TUNNEL is not set ++# CONFIG_NETWORK_SECMARK is not set ++# CONFIG_NETFILTER is not set ++# CONFIG_IP_DCCP is not set ++# CONFIG_IP_SCTP is not set ++# CONFIG_TIPC is not set ++# CONFIG_ATM is not set ++# CONFIG_BRIDGE is not set ++# CONFIG_VLAN_8021Q is not set ++# CONFIG_DECNET is not set ++# CONFIG_LLC2 is not set ++# CONFIG_IPX is not set ++# CONFIG_ATALK is not set ++# CONFIG_X25 is not set ++# CONFIG_LAPB is not set ++# CONFIG_ECONET is not set ++# CONFIG_WAN_ROUTER is not set ++# CONFIG_NET_SCHED is not set ++ ++# ++# Network testing ++# ++# CONFIG_NET_PKTGEN is not set ++# CONFIG_HAMRADIO is not set ++# CONFIG_IRDA is not set ++# CONFIG_BT is not set ++# CONFIG_AF_RXRPC is not set ++ ++# ++# Wireless ++# ++# CONFIG_CFG80211 is not set ++# CONFIG_WIRELESS_EXT is not set ++# CONFIG_MAC80211 is not set ++# CONFIG_IEEE80211 is not set ++# CONFIG_RFKILL is not set ++# CONFIG_NET_9P is not set ++ ++# ++# Device Drivers ++# ++ ++# ++# Generic Driver Options ++# ++CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" ++CONFIG_STANDALONE=y ++CONFIG_PREVENT_FIRMWARE_BUILD=y ++# CONFIG_FW_LOADER is not set ++# CONFIG_DEBUG_DRIVER is not set ++# CONFIG_DEBUG_DEVRES is not set ++# CONFIG_SYS_HYPERVISOR is not set ++# CONFIG_CONNECTOR is not set ++CONFIG_MTD=y ++# CONFIG_MTD_DEBUG is not set ++# CONFIG_MTD_CONCAT is not set ++# CONFIG_MTD_PARTITIONS is not set ++ ++# ++# User Modules And Translation Layers ++# ++CONFIG_MTD_CHAR=y ++CONFIG_MTD_BLKDEVS=y ++CONFIG_MTD_BLOCK=y ++# CONFIG_FTL is not set ++# CONFIG_NFTL is not set ++# CONFIG_INFTL is not set ++# CONFIG_RFD_FTL is not set ++# CONFIG_SSFDC is not set ++# CONFIG_MTD_OOPS is not set ++ ++# ++# RAM/ROM/Flash chip drivers ++# ++CONFIG_MTD_CFI=y ++# CONFIG_MTD_JEDECPROBE is not set ++CONFIG_MTD_GEN_PROBE=y ++# CONFIG_MTD_CFI_ADV_OPTIONS is not set ++CONFIG_MTD_MAP_BANK_WIDTH_1=y ++CONFIG_MTD_MAP_BANK_WIDTH_2=y ++CONFIG_MTD_MAP_BANK_WIDTH_4=y ++# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set ++CONFIG_MTD_CFI_I1=y ++CONFIG_MTD_CFI_I2=y ++# CONFIG_MTD_CFI_I4 is not set ++# CONFIG_MTD_CFI_I8 is not set ++# CONFIG_MTD_CFI_INTELEXT is not set ++CONFIG_MTD_CFI_AMDSTD=y ++# CONFIG_MTD_CFI_STAA is not set ++CONFIG_MTD_CFI_UTIL=y ++# CONFIG_MTD_RAM is not set ++# CONFIG_MTD_ROM is not set ++# CONFIG_MTD_ABSENT is not set ++ ++# ++# Mapping drivers for chip access ++# ++# CONFIG_MTD_COMPLEX_MAPPINGS is not set ++# CONFIG_MTD_PHYSMAP is not set ++CONFIG_MTD_PHYSMAP_OF=y ++# CONFIG_MTD_CFI_FLAGADM is not set ++# CONFIG_MTD_PLATRAM is not set ++ ++# ++# Self-contained MTD device drivers ++# ++# CONFIG_MTD_SLRAM is not set ++# CONFIG_MTD_PHRAM is not set ++# CONFIG_MTD_MTDRAM is not set ++# CONFIG_MTD_BLOCK2MTD is not set ++ ++# ++# Disk-On-Chip Device Drivers ++# ++# CONFIG_MTD_DOC2000 is not set ++# CONFIG_MTD_DOC2001 is not set ++# CONFIG_MTD_DOC2001PLUS is not set ++# CONFIG_MTD_NAND is not set ++# CONFIG_MTD_ONENAND is not set ++ ++# ++# UBI - Unsorted block images ++# ++# CONFIG_MTD_UBI is not set ++CONFIG_OF_DEVICE=y ++# CONFIG_PARPORT is not set ++# CONFIG_BLK_DEV is not set ++# CONFIG_MISC_DEVICES is not set ++# CONFIG_IDE is not set ++ ++# ++# SCSI device support ++# ++# CONFIG_RAID_ATTRS is not set ++# CONFIG_SCSI is not set ++# CONFIG_SCSI_DMA is not set ++# CONFIG_SCSI_NETLINK is not set ++# CONFIG_ATA is not set ++# CONFIG_MD is not set ++# CONFIG_MACINTOSH_DRIVERS is not set ++CONFIG_NETDEVICES=y ++# CONFIG_NETDEVICES_MULTIQUEUE is not set ++# CONFIG_DUMMY is not set ++# CONFIG_BONDING is not set ++# CONFIG_MACVLAN is not set ++# CONFIG_EQUALIZER is not set ++# CONFIG_TUN is not set ++# CONFIG_VETH is not set ++CONFIG_PHYLIB=y ++ ++# ++# MII PHY device drivers ++# ++# CONFIG_MARVELL_PHY is not set ++CONFIG_DAVICOM_PHY=y ++# CONFIG_QSEMI_PHY is not set ++# CONFIG_LXT_PHY is not set ++# CONFIG_CICADA_PHY is not set ++# CONFIG_VITESSE_PHY is not set ++# CONFIG_SMSC_PHY is not set ++# CONFIG_BROADCOM_PHY is not set ++# CONFIG_ICPLUS_PHY is not set ++# CONFIG_FIXED_PHY is not set ++# CONFIG_MDIO_BITBANG is not set ++CONFIG_NET_ETHERNET=y ++CONFIG_MII=y ++# CONFIG_IBM_NEW_EMAC_ZMII is not set ++# CONFIG_IBM_NEW_EMAC_RGMII is not set ++# CONFIG_IBM_NEW_EMAC_TAH is not set ++# CONFIG_IBM_NEW_EMAC_EMAC4 is not set ++# CONFIG_B44 is not set ++CONFIG_FS_ENET=y ++# CONFIG_FS_ENET_HAS_SCC is not set ++CONFIG_FS_ENET_HAS_FEC=y ++CONFIG_FS_ENET_MDIO_FEC=y ++# CONFIG_NETDEV_1000 is not set ++# CONFIG_NETDEV_10000 is not set ++ ++# ++# Wireless LAN ++# ++# CONFIG_WLAN_PRE80211 is not set ++# CONFIG_WLAN_80211 is not set ++# CONFIG_WAN is not set ++# CONFIG_PPP is not set ++# CONFIG_SLIP is not set ++# CONFIG_SHAPER is not set ++# CONFIG_NETCONSOLE is not set ++# CONFIG_NETPOLL is not set ++# CONFIG_NET_POLL_CONTROLLER is not set ++# CONFIG_ISDN is not set ++# CONFIG_PHONE is not set ++ ++# ++# Input device support ++# ++CONFIG_INPUT=y ++# CONFIG_INPUT_FF_MEMLESS is not set ++# CONFIG_INPUT_POLLDEV is not set ++ ++# ++# Userland interfaces ++# ++CONFIG_INPUT_MOUSEDEV=y ++CONFIG_INPUT_MOUSEDEV_PSAUX=y ++CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 ++CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 ++# CONFIG_INPUT_JOYDEV is not set ++# CONFIG_INPUT_EVDEV is not set ++# CONFIG_INPUT_EVBUG is not set ++ ++# ++# Input Device Drivers ++# ++CONFIG_INPUT_KEYBOARD=y ++CONFIG_KEYBOARD_ATKBD=y ++# CONFIG_KEYBOARD_SUNKBD is not set ++# CONFIG_KEYBOARD_LKKBD is not set ++# CONFIG_KEYBOARD_XTKBD is not set ++# CONFIG_KEYBOARD_NEWTON is not set ++# CONFIG_KEYBOARD_STOWAWAY is not set ++CONFIG_INPUT_MOUSE=y ++CONFIG_MOUSE_PS2=y ++CONFIG_MOUSE_PS2_ALPS=y ++CONFIG_MOUSE_PS2_LOGIPS2PP=y ++CONFIG_MOUSE_PS2_SYNAPTICS=y ++CONFIG_MOUSE_PS2_LIFEBOOK=y ++CONFIG_MOUSE_PS2_TRACKPOINT=y ++# CONFIG_MOUSE_PS2_TOUCHKIT is not set ++# CONFIG_MOUSE_SERIAL is not set ++# CONFIG_MOUSE_VSXXXAA is not set ++# CONFIG_INPUT_JOYSTICK is not set ++# CONFIG_INPUT_TABLET is not set ++# CONFIG_INPUT_TOUCHSCREEN is not set ++# CONFIG_INPUT_MISC is not set ++ ++# ++# Hardware I/O ports ++# ++CONFIG_SERIO=y ++CONFIG_SERIO_I8042=y ++CONFIG_SERIO_SERPORT=y ++CONFIG_SERIO_LIBPS2=y ++# CONFIG_SERIO_RAW is not set ++# CONFIG_GAMEPORT is not set ++ ++# ++# Character devices ++# ++# CONFIG_VT is not set ++# CONFIG_SERIAL_NONSTANDARD is not set ++ ++# ++# Serial drivers ++# ++# CONFIG_SERIAL_8250 is not set ++ ++# ++# Non-8250 serial port support ++# ++# CONFIG_SERIAL_UARTLITE is not set ++CONFIG_SERIAL_CORE=y ++CONFIG_SERIAL_CORE_CONSOLE=y ++CONFIG_SERIAL_CPM=y ++CONFIG_SERIAL_CPM_CONSOLE=y ++# CONFIG_SERIAL_CPM_SCC1 is not set ++# CONFIG_SERIAL_CPM_SCC2 is not set ++# CONFIG_SERIAL_CPM_SCC3 is not set ++# CONFIG_SERIAL_CPM_SCC4 is not set ++CONFIG_SERIAL_CPM_SMC1=y ++CONFIG_SERIAL_CPM_SMC2=y ++CONFIG_UNIX98_PTYS=y ++# CONFIG_LEGACY_PTYS is not set ++# CONFIG_IPMI_HANDLER is not set ++CONFIG_HW_RANDOM=y ++# CONFIG_NVRAM is not set ++CONFIG_GEN_RTC=y ++# CONFIG_GEN_RTC_X is not set ++# CONFIG_R3964 is not set ++# CONFIG_RAW_DRIVER is not set ++# CONFIG_TCG_TPM is not set ++# CONFIG_I2C is not set ++ ++# ++# SPI support ++# ++# CONFIG_SPI is not set ++# CONFIG_SPI_MASTER is not set ++# CONFIG_W1 is not set ++# CONFIG_POWER_SUPPLY is not set ++# CONFIG_HWMON is not set ++# CONFIG_WATCHDOG is not set ++ ++# ++# Sonics Silicon Backplane ++# ++CONFIG_SSB_POSSIBLE=y ++# CONFIG_SSB is not set ++ ++# ++# Multifunction device drivers ++# ++# CONFIG_MFD_SM501 is not set ++ ++# ++# Multimedia devices ++# ++# CONFIG_VIDEO_DEV is not set ++# CONFIG_DVB_CORE is not set ++CONFIG_DAB=y ++ ++# ++# Graphics support ++# ++# CONFIG_VGASTATE is not set ++CONFIG_VIDEO_OUTPUT_CONTROL=y ++# CONFIG_FB is not set ++# CONFIG_BACKLIGHT_LCD_SUPPORT is not set ++ ++# ++# Display device support ++# ++# CONFIG_DISPLAY_SUPPORT is not set ++ ++# ++# Sound ++# ++# CONFIG_SOUND is not set ++# CONFIG_HID_SUPPORT is not set ++# CONFIG_USB_SUPPORT is not set ++# CONFIG_MMC is not set ++# CONFIG_NEW_LEDS is not set ++# CONFIG_EDAC is not set ++# CONFIG_RTC_CLASS is not set ++ ++# ++# Userspace I/O ++# ++# CONFIG_UIO is not set ++ ++# ++# File systems ++# ++# CONFIG_EXT2_FS is not set ++# CONFIG_EXT3_FS is not set ++# CONFIG_EXT4DEV_FS is not set ++# CONFIG_REISERFS_FS is not set ++# CONFIG_JFS_FS is not set ++# CONFIG_FS_POSIX_ACL is not set ++# CONFIG_XFS_FS is not set ++# CONFIG_GFS2_FS is not set ++# CONFIG_OCFS2_FS is not set ++# CONFIG_MINIX_FS is not set ++# CONFIG_ROMFS_FS is not set ++# CONFIG_INOTIFY is not set ++# CONFIG_QUOTA is not set ++# CONFIG_DNOTIFY is not set ++# CONFIG_AUTOFS_FS is not set ++# CONFIG_AUTOFS4_FS is not set ++# CONFIG_FUSE_FS is not set ++ ++# ++# CD-ROM/DVD Filesystems ++# ++# CONFIG_ISO9660_FS is not set ++# CONFIG_UDF_FS is not set ++ ++# ++# DOS/FAT/NT Filesystems ++# ++# CONFIG_MSDOS_FS is not set ++# CONFIG_VFAT_FS is not set ++# CONFIG_NTFS_FS is not set ++ ++# ++# Pseudo filesystems ++# ++CONFIG_PROC_FS=y ++# CONFIG_PROC_KCORE is not set ++CONFIG_PROC_SYSCTL=y ++CONFIG_SYSFS=y ++CONFIG_TMPFS=y ++# CONFIG_TMPFS_POSIX_ACL is not set ++# CONFIG_HUGETLB_PAGE is not set ++# CONFIG_CONFIGFS_FS is not set ++ ++# ++# Miscellaneous filesystems ++# ++# CONFIG_ADFS_FS is not set ++# CONFIG_AFFS_FS is not set ++# CONFIG_HFS_FS is not set ++# CONFIG_HFSPLUS_FS is not set ++# CONFIG_BEFS_FS is not set ++# CONFIG_BFS_FS is not set ++# CONFIG_EFS_FS is not set ++# CONFIG_JFFS2_FS is not set ++CONFIG_CRAMFS=y ++# CONFIG_VXFS_FS is not set ++# CONFIG_HPFS_FS is not set ++# CONFIG_QNX4FS_FS is not set ++# CONFIG_SYSV_FS is not set ++# CONFIG_UFS_FS is not set ++CONFIG_NETWORK_FILESYSTEMS=y ++CONFIG_NFS_FS=y ++CONFIG_NFS_V3=y ++# CONFIG_NFS_V3_ACL is not set ++# CONFIG_NFS_V4 is not set ++# CONFIG_NFS_DIRECTIO is not set ++# CONFIG_NFSD is not set ++CONFIG_ROOT_NFS=y ++CONFIG_LOCKD=y ++CONFIG_LOCKD_V4=y ++CONFIG_NFS_COMMON=y ++CONFIG_SUNRPC=y ++# CONFIG_SUNRPC_BIND34 is not set ++# CONFIG_RPCSEC_GSS_KRB5 is not set ++# CONFIG_RPCSEC_GSS_SPKM3 is not set ++# CONFIG_SMB_FS is not set ++# CONFIG_CIFS is not set ++# CONFIG_NCP_FS is not set ++# CONFIG_CODA_FS is not set ++# CONFIG_AFS_FS is not set ++ ++# ++# Partition Types ++# ++CONFIG_PARTITION_ADVANCED=y ++# CONFIG_ACORN_PARTITION is not set ++# CONFIG_OSF_PARTITION is not set ++# CONFIG_AMIGA_PARTITION is not set ++# CONFIG_ATARI_PARTITION is not set ++# CONFIG_MAC_PARTITION is not set ++CONFIG_MSDOS_PARTITION=y ++# CONFIG_BSD_DISKLABEL is not set ++# CONFIG_MINIX_SUBPARTITION is not set ++# CONFIG_SOLARIS_X86_PARTITION is not set ++# CONFIG_UNIXWARE_DISKLABEL is not set ++# CONFIG_LDM_PARTITION is not set ++# CONFIG_SGI_PARTITION is not set ++# CONFIG_ULTRIX_PARTITION is not set ++# CONFIG_SUN_PARTITION is not set ++# CONFIG_KARMA_PARTITION is not set ++# CONFIG_EFI_PARTITION is not set ++# CONFIG_SYSV68_PARTITION is not set ++# CONFIG_NLS is not set ++# CONFIG_DLM is not set ++# CONFIG_UCC_SLOW is not set ++ ++# ++# Library routines ++# ++# CONFIG_CRC_CCITT is not set ++# CONFIG_CRC16 is not set ++# CONFIG_CRC_ITU_T is not set ++# CONFIG_CRC32 is not set ++# CONFIG_CRC7 is not set ++# CONFIG_LIBCRC32C is not set ++CONFIG_ZLIB_INFLATE=y ++CONFIG_HAS_IOMEM=y ++CONFIG_HAS_IOPORT=y ++CONFIG_HAS_DMA=y ++CONFIG_INSTRUMENTATION=y ++# CONFIG_PROFILING is not set ++# CONFIG_MARKERS is not set ++ ++# ++# Kernel hacking ++# ++# CONFIG_PRINTK_TIME is not set ++CONFIG_ENABLE_WARN_DEPRECATED=y ++CONFIG_ENABLE_MUST_CHECK=y ++CONFIG_MAGIC_SYSRQ=y ++# CONFIG_UNUSED_SYMBOLS is not set ++# CONFIG_DEBUG_FS is not set ++# CONFIG_HEADERS_CHECK is not set ++CONFIG_DEBUG_KERNEL=y ++# CONFIG_DEBUG_SHIRQ is not set ++CONFIG_DETECT_SOFTLOCKUP=y ++CONFIG_SCHED_DEBUG=y ++# CONFIG_SCHEDSTATS is not set ++# CONFIG_TIMER_STATS is not set ++# CONFIG_SLUB_DEBUG_ON is not set ++# CONFIG_DEBUG_SPINLOCK is not set ++# CONFIG_DEBUG_MUTEXES is not set ++# CONFIG_DEBUG_SPINLOCK_SLEEP is not set ++# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set ++# CONFIG_DEBUG_KOBJECT is not set ++CONFIG_DEBUG_BUGVERBOSE=y ++CONFIG_DEBUG_INFO=y ++# CONFIG_DEBUG_VM is not set ++# CONFIG_DEBUG_LIST is not set ++# CONFIG_DEBUG_SG is not set ++CONFIG_FORCED_INLINING=y ++# CONFIG_BOOT_PRINTK_DELAY is not set ++# CONFIG_FAULT_INJECTION is not set ++# CONFIG_SAMPLES is not set ++# CONFIG_DEBUG_STACKOVERFLOW is not set ++# CONFIG_DEBUG_STACK_USAGE is not set ++# CONFIG_DEBUG_PAGEALLOC is not set ++# CONFIG_DEBUGGER is not set ++# CONFIG_BDI_SWITCH is not set ++# CONFIG_PPC_EARLY_DEBUG is not set ++ ++# ++# Security options ++# ++# CONFIG_KEYS is not set ++# CONFIG_SECURITY is not set ++# CONFIG_SECURITY_FILE_CAPABILITIES is not set ++# CONFIG_CRYPTO is not set ++# CONFIG_PPC_CLOCK is not set ++CONFIG_PPC_LIB_RHEAP=y +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/bamboo_defconfig powerpc.git/arch/powerpc/configs/bamboo_defconfig +--- linux-2.6.24/arch/powerpc/configs/bamboo_defconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/bamboo_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -1,7 +1,7 @@ + # + # Automatically generated make config: don't edit +-# Linux kernel version: 2.6.24-rc4 +-# Thu Dec 6 16:48:04 2007 ++# Linux kernel version: 2.6.24-rc6 ++# Mon Dec 24 10:49:50 2007 + # + # CONFIG_PPC64 is not set + +@@ -131,6 +131,7 @@ + # CONFIG_DEFAULT_CFQ is not set + # CONFIG_DEFAULT_NOOP is not set + CONFIG_DEFAULT_IOSCHED="anticipatory" ++# CONFIG_PPC4xx_PCI_EXPRESS is not set + + # + # Platform support +@@ -143,6 +144,9 @@ + CONFIG_BAMBOO=y + # CONFIG_EBONY is not set + # CONFIG_SEQUOIA is not set ++# CONFIG_TAISHAN is not set ++# CONFIG_KATMAI is not set ++# CONFIG_RAINIER is not set + CONFIG_440EP=y + CONFIG_IBM440EP_ERR42=y + # CONFIG_MPIC is not set +@@ -372,9 +376,7 @@ + # CONFIG_FIREWIRE is not set + # CONFIG_IEEE1394 is not set + # CONFIG_I2O is not set +-CONFIG_MACINTOSH_DRIVERS=y +-# CONFIG_MAC_EMUMOUSEBTN is not set +-# CONFIG_WINDFARM is not set ++# CONFIG_MACINTOSH_DRIVERS is not set + CONFIG_NETDEVICES=y + # CONFIG_NETDEVICES_MULTIQUEUE is not set + # CONFIG_DUMMY is not set +@@ -736,19 +738,7 @@ + # CONFIG_KGDB is not set + # CONFIG_XMON is not set + # CONFIG_BDI_SWITCH is not set +-CONFIG_PPC_EARLY_DEBUG=y +-# CONFIG_PPC_EARLY_DEBUG_LPAR is not set +-# CONFIG_PPC_EARLY_DEBUG_G5 is not set +-# CONFIG_PPC_EARLY_DEBUG_RTAS_PANEL is not set +-# CONFIG_PPC_EARLY_DEBUG_RTAS_CONSOLE is not set +-# CONFIG_PPC_EARLY_DEBUG_MAPLE is not set +-# CONFIG_PPC_EARLY_DEBUG_ISERIES is not set +-# CONFIG_PPC_EARLY_DEBUG_PAS_REALMODE is not set +-# CONFIG_PPC_EARLY_DEBUG_BEAT is not set +-CONFIG_PPC_EARLY_DEBUG_44x=y +-# CONFIG_PPC_EARLY_DEBUG_CPM is not set +-CONFIG_PPC_EARLY_DEBUG_44x_PHYSLOW=0xef600300 +-CONFIG_PPC_EARLY_DEBUG_44x_PHYSHIGH=0x0 ++# CONFIG_PPC_EARLY_DEBUG is not set + + # + # Security options +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/celleb_defconfig powerpc.git/arch/powerpc/configs/celleb_defconfig +--- linux-2.6.24/arch/powerpc/configs/celleb_defconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/celleb_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -50,7 +50,8 @@ + CONFIG_GENERIC_BUG=y + # CONFIG_DEFAULT_UIMAGE is not set + # CONFIG_PPC_DCR_NATIVE is not set +-# CONFIG_PPC_DCR_MMIO is not set ++CONFIG_PPC_DCR_MMIO=y ++CONFIG_PPC_DCR=y + CONFIG_PPC_OF_PLATFORM_PCI=y + CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" + +@@ -148,7 +149,7 @@ + CONFIG_PPC_CELLEB=y + # CONFIG_PPC_PS3 is not set + CONFIG_PPC_CELL=y +-# CONFIG_PPC_CELL_NATIVE is not set ++CONFIG_PPC_CELL_NATIVE=y + # CONFIG_PPC_IBM_CELL_BLADE is not set + + # +@@ -157,13 +158,19 @@ + CONFIG_SPU_FS=y + CONFIG_SPU_FS_64K_LS=y + CONFIG_SPU_BASE=y ++CONFIG_CBE_RAS=y ++# CONFIG_CBE_THERM is not set + # CONFIG_PQ2ADS is not set ++CONFIG_PPC_NATIVE=y ++CONFIG_UDBG_RTAS_CONSOLE=y + CONFIG_PPC_UDBG_BEAT=y +-# CONFIG_MPIC is not set ++CONFIG_MPIC=y + # CONFIG_MPIC_WEIRD is not set + # CONFIG_PPC_I8259 is not set + # CONFIG_U3_DART is not set +-# CONFIG_PPC_RTAS is not set ++CONFIG_PPC_RTAS=y ++# CONFIG_RTAS_ERROR_LOGGING is not set ++# CONFIG_RTAS_PROC is not set + # CONFIG_MMIO_NVRAM is not set + # CONFIG_PPC_MPC106 is not set + # CONFIG_PPC_970_NAP is not set +@@ -593,10 +600,11 @@ + # CONFIG_NET_VENDOR_3COM is not set + # CONFIG_NET_TULIP is not set + # CONFIG_HP100 is not set +-# CONFIG_IBM_NEW_EMAC_ZMII is not set +-# CONFIG_IBM_NEW_EMAC_RGMII is not set +-# CONFIG_IBM_NEW_EMAC_TAH is not set +-# CONFIG_IBM_NEW_EMAC_EMAC4 is not set ++# CONFIG_IBM_NEW_EMAC is not set ++CONFIG_IBM_NEW_EMAC_ZMII=y ++CONFIG_IBM_NEW_EMAC_RGMII=y ++CONFIG_IBM_NEW_EMAC_TAH=y ++CONFIG_IBM_NEW_EMAC_EMAC4=y + # CONFIG_NET_PCI is not set + # CONFIG_B44 is not set + CONFIG_NETDEV_1000=y +@@ -741,6 +749,7 @@ + CONFIG_UNIX98_PTYS=y + # CONFIG_LEGACY_PTYS is not set + CONFIG_HVC_DRIVER=y ++CONFIG_HVC_RTAS=y + CONFIG_HVC_BEAT=y + # CONFIG_IPMI_HANDLER is not set + # CONFIG_HW_RANDOM is not set +@@ -822,6 +831,7 @@ + # Watchdog Device Drivers + # + # CONFIG_SOFT_WATCHDOG is not set ++# CONFIG_WATCHDOG_RTAS is not set + + # + # PCI-based Watchdog Cards +@@ -1245,17 +1255,7 @@ + CONFIG_IRQSTACKS=y + # CONFIG_VIRQ_DEBUG is not set + # CONFIG_BOOTX_TEXT is not set +-CONFIG_PPC_EARLY_DEBUG=y +-# CONFIG_PPC_EARLY_DEBUG_LPAR is not set +-# CONFIG_PPC_EARLY_DEBUG_G5 is not set +-# CONFIG_PPC_EARLY_DEBUG_RTAS_PANEL is not set +-# CONFIG_PPC_EARLY_DEBUG_RTAS_CONSOLE is not set +-# CONFIG_PPC_EARLY_DEBUG_MAPLE is not set +-# CONFIG_PPC_EARLY_DEBUG_ISERIES is not set +-# CONFIG_PPC_EARLY_DEBUG_PAS_REALMODE is not set +-CONFIG_PPC_EARLY_DEBUG_BEAT=y +-# CONFIG_PPC_EARLY_DEBUG_44x is not set +-# CONFIG_PPC_EARLY_DEBUG_CPM is not set ++# CONFIG_PPC_EARLY_DEBUG is not set + + # + # Security options +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/ebony_defconfig powerpc.git/arch/powerpc/configs/ebony_defconfig +--- linux-2.6.24/arch/powerpc/configs/ebony_defconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/ebony_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -1,7 +1,7 @@ + # + # Automatically generated make config: don't edit +-# Linux kernel version: 2.6.24-rc4 +-# Thu Dec 6 16:48:11 2007 ++# Linux kernel version: 2.6.24-rc6 ++# Mon Dec 24 11:16:26 2007 + # + # CONFIG_PPC64 is not set + +@@ -130,6 +130,7 @@ + # CONFIG_DEFAULT_CFQ is not set + # CONFIG_DEFAULT_NOOP is not set + CONFIG_DEFAULT_IOSCHED="anticipatory" ++# CONFIG_PPC4xx_PCI_EXPRESS is not set + + # + # Platform support +@@ -142,6 +143,9 @@ + # CONFIG_BAMBOO is not set + CONFIG_EBONY=y + # CONFIG_SEQUOIA is not set ++# CONFIG_TAISHAN is not set ++# CONFIG_KATMAI is not set ++# CONFIG_RAINIER is not set + CONFIG_440GP=y + # CONFIG_MPIC is not set + # CONFIG_MPIC_WEIRD is not set +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/ep405_defconfig powerpc.git/arch/powerpc/configs/ep405_defconfig +--- linux-2.6.24/arch/powerpc/configs/ep405_defconfig 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/ep405_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,952 @@ ++# ++# Automatically generated make config: don't edit ++# Linux kernel version: 2.6.24-rc6 ++# Mon Dec 24 11:17:13 2007 ++# ++# CONFIG_PPC64 is not set ++ ++# ++# Processor support ++# ++# CONFIG_6xx is not set ++# CONFIG_PPC_85xx is not set ++# CONFIG_PPC_8xx is not set ++CONFIG_40x=y ++# CONFIG_44x is not set ++# CONFIG_E200 is not set ++CONFIG_4xx=y ++# CONFIG_PPC_MM_SLICES is not set ++CONFIG_NOT_COHERENT_CACHE=y ++CONFIG_PPC32=y ++CONFIG_WORD_SIZE=32 ++CONFIG_PPC_MERGE=y ++CONFIG_MMU=y ++CONFIG_GENERIC_CMOS_UPDATE=y ++CONFIG_GENERIC_TIME=y ++CONFIG_GENERIC_TIME_VSYSCALL=y ++CONFIG_GENERIC_CLOCKEVENTS=y ++CONFIG_GENERIC_HARDIRQS=y ++CONFIG_IRQ_PER_CPU=y ++CONFIG_RWSEM_XCHGADD_ALGORITHM=y ++CONFIG_ARCH_HAS_ILOG2_U32=y ++CONFIG_GENERIC_HWEIGHT=y ++CONFIG_GENERIC_CALIBRATE_DELAY=y ++CONFIG_GENERIC_FIND_NEXT_BIT=y ++# CONFIG_ARCH_NO_VIRT_TO_BUS is not set ++CONFIG_PPC=y ++CONFIG_EARLY_PRINTK=y ++CONFIG_GENERIC_NVRAM=y ++CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y ++CONFIG_ARCH_MAY_HAVE_PC_FDC=y ++CONFIG_PPC_OF=y ++CONFIG_OF=y ++CONFIG_PPC_UDBG_16550=y ++# CONFIG_GENERIC_TBSYNC is not set ++CONFIG_AUDIT_ARCH=y ++CONFIG_GENERIC_BUG=y ++# CONFIG_DEFAULT_UIMAGE is not set ++CONFIG_PPC_DCR_NATIVE=y ++# CONFIG_PPC_DCR_MMIO is not set ++CONFIG_PPC_DCR=y ++CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" ++ ++# ++# General setup ++# ++CONFIG_EXPERIMENTAL=y ++CONFIG_BROKEN_ON_SMP=y ++CONFIG_INIT_ENV_ARG_LIMIT=32 ++CONFIG_LOCALVERSION="" ++CONFIG_LOCALVERSION_AUTO=y ++CONFIG_SWAP=y ++CONFIG_SYSVIPC=y ++CONFIG_SYSVIPC_SYSCTL=y ++CONFIG_POSIX_MQUEUE=y ++# CONFIG_BSD_PROCESS_ACCT is not set ++# CONFIG_TASKSTATS is not set ++# CONFIG_USER_NS is not set ++# CONFIG_PID_NS is not set ++# CONFIG_AUDIT is not set ++# CONFIG_IKCONFIG is not set ++CONFIG_LOG_BUF_SHIFT=14 ++# CONFIG_CGROUPS is not set ++CONFIG_FAIR_GROUP_SCHED=y ++CONFIG_FAIR_USER_SCHED=y ++# CONFIG_FAIR_CGROUP_SCHED is not set ++CONFIG_SYSFS_DEPRECATED=y ++# CONFIG_RELAY is not set ++CONFIG_BLK_DEV_INITRD=y ++CONFIG_INITRAMFS_SOURCE="" ++# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set ++CONFIG_SYSCTL=y ++CONFIG_EMBEDDED=y ++CONFIG_SYSCTL_SYSCALL=y ++CONFIG_KALLSYMS=y ++CONFIG_KALLSYMS_ALL=y ++CONFIG_KALLSYMS_EXTRA_PASS=y ++CONFIG_HOTPLUG=y ++CONFIG_PRINTK=y ++CONFIG_BUG=y ++CONFIG_ELF_CORE=y ++CONFIG_BASE_FULL=y ++CONFIG_FUTEX=y ++CONFIG_ANON_INODES=y ++CONFIG_EPOLL=y ++CONFIG_SIGNALFD=y ++CONFIG_EVENTFD=y ++CONFIG_SHMEM=y ++CONFIG_VM_EVENT_COUNTERS=y ++CONFIG_SLUB_DEBUG=y ++# CONFIG_SLAB is not set ++CONFIG_SLUB=y ++# CONFIG_SLOB is not set ++CONFIG_RT_MUTEXES=y ++# CONFIG_TINY_SHMEM is not set ++CONFIG_BASE_SMALL=0 ++CONFIG_MODULES=y ++CONFIG_MODULE_UNLOAD=y ++# CONFIG_MODULE_FORCE_UNLOAD is not set ++# CONFIG_MODVERSIONS is not set ++# CONFIG_MODULE_SRCVERSION_ALL is not set ++CONFIG_KMOD=y ++CONFIG_BLOCK=y ++CONFIG_LBD=y ++# CONFIG_BLK_DEV_IO_TRACE is not set ++# CONFIG_LSF is not set ++# CONFIG_BLK_DEV_BSG is not set ++ ++# ++# IO Schedulers ++# ++CONFIG_IOSCHED_NOOP=y ++CONFIG_IOSCHED_AS=y ++CONFIG_IOSCHED_DEADLINE=y ++CONFIG_IOSCHED_CFQ=y ++CONFIG_DEFAULT_AS=y ++# CONFIG_DEFAULT_DEADLINE is not set ++# CONFIG_DEFAULT_CFQ is not set ++# CONFIG_DEFAULT_NOOP is not set ++CONFIG_DEFAULT_IOSCHED="anticipatory" ++# CONFIG_PPC4xx_PCI_EXPRESS is not set ++ ++# ++# Platform support ++# ++# CONFIG_PPC_MPC52xx is not set ++# CONFIG_PPC_MPC5200 is not set ++# CONFIG_PPC_CELL is not set ++# CONFIG_PPC_CELL_NATIVE is not set ++# CONFIG_PQ2ADS is not set ++CONFIG_EP405=y ++# CONFIG_KILAUEA is not set ++# CONFIG_MAKALU is not set ++# CONFIG_WALNUT is not set ++# CONFIG_XILINX_VIRTEX_GENERIC_BOARD is not set ++CONFIG_405GP=y ++CONFIG_IBM405_ERR77=y ++CONFIG_IBM405_ERR51=y ++# CONFIG_MPIC is not set ++# CONFIG_MPIC_WEIRD is not set ++# CONFIG_PPC_I8259 is not set ++# CONFIG_PPC_RTAS is not set ++# CONFIG_MMIO_NVRAM is not set ++# CONFIG_PPC_MPC106 is not set ++# CONFIG_PPC_970_NAP is not set ++# CONFIG_PPC_INDIRECT_IO is not set ++# CONFIG_GENERIC_IOMAP is not set ++# CONFIG_CPU_FREQ is not set ++# CONFIG_CPM2 is not set ++# CONFIG_FSL_ULI1575 is not set ++ ++# ++# Kernel options ++# ++# CONFIG_HIGHMEM is not set ++# CONFIG_TICK_ONESHOT is not set ++# CONFIG_NO_HZ is not set ++# CONFIG_HIGH_RES_TIMERS is not set ++CONFIG_GENERIC_CLOCKEVENTS_BUILD=y ++# CONFIG_HZ_100 is not set ++CONFIG_HZ_250=y ++# CONFIG_HZ_300 is not set ++# CONFIG_HZ_1000 is not set ++CONFIG_HZ=250 ++CONFIG_PREEMPT_NONE=y ++# CONFIG_PREEMPT_VOLUNTARY is not set ++# CONFIG_PREEMPT is not set ++CONFIG_BINFMT_ELF=y ++# CONFIG_BINFMT_MISC is not set ++# CONFIG_MATH_EMULATION is not set ++CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y ++CONFIG_ARCH_FLATMEM_ENABLE=y ++CONFIG_ARCH_POPULATES_NODE_MAP=y ++CONFIG_SELECT_MEMORY_MODEL=y ++CONFIG_FLATMEM_MANUAL=y ++# CONFIG_DISCONTIGMEM_MANUAL is not set ++# CONFIG_SPARSEMEM_MANUAL is not set ++CONFIG_FLATMEM=y ++CONFIG_FLAT_NODE_MEM_MAP=y ++# CONFIG_SPARSEMEM_STATIC is not set ++# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set ++CONFIG_SPLIT_PTLOCK_CPUS=4 ++# CONFIG_RESOURCES_64BIT is not set ++CONFIG_ZONE_DMA_FLAG=1 ++CONFIG_BOUNCE=y ++CONFIG_VIRT_TO_BUS=y ++CONFIG_PROC_DEVICETREE=y ++# CONFIG_CMDLINE_BOOL is not set ++# CONFIG_PM is not set ++CONFIG_SUSPEND_UP_POSSIBLE=y ++CONFIG_HIBERNATION_UP_POSSIBLE=y ++CONFIG_SECCOMP=y ++CONFIG_WANT_DEVICE_TREE=y ++CONFIG_DEVICE_TREE="ep405.dts" ++CONFIG_ISA_DMA_API=y ++ ++# ++# Bus options ++# ++CONFIG_ZONE_DMA=y ++CONFIG_PPC_INDIRECT_PCI=y ++CONFIG_PCI=y ++CONFIG_PCI_DOMAINS=y ++CONFIG_PCI_SYSCALL=y ++# CONFIG_PCIEPORTBUS is not set ++CONFIG_ARCH_SUPPORTS_MSI=y ++# CONFIG_PCI_MSI is not set ++CONFIG_PCI_LEGACY=y ++# CONFIG_PCI_DEBUG is not set ++# CONFIG_PCCARD is not set ++# CONFIG_HOTPLUG_PCI is not set ++ ++# ++# Advanced setup ++# ++# CONFIG_ADVANCED_OPTIONS is not set ++ ++# ++# Default settings for advanced configuration options are used ++# ++CONFIG_HIGHMEM_START=0xfe000000 ++CONFIG_LOWMEM_SIZE=0x30000000 ++CONFIG_KERNEL_START=0xc0000000 ++CONFIG_TASK_SIZE=0xc0000000 ++CONFIG_CONSISTENT_START=0xff100000 ++CONFIG_CONSISTENT_SIZE=0x00200000 ++CONFIG_BOOT_LOAD=0x00400000 ++ ++# ++# Networking ++# ++CONFIG_NET=y ++ ++# ++# Networking options ++# ++CONFIG_PACKET=y ++# CONFIG_PACKET_MMAP is not set ++CONFIG_UNIX=y ++# CONFIG_NET_KEY is not set ++CONFIG_INET=y ++# CONFIG_IP_MULTICAST is not set ++# CONFIG_IP_ADVANCED_ROUTER is not set ++CONFIG_IP_FIB_HASH=y ++CONFIG_IP_PNP=y ++CONFIG_IP_PNP_DHCP=y ++CONFIG_IP_PNP_BOOTP=y ++# CONFIG_IP_PNP_RARP is not set ++# CONFIG_NET_IPIP is not set ++# CONFIG_NET_IPGRE is not set ++# CONFIG_ARPD is not set ++# CONFIG_SYN_COOKIES is not set ++# CONFIG_INET_AH is not set ++# CONFIG_INET_ESP is not set ++# CONFIG_INET_IPCOMP is not set ++# CONFIG_INET_XFRM_TUNNEL is not set ++# CONFIG_INET_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_TRANSPORT is not set ++# CONFIG_INET_XFRM_MODE_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_BEET is not set ++# CONFIG_INET_LRO is not set ++CONFIG_INET_DIAG=y ++CONFIG_INET_TCP_DIAG=y ++# CONFIG_TCP_CONG_ADVANCED is not set ++CONFIG_TCP_CONG_CUBIC=y ++CONFIG_DEFAULT_TCP_CONG="cubic" ++# CONFIG_TCP_MD5SIG is not set ++# CONFIG_IPV6 is not set ++# CONFIG_INET6_XFRM_TUNNEL is not set ++# CONFIG_INET6_TUNNEL is not set ++# CONFIG_NETWORK_SECMARK is not set ++# CONFIG_NETFILTER is not set ++# CONFIG_IP_DCCP is not set ++# CONFIG_IP_SCTP is not set ++# CONFIG_TIPC is not set ++# CONFIG_ATM is not set ++# CONFIG_BRIDGE is not set ++# CONFIG_VLAN_8021Q is not set ++# CONFIG_DECNET is not set ++# CONFIG_LLC2 is not set ++# CONFIG_IPX is not set ++# CONFIG_ATALK is not set ++# CONFIG_X25 is not set ++# CONFIG_LAPB is not set ++# CONFIG_ECONET is not set ++# CONFIG_WAN_ROUTER is not set ++# CONFIG_NET_SCHED is not set ++ ++# ++# Network testing ++# ++# CONFIG_NET_PKTGEN is not set ++# CONFIG_HAMRADIO is not set ++# CONFIG_IRDA is not set ++# CONFIG_BT is not set ++# CONFIG_AF_RXRPC is not set ++ ++# ++# Wireless ++# ++# CONFIG_CFG80211 is not set ++# CONFIG_WIRELESS_EXT is not set ++# CONFIG_MAC80211 is not set ++# CONFIG_IEEE80211 is not set ++# CONFIG_RFKILL is not set ++# CONFIG_NET_9P is not set ++ ++# ++# Device Drivers ++# ++ ++# ++# Generic Driver Options ++# ++CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" ++CONFIG_STANDALONE=y ++CONFIG_PREVENT_FIRMWARE_BUILD=y ++CONFIG_FW_LOADER=y ++# CONFIG_DEBUG_DRIVER is not set ++# CONFIG_DEBUG_DEVRES is not set ++# CONFIG_SYS_HYPERVISOR is not set ++CONFIG_CONNECTOR=y ++CONFIG_PROC_EVENTS=y ++CONFIG_MTD=y ++# CONFIG_MTD_DEBUG is not set ++# CONFIG_MTD_CONCAT is not set ++CONFIG_MTD_PARTITIONS=y ++# CONFIG_MTD_REDBOOT_PARTS is not set ++CONFIG_MTD_CMDLINE_PARTS=y ++ ++# ++# User Modules And Translation Layers ++# ++CONFIG_MTD_CHAR=y ++CONFIG_MTD_BLKDEVS=m ++CONFIG_MTD_BLOCK=m ++# CONFIG_MTD_BLOCK_RO is not set ++# CONFIG_FTL is not set ++# CONFIG_NFTL is not set ++# CONFIG_INFTL is not set ++# CONFIG_RFD_FTL is not set ++# CONFIG_SSFDC is not set ++# CONFIG_MTD_OOPS is not set ++ ++# ++# RAM/ROM/Flash chip drivers ++# ++CONFIG_MTD_CFI=y ++CONFIG_MTD_JEDECPROBE=y ++CONFIG_MTD_GEN_PROBE=y ++# CONFIG_MTD_CFI_ADV_OPTIONS is not set ++CONFIG_MTD_MAP_BANK_WIDTH_1=y ++CONFIG_MTD_MAP_BANK_WIDTH_2=y ++CONFIG_MTD_MAP_BANK_WIDTH_4=y ++# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set ++CONFIG_MTD_CFI_I1=y ++CONFIG_MTD_CFI_I2=y ++# CONFIG_MTD_CFI_I4 is not set ++# CONFIG_MTD_CFI_I8 is not set ++# CONFIG_MTD_CFI_INTELEXT is not set ++CONFIG_MTD_CFI_AMDSTD=y ++# CONFIG_MTD_CFI_STAA is not set ++CONFIG_MTD_CFI_UTIL=y ++# CONFIG_MTD_RAM is not set ++# CONFIG_MTD_ROM is not set ++# CONFIG_MTD_ABSENT is not set ++ ++# ++# Mapping drivers for chip access ++# ++# CONFIG_MTD_COMPLEX_MAPPINGS is not set ++# CONFIG_MTD_PHYSMAP is not set ++CONFIG_MTD_PHYSMAP_OF=y ++# CONFIG_MTD_INTEL_VR_NOR is not set ++# CONFIG_MTD_PLATRAM is not set ++ ++# ++# Self-contained MTD device drivers ++# ++# CONFIG_MTD_PMC551 is not set ++# CONFIG_MTD_SLRAM is not set ++# CONFIG_MTD_PHRAM is not set ++# CONFIG_MTD_MTDRAM is not set ++# CONFIG_MTD_BLOCK2MTD is not set ++ ++# ++# Disk-On-Chip Device Drivers ++# ++# CONFIG_MTD_DOC2000 is not set ++# CONFIG_MTD_DOC2001 is not set ++# CONFIG_MTD_DOC2001PLUS is not set ++# CONFIG_MTD_NAND is not set ++# CONFIG_MTD_ONENAND is not set ++ ++# ++# UBI - Unsorted block images ++# ++# CONFIG_MTD_UBI is not set ++CONFIG_OF_DEVICE=y ++# CONFIG_PARPORT is not set ++CONFIG_BLK_DEV=y ++# CONFIG_BLK_DEV_FD is not set ++# CONFIG_BLK_CPQ_DA is not set ++# CONFIG_BLK_CPQ_CISS_DA is not set ++# CONFIG_BLK_DEV_DAC960 is not set ++# CONFIG_BLK_DEV_UMEM is not set ++# CONFIG_BLK_DEV_COW_COMMON is not set ++# CONFIG_BLK_DEV_LOOP is not set ++# CONFIG_BLK_DEV_NBD is not set ++# CONFIG_BLK_DEV_SX8 is not set ++# CONFIG_BLK_DEV_UB is not set ++CONFIG_BLK_DEV_RAM=y ++CONFIG_BLK_DEV_RAM_COUNT=16 ++CONFIG_BLK_DEV_RAM_SIZE=35000 ++CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024 ++# CONFIG_CDROM_PKTCDVD is not set ++# CONFIG_ATA_OVER_ETH is not set ++# CONFIG_XILINX_SYSACE is not set ++CONFIG_MISC_DEVICES=y ++# CONFIG_PHANTOM is not set ++# CONFIG_EEPROM_93CX6 is not set ++# CONFIG_SGI_IOC4 is not set ++# CONFIG_TIFM_CORE is not set ++# CONFIG_IDE is not set ++ ++# ++# SCSI device support ++# ++# CONFIG_RAID_ATTRS is not set ++# CONFIG_SCSI is not set ++# CONFIG_SCSI_DMA is not set ++# CONFIG_SCSI_NETLINK is not set ++# CONFIG_ATA is not set ++# CONFIG_MD is not set ++# CONFIG_FUSION is not set ++ ++# ++# IEEE 1394 (FireWire) support ++# ++# CONFIG_FIREWIRE is not set ++# CONFIG_IEEE1394 is not set ++# CONFIG_I2O is not set ++# CONFIG_MACINTOSH_DRIVERS is not set ++CONFIG_NETDEVICES=y ++# CONFIG_NETDEVICES_MULTIQUEUE is not set ++# CONFIG_DUMMY is not set ++# CONFIG_BONDING is not set ++# CONFIG_MACVLAN is not set ++# CONFIG_EQUALIZER is not set ++# CONFIG_TUN is not set ++# CONFIG_VETH is not set ++# CONFIG_IP1000 is not set ++# CONFIG_ARCNET is not set ++# CONFIG_PHYLIB is not set ++CONFIG_NET_ETHERNET=y ++# CONFIG_MII is not set ++# CONFIG_HAPPYMEAL is not set ++# CONFIG_SUNGEM is not set ++# CONFIG_CASSINI is not set ++# CONFIG_NET_VENDOR_3COM is not set ++# CONFIG_NET_TULIP is not set ++# CONFIG_HP100 is not set ++CONFIG_IBM_NEW_EMAC=y ++CONFIG_IBM_NEW_EMAC_RXB=128 ++CONFIG_IBM_NEW_EMAC_TXB=64 ++CONFIG_IBM_NEW_EMAC_POLL_WEIGHT=32 ++CONFIG_IBM_NEW_EMAC_RX_COPY_THRESHOLD=256 ++CONFIG_IBM_NEW_EMAC_RX_SKB_HEADROOM=0 ++# CONFIG_IBM_NEW_EMAC_DEBUG is not set ++CONFIG_IBM_NEW_EMAC_ZMII=y ++# CONFIG_IBM_NEW_EMAC_RGMII is not set ++# CONFIG_IBM_NEW_EMAC_TAH is not set ++# CONFIG_IBM_NEW_EMAC_EMAC4 is not set ++# CONFIG_NET_PCI is not set ++# CONFIG_B44 is not set ++CONFIG_NETDEV_1000=y ++# CONFIG_ACENIC is not set ++# CONFIG_DL2K is not set ++# CONFIG_E1000 is not set ++# CONFIG_E1000E is not set ++# CONFIG_NS83820 is not set ++# CONFIG_HAMACHI is not set ++# CONFIG_YELLOWFIN is not set ++# CONFIG_R8169 is not set ++# CONFIG_SIS190 is not set ++# CONFIG_SKGE is not set ++# CONFIG_SKY2 is not set ++# CONFIG_SK98LIN is not set ++# CONFIG_VIA_VELOCITY is not set ++# CONFIG_TIGON3 is not set ++# CONFIG_BNX2 is not set ++# CONFIG_QLA3XXX is not set ++# CONFIG_ATL1 is not set ++CONFIG_NETDEV_10000=y ++# CONFIG_CHELSIO_T1 is not set ++# CONFIG_CHELSIO_T3 is not set ++# CONFIG_IXGBE is not set ++# CONFIG_IXGB is not set ++# CONFIG_S2IO is not set ++# CONFIG_MYRI10GE is not set ++# CONFIG_NETXEN_NIC is not set ++# CONFIG_NIU is not set ++# CONFIG_MLX4_CORE is not set ++# CONFIG_TEHUTI is not set ++# CONFIG_TR is not set ++ ++# ++# Wireless LAN ++# ++# CONFIG_WLAN_PRE80211 is not set ++# CONFIG_WLAN_80211 is not set ++ ++# ++# USB Network Adapters ++# ++# CONFIG_USB_CATC is not set ++# CONFIG_USB_KAWETH is not set ++# CONFIG_USB_PEGASUS is not set ++# CONFIG_USB_RTL8150 is not set ++# CONFIG_USB_USBNET is not set ++# CONFIG_WAN is not set ++# CONFIG_FDDI is not set ++# CONFIG_HIPPI is not set ++# CONFIG_PPP is not set ++# CONFIG_SLIP is not set ++# CONFIG_SHAPER is not set ++# CONFIG_NETCONSOLE is not set ++# CONFIG_NETPOLL is not set ++# CONFIG_NET_POLL_CONTROLLER is not set ++# CONFIG_ISDN is not set ++# CONFIG_PHONE is not set ++ ++# ++# Input device support ++# ++# CONFIG_INPUT is not set ++ ++# ++# Hardware I/O ports ++# ++# CONFIG_SERIO is not set ++# CONFIG_GAMEPORT is not set ++ ++# ++# Character devices ++# ++# CONFIG_VT is not set ++# CONFIG_SERIAL_NONSTANDARD is not set ++ ++# ++# Serial drivers ++# ++CONFIG_SERIAL_8250=y ++CONFIG_SERIAL_8250_CONSOLE=y ++CONFIG_SERIAL_8250_PCI=y ++CONFIG_SERIAL_8250_NR_UARTS=4 ++CONFIG_SERIAL_8250_RUNTIME_UARTS=4 ++CONFIG_SERIAL_8250_EXTENDED=y ++# CONFIG_SERIAL_8250_MANY_PORTS is not set ++CONFIG_SERIAL_8250_SHARE_IRQ=y ++# CONFIG_SERIAL_8250_DETECT_IRQ is not set ++# CONFIG_SERIAL_8250_RSA is not set ++ ++# ++# Non-8250 serial port support ++# ++# CONFIG_SERIAL_UARTLITE is not set ++CONFIG_SERIAL_CORE=y ++CONFIG_SERIAL_CORE_CONSOLE=y ++# CONFIG_SERIAL_JSM is not set ++CONFIG_SERIAL_OF_PLATFORM=y ++CONFIG_UNIX98_PTYS=y ++CONFIG_LEGACY_PTYS=y ++CONFIG_LEGACY_PTY_COUNT=256 ++# CONFIG_IPMI_HANDLER is not set ++# CONFIG_HW_RANDOM is not set ++# CONFIG_NVRAM is not set ++# CONFIG_GEN_RTC is not set ++# CONFIG_R3964 is not set ++# CONFIG_APPLICOM is not set ++# CONFIG_RAW_DRIVER is not set ++# CONFIG_TCG_TPM is not set ++CONFIG_DEVPORT=y ++# CONFIG_I2C is not set ++ ++# ++# SPI support ++# ++# CONFIG_SPI is not set ++# CONFIG_SPI_MASTER is not set ++# CONFIG_W1 is not set ++# CONFIG_POWER_SUPPLY is not set ++# CONFIG_HWMON is not set ++# CONFIG_WATCHDOG is not set ++ ++# ++# Sonics Silicon Backplane ++# ++CONFIG_SSB_POSSIBLE=y ++# CONFIG_SSB is not set ++ ++# ++# Multifunction device drivers ++# ++# CONFIG_MFD_SM501 is not set ++ ++# ++# Multimedia devices ++# ++# CONFIG_VIDEO_DEV is not set ++# CONFIG_DVB_CORE is not set ++# CONFIG_DAB is not set ++ ++# ++# Graphics support ++# ++# CONFIG_AGP is not set ++# CONFIG_DRM is not set ++# CONFIG_VGASTATE is not set ++CONFIG_VIDEO_OUTPUT_CONTROL=m ++# CONFIG_FB is not set ++# CONFIG_BACKLIGHT_LCD_SUPPORT is not set ++ ++# ++# Display device support ++# ++# CONFIG_DISPLAY_SUPPORT is not set ++ ++# ++# Sound ++# ++# CONFIG_SOUND is not set ++CONFIG_USB_SUPPORT=y ++CONFIG_USB_ARCH_HAS_HCD=y ++CONFIG_USB_ARCH_HAS_OHCI=y ++CONFIG_USB_ARCH_HAS_EHCI=y ++CONFIG_USB=y ++# CONFIG_USB_DEBUG is not set ++ ++# ++# Miscellaneous USB options ++# ++CONFIG_USB_DEVICEFS=y ++CONFIG_USB_DEVICE_CLASS=y ++# CONFIG_USB_DYNAMIC_MINORS is not set ++# CONFIG_USB_OTG is not set ++ ++# ++# USB Host Controller Drivers ++# ++# CONFIG_USB_EHCI_HCD is not set ++# CONFIG_USB_ISP116X_HCD is not set ++CONFIG_USB_OHCI_HCD=y ++CONFIG_USB_OHCI_HCD_PPC_OF=y ++CONFIG_USB_OHCI_HCD_PPC_OF_BE=y ++CONFIG_USB_OHCI_HCD_PPC_OF_LE=y ++CONFIG_USB_OHCI_HCD_PCI=y ++CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y ++CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y ++CONFIG_USB_OHCI_LITTLE_ENDIAN=y ++# CONFIG_USB_UHCI_HCD is not set ++# CONFIG_USB_SL811_HCD is not set ++# CONFIG_USB_R8A66597_HCD is not set ++ ++# ++# USB Device Class drivers ++# ++# CONFIG_USB_ACM is not set ++# CONFIG_USB_PRINTER is not set ++ ++# ++# NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' ++# ++ ++# ++# may also be needed; see USB_STORAGE Help for more information ++# ++# CONFIG_USB_LIBUSUAL is not set ++ ++# ++# USB Imaging devices ++# ++# CONFIG_USB_MDC800 is not set ++CONFIG_USB_MON=y ++ ++# ++# USB port drivers ++# ++ ++# ++# USB Serial Converter support ++# ++# CONFIG_USB_SERIAL is not set ++ ++# ++# USB Miscellaneous drivers ++# ++# CONFIG_USB_EMI62 is not set ++# CONFIG_USB_EMI26 is not set ++# CONFIG_USB_ADUTUX is not set ++# CONFIG_USB_AUERSWALD is not set ++# CONFIG_USB_RIO500 is not set ++# CONFIG_USB_LEGOTOWER is not set ++# CONFIG_USB_LCD is not set ++# CONFIG_USB_BERRY_CHARGE is not set ++# CONFIG_USB_LED is not set ++# CONFIG_USB_CYPRESS_CY7C63 is not set ++# CONFIG_USB_CYTHERM is not set ++# CONFIG_USB_PHIDGET is not set ++# CONFIG_USB_IDMOUSE is not set ++# CONFIG_USB_FTDI_ELAN is not set ++# CONFIG_USB_APPLEDISPLAY is not set ++# CONFIG_USB_LD is not set ++# CONFIG_USB_TRANCEVIBRATOR is not set ++# CONFIG_USB_IOWARRIOR is not set ++# CONFIG_USB_TEST is not set ++ ++# ++# USB DSL modem support ++# ++ ++# ++# USB Gadget Support ++# ++# CONFIG_USB_GADGET is not set ++# CONFIG_MMC is not set ++# CONFIG_NEW_LEDS is not set ++# CONFIG_INFINIBAND is not set ++# CONFIG_EDAC is not set ++# CONFIG_RTC_CLASS is not set ++ ++# ++# Userspace I/O ++# ++# CONFIG_UIO is not set ++ ++# ++# File systems ++# ++CONFIG_EXT2_FS=y ++# CONFIG_EXT2_FS_XATTR is not set ++# CONFIG_EXT2_FS_XIP is not set ++# CONFIG_EXT3_FS is not set ++# CONFIG_EXT4DEV_FS is not set ++# CONFIG_REISERFS_FS is not set ++# CONFIG_JFS_FS is not set ++# CONFIG_FS_POSIX_ACL is not set ++# CONFIG_XFS_FS is not set ++# CONFIG_GFS2_FS is not set ++# CONFIG_OCFS2_FS is not set ++# CONFIG_MINIX_FS is not set ++# CONFIG_ROMFS_FS is not set ++CONFIG_INOTIFY=y ++CONFIG_INOTIFY_USER=y ++# CONFIG_QUOTA is not set ++CONFIG_DNOTIFY=y ++# CONFIG_AUTOFS_FS is not set ++# CONFIG_AUTOFS4_FS is not set ++# CONFIG_FUSE_FS is not set ++ ++# ++# CD-ROM/DVD Filesystems ++# ++# CONFIG_ISO9660_FS is not set ++# CONFIG_UDF_FS is not set ++ ++# ++# DOS/FAT/NT Filesystems ++# ++# CONFIG_MSDOS_FS is not set ++# CONFIG_VFAT_FS is not set ++# CONFIG_NTFS_FS is not set ++ ++# ++# Pseudo filesystems ++# ++CONFIG_PROC_FS=y ++CONFIG_PROC_KCORE=y ++CONFIG_PROC_SYSCTL=y ++CONFIG_SYSFS=y ++CONFIG_TMPFS=y ++# CONFIG_TMPFS_POSIX_ACL is not set ++# CONFIG_HUGETLB_PAGE is not set ++# CONFIG_CONFIGFS_FS is not set ++ ++# ++# Miscellaneous filesystems ++# ++# CONFIG_ADFS_FS is not set ++# CONFIG_AFFS_FS is not set ++# CONFIG_HFS_FS is not set ++# CONFIG_HFSPLUS_FS is not set ++# CONFIG_BEFS_FS is not set ++# CONFIG_BFS_FS is not set ++# CONFIG_EFS_FS is not set ++# CONFIG_JFFS2_FS is not set ++CONFIG_CRAMFS=y ++# CONFIG_VXFS_FS is not set ++# CONFIG_HPFS_FS is not set ++# CONFIG_QNX4FS_FS is not set ++# CONFIG_SYSV_FS is not set ++# CONFIG_UFS_FS is not set ++CONFIG_NETWORK_FILESYSTEMS=y ++CONFIG_NFS_FS=y ++CONFIG_NFS_V3=y ++# CONFIG_NFS_V3_ACL is not set ++# CONFIG_NFS_V4 is not set ++# CONFIG_NFS_DIRECTIO is not set ++# CONFIG_NFSD is not set ++CONFIG_ROOT_NFS=y ++CONFIG_LOCKD=y ++CONFIG_LOCKD_V4=y ++CONFIG_NFS_COMMON=y ++CONFIG_SUNRPC=y ++# CONFIG_SUNRPC_BIND34 is not set ++# CONFIG_RPCSEC_GSS_KRB5 is not set ++# CONFIG_RPCSEC_GSS_SPKM3 is not set ++# CONFIG_SMB_FS is not set ++# CONFIG_CIFS is not set ++# CONFIG_NCP_FS is not set ++# CONFIG_CODA_FS is not set ++# CONFIG_AFS_FS is not set ++ ++# ++# Partition Types ++# ++# CONFIG_PARTITION_ADVANCED is not set ++CONFIG_MSDOS_PARTITION=y ++# CONFIG_NLS is not set ++# CONFIG_DLM is not set ++# CONFIG_UCC_SLOW is not set ++ ++# ++# Library routines ++# ++CONFIG_BITREVERSE=y ++# CONFIG_CRC_CCITT is not set ++# CONFIG_CRC16 is not set ++# CONFIG_CRC_ITU_T is not set ++CONFIG_CRC32=y ++# CONFIG_CRC7 is not set ++# CONFIG_LIBCRC32C is not set ++CONFIG_ZLIB_INFLATE=y ++CONFIG_PLIST=y ++CONFIG_HAS_IOMEM=y ++CONFIG_HAS_IOPORT=y ++CONFIG_HAS_DMA=y ++CONFIG_INSTRUMENTATION=y ++# CONFIG_PROFILING is not set ++# CONFIG_KPROBES is not set ++# CONFIG_MARKERS is not set ++ ++# ++# Kernel hacking ++# ++# CONFIG_PRINTK_TIME is not set ++CONFIG_ENABLE_WARN_DEPRECATED=y ++CONFIG_ENABLE_MUST_CHECK=y ++CONFIG_MAGIC_SYSRQ=y ++# CONFIG_UNUSED_SYMBOLS is not set ++# CONFIG_DEBUG_FS is not set ++# CONFIG_HEADERS_CHECK is not set ++CONFIG_DEBUG_KERNEL=y ++# CONFIG_DEBUG_SHIRQ is not set ++CONFIG_DETECT_SOFTLOCKUP=y ++CONFIG_SCHED_DEBUG=y ++# CONFIG_SCHEDSTATS is not set ++# CONFIG_TIMER_STATS is not set ++# CONFIG_SLUB_DEBUG_ON is not set ++# CONFIG_DEBUG_RT_MUTEXES is not set ++# CONFIG_RT_MUTEX_TESTER is not set ++# CONFIG_DEBUG_SPINLOCK is not set ++# CONFIG_DEBUG_MUTEXES is not set ++# CONFIG_DEBUG_SPINLOCK_SLEEP is not set ++# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set ++# CONFIG_DEBUG_KOBJECT is not set ++CONFIG_DEBUG_BUGVERBOSE=y ++# CONFIG_DEBUG_INFO is not set ++# CONFIG_DEBUG_VM is not set ++# CONFIG_DEBUG_LIST is not set ++# CONFIG_DEBUG_SG is not set ++CONFIG_FORCED_INLINING=y ++# CONFIG_BOOT_PRINTK_DELAY is not set ++# CONFIG_RCU_TORTURE_TEST is not set ++# CONFIG_FAULT_INJECTION is not set ++# CONFIG_SAMPLES is not set ++# CONFIG_DEBUG_STACKOVERFLOW is not set ++# CONFIG_DEBUG_STACK_USAGE is not set ++# CONFIG_DEBUG_PAGEALLOC is not set ++# CONFIG_DEBUGGER is not set ++# CONFIG_BDI_SWITCH is not set ++# CONFIG_PPC_EARLY_DEBUG is not set ++ ++# ++# Security options ++# ++# CONFIG_KEYS is not set ++# CONFIG_SECURITY is not set ++# CONFIG_SECURITY_FILE_CAPABILITIES is not set ++CONFIG_CRYPTO=y ++CONFIG_CRYPTO_ALGAPI=y ++CONFIG_CRYPTO_BLKCIPHER=y ++CONFIG_CRYPTO_MANAGER=y ++# CONFIG_CRYPTO_HMAC is not set ++# CONFIG_CRYPTO_XCBC is not set ++# CONFIG_CRYPTO_NULL is not set ++# CONFIG_CRYPTO_MD4 is not set ++CONFIG_CRYPTO_MD5=y ++# CONFIG_CRYPTO_SHA1 is not set ++# CONFIG_CRYPTO_SHA256 is not set ++# CONFIG_CRYPTO_SHA512 is not set ++# CONFIG_CRYPTO_WP512 is not set ++# CONFIG_CRYPTO_TGR192 is not set ++# CONFIG_CRYPTO_GF128MUL is not set ++CONFIG_CRYPTO_ECB=y ++CONFIG_CRYPTO_CBC=y ++CONFIG_CRYPTO_PCBC=y ++# CONFIG_CRYPTO_LRW is not set ++# CONFIG_CRYPTO_XTS is not set ++# CONFIG_CRYPTO_CRYPTD is not set ++CONFIG_CRYPTO_DES=y ++# CONFIG_CRYPTO_FCRYPT is not set ++# CONFIG_CRYPTO_BLOWFISH is not set ++# CONFIG_CRYPTO_TWOFISH is not set ++# CONFIG_CRYPTO_SERPENT is not set ++# CONFIG_CRYPTO_AES is not set ++# CONFIG_CRYPTO_CAST5 is not set ++# CONFIG_CRYPTO_CAST6 is not set ++# CONFIG_CRYPTO_TEA is not set ++# CONFIG_CRYPTO_ARC4 is not set ++# CONFIG_CRYPTO_KHAZAD is not set ++# CONFIG_CRYPTO_ANUBIS is not set ++# CONFIG_CRYPTO_SEED is not set ++# CONFIG_CRYPTO_DEFLATE is not set ++# CONFIG_CRYPTO_MICHAEL_MIC is not set ++# CONFIG_CRYPTO_CRC32C is not set ++# CONFIG_CRYPTO_CAMELLIA is not set ++# CONFIG_CRYPTO_TEST is not set ++# CONFIG_CRYPTO_AUTHENC is not set ++CONFIG_CRYPTO_HW=y ++# CONFIG_PPC_CLOCK is not set +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/ep8248e_defconfig powerpc.git/arch/powerpc/configs/ep8248e_defconfig +--- linux-2.6.24/arch/powerpc/configs/ep8248e_defconfig 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/ep8248e_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,821 @@ ++# ++# Automatically generated make config: don't edit ++# Linux kernel version: 2.6.24-rc6 ++# Fri Jan 11 14:02:06 2008 ++# ++# CONFIG_PPC64 is not set ++ ++# ++# Processor support ++# ++CONFIG_6xx=y ++# CONFIG_PPC_85xx is not set ++# CONFIG_PPC_8xx is not set ++# CONFIG_40x is not set ++# CONFIG_44x is not set ++# CONFIG_E200 is not set ++CONFIG_PPC_FPU=y ++CONFIG_PPC_STD_MMU=y ++CONFIG_PPC_STD_MMU_32=y ++# CONFIG_PPC_MM_SLICES is not set ++# CONFIG_SMP is not set ++CONFIG_PPC32=y ++CONFIG_WORD_SIZE=32 ++CONFIG_PPC_MERGE=y ++CONFIG_MMU=y ++CONFIG_GENERIC_CMOS_UPDATE=y ++CONFIG_GENERIC_TIME=y ++CONFIG_GENERIC_TIME_VSYSCALL=y ++CONFIG_GENERIC_CLOCKEVENTS=y ++CONFIG_GENERIC_HARDIRQS=y ++CONFIG_IRQ_PER_CPU=y ++CONFIG_RWSEM_XCHGADD_ALGORITHM=y ++CONFIG_ARCH_HAS_ILOG2_U32=y ++CONFIG_GENERIC_HWEIGHT=y ++CONFIG_GENERIC_CALIBRATE_DELAY=y ++CONFIG_GENERIC_FIND_NEXT_BIT=y ++# CONFIG_ARCH_NO_VIRT_TO_BUS is not set ++CONFIG_PPC=y ++CONFIG_EARLY_PRINTK=y ++CONFIG_GENERIC_NVRAM=y ++CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y ++CONFIG_ARCH_MAY_HAVE_PC_FDC=y ++CONFIG_PPC_OF=y ++CONFIG_OF=y ++# CONFIG_PPC_UDBG_16550 is not set ++# CONFIG_GENERIC_TBSYNC is not set ++CONFIG_AUDIT_ARCH=y ++CONFIG_GENERIC_BUG=y ++# CONFIG_DEFAULT_UIMAGE is not set ++# CONFIG_PPC_DCR_NATIVE is not set ++# CONFIG_PPC_DCR_MMIO is not set ++CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" ++ ++# ++# General setup ++# ++# CONFIG_EXPERIMENTAL is not set ++CONFIG_BROKEN_ON_SMP=y ++CONFIG_INIT_ENV_ARG_LIMIT=32 ++CONFIG_LOCALVERSION="" ++CONFIG_LOCALVERSION_AUTO=y ++CONFIG_SWAP=y ++CONFIG_SYSVIPC=y ++CONFIG_SYSVIPC_SYSCTL=y ++# CONFIG_BSD_PROCESS_ACCT is not set ++# CONFIG_TASKSTATS is not set ++# CONFIG_AUDIT is not set ++CONFIG_IKCONFIG=y ++CONFIG_IKCONFIG_PROC=y ++CONFIG_LOG_BUF_SHIFT=14 ++# CONFIG_CGROUPS is not set ++CONFIG_FAIR_GROUP_SCHED=y ++CONFIG_FAIR_USER_SCHED=y ++# CONFIG_FAIR_CGROUP_SCHED is not set ++CONFIG_SYSFS_DEPRECATED=y ++# CONFIG_RELAY is not set ++# CONFIG_BLK_DEV_INITRD is not set ++CONFIG_SYSCTL=y ++CONFIG_EMBEDDED=y ++CONFIG_SYSCTL_SYSCALL=y ++CONFIG_KALLSYMS=y ++CONFIG_KALLSYMS_ALL=y ++# CONFIG_KALLSYMS_EXTRA_PASS is not set ++CONFIG_HOTPLUG=y ++CONFIG_PRINTK=y ++CONFIG_BUG=y ++CONFIG_ELF_CORE=y ++CONFIG_BASE_FULL=y ++CONFIG_FUTEX=y ++CONFIG_ANON_INODES=y ++CONFIG_EPOLL=y ++CONFIG_SIGNALFD=y ++CONFIG_EVENTFD=y ++CONFIG_SHMEM=y ++CONFIG_VM_EVENT_COUNTERS=y ++CONFIG_SLAB=y ++# CONFIG_SLUB is not set ++# CONFIG_SLOB is not set ++CONFIG_RT_MUTEXES=y ++# CONFIG_TINY_SHMEM is not set ++CONFIG_BASE_SMALL=0 ++# CONFIG_MODULES is not set ++CONFIG_BLOCK=y ++# CONFIG_LBD is not set ++# CONFIG_BLK_DEV_IO_TRACE is not set ++# CONFIG_LSF is not set ++ ++# ++# IO Schedulers ++# ++CONFIG_IOSCHED_NOOP=y ++# CONFIG_IOSCHED_AS is not set ++CONFIG_IOSCHED_DEADLINE=y ++# CONFIG_IOSCHED_CFQ is not set ++# CONFIG_DEFAULT_AS is not set ++CONFIG_DEFAULT_DEADLINE=y ++# CONFIG_DEFAULT_CFQ is not set ++# CONFIG_DEFAULT_NOOP is not set ++CONFIG_DEFAULT_IOSCHED="deadline" ++ ++# ++# Platform support ++# ++# CONFIG_PPC_MULTIPLATFORM is not set ++CONFIG_PPC_82xx=y ++# CONFIG_PPC_83xx is not set ++# CONFIG_PPC_86xx is not set ++# CONFIG_PPC_MPC52xx is not set ++# CONFIG_PPC_MPC5200 is not set ++# CONFIG_PPC_CELL is not set ++# CONFIG_PPC_CELL_NATIVE is not set ++# CONFIG_MPC8272_ADS is not set ++# CONFIG_PQ2FADS is not set ++CONFIG_EP8248E=y ++# CONFIG_PQ2ADS is not set ++CONFIG_8260=y ++CONFIG_8272=y ++# CONFIG_MPIC is not set ++# CONFIG_MPIC_WEIRD is not set ++# CONFIG_PPC_I8259 is not set ++# CONFIG_PPC_RTAS is not set ++# CONFIG_MMIO_NVRAM is not set ++# CONFIG_PPC_MPC106 is not set ++# CONFIG_PPC_970_NAP is not set ++# CONFIG_PPC_INDIRECT_IO is not set ++# CONFIG_GENERIC_IOMAP is not set ++# CONFIG_CPU_FREQ is not set ++CONFIG_CPM2=y ++CONFIG_PPC_CPM_NEW_BINDING=y ++# CONFIG_FSL_ULI1575 is not set ++CONFIG_CPM=y ++ ++# ++# Kernel options ++# ++# CONFIG_HIGHMEM is not set ++# CONFIG_TICK_ONESHOT is not set ++# CONFIG_NO_HZ is not set ++# CONFIG_HIGH_RES_TIMERS is not set ++CONFIG_GENERIC_CLOCKEVENTS_BUILD=y ++# CONFIG_HZ_100 is not set ++CONFIG_HZ_250=y ++# CONFIG_HZ_300 is not set ++# CONFIG_HZ_1000 is not set ++CONFIG_HZ=250 ++CONFIG_PREEMPT_NONE=y ++# CONFIG_PREEMPT_VOLUNTARY is not set ++# CONFIG_PREEMPT is not set ++CONFIG_BINFMT_ELF=y ++CONFIG_BINFMT_MISC=y ++CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y ++CONFIG_ARCH_FLATMEM_ENABLE=y ++CONFIG_ARCH_POPULATES_NODE_MAP=y ++CONFIG_FLATMEM=y ++CONFIG_FLAT_NODE_MEM_MAP=y ++# CONFIG_SPARSEMEM_STATIC is not set ++# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set ++CONFIG_SPLIT_PTLOCK_CPUS=4 ++# CONFIG_RESOURCES_64BIT is not set ++CONFIG_ZONE_DMA_FLAG=1 ++CONFIG_BOUNCE=y ++CONFIG_VIRT_TO_BUS=y ++CONFIG_PROC_DEVICETREE=y ++# CONFIG_CMDLINE_BOOL is not set ++# CONFIG_PM is not set ++CONFIG_SUSPEND_UP_POSSIBLE=y ++CONFIG_HIBERNATION_UP_POSSIBLE=y ++# CONFIG_SECCOMP is not set ++CONFIG_WANT_DEVICE_TREE=y ++CONFIG_DEVICE_TREE="ep8248e.dts" ++CONFIG_ISA_DMA_API=y ++ ++# ++# Bus options ++# ++CONFIG_ZONE_DMA=y ++CONFIG_FSL_SOC=y ++# CONFIG_PCI is not set ++# CONFIG_PCI_DOMAINS is not set ++# CONFIG_PCI_SYSCALL is not set ++# CONFIG_ARCH_SUPPORTS_MSI is not set ++# CONFIG_PCCARD is not set ++ ++# ++# Advanced setup ++# ++# CONFIG_ADVANCED_OPTIONS is not set ++ ++# ++# Default settings for advanced configuration options are used ++# ++CONFIG_HIGHMEM_START=0xfe000000 ++CONFIG_LOWMEM_SIZE=0x30000000 ++CONFIG_KERNEL_START=0xc0000000 ++CONFIG_TASK_SIZE=0xc0000000 ++CONFIG_BOOT_LOAD=0x00400000 ++ ++# ++# Networking ++# ++CONFIG_NET=y ++ ++# ++# Networking options ++# ++CONFIG_PACKET=y ++# CONFIG_PACKET_MMAP is not set ++CONFIG_UNIX=y ++CONFIG_XFRM=y ++# CONFIG_XFRM_USER is not set ++# CONFIG_NET_KEY is not set ++CONFIG_INET=y ++CONFIG_IP_MULTICAST=y ++# CONFIG_IP_ADVANCED_ROUTER is not set ++CONFIG_IP_FIB_HASH=y ++CONFIG_IP_PNP=y ++CONFIG_IP_PNP_DHCP=y ++CONFIG_IP_PNP_BOOTP=y ++# CONFIG_IP_PNP_RARP is not set ++# CONFIG_NET_IPIP is not set ++# CONFIG_NET_IPGRE is not set ++# CONFIG_IP_MROUTE is not set ++CONFIG_SYN_COOKIES=y ++# CONFIG_INET_AH is not set ++# CONFIG_INET_ESP is not set ++# CONFIG_INET_IPCOMP is not set ++# CONFIG_INET_XFRM_TUNNEL is not set ++CONFIG_INET_TUNNEL=y ++CONFIG_INET_XFRM_MODE_TRANSPORT=y ++CONFIG_INET_XFRM_MODE_TUNNEL=y ++CONFIG_INET_XFRM_MODE_BEET=y ++# CONFIG_INET_LRO is not set ++CONFIG_INET_DIAG=y ++CONFIG_INET_TCP_DIAG=y ++# CONFIG_TCP_CONG_ADVANCED is not set ++CONFIG_TCP_CONG_CUBIC=y ++CONFIG_DEFAULT_TCP_CONG="cubic" ++# CONFIG_IP_VS is not set ++CONFIG_IPV6=y ++# CONFIG_IPV6_PRIVACY is not set ++# CONFIG_IPV6_ROUTER_PREF is not set ++# CONFIG_INET6_AH is not set ++# CONFIG_INET6_ESP is not set ++# CONFIG_INET6_IPCOMP is not set ++# CONFIG_INET6_XFRM_TUNNEL is not set ++# CONFIG_INET6_TUNNEL is not set ++CONFIG_INET6_XFRM_MODE_TRANSPORT=y ++CONFIG_INET6_XFRM_MODE_TUNNEL=y ++CONFIG_INET6_XFRM_MODE_BEET=y ++CONFIG_IPV6_SIT=y ++# CONFIG_IPV6_TUNNEL is not set ++# CONFIG_NETWORK_SECMARK is not set ++CONFIG_NETFILTER=y ++# CONFIG_NETFILTER_DEBUG is not set ++ ++# ++# Core Netfilter Configuration ++# ++# CONFIG_NETFILTER_NETLINK is not set ++# CONFIG_NF_CONNTRACK_ENABLED is not set ++# CONFIG_NF_CONNTRACK is not set ++# CONFIG_NETFILTER_XTABLES is not set ++ ++# ++# IP: Netfilter Configuration ++# ++# CONFIG_IP_NF_QUEUE is not set ++# CONFIG_IP_NF_IPTABLES is not set ++# CONFIG_IP_NF_ARPTABLES is not set ++# CONFIG_BRIDGE is not set ++# CONFIG_VLAN_8021Q is not set ++# CONFIG_DECNET is not set ++# CONFIG_LLC2 is not set ++# CONFIG_IPX is not set ++# CONFIG_ATALK is not set ++# CONFIG_NET_SCHED is not set ++ ++# ++# Network testing ++# ++# CONFIG_NET_PKTGEN is not set ++# CONFIG_HAMRADIO is not set ++# CONFIG_IRDA is not set ++# CONFIG_BT is not set ++ ++# ++# Wireless ++# ++# CONFIG_CFG80211 is not set ++# CONFIG_WIRELESS_EXT is not set ++# CONFIG_IEEE80211 is not set ++# CONFIG_RFKILL is not set ++ ++# ++# Device Drivers ++# ++ ++# ++# Generic Driver Options ++# ++CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" ++CONFIG_STANDALONE=y ++CONFIG_PREVENT_FIRMWARE_BUILD=y ++# CONFIG_FW_LOADER is not set ++# CONFIG_DEBUG_DRIVER is not set ++# CONFIG_DEBUG_DEVRES is not set ++# CONFIG_SYS_HYPERVISOR is not set ++# CONFIG_CONNECTOR is not set ++CONFIG_MTD=y ++# CONFIG_MTD_DEBUG is not set ++# CONFIG_MTD_CONCAT is not set ++# CONFIG_MTD_PARTITIONS is not set ++ ++# ++# User Modules And Translation Layers ++# ++CONFIG_MTD_CHAR=y ++CONFIG_MTD_BLKDEVS=y ++CONFIG_MTD_BLOCK=y ++# CONFIG_FTL is not set ++# CONFIG_NFTL is not set ++# CONFIG_INFTL is not set ++# CONFIG_RFD_FTL is not set ++# CONFIG_SSFDC is not set ++# CONFIG_MTD_OOPS is not set ++ ++# ++# RAM/ROM/Flash chip drivers ++# ++CONFIG_MTD_CFI=y ++# CONFIG_MTD_JEDECPROBE is not set ++CONFIG_MTD_GEN_PROBE=y ++CONFIG_MTD_CFI_ADV_OPTIONS=y ++CONFIG_MTD_CFI_NOSWAP=y ++# CONFIG_MTD_CFI_BE_BYTE_SWAP is not set ++# CONFIG_MTD_CFI_LE_BYTE_SWAP is not set ++CONFIG_MTD_CFI_GEOMETRY=y ++# CONFIG_MTD_MAP_BANK_WIDTH_1 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_2 is not set ++CONFIG_MTD_MAP_BANK_WIDTH_4=y ++# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set ++# CONFIG_MTD_CFI_I1 is not set ++CONFIG_MTD_CFI_I2=y ++# CONFIG_MTD_CFI_I4 is not set ++# CONFIG_MTD_CFI_I8 is not set ++# CONFIG_MTD_OTP is not set ++# CONFIG_MTD_CFI_INTELEXT is not set ++CONFIG_MTD_CFI_AMDSTD=y ++# CONFIG_MTD_CFI_STAA is not set ++CONFIG_MTD_CFI_UTIL=y ++# CONFIG_MTD_RAM is not set ++# CONFIG_MTD_ROM is not set ++# CONFIG_MTD_ABSENT is not set ++ ++# ++# Mapping drivers for chip access ++# ++# CONFIG_MTD_COMPLEX_MAPPINGS is not set ++# CONFIG_MTD_PHYSMAP is not set ++CONFIG_MTD_PHYSMAP_OF=y ++# CONFIG_MTD_PLATRAM is not set ++ ++# ++# Self-contained MTD device drivers ++# ++# CONFIG_MTD_SLRAM is not set ++# CONFIG_MTD_PHRAM is not set ++# CONFIG_MTD_MTDRAM is not set ++# CONFIG_MTD_BLOCK2MTD is not set ++ ++# ++# Disk-On-Chip Device Drivers ++# ++# CONFIG_MTD_DOC2000 is not set ++# CONFIG_MTD_DOC2001 is not set ++# CONFIG_MTD_DOC2001PLUS is not set ++# CONFIG_MTD_NAND is not set ++# CONFIG_MTD_ONENAND is not set ++ ++# ++# UBI - Unsorted block images ++# ++# CONFIG_MTD_UBI is not set ++CONFIG_OF_DEVICE=y ++# CONFIG_PARPORT is not set ++CONFIG_BLK_DEV=y ++# CONFIG_BLK_DEV_FD is not set ++# CONFIG_BLK_DEV_COW_COMMON is not set ++CONFIG_BLK_DEV_LOOP=y ++# CONFIG_BLK_DEV_CRYPTOLOOP is not set ++# CONFIG_BLK_DEV_NBD is not set ++# CONFIG_BLK_DEV_RAM is not set ++# CONFIG_CDROM_PKTCDVD is not set ++# CONFIG_ATA_OVER_ETH is not set ++# CONFIG_MISC_DEVICES is not set ++# CONFIG_IDE is not set ++ ++# ++# SCSI device support ++# ++# CONFIG_RAID_ATTRS is not set ++# CONFIG_SCSI is not set ++# CONFIG_SCSI_DMA is not set ++# CONFIG_SCSI_NETLINK is not set ++# CONFIG_ATA is not set ++# CONFIG_MD is not set ++# CONFIG_MACINTOSH_DRIVERS is not set ++CONFIG_NETDEVICES=y ++# CONFIG_NETDEVICES_MULTIQUEUE is not set ++# CONFIG_DUMMY is not set ++# CONFIG_BONDING is not set ++# CONFIG_EQUALIZER is not set ++# CONFIG_TUN is not set ++# CONFIG_VETH is not set ++CONFIG_PHYLIB=y ++ ++# ++# MII PHY device drivers ++# ++# CONFIG_MARVELL_PHY is not set ++CONFIG_DAVICOM_PHY=y ++# CONFIG_QSEMI_PHY is not set ++# CONFIG_LXT_PHY is not set ++# CONFIG_CICADA_PHY is not set ++# CONFIG_VITESSE_PHY is not set ++# CONFIG_SMSC_PHY is not set ++# CONFIG_BROADCOM_PHY is not set ++# CONFIG_ICPLUS_PHY is not set ++# CONFIG_FIXED_PHY is not set ++CONFIG_MDIO_BITBANG=y ++CONFIG_NET_ETHERNET=y ++CONFIG_MII=y ++# CONFIG_IBM_NEW_EMAC_ZMII is not set ++# CONFIG_IBM_NEW_EMAC_RGMII is not set ++# CONFIG_IBM_NEW_EMAC_TAH is not set ++# CONFIG_IBM_NEW_EMAC_EMAC4 is not set ++# CONFIG_B44 is not set ++CONFIG_FS_ENET=y ++# CONFIG_FS_ENET_HAS_SCC is not set ++CONFIG_FS_ENET_HAS_FCC=y ++# CONFIG_FS_ENET_MDIO_FCC is not set ++CONFIG_NETDEV_1000=y ++CONFIG_NETDEV_10000=y ++ ++# ++# Wireless LAN ++# ++# CONFIG_WLAN_PRE80211 is not set ++# CONFIG_WLAN_80211 is not set ++# CONFIG_WAN is not set ++# CONFIG_PPP is not set ++# CONFIG_SLIP is not set ++# CONFIG_NETPOLL is not set ++# CONFIG_NET_POLL_CONTROLLER is not set ++# CONFIG_ISDN is not set ++# CONFIG_PHONE is not set ++ ++# ++# Input device support ++# ++# CONFIG_INPUT is not set ++ ++# ++# Hardware I/O ports ++# ++# CONFIG_SERIO is not set ++# CONFIG_GAMEPORT is not set ++ ++# ++# Character devices ++# ++# CONFIG_VT is not set ++# CONFIG_SERIAL_NONSTANDARD is not set ++ ++# ++# Serial drivers ++# ++# CONFIG_SERIAL_8250 is not set ++ ++# ++# Non-8250 serial port support ++# ++# CONFIG_SERIAL_UARTLITE is not set ++CONFIG_SERIAL_CORE=y ++CONFIG_SERIAL_CORE_CONSOLE=y ++CONFIG_SERIAL_CPM=y ++CONFIG_SERIAL_CPM_CONSOLE=y ++CONFIG_SERIAL_CPM_SCC1=y ++# CONFIG_SERIAL_CPM_SCC2 is not set ++# CONFIG_SERIAL_CPM_SCC3 is not set ++CONFIG_SERIAL_CPM_SCC4=y ++# CONFIG_SERIAL_CPM_SMC1 is not set ++# CONFIG_SERIAL_CPM_SMC2 is not set ++CONFIG_UNIX98_PTYS=y ++CONFIG_LEGACY_PTYS=y ++CONFIG_LEGACY_PTY_COUNT=256 ++# CONFIG_IPMI_HANDLER is not set ++CONFIG_HW_RANDOM=y ++# CONFIG_NVRAM is not set ++# CONFIG_GEN_RTC is not set ++# CONFIG_R3964 is not set ++# CONFIG_RAW_DRIVER is not set ++# CONFIG_I2C is not set ++ ++# ++# SPI support ++# ++# CONFIG_SPI is not set ++# CONFIG_SPI_MASTER is not set ++# CONFIG_W1 is not set ++# CONFIG_POWER_SUPPLY is not set ++# CONFIG_HWMON is not set ++# CONFIG_WATCHDOG is not set ++ ++# ++# Sonics Silicon Backplane ++# ++CONFIG_SSB_POSSIBLE=y ++# CONFIG_SSB is not set ++ ++# ++# Multifunction device drivers ++# ++# CONFIG_MFD_SM501 is not set ++ ++# ++# Multimedia devices ++# ++# CONFIG_VIDEO_DEV is not set ++# CONFIG_DVB_CORE is not set ++CONFIG_DAB=y ++ ++# ++# Graphics support ++# ++# CONFIG_VGASTATE is not set ++# CONFIG_VIDEO_OUTPUT_CONTROL is not set ++# CONFIG_FB is not set ++# CONFIG_BACKLIGHT_LCD_SUPPORT is not set ++ ++# ++# Display device support ++# ++# CONFIG_DISPLAY_SUPPORT is not set ++ ++# ++# Sound ++# ++# CONFIG_SOUND is not set ++# CONFIG_USB_SUPPORT is not set ++# CONFIG_MMC is not set ++# CONFIG_NEW_LEDS is not set ++# CONFIG_RTC_CLASS is not set ++ ++# ++# Userspace I/O ++# ++# CONFIG_UIO is not set ++ ++# ++# File systems ++# ++CONFIG_EXT2_FS=y ++# CONFIG_EXT2_FS_XATTR is not set ++# CONFIG_EXT2_FS_XIP is not set ++CONFIG_EXT3_FS=y ++# CONFIG_EXT3_FS_XATTR is not set ++CONFIG_JBD=y ++# CONFIG_REISERFS_FS is not set ++# CONFIG_JFS_FS is not set ++# CONFIG_FS_POSIX_ACL is not set ++# CONFIG_XFS_FS is not set ++# CONFIG_OCFS2_FS is not set ++# CONFIG_MINIX_FS is not set ++# CONFIG_ROMFS_FS is not set ++CONFIG_INOTIFY=y ++CONFIG_INOTIFY_USER=y ++# CONFIG_QUOTA is not set ++CONFIG_DNOTIFY=y ++# CONFIG_AUTOFS_FS is not set ++CONFIG_AUTOFS4_FS=y ++# CONFIG_FUSE_FS is not set ++ ++# ++# CD-ROM/DVD Filesystems ++# ++# CONFIG_ISO9660_FS is not set ++# CONFIG_UDF_FS is not set ++ ++# ++# DOS/FAT/NT Filesystems ++# ++# CONFIG_MSDOS_FS is not set ++# CONFIG_VFAT_FS is not set ++# CONFIG_NTFS_FS is not set ++ ++# ++# Pseudo filesystems ++# ++CONFIG_PROC_FS=y ++CONFIG_PROC_KCORE=y ++CONFIG_PROC_SYSCTL=y ++CONFIG_SYSFS=y ++CONFIG_TMPFS=y ++# CONFIG_TMPFS_POSIX_ACL is not set ++# CONFIG_HUGETLB_PAGE is not set ++ ++# ++# Miscellaneous filesystems ++# ++# CONFIG_HFSPLUS_FS is not set ++# CONFIG_JFFS2_FS is not set ++CONFIG_CRAMFS=y ++# CONFIG_VXFS_FS is not set ++# CONFIG_HPFS_FS is not set ++# CONFIG_QNX4FS_FS is not set ++# CONFIG_SYSV_FS is not set ++# CONFIG_UFS_FS is not set ++CONFIG_NETWORK_FILESYSTEMS=y ++CONFIG_NFS_FS=y ++CONFIG_NFS_V3=y ++# CONFIG_NFS_V3_ACL is not set ++# CONFIG_NFS_DIRECTIO is not set ++# CONFIG_NFSD is not set ++CONFIG_ROOT_NFS=y ++CONFIG_LOCKD=y ++CONFIG_LOCKD_V4=y ++CONFIG_NFS_COMMON=y ++CONFIG_SUNRPC=y ++# CONFIG_SMB_FS is not set ++# CONFIG_CIFS is not set ++# CONFIG_NCP_FS is not set ++# CONFIG_CODA_FS is not set ++ ++# ++# Partition Types ++# ++CONFIG_PARTITION_ADVANCED=y ++# CONFIG_ACORN_PARTITION is not set ++# CONFIG_OSF_PARTITION is not set ++# CONFIG_AMIGA_PARTITION is not set ++# CONFIG_ATARI_PARTITION is not set ++# CONFIG_MAC_PARTITION is not set ++CONFIG_MSDOS_PARTITION=y ++# CONFIG_BSD_DISKLABEL is not set ++# CONFIG_MINIX_SUBPARTITION is not set ++# CONFIG_SOLARIS_X86_PARTITION is not set ++# CONFIG_UNIXWARE_DISKLABEL is not set ++# CONFIG_LDM_PARTITION is not set ++# CONFIG_SGI_PARTITION is not set ++# CONFIG_ULTRIX_PARTITION is not set ++# CONFIG_SUN_PARTITION is not set ++# CONFIG_KARMA_PARTITION is not set ++# CONFIG_EFI_PARTITION is not set ++# CONFIG_SYSV68_PARTITION is not set ++CONFIG_NLS=y ++CONFIG_NLS_DEFAULT="iso8859-1" ++CONFIG_NLS_CODEPAGE_437=y ++# CONFIG_NLS_CODEPAGE_737 is not set ++# CONFIG_NLS_CODEPAGE_775 is not set ++# CONFIG_NLS_CODEPAGE_850 is not set ++# CONFIG_NLS_CODEPAGE_852 is not set ++# CONFIG_NLS_CODEPAGE_855 is not set ++# CONFIG_NLS_CODEPAGE_857 is not set ++# CONFIG_NLS_CODEPAGE_860 is not set ++# CONFIG_NLS_CODEPAGE_861 is not set ++# CONFIG_NLS_CODEPAGE_862 is not set ++# CONFIG_NLS_CODEPAGE_863 is not set ++# CONFIG_NLS_CODEPAGE_864 is not set ++# CONFIG_NLS_CODEPAGE_865 is not set ++# CONFIG_NLS_CODEPAGE_866 is not set ++# CONFIG_NLS_CODEPAGE_869 is not set ++# CONFIG_NLS_CODEPAGE_936 is not set ++# CONFIG_NLS_CODEPAGE_950 is not set ++# CONFIG_NLS_CODEPAGE_932 is not set ++# CONFIG_NLS_CODEPAGE_949 is not set ++# CONFIG_NLS_CODEPAGE_874 is not set ++# CONFIG_NLS_ISO8859_8 is not set ++# CONFIG_NLS_CODEPAGE_1250 is not set ++# CONFIG_NLS_CODEPAGE_1251 is not set ++CONFIG_NLS_ASCII=y ++CONFIG_NLS_ISO8859_1=y ++# CONFIG_NLS_ISO8859_2 is not set ++# CONFIG_NLS_ISO8859_3 is not set ++# CONFIG_NLS_ISO8859_4 is not set ++# CONFIG_NLS_ISO8859_5 is not set ++# CONFIG_NLS_ISO8859_6 is not set ++# CONFIG_NLS_ISO8859_7 is not set ++# CONFIG_NLS_ISO8859_9 is not set ++# CONFIG_NLS_ISO8859_13 is not set ++# CONFIG_NLS_ISO8859_14 is not set ++# CONFIG_NLS_ISO8859_15 is not set ++# CONFIG_NLS_KOI8_R is not set ++# CONFIG_NLS_KOI8_U is not set ++CONFIG_NLS_UTF8=y ++# CONFIG_UCC_SLOW is not set ++ ++# ++# Library routines ++# ++# CONFIG_CRC_CCITT is not set ++# CONFIG_CRC16 is not set ++# CONFIG_CRC_ITU_T is not set ++# CONFIG_CRC32 is not set ++# CONFIG_CRC7 is not set ++# CONFIG_LIBCRC32C is not set ++CONFIG_ZLIB_INFLATE=y ++CONFIG_PLIST=y ++CONFIG_HAS_IOMEM=y ++CONFIG_HAS_IOPORT=y ++CONFIG_HAS_DMA=y ++CONFIG_INSTRUMENTATION=y ++# CONFIG_PROFILING is not set ++# CONFIG_MARKERS is not set ++ ++# ++# Kernel hacking ++# ++# CONFIG_PRINTK_TIME is not set ++CONFIG_ENABLE_WARN_DEPRECATED=y ++CONFIG_ENABLE_MUST_CHECK=y ++CONFIG_MAGIC_SYSRQ=y ++# CONFIG_UNUSED_SYMBOLS is not set ++# CONFIG_DEBUG_FS is not set ++# CONFIG_HEADERS_CHECK is not set ++CONFIG_DEBUG_KERNEL=y ++# CONFIG_DEBUG_SHIRQ is not set ++# CONFIG_DETECT_SOFTLOCKUP is not set ++# CONFIG_SCHED_DEBUG is not set ++# CONFIG_SCHEDSTATS is not set ++# CONFIG_TIMER_STATS is not set ++# CONFIG_DEBUG_SLAB is not set ++# CONFIG_DEBUG_RT_MUTEXES is not set ++# CONFIG_RT_MUTEX_TESTER is not set ++# CONFIG_DEBUG_SPINLOCK is not set ++# CONFIG_DEBUG_MUTEXES is not set ++# CONFIG_DEBUG_SPINLOCK_SLEEP is not set ++# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set ++# CONFIG_DEBUG_KOBJECT is not set ++CONFIG_DEBUG_BUGVERBOSE=y ++CONFIG_DEBUG_INFO=y ++# CONFIG_DEBUG_VM is not set ++# CONFIG_DEBUG_LIST is not set ++# CONFIG_DEBUG_SG is not set ++CONFIG_FORCED_INLINING=y ++# CONFIG_BOOT_PRINTK_DELAY is not set ++# CONFIG_FAULT_INJECTION is not set ++# CONFIG_SAMPLES is not set ++# CONFIG_DEBUG_STACKOVERFLOW is not set ++# CONFIG_DEBUG_STACK_USAGE is not set ++# CONFIG_DEBUG_PAGEALLOC is not set ++# CONFIG_DEBUGGER is not set ++# CONFIG_KGDB_CONSOLE is not set ++CONFIG_BDI_SWITCH=y ++# CONFIG_PPC_EARLY_DEBUG is not set ++ ++# ++# Security options ++# ++# CONFIG_KEYS is not set ++# CONFIG_SECURITY is not set ++CONFIG_CRYPTO=y ++CONFIG_CRYPTO_ALGAPI=y ++CONFIG_CRYPTO_BLKCIPHER=y ++CONFIG_CRYPTO_MANAGER=y ++# CONFIG_CRYPTO_HMAC is not set ++# CONFIG_CRYPTO_NULL is not set ++# CONFIG_CRYPTO_MD4 is not set ++CONFIG_CRYPTO_MD5=y ++# CONFIG_CRYPTO_SHA1 is not set ++# CONFIG_CRYPTO_SHA256 is not set ++# CONFIG_CRYPTO_SHA512 is not set ++# CONFIG_CRYPTO_WP512 is not set ++# CONFIG_CRYPTO_TGR192 is not set ++CONFIG_CRYPTO_ECB=y ++CONFIG_CRYPTO_CBC=y ++CONFIG_CRYPTO_PCBC=y ++# CONFIG_CRYPTO_CRYPTD is not set ++CONFIG_CRYPTO_DES=y ++# CONFIG_CRYPTO_FCRYPT is not set ++# CONFIG_CRYPTO_BLOWFISH is not set ++# CONFIG_CRYPTO_TWOFISH is not set ++# CONFIG_CRYPTO_SERPENT is not set ++# CONFIG_CRYPTO_AES is not set ++# CONFIG_CRYPTO_CAST5 is not set ++# CONFIG_CRYPTO_CAST6 is not set ++# CONFIG_CRYPTO_TEA is not set ++# CONFIG_CRYPTO_ARC4 is not set ++# CONFIG_CRYPTO_KHAZAD is not set ++# CONFIG_CRYPTO_ANUBIS is not set ++# CONFIG_CRYPTO_SEED is not set ++# CONFIG_CRYPTO_DEFLATE is not set ++# CONFIG_CRYPTO_MICHAEL_MIC is not set ++# CONFIG_CRYPTO_CRC32C is not set ++# CONFIG_CRYPTO_CAMELLIA is not set ++# CONFIG_CRYPTO_AUTHENC is not set ++# CONFIG_CRYPTO_HW is not set ++# CONFIG_PPC_CLOCK is not set ++CONFIG_PPC_LIB_RHEAP=y +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/katmai_defconfig powerpc.git/arch/powerpc/configs/katmai_defconfig +--- linux-2.6.24/arch/powerpc/configs/katmai_defconfig 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/katmai_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,790 @@ ++# ++# Automatically generated make config: don't edit ++# Linux kernel version: 2.6.24-rc6 ++# Mon Dec 24 11:17:43 2007 ++# ++# CONFIG_PPC64 is not set ++ ++# ++# Processor support ++# ++# CONFIG_6xx is not set ++# CONFIG_PPC_85xx is not set ++# CONFIG_PPC_8xx is not set ++# CONFIG_40x is not set ++CONFIG_44x=y ++# CONFIG_E200 is not set ++CONFIG_4xx=y ++CONFIG_BOOKE=y ++CONFIG_PTE_64BIT=y ++CONFIG_PHYS_64BIT=y ++# CONFIG_PPC_MM_SLICES is not set ++CONFIG_NOT_COHERENT_CACHE=y ++CONFIG_PPC32=y ++CONFIG_WORD_SIZE=32 ++CONFIG_PPC_MERGE=y ++CONFIG_MMU=y ++CONFIG_GENERIC_CMOS_UPDATE=y ++CONFIG_GENERIC_TIME=y ++CONFIG_GENERIC_TIME_VSYSCALL=y ++CONFIG_GENERIC_CLOCKEVENTS=y ++CONFIG_GENERIC_HARDIRQS=y ++CONFIG_IRQ_PER_CPU=y ++CONFIG_RWSEM_XCHGADD_ALGORITHM=y ++CONFIG_ARCH_HAS_ILOG2_U32=y ++CONFIG_GENERIC_HWEIGHT=y ++CONFIG_GENERIC_CALIBRATE_DELAY=y ++CONFIG_GENERIC_FIND_NEXT_BIT=y ++# CONFIG_ARCH_NO_VIRT_TO_BUS is not set ++CONFIG_PPC=y ++CONFIG_EARLY_PRINTK=y ++CONFIG_GENERIC_NVRAM=y ++CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y ++CONFIG_ARCH_MAY_HAVE_PC_FDC=y ++CONFIG_PPC_OF=y ++CONFIG_OF=y ++CONFIG_PPC_UDBG_16550=y ++# CONFIG_GENERIC_TBSYNC is not set ++CONFIG_AUDIT_ARCH=y ++CONFIG_GENERIC_BUG=y ++# CONFIG_DEFAULT_UIMAGE is not set ++CONFIG_PPC_DCR_NATIVE=y ++# CONFIG_PPC_DCR_MMIO is not set ++CONFIG_PPC_DCR=y ++CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" ++ ++# ++# General setup ++# ++CONFIG_EXPERIMENTAL=y ++CONFIG_BROKEN_ON_SMP=y ++CONFIG_INIT_ENV_ARG_LIMIT=32 ++CONFIG_LOCALVERSION="" ++CONFIG_LOCALVERSION_AUTO=y ++CONFIG_SWAP=y ++CONFIG_SYSVIPC=y ++CONFIG_SYSVIPC_SYSCTL=y ++CONFIG_POSIX_MQUEUE=y ++# CONFIG_BSD_PROCESS_ACCT is not set ++# CONFIG_TASKSTATS is not set ++# CONFIG_USER_NS is not set ++# CONFIG_PID_NS is not set ++# CONFIG_AUDIT is not set ++# CONFIG_IKCONFIG is not set ++CONFIG_LOG_BUF_SHIFT=14 ++# CONFIG_CGROUPS is not set ++CONFIG_FAIR_GROUP_SCHED=y ++CONFIG_FAIR_USER_SCHED=y ++# CONFIG_FAIR_CGROUP_SCHED is not set ++CONFIG_SYSFS_DEPRECATED=y ++# CONFIG_RELAY is not set ++CONFIG_BLK_DEV_INITRD=y ++CONFIG_INITRAMFS_SOURCE="" ++# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set ++CONFIG_SYSCTL=y ++CONFIG_EMBEDDED=y ++CONFIG_SYSCTL_SYSCALL=y ++CONFIG_KALLSYMS=y ++# CONFIG_KALLSYMS_ALL is not set ++# CONFIG_KALLSYMS_EXTRA_PASS is not set ++CONFIG_HOTPLUG=y ++CONFIG_PRINTK=y ++CONFIG_BUG=y ++CONFIG_ELF_CORE=y ++CONFIG_BASE_FULL=y ++CONFIG_FUTEX=y ++CONFIG_ANON_INODES=y ++CONFIG_EPOLL=y ++CONFIG_SIGNALFD=y ++CONFIG_EVENTFD=y ++CONFIG_SHMEM=y ++CONFIG_VM_EVENT_COUNTERS=y ++CONFIG_SLUB_DEBUG=y ++# CONFIG_SLAB is not set ++CONFIG_SLUB=y ++# CONFIG_SLOB is not set ++CONFIG_RT_MUTEXES=y ++# CONFIG_TINY_SHMEM is not set ++CONFIG_BASE_SMALL=0 ++CONFIG_MODULES=y ++CONFIG_MODULE_UNLOAD=y ++# CONFIG_MODULE_FORCE_UNLOAD is not set ++# CONFIG_MODVERSIONS is not set ++# CONFIG_MODULE_SRCVERSION_ALL is not set ++CONFIG_KMOD=y ++CONFIG_BLOCK=y ++CONFIG_LBD=y ++# CONFIG_BLK_DEV_IO_TRACE is not set ++# CONFIG_LSF is not set ++# CONFIG_BLK_DEV_BSG is not set ++ ++# ++# IO Schedulers ++# ++CONFIG_IOSCHED_NOOP=y ++CONFIG_IOSCHED_AS=y ++CONFIG_IOSCHED_DEADLINE=y ++CONFIG_IOSCHED_CFQ=y ++CONFIG_DEFAULT_AS=y ++# CONFIG_DEFAULT_DEADLINE is not set ++# CONFIG_DEFAULT_CFQ is not set ++# CONFIG_DEFAULT_NOOP is not set ++CONFIG_DEFAULT_IOSCHED="anticipatory" ++CONFIG_PPC4xx_PCI_EXPRESS=y ++ ++# ++# Platform support ++# ++# CONFIG_PPC_MPC52xx is not set ++# CONFIG_PPC_MPC5200 is not set ++# CONFIG_PPC_CELL is not set ++# CONFIG_PPC_CELL_NATIVE is not set ++# CONFIG_PQ2ADS is not set ++# CONFIG_BAMBOO is not set ++# CONFIG_EBONY is not set ++# CONFIG_SEQUOIA is not set ++# CONFIG_TAISHAN is not set ++CONFIG_KATMAI=y ++# CONFIG_RAINIER is not set ++CONFIG_440SPe=y ++# CONFIG_MPIC is not set ++# CONFIG_MPIC_WEIRD is not set ++# CONFIG_PPC_I8259 is not set ++# CONFIG_PPC_RTAS is not set ++# CONFIG_MMIO_NVRAM is not set ++# CONFIG_PPC_MPC106 is not set ++# CONFIG_PPC_970_NAP is not set ++# CONFIG_PPC_INDIRECT_IO is not set ++# CONFIG_GENERIC_IOMAP is not set ++# CONFIG_CPU_FREQ is not set ++# CONFIG_CPM2 is not set ++# CONFIG_FSL_ULI1575 is not set ++ ++# ++# Kernel options ++# ++# CONFIG_HIGHMEM is not set ++# CONFIG_TICK_ONESHOT is not set ++# CONFIG_NO_HZ is not set ++# CONFIG_HIGH_RES_TIMERS is not set ++CONFIG_GENERIC_CLOCKEVENTS_BUILD=y ++# CONFIG_HZ_100 is not set ++CONFIG_HZ_250=y ++# CONFIG_HZ_300 is not set ++# CONFIG_HZ_1000 is not set ++CONFIG_HZ=250 ++CONFIG_PREEMPT_NONE=y ++# CONFIG_PREEMPT_VOLUNTARY is not set ++# CONFIG_PREEMPT is not set ++CONFIG_BINFMT_ELF=y ++# CONFIG_BINFMT_MISC is not set ++# CONFIG_MATH_EMULATION is not set ++CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y ++CONFIG_ARCH_FLATMEM_ENABLE=y ++CONFIG_ARCH_POPULATES_NODE_MAP=y ++CONFIG_SELECT_MEMORY_MODEL=y ++CONFIG_FLATMEM_MANUAL=y ++# CONFIG_DISCONTIGMEM_MANUAL is not set ++# CONFIG_SPARSEMEM_MANUAL is not set ++CONFIG_FLATMEM=y ++CONFIG_FLAT_NODE_MEM_MAP=y ++# CONFIG_SPARSEMEM_STATIC is not set ++# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set ++CONFIG_SPLIT_PTLOCK_CPUS=4 ++CONFIG_RESOURCES_64BIT=y ++CONFIG_ZONE_DMA_FLAG=1 ++CONFIG_BOUNCE=y ++CONFIG_VIRT_TO_BUS=y ++CONFIG_PROC_DEVICETREE=y ++CONFIG_CMDLINE_BOOL=y ++CONFIG_CMDLINE="" ++CONFIG_SECCOMP=y ++CONFIG_WANT_DEVICE_TREE=y ++CONFIG_DEVICE_TREE="katmai.dts" ++CONFIG_ISA_DMA_API=y ++ ++# ++# Bus options ++# ++CONFIG_ZONE_DMA=y ++CONFIG_PPC_INDIRECT_PCI=y ++CONFIG_PCI=y ++CONFIG_PCI_DOMAINS=y ++CONFIG_PCI_SYSCALL=y ++# CONFIG_PCIEPORTBUS is not set ++CONFIG_ARCH_SUPPORTS_MSI=y ++# CONFIG_PCI_MSI is not set ++CONFIG_PCI_LEGACY=y ++# CONFIG_PCI_DEBUG is not set ++# CONFIG_PCCARD is not set ++# CONFIG_HOTPLUG_PCI is not set ++ ++# ++# Advanced setup ++# ++# CONFIG_ADVANCED_OPTIONS is not set ++ ++# ++# Default settings for advanced configuration options are used ++# ++CONFIG_HIGHMEM_START=0xfe000000 ++CONFIG_LOWMEM_SIZE=0x30000000 ++CONFIG_KERNEL_START=0xc0000000 ++CONFIG_TASK_SIZE=0xc0000000 ++CONFIG_CONSISTENT_START=0xff100000 ++CONFIG_CONSISTENT_SIZE=0x00200000 ++CONFIG_BOOT_LOAD=0x01000000 ++ ++# ++# Networking ++# ++CONFIG_NET=y ++ ++# ++# Networking options ++# ++CONFIG_PACKET=y ++# CONFIG_PACKET_MMAP is not set ++CONFIG_UNIX=y ++# CONFIG_NET_KEY is not set ++CONFIG_INET=y ++# CONFIG_IP_MULTICAST is not set ++# CONFIG_IP_ADVANCED_ROUTER is not set ++CONFIG_IP_FIB_HASH=y ++CONFIG_IP_PNP=y ++CONFIG_IP_PNP_DHCP=y ++CONFIG_IP_PNP_BOOTP=y ++# CONFIG_IP_PNP_RARP is not set ++# CONFIG_NET_IPIP is not set ++# CONFIG_NET_IPGRE is not set ++# CONFIG_ARPD is not set ++# CONFIG_SYN_COOKIES is not set ++# CONFIG_INET_AH is not set ++# CONFIG_INET_ESP is not set ++# CONFIG_INET_IPCOMP is not set ++# CONFIG_INET_XFRM_TUNNEL is not set ++# CONFIG_INET_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_TRANSPORT is not set ++# CONFIG_INET_XFRM_MODE_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_BEET is not set ++# CONFIG_INET_LRO is not set ++CONFIG_INET_DIAG=y ++CONFIG_INET_TCP_DIAG=y ++# CONFIG_TCP_CONG_ADVANCED is not set ++CONFIG_TCP_CONG_CUBIC=y ++CONFIG_DEFAULT_TCP_CONG="cubic" ++# CONFIG_TCP_MD5SIG is not set ++# CONFIG_IPV6 is not set ++# CONFIG_INET6_XFRM_TUNNEL is not set ++# CONFIG_INET6_TUNNEL is not set ++# CONFIG_NETWORK_SECMARK is not set ++# CONFIG_NETFILTER is not set ++# CONFIG_IP_DCCP is not set ++# CONFIG_IP_SCTP is not set ++# CONFIG_TIPC is not set ++# CONFIG_ATM is not set ++# CONFIG_BRIDGE is not set ++# CONFIG_VLAN_8021Q is not set ++# CONFIG_DECNET is not set ++# CONFIG_LLC2 is not set ++# CONFIG_IPX is not set ++# CONFIG_ATALK is not set ++# CONFIG_X25 is not set ++# CONFIG_LAPB is not set ++# CONFIG_ECONET is not set ++# CONFIG_WAN_ROUTER is not set ++# CONFIG_NET_SCHED is not set ++ ++# ++# Network testing ++# ++# CONFIG_NET_PKTGEN is not set ++# CONFIG_HAMRADIO is not set ++# CONFIG_IRDA is not set ++# CONFIG_BT is not set ++# CONFIG_AF_RXRPC is not set ++ ++# ++# Wireless ++# ++# CONFIG_CFG80211 is not set ++# CONFIG_WIRELESS_EXT is not set ++# CONFIG_MAC80211 is not set ++# CONFIG_IEEE80211 is not set ++# CONFIG_RFKILL is not set ++# CONFIG_NET_9P is not set ++ ++# ++# Device Drivers ++# ++ ++# ++# Generic Driver Options ++# ++CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" ++CONFIG_STANDALONE=y ++CONFIG_PREVENT_FIRMWARE_BUILD=y ++CONFIG_FW_LOADER=y ++# CONFIG_DEBUG_DRIVER is not set ++# CONFIG_DEBUG_DEVRES is not set ++# CONFIG_SYS_HYPERVISOR is not set ++CONFIG_CONNECTOR=y ++CONFIG_PROC_EVENTS=y ++# CONFIG_MTD is not set ++CONFIG_OF_DEVICE=y ++# CONFIG_PARPORT is not set ++CONFIG_BLK_DEV=y ++# CONFIG_BLK_DEV_FD is not set ++# CONFIG_BLK_CPQ_DA is not set ++# CONFIG_BLK_CPQ_CISS_DA is not set ++# CONFIG_BLK_DEV_DAC960 is not set ++# CONFIG_BLK_DEV_UMEM is not set ++# CONFIG_BLK_DEV_COW_COMMON is not set ++# CONFIG_BLK_DEV_LOOP is not set ++# CONFIG_BLK_DEV_NBD is not set ++# CONFIG_BLK_DEV_SX8 is not set ++CONFIG_BLK_DEV_RAM=y ++CONFIG_BLK_DEV_RAM_COUNT=16 ++CONFIG_BLK_DEV_RAM_SIZE=35000 ++CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024 ++# CONFIG_CDROM_PKTCDVD is not set ++# CONFIG_ATA_OVER_ETH is not set ++# CONFIG_XILINX_SYSACE is not set ++CONFIG_MISC_DEVICES=y ++# CONFIG_PHANTOM is not set ++# CONFIG_EEPROM_93CX6 is not set ++# CONFIG_SGI_IOC4 is not set ++# CONFIG_TIFM_CORE is not set ++# CONFIG_IDE is not set ++ ++# ++# SCSI device support ++# ++# CONFIG_RAID_ATTRS is not set ++# CONFIG_SCSI is not set ++# CONFIG_SCSI_DMA is not set ++# CONFIG_SCSI_NETLINK is not set ++# CONFIG_ATA is not set ++# CONFIG_MD is not set ++# CONFIG_FUSION is not set ++ ++# ++# IEEE 1394 (FireWire) support ++# ++# CONFIG_FIREWIRE is not set ++# CONFIG_IEEE1394 is not set ++# CONFIG_I2O is not set ++CONFIG_MACINTOSH_DRIVERS=y ++# CONFIG_MAC_EMUMOUSEBTN is not set ++# CONFIG_WINDFARM is not set ++CONFIG_NETDEVICES=y ++# CONFIG_NETDEVICES_MULTIQUEUE is not set ++# CONFIG_DUMMY is not set ++# CONFIG_BONDING is not set ++# CONFIG_MACVLAN is not set ++# CONFIG_EQUALIZER is not set ++# CONFIG_TUN is not set ++# CONFIG_VETH is not set ++# CONFIG_IP1000 is not set ++# CONFIG_ARCNET is not set ++# CONFIG_PHYLIB is not set ++CONFIG_NET_ETHERNET=y ++# CONFIG_MII is not set ++# CONFIG_HAPPYMEAL is not set ++# CONFIG_SUNGEM is not set ++# CONFIG_CASSINI is not set ++# CONFIG_NET_VENDOR_3COM is not set ++# CONFIG_NET_TULIP is not set ++# CONFIG_HP100 is not set ++CONFIG_IBM_NEW_EMAC=y ++CONFIG_IBM_NEW_EMAC_RXB=128 ++CONFIG_IBM_NEW_EMAC_TXB=64 ++CONFIG_IBM_NEW_EMAC_POLL_WEIGHT=32 ++CONFIG_IBM_NEW_EMAC_RX_COPY_THRESHOLD=256 ++CONFIG_IBM_NEW_EMAC_RX_SKB_HEADROOM=0 ++# CONFIG_IBM_NEW_EMAC_DEBUG is not set ++# CONFIG_IBM_NEW_EMAC_ZMII is not set ++# CONFIG_IBM_NEW_EMAC_RGMII is not set ++# CONFIG_IBM_NEW_EMAC_TAH is not set ++CONFIG_IBM_NEW_EMAC_EMAC4=y ++# CONFIG_NET_PCI is not set ++# CONFIG_B44 is not set ++CONFIG_NETDEV_1000=y ++# CONFIG_ACENIC is not set ++# CONFIG_DL2K is not set ++# CONFIG_E1000 is not set ++# CONFIG_E1000E is not set ++# CONFIG_NS83820 is not set ++# CONFIG_HAMACHI is not set ++# CONFIG_YELLOWFIN is not set ++# CONFIG_R8169 is not set ++# CONFIG_SIS190 is not set ++# CONFIG_SKGE is not set ++# CONFIG_SKY2 is not set ++# CONFIG_SK98LIN is not set ++# CONFIG_VIA_VELOCITY is not set ++# CONFIG_TIGON3 is not set ++# CONFIG_BNX2 is not set ++# CONFIG_QLA3XXX is not set ++# CONFIG_ATL1 is not set ++CONFIG_NETDEV_10000=y ++# CONFIG_CHELSIO_T1 is not set ++# CONFIG_CHELSIO_T3 is not set ++# CONFIG_IXGBE is not set ++# CONFIG_IXGB is not set ++# CONFIG_S2IO is not set ++# CONFIG_MYRI10GE is not set ++# CONFIG_NETXEN_NIC is not set ++# CONFIG_NIU is not set ++# CONFIG_MLX4_CORE is not set ++# CONFIG_TEHUTI is not set ++# CONFIG_TR is not set ++ ++# ++# Wireless LAN ++# ++# CONFIG_WLAN_PRE80211 is not set ++# CONFIG_WLAN_80211 is not set ++# CONFIG_WAN is not set ++# CONFIG_FDDI is not set ++# CONFIG_HIPPI is not set ++# CONFIG_PPP is not set ++# CONFIG_SLIP is not set ++# CONFIG_SHAPER is not set ++# CONFIG_NETCONSOLE is not set ++# CONFIG_NETPOLL is not set ++# CONFIG_NET_POLL_CONTROLLER is not set ++# CONFIG_ISDN is not set ++# CONFIG_PHONE is not set ++ ++# ++# Input device support ++# ++# CONFIG_INPUT is not set ++ ++# ++# Hardware I/O ports ++# ++# CONFIG_SERIO is not set ++# CONFIG_GAMEPORT is not set ++ ++# ++# Character devices ++# ++# CONFIG_VT is not set ++# CONFIG_SERIAL_NONSTANDARD is not set ++ ++# ++# Serial drivers ++# ++CONFIG_SERIAL_8250=y ++CONFIG_SERIAL_8250_CONSOLE=y ++# CONFIG_SERIAL_8250_PCI is not set ++CONFIG_SERIAL_8250_NR_UARTS=4 ++CONFIG_SERIAL_8250_RUNTIME_UARTS=4 ++CONFIG_SERIAL_8250_EXTENDED=y ++# CONFIG_SERIAL_8250_MANY_PORTS is not set ++CONFIG_SERIAL_8250_SHARE_IRQ=y ++# CONFIG_SERIAL_8250_DETECT_IRQ is not set ++# CONFIG_SERIAL_8250_RSA is not set ++ ++# ++# Non-8250 serial port support ++# ++# CONFIG_SERIAL_UARTLITE is not set ++CONFIG_SERIAL_CORE=y ++CONFIG_SERIAL_CORE_CONSOLE=y ++# CONFIG_SERIAL_JSM is not set ++CONFIG_SERIAL_OF_PLATFORM=y ++CONFIG_UNIX98_PTYS=y ++CONFIG_LEGACY_PTYS=y ++CONFIG_LEGACY_PTY_COUNT=256 ++# CONFIG_IPMI_HANDLER is not set ++# CONFIG_HW_RANDOM is not set ++# CONFIG_NVRAM is not set ++# CONFIG_GEN_RTC is not set ++# CONFIG_R3964 is not set ++# CONFIG_APPLICOM is not set ++# CONFIG_RAW_DRIVER is not set ++# CONFIG_TCG_TPM is not set ++CONFIG_DEVPORT=y ++# CONFIG_I2C is not set ++ ++# ++# SPI support ++# ++# CONFIG_SPI is not set ++# CONFIG_SPI_MASTER is not set ++# CONFIG_W1 is not set ++# CONFIG_POWER_SUPPLY is not set ++# CONFIG_HWMON is not set ++# CONFIG_WATCHDOG is not set ++ ++# ++# Sonics Silicon Backplane ++# ++CONFIG_SSB_POSSIBLE=y ++# CONFIG_SSB is not set ++ ++# ++# Multifunction device drivers ++# ++# CONFIG_MFD_SM501 is not set ++ ++# ++# Multimedia devices ++# ++# CONFIG_VIDEO_DEV is not set ++# CONFIG_DVB_CORE is not set ++CONFIG_DAB=y ++ ++# ++# Graphics support ++# ++# CONFIG_AGP is not set ++# CONFIG_DRM is not set ++# CONFIG_VGASTATE is not set ++CONFIG_VIDEO_OUTPUT_CONTROL=m ++# CONFIG_FB is not set ++# CONFIG_BACKLIGHT_LCD_SUPPORT is not set ++ ++# ++# Display device support ++# ++# CONFIG_DISPLAY_SUPPORT is not set ++ ++# ++# Sound ++# ++# CONFIG_SOUND is not set ++CONFIG_USB_SUPPORT=y ++CONFIG_USB_ARCH_HAS_HCD=y ++CONFIG_USB_ARCH_HAS_OHCI=y ++CONFIG_USB_ARCH_HAS_EHCI=y ++# CONFIG_USB is not set ++ ++# ++# NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' ++# ++ ++# ++# USB Gadget Support ++# ++# CONFIG_USB_GADGET is not set ++# CONFIG_MMC is not set ++# CONFIG_NEW_LEDS is not set ++# CONFIG_INFINIBAND is not set ++# CONFIG_EDAC is not set ++# CONFIG_RTC_CLASS is not set ++ ++# ++# Userspace I/O ++# ++# CONFIG_UIO is not set ++ ++# ++# File systems ++# ++CONFIG_EXT2_FS=y ++# CONFIG_EXT2_FS_XATTR is not set ++# CONFIG_EXT2_FS_XIP is not set ++# CONFIG_EXT3_FS is not set ++# CONFIG_EXT4DEV_FS is not set ++# CONFIG_REISERFS_FS is not set ++# CONFIG_JFS_FS is not set ++# CONFIG_FS_POSIX_ACL is not set ++# CONFIG_XFS_FS is not set ++# CONFIG_GFS2_FS is not set ++# CONFIG_OCFS2_FS is not set ++# CONFIG_MINIX_FS is not set ++# CONFIG_ROMFS_FS is not set ++CONFIG_INOTIFY=y ++CONFIG_INOTIFY_USER=y ++# CONFIG_QUOTA is not set ++CONFIG_DNOTIFY=y ++# CONFIG_AUTOFS_FS is not set ++# CONFIG_AUTOFS4_FS is not set ++# CONFIG_FUSE_FS is not set ++ ++# ++# CD-ROM/DVD Filesystems ++# ++# CONFIG_ISO9660_FS is not set ++# CONFIG_UDF_FS is not set ++ ++# ++# DOS/FAT/NT Filesystems ++# ++# CONFIG_MSDOS_FS is not set ++# CONFIG_VFAT_FS is not set ++# CONFIG_NTFS_FS is not set ++ ++# ++# Pseudo filesystems ++# ++CONFIG_PROC_FS=y ++CONFIG_PROC_KCORE=y ++CONFIG_PROC_SYSCTL=y ++CONFIG_SYSFS=y ++CONFIG_TMPFS=y ++# CONFIG_TMPFS_POSIX_ACL is not set ++# CONFIG_HUGETLB_PAGE is not set ++# CONFIG_CONFIGFS_FS is not set ++ ++# ++# Miscellaneous filesystems ++# ++# CONFIG_ADFS_FS is not set ++# CONFIG_AFFS_FS is not set ++# CONFIG_HFS_FS is not set ++# CONFIG_HFSPLUS_FS is not set ++# CONFIG_BEFS_FS is not set ++# CONFIG_BFS_FS is not set ++# CONFIG_EFS_FS is not set ++CONFIG_CRAMFS=y ++# CONFIG_VXFS_FS is not set ++# CONFIG_HPFS_FS is not set ++# CONFIG_QNX4FS_FS is not set ++# CONFIG_SYSV_FS is not set ++# CONFIG_UFS_FS is not set ++CONFIG_NETWORK_FILESYSTEMS=y ++CONFIG_NFS_FS=y ++CONFIG_NFS_V3=y ++# CONFIG_NFS_V3_ACL is not set ++# CONFIG_NFS_V4 is not set ++# CONFIG_NFS_DIRECTIO is not set ++# CONFIG_NFSD is not set ++CONFIG_ROOT_NFS=y ++CONFIG_LOCKD=y ++CONFIG_LOCKD_V4=y ++CONFIG_NFS_COMMON=y ++CONFIG_SUNRPC=y ++# CONFIG_SUNRPC_BIND34 is not set ++# CONFIG_RPCSEC_GSS_KRB5 is not set ++# CONFIG_RPCSEC_GSS_SPKM3 is not set ++# CONFIG_SMB_FS is not set ++# CONFIG_CIFS is not set ++# CONFIG_NCP_FS is not set ++# CONFIG_CODA_FS is not set ++# CONFIG_AFS_FS is not set ++ ++# ++# Partition Types ++# ++# CONFIG_PARTITION_ADVANCED is not set ++CONFIG_MSDOS_PARTITION=y ++# CONFIG_NLS is not set ++# CONFIG_DLM is not set ++# CONFIG_UCC_SLOW is not set ++ ++# ++# Library routines ++# ++CONFIG_BITREVERSE=y ++# CONFIG_CRC_CCITT is not set ++# CONFIG_CRC16 is not set ++# CONFIG_CRC_ITU_T is not set ++CONFIG_CRC32=y ++# CONFIG_CRC7 is not set ++# CONFIG_LIBCRC32C is not set ++CONFIG_ZLIB_INFLATE=y ++CONFIG_PLIST=y ++CONFIG_HAS_IOMEM=y ++CONFIG_HAS_IOPORT=y ++CONFIG_HAS_DMA=y ++CONFIG_INSTRUMENTATION=y ++# CONFIG_PROFILING is not set ++# CONFIG_KPROBES is not set ++# CONFIG_MARKERS is not set ++ ++# ++# Kernel hacking ++# ++# CONFIG_PRINTK_TIME is not set ++CONFIG_ENABLE_WARN_DEPRECATED=y ++CONFIG_ENABLE_MUST_CHECK=y ++CONFIG_MAGIC_SYSRQ=y ++# CONFIG_UNUSED_SYMBOLS is not set ++# CONFIG_DEBUG_FS is not set ++# CONFIG_HEADERS_CHECK is not set ++CONFIG_DEBUG_KERNEL=y ++# CONFIG_DEBUG_SHIRQ is not set ++CONFIG_DETECT_SOFTLOCKUP=y ++CONFIG_SCHED_DEBUG=y ++# CONFIG_SCHEDSTATS is not set ++# CONFIG_TIMER_STATS is not set ++# CONFIG_SLUB_DEBUG_ON is not set ++# CONFIG_DEBUG_RT_MUTEXES is not set ++# CONFIG_RT_MUTEX_TESTER is not set ++# CONFIG_DEBUG_SPINLOCK is not set ++# CONFIG_DEBUG_MUTEXES is not set ++# CONFIG_DEBUG_SPINLOCK_SLEEP is not set ++# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set ++# CONFIG_DEBUG_KOBJECT is not set ++# CONFIG_DEBUG_BUGVERBOSE is not set ++# CONFIG_DEBUG_INFO is not set ++# CONFIG_DEBUG_VM is not set ++# CONFIG_DEBUG_LIST is not set ++# CONFIG_DEBUG_SG is not set ++CONFIG_FORCED_INLINING=y ++# CONFIG_BOOT_PRINTK_DELAY is not set ++# CONFIG_RCU_TORTURE_TEST is not set ++# CONFIG_FAULT_INJECTION is not set ++# CONFIG_SAMPLES is not set ++# CONFIG_DEBUG_STACKOVERFLOW is not set ++# CONFIG_DEBUG_STACK_USAGE is not set ++# CONFIG_DEBUG_PAGEALLOC is not set ++CONFIG_DEBUGGER=y ++# CONFIG_KGDB is not set ++# CONFIG_XMON is not set ++# CONFIG_BDI_SWITCH is not set ++# CONFIG_PPC_EARLY_DEBUG is not set ++ ++# ++# Security options ++# ++# CONFIG_KEYS is not set ++# CONFIG_SECURITY is not set ++# CONFIG_SECURITY_FILE_CAPABILITIES is not set ++CONFIG_CRYPTO=y ++CONFIG_CRYPTO_ALGAPI=y ++CONFIG_CRYPTO_BLKCIPHER=y ++CONFIG_CRYPTO_MANAGER=y ++# CONFIG_CRYPTO_HMAC is not set ++# CONFIG_CRYPTO_XCBC is not set ++# CONFIG_CRYPTO_NULL is not set ++# CONFIG_CRYPTO_MD4 is not set ++CONFIG_CRYPTO_MD5=y ++# CONFIG_CRYPTO_SHA1 is not set ++# CONFIG_CRYPTO_SHA256 is not set ++# CONFIG_CRYPTO_SHA512 is not set ++# CONFIG_CRYPTO_WP512 is not set ++# CONFIG_CRYPTO_TGR192 is not set ++# CONFIG_CRYPTO_GF128MUL is not set ++CONFIG_CRYPTO_ECB=y ++CONFIG_CRYPTO_CBC=y ++CONFIG_CRYPTO_PCBC=y ++# CONFIG_CRYPTO_LRW is not set ++# CONFIG_CRYPTO_XTS is not set ++# CONFIG_CRYPTO_CRYPTD is not set ++CONFIG_CRYPTO_DES=y ++# CONFIG_CRYPTO_FCRYPT is not set ++# CONFIG_CRYPTO_BLOWFISH is not set ++# CONFIG_CRYPTO_TWOFISH is not set ++# CONFIG_CRYPTO_SERPENT is not set ++# CONFIG_CRYPTO_AES is not set ++# CONFIG_CRYPTO_CAST5 is not set ++# CONFIG_CRYPTO_CAST6 is not set ++# CONFIG_CRYPTO_TEA is not set ++# CONFIG_CRYPTO_ARC4 is not set ++# CONFIG_CRYPTO_KHAZAD is not set ++# CONFIG_CRYPTO_ANUBIS is not set ++# CONFIG_CRYPTO_SEED is not set ++# CONFIG_CRYPTO_DEFLATE is not set ++# CONFIG_CRYPTO_MICHAEL_MIC is not set ++# CONFIG_CRYPTO_CRC32C is not set ++# CONFIG_CRYPTO_CAMELLIA is not set ++# CONFIG_CRYPTO_TEST is not set ++# CONFIG_CRYPTO_AUTHENC is not set ++CONFIG_CRYPTO_HW=y ++# CONFIG_PPC_CLOCK is not set +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/kilauea_defconfig powerpc.git/arch/powerpc/configs/kilauea_defconfig +--- linux-2.6.24/arch/powerpc/configs/kilauea_defconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/kilauea_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -1,7 +1,7 @@ + # + # Automatically generated make config: don't edit +-# Linux kernel version: 2.6.24-rc4 +-# Thu Dec 6 16:48:20 2007 ++# Linux kernel version: 2.6.24-rc6 ++# Thu Jan 3 14:21:31 2008 + # + # CONFIG_PPC64 is not set + +@@ -40,7 +40,7 @@ + CONFIG_ARCH_MAY_HAVE_PC_FDC=y + CONFIG_PPC_OF=y + CONFIG_OF=y +-# CONFIG_PPC_UDBG_16550 is not set ++CONFIG_PPC_UDBG_16550=y + # CONFIG_GENERIC_TBSYNC is not set + CONFIG_AUDIT_ARCH=y + CONFIG_GENERIC_BUG=y +@@ -125,6 +125,7 @@ + # CONFIG_DEFAULT_CFQ is not set + # CONFIG_DEFAULT_NOOP is not set + CONFIG_DEFAULT_IOSCHED="anticipatory" ++CONFIG_PPC4xx_PCI_EXPRESS=y + + # + # Platform support +@@ -134,9 +135,12 @@ + # CONFIG_PPC_CELL is not set + # CONFIG_PPC_CELL_NATIVE is not set + # CONFIG_PQ2ADS is not set ++# CONFIG_EP405 is not set + CONFIG_KILAUEA=y ++# CONFIG_MAKALU is not set + # CONFIG_WALNUT is not set + # CONFIG_XILINX_VIRTEX_GENERIC_BOARD is not set ++CONFIG_405EX=y + # CONFIG_MPIC is not set + # CONFIG_MPIC_WEIRD is not set + # CONFIG_PPC_I8259 is not set +@@ -199,11 +203,17 @@ + # Bus options + # + CONFIG_ZONE_DMA=y +-# CONFIG_PCI is not set +-# CONFIG_PCI_DOMAINS is not set +-# CONFIG_PCI_SYSCALL is not set +-# CONFIG_ARCH_SUPPORTS_MSI is not set ++CONFIG_PPC_INDIRECT_PCI=y ++CONFIG_PCI=y ++CONFIG_PCI_DOMAINS=y ++CONFIG_PCI_SYSCALL=y ++# CONFIG_PCIEPORTBUS is not set ++CONFIG_ARCH_SUPPORTS_MSI=y ++# CONFIG_PCI_MSI is not set ++CONFIG_PCI_LEGACY=y ++# CONFIG_PCI_DEBUG is not set + # CONFIG_PCCARD is not set ++# CONFIG_HOTPLUG_PCI is not set + + # + # Advanced setup +@@ -368,11 +378,13 @@ + # CONFIG_MTD_COMPLEX_MAPPINGS is not set + # CONFIG_MTD_PHYSMAP is not set + CONFIG_MTD_PHYSMAP_OF=y ++# CONFIG_MTD_INTEL_VR_NOR is not set + # CONFIG_MTD_PLATRAM is not set + + # + # Self-contained MTD device drivers + # ++# CONFIG_MTD_PMC551 is not set + # CONFIG_MTD_SLRAM is not set + # CONFIG_MTD_PHRAM is not set + # CONFIG_MTD_MTDRAM is not set +@@ -395,9 +407,14 @@ + # CONFIG_PARPORT is not set + CONFIG_BLK_DEV=y + # CONFIG_BLK_DEV_FD is not set ++# CONFIG_BLK_CPQ_DA is not set ++# CONFIG_BLK_CPQ_CISS_DA is not set ++# CONFIG_BLK_DEV_DAC960 is not set ++# CONFIG_BLK_DEV_UMEM is not set + # CONFIG_BLK_DEV_COW_COMMON is not set + # CONFIG_BLK_DEV_LOOP is not set + # CONFIG_BLK_DEV_NBD is not set ++# CONFIG_BLK_DEV_SX8 is not set + CONFIG_BLK_DEV_RAM=y + CONFIG_BLK_DEV_RAM_COUNT=16 + CONFIG_BLK_DEV_RAM_SIZE=35000 +@@ -417,6 +434,14 @@ + # CONFIG_SCSI_NETLINK is not set + # CONFIG_ATA is not set + # CONFIG_MD is not set ++# CONFIG_FUSION is not set ++ ++# ++# IEEE 1394 (FireWire) support ++# ++# CONFIG_FIREWIRE is not set ++# CONFIG_IEEE1394 is not set ++# CONFIG_I2O is not set + # CONFIG_MACINTOSH_DRIVERS is not set + CONFIG_NETDEVICES=y + # CONFIG_NETDEVICES_MULTIQUEUE is not set +@@ -426,9 +451,33 @@ + # CONFIG_EQUALIZER is not set + # CONFIG_TUN is not set + # CONFIG_VETH is not set +-# CONFIG_NET_ETHERNET is not set ++# CONFIG_IP1000 is not set ++# CONFIG_ARCNET is not set ++# CONFIG_PHYLIB is not set ++CONFIG_NET_ETHERNET=y ++# CONFIG_MII is not set ++# CONFIG_HAPPYMEAL is not set ++# CONFIG_SUNGEM is not set ++# CONFIG_CASSINI is not set ++# CONFIG_NET_VENDOR_3COM is not set ++# CONFIG_NET_TULIP is not set ++# CONFIG_HP100 is not set ++CONFIG_IBM_NEW_EMAC=y ++CONFIG_IBM_NEW_EMAC_RXB=256 ++CONFIG_IBM_NEW_EMAC_TXB=256 ++CONFIG_IBM_NEW_EMAC_POLL_WEIGHT=32 ++CONFIG_IBM_NEW_EMAC_RX_COPY_THRESHOLD=256 ++CONFIG_IBM_NEW_EMAC_RX_SKB_HEADROOM=0 ++# CONFIG_IBM_NEW_EMAC_DEBUG is not set ++# CONFIG_IBM_NEW_EMAC_ZMII is not set ++CONFIG_IBM_NEW_EMAC_RGMII=y ++# CONFIG_IBM_NEW_EMAC_TAH is not set ++CONFIG_IBM_NEW_EMAC_EMAC4=y ++# CONFIG_NET_PCI is not set ++# CONFIG_B44 is not set + # CONFIG_NETDEV_1000 is not set + # CONFIG_NETDEV_10000 is not set ++# CONFIG_TR is not set + + # + # Wireless LAN +@@ -436,6 +485,8 @@ + # CONFIG_WLAN_PRE80211 is not set + # CONFIG_WLAN_80211 is not set + # CONFIG_WAN is not set ++# CONFIG_FDDI is not set ++# CONFIG_HIPPI is not set + # CONFIG_PPP is not set + # CONFIG_SLIP is not set + # CONFIG_SHAPER is not set +@@ -467,6 +518,7 @@ + # + CONFIG_SERIAL_8250=y + CONFIG_SERIAL_8250_CONSOLE=y ++CONFIG_SERIAL_8250_PCI=y + CONFIG_SERIAL_8250_NR_UARTS=4 + CONFIG_SERIAL_8250_RUNTIME_UARTS=4 + CONFIG_SERIAL_8250_EXTENDED=y +@@ -481,6 +533,7 @@ + # CONFIG_SERIAL_UARTLITE is not set + CONFIG_SERIAL_CORE=y + CONFIG_SERIAL_CORE_CONSOLE=y ++# CONFIG_SERIAL_JSM is not set + CONFIG_SERIAL_OF_PLATFORM=y + CONFIG_UNIX98_PTYS=y + CONFIG_LEGACY_PTYS=y +@@ -490,8 +543,10 @@ + # CONFIG_NVRAM is not set + # CONFIG_GEN_RTC is not set + # CONFIG_R3964 is not set ++# CONFIG_APPLICOM is not set + # CONFIG_RAW_DRIVER is not set + # CONFIG_TCG_TPM is not set ++CONFIG_DEVPORT=y + # CONFIG_I2C is not set + + # +@@ -525,6 +580,8 @@ + # + # Graphics support + # ++# CONFIG_AGP is not set ++# CONFIG_DRM is not set + # CONFIG_VGASTATE is not set + # CONFIG_VIDEO_OUTPUT_CONTROL is not set + # CONFIG_FB is not set +@@ -542,6 +599,7 @@ + # CONFIG_USB_SUPPORT is not set + # CONFIG_MMC is not set + # CONFIG_NEW_LEDS is not set ++# CONFIG_INFINIBAND is not set + # CONFIG_EDAC is not set + # CONFIG_RTC_CLASS is not set + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/lite5200_defconfig powerpc.git/arch/powerpc/configs/lite5200_defconfig +--- linux-2.6.24/arch/powerpc/configs/lite5200_defconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/lite5200_defconfig 1970-01-01 01:00:00.000000000 +0100 +@@ -1,847 +0,0 @@ +-# +-# Automatically generated make config: don't edit +-# Linux kernel version: 2.6.24-rc4 +-# Thu Dec 6 16:48:24 2007 +-# +-# CONFIG_PPC64 is not set +- +-# +-# Processor support +-# +-CONFIG_6xx=y +-# CONFIG_PPC_85xx is not set +-# CONFIG_PPC_8xx is not set +-# CONFIG_40x is not set +-# CONFIG_44x is not set +-# CONFIG_E200 is not set +-CONFIG_PPC_FPU=y +-# CONFIG_ALTIVEC is not set +-CONFIG_PPC_STD_MMU=y +-CONFIG_PPC_STD_MMU_32=y +-# CONFIG_PPC_MM_SLICES is not set +-# CONFIG_SMP is not set +-CONFIG_PPC32=y +-CONFIG_WORD_SIZE=32 +-CONFIG_PPC_MERGE=y +-CONFIG_MMU=y +-CONFIG_GENERIC_CMOS_UPDATE=y +-CONFIG_GENERIC_TIME=y +-CONFIG_GENERIC_TIME_VSYSCALL=y +-CONFIG_GENERIC_CLOCKEVENTS=y +-CONFIG_GENERIC_HARDIRQS=y +-CONFIG_IRQ_PER_CPU=y +-CONFIG_RWSEM_XCHGADD_ALGORITHM=y +-CONFIG_ARCH_HAS_ILOG2_U32=y +-CONFIG_GENERIC_HWEIGHT=y +-CONFIG_GENERIC_CALIBRATE_DELAY=y +-CONFIG_GENERIC_FIND_NEXT_BIT=y +-# CONFIG_ARCH_NO_VIRT_TO_BUS is not set +-CONFIG_PPC=y +-CONFIG_EARLY_PRINTK=y +-CONFIG_GENERIC_NVRAM=y +-CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y +-CONFIG_ARCH_MAY_HAVE_PC_FDC=y +-CONFIG_PPC_OF=y +-CONFIG_OF=y +-# CONFIG_PPC_UDBG_16550 is not set +-# CONFIG_GENERIC_TBSYNC is not set +-CONFIG_AUDIT_ARCH=y +-CONFIG_GENERIC_BUG=y +-# CONFIG_DEFAULT_UIMAGE is not set +-# CONFIG_PPC_DCR_NATIVE is not set +-# CONFIG_PPC_DCR_MMIO is not set +-CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" +- +-# +-# General setup +-# +-CONFIG_EXPERIMENTAL=y +-CONFIG_BROKEN_ON_SMP=y +-CONFIG_INIT_ENV_ARG_LIMIT=32 +-CONFIG_LOCALVERSION="" +-CONFIG_LOCALVERSION_AUTO=y +-CONFIG_SWAP=y +-CONFIG_SYSVIPC=y +-CONFIG_SYSVIPC_SYSCTL=y +-# CONFIG_POSIX_MQUEUE is not set +-# CONFIG_BSD_PROCESS_ACCT is not set +-# CONFIG_TASKSTATS is not set +-# CONFIG_USER_NS is not set +-# CONFIG_PID_NS is not set +-# CONFIG_AUDIT is not set +-# CONFIG_IKCONFIG is not set +-CONFIG_LOG_BUF_SHIFT=14 +-# CONFIG_CGROUPS is not set +-# CONFIG_FAIR_GROUP_SCHED is not set +-CONFIG_SYSFS_DEPRECATED=y +-# CONFIG_RELAY is not set +-CONFIG_BLK_DEV_INITRD=y +-CONFIG_INITRAMFS_SOURCE="" +-# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set +-CONFIG_SYSCTL=y +-CONFIG_EMBEDDED=y +-# CONFIG_SYSCTL_SYSCALL is not set +-# CONFIG_KALLSYMS is not set +-CONFIG_HOTPLUG=y +-CONFIG_PRINTK=y +-CONFIG_BUG=y +-CONFIG_ELF_CORE=y +-CONFIG_BASE_FULL=y +-CONFIG_FUTEX=y +-CONFIG_ANON_INODES=y +-# CONFIG_EPOLL is not set +-CONFIG_SIGNALFD=y +-CONFIG_EVENTFD=y +-CONFIG_SHMEM=y +-CONFIG_VM_EVENT_COUNTERS=y +-CONFIG_SLUB_DEBUG=y +-# CONFIG_SLAB is not set +-CONFIG_SLUB=y +-# CONFIG_SLOB is not set +-CONFIG_RT_MUTEXES=y +-# CONFIG_TINY_SHMEM is not set +-CONFIG_BASE_SMALL=0 +-CONFIG_MODULES=y +-CONFIG_MODULE_UNLOAD=y +-# CONFIG_MODULE_FORCE_UNLOAD is not set +-# CONFIG_MODVERSIONS is not set +-# CONFIG_MODULE_SRCVERSION_ALL is not set +-# CONFIG_KMOD is not set +-CONFIG_BLOCK=y +-# CONFIG_LBD is not set +-# CONFIG_BLK_DEV_IO_TRACE is not set +-# CONFIG_LSF is not set +-# CONFIG_BLK_DEV_BSG is not set +- +-# +-# IO Schedulers +-# +-CONFIG_IOSCHED_NOOP=y +-CONFIG_IOSCHED_AS=y +-CONFIG_IOSCHED_DEADLINE=y +-CONFIG_IOSCHED_CFQ=y +-CONFIG_DEFAULT_AS=y +-# CONFIG_DEFAULT_DEADLINE is not set +-# CONFIG_DEFAULT_CFQ is not set +-# CONFIG_DEFAULT_NOOP is not set +-CONFIG_DEFAULT_IOSCHED="anticipatory" +- +-# +-# Platform support +-# +-CONFIG_PPC_MULTIPLATFORM=y +-# CONFIG_PPC_82xx is not set +-# CONFIG_PPC_83xx is not set +-# CONFIG_PPC_86xx is not set +-CONFIG_CLASSIC32=y +-# CONFIG_PPC_CHRP is not set +-CONFIG_PPC_MPC52xx=y +-CONFIG_PPC_MPC5200=y +-CONFIG_PPC_MPC5200_BUGFIX=y +-# CONFIG_PPC_EFIKA is not set +-CONFIG_PPC_LITE5200=y +-# CONFIG_PPC_PMAC is not set +-# CONFIG_PPC_CELL is not set +-# CONFIG_PPC_CELL_NATIVE is not set +-# CONFIG_PQ2ADS is not set +-# CONFIG_EMBEDDED6xx is not set +-# CONFIG_MPIC is not set +-# CONFIG_MPIC_WEIRD is not set +-# CONFIG_PPC_I8259 is not set +-# CONFIG_PPC_RTAS is not set +-# CONFIG_MMIO_NVRAM is not set +-# CONFIG_PPC_MPC106 is not set +-# CONFIG_PPC_970_NAP is not set +-# CONFIG_PPC_INDIRECT_IO is not set +-# CONFIG_GENERIC_IOMAP is not set +-# CONFIG_CPU_FREQ is not set +-# CONFIG_TAU is not set +-# CONFIG_CPM2 is not set +-# CONFIG_FSL_ULI1575 is not set +-CONFIG_PPC_BESTCOMM=y +-CONFIG_PPC_BESTCOMM_ATA=y +-CONFIG_PPC_BESTCOMM_FEC=y +-CONFIG_PPC_BESTCOMM_GEN_BD=y +- +-# +-# Kernel options +-# +-# CONFIG_HIGHMEM is not set +-CONFIG_TICK_ONESHOT=y +-CONFIG_NO_HZ=y +-CONFIG_HIGH_RES_TIMERS=y +-CONFIG_GENERIC_CLOCKEVENTS_BUILD=y +-# CONFIG_HZ_100 is not set +-CONFIG_HZ_250=y +-# CONFIG_HZ_300 is not set +-# CONFIG_HZ_1000 is not set +-CONFIG_HZ=250 +-CONFIG_PREEMPT_NONE=y +-# CONFIG_PREEMPT_VOLUNTARY is not set +-# CONFIG_PREEMPT is not set +-CONFIG_BINFMT_ELF=y +-# CONFIG_BINFMT_MISC is not set +-CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y +-# CONFIG_KEXEC is not set +-CONFIG_ARCH_FLATMEM_ENABLE=y +-CONFIG_ARCH_POPULATES_NODE_MAP=y +-CONFIG_SELECT_MEMORY_MODEL=y +-CONFIG_FLATMEM_MANUAL=y +-# CONFIG_DISCONTIGMEM_MANUAL is not set +-# CONFIG_SPARSEMEM_MANUAL is not set +-CONFIG_FLATMEM=y +-CONFIG_FLAT_NODE_MEM_MAP=y +-# CONFIG_SPARSEMEM_STATIC is not set +-# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set +-CONFIG_SPLIT_PTLOCK_CPUS=4 +-# CONFIG_RESOURCES_64BIT is not set +-CONFIG_ZONE_DMA_FLAG=1 +-CONFIG_BOUNCE=y +-CONFIG_VIRT_TO_BUS=y +-CONFIG_PROC_DEVICETREE=y +-# CONFIG_CMDLINE_BOOL is not set +-CONFIG_PM=y +-# CONFIG_PM_LEGACY is not set +-# CONFIG_PM_DEBUG is not set +-CONFIG_PM_SLEEP=y +-CONFIG_SUSPEND_UP_POSSIBLE=y +-CONFIG_SUSPEND=y +-CONFIG_HIBERNATION_UP_POSSIBLE=y +-# CONFIG_HIBERNATION is not set +-CONFIG_SECCOMP=y +-CONFIG_WANT_DEVICE_TREE=y +-CONFIG_DEVICE_TREE="" +-CONFIG_ISA_DMA_API=y +- +-# +-# Bus options +-# +-CONFIG_ZONE_DMA=y +-CONFIG_GENERIC_ISA_DMA=y +-# CONFIG_PPC_INDIRECT_PCI is not set +-CONFIG_FSL_SOC=y +-CONFIG_PCI=y +-CONFIG_PCI_DOMAINS=y +-CONFIG_PCI_SYSCALL=y +-# CONFIG_PCIEPORTBUS is not set +-CONFIG_ARCH_SUPPORTS_MSI=y +-# CONFIG_PCI_MSI is not set +-CONFIG_PCI_LEGACY=y +-# CONFIG_PCI_DEBUG is not set +-# CONFIG_PCCARD is not set +-# CONFIG_HOTPLUG_PCI is not set +- +-# +-# Advanced setup +-# +-# CONFIG_ADVANCED_OPTIONS is not set +- +-# +-# Default settings for advanced configuration options are used +-# +-CONFIG_HIGHMEM_START=0xfe000000 +-CONFIG_LOWMEM_SIZE=0x30000000 +-CONFIG_KERNEL_START=0xc0000000 +-CONFIG_TASK_SIZE=0xc0000000 +-CONFIG_BOOT_LOAD=0x00800000 +- +-# +-# Networking +-# +-CONFIG_NET=y +- +-# +-# Networking options +-# +-CONFIG_PACKET=y +-# CONFIG_PACKET_MMAP is not set +-CONFIG_UNIX=y +-CONFIG_XFRM=y +-CONFIG_XFRM_USER=m +-# CONFIG_XFRM_SUB_POLICY is not set +-# CONFIG_XFRM_MIGRATE is not set +-# CONFIG_NET_KEY is not set +-CONFIG_INET=y +-CONFIG_IP_MULTICAST=y +-# CONFIG_IP_ADVANCED_ROUTER is not set +-CONFIG_IP_FIB_HASH=y +-CONFIG_IP_PNP=y +-CONFIG_IP_PNP_DHCP=y +-CONFIG_IP_PNP_BOOTP=y +-# CONFIG_IP_PNP_RARP is not set +-# CONFIG_NET_IPIP is not set +-# CONFIG_NET_IPGRE is not set +-# CONFIG_IP_MROUTE is not set +-# CONFIG_ARPD is not set +-CONFIG_SYN_COOKIES=y +-# CONFIG_INET_AH is not set +-# CONFIG_INET_ESP is not set +-# CONFIG_INET_IPCOMP is not set +-# CONFIG_INET_XFRM_TUNNEL is not set +-# CONFIG_INET_TUNNEL is not set +-CONFIG_INET_XFRM_MODE_TRANSPORT=y +-CONFIG_INET_XFRM_MODE_TUNNEL=y +-CONFIG_INET_XFRM_MODE_BEET=y +-# CONFIG_INET_LRO is not set +-CONFIG_INET_DIAG=y +-CONFIG_INET_TCP_DIAG=y +-# CONFIG_TCP_CONG_ADVANCED is not set +-CONFIG_TCP_CONG_CUBIC=y +-CONFIG_DEFAULT_TCP_CONG="cubic" +-# CONFIG_TCP_MD5SIG is not set +-# CONFIG_IPV6 is not set +-# CONFIG_INET6_XFRM_TUNNEL is not set +-# CONFIG_INET6_TUNNEL is not set +-# CONFIG_NETWORK_SECMARK is not set +-# CONFIG_NETFILTER is not set +-# CONFIG_IP_DCCP is not set +-# CONFIG_IP_SCTP is not set +-# CONFIG_TIPC is not set +-# CONFIG_ATM is not set +-# CONFIG_BRIDGE is not set +-# CONFIG_VLAN_8021Q is not set +-# CONFIG_DECNET is not set +-# CONFIG_LLC2 is not set +-# CONFIG_IPX is not set +-# CONFIG_ATALK is not set +-# CONFIG_X25 is not set +-# CONFIG_LAPB is not set +-# CONFIG_ECONET is not set +-# CONFIG_WAN_ROUTER is not set +-# CONFIG_NET_SCHED is not set +- +-# +-# Network testing +-# +-# CONFIG_NET_PKTGEN is not set +-# CONFIG_HAMRADIO is not set +-# CONFIG_IRDA is not set +-# CONFIG_BT is not set +-# CONFIG_AF_RXRPC is not set +- +-# +-# Wireless +-# +-# CONFIG_CFG80211 is not set +-# CONFIG_WIRELESS_EXT is not set +-# CONFIG_MAC80211 is not set +-# CONFIG_IEEE80211 is not set +-# CONFIG_RFKILL is not set +-# CONFIG_NET_9P is not set +- +-# +-# Device Drivers +-# +- +-# +-# Generic Driver Options +-# +-CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" +-CONFIG_STANDALONE=y +-CONFIG_PREVENT_FIRMWARE_BUILD=y +-# CONFIG_FW_LOADER is not set +-# CONFIG_DEBUG_DRIVER is not set +-# CONFIG_DEBUG_DEVRES is not set +-# CONFIG_SYS_HYPERVISOR is not set +-# CONFIG_CONNECTOR is not set +-# CONFIG_MTD is not set +-CONFIG_OF_DEVICE=y +-# CONFIG_PARPORT is not set +-CONFIG_BLK_DEV=y +-# CONFIG_BLK_DEV_FD is not set +-# CONFIG_BLK_CPQ_DA is not set +-# CONFIG_BLK_CPQ_CISS_DA is not set +-# CONFIG_BLK_DEV_DAC960 is not set +-# CONFIG_BLK_DEV_UMEM is not set +-# CONFIG_BLK_DEV_COW_COMMON is not set +-CONFIG_BLK_DEV_LOOP=y +-# CONFIG_BLK_DEV_CRYPTOLOOP is not set +-# CONFIG_BLK_DEV_NBD is not set +-# CONFIG_BLK_DEV_SX8 is not set +-CONFIG_BLK_DEV_RAM=y +-CONFIG_BLK_DEV_RAM_COUNT=16 +-CONFIG_BLK_DEV_RAM_SIZE=32768 +-CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024 +-# CONFIG_CDROM_PKTCDVD is not set +-# CONFIG_ATA_OVER_ETH is not set +-CONFIG_MISC_DEVICES=y +-# CONFIG_PHANTOM is not set +-# CONFIG_EEPROM_93CX6 is not set +-# CONFIG_SGI_IOC4 is not set +-# CONFIG_TIFM_CORE is not set +-# CONFIG_IDE is not set +- +-# +-# SCSI device support +-# +-# CONFIG_RAID_ATTRS is not set +-CONFIG_SCSI=y +-CONFIG_SCSI_DMA=y +-# CONFIG_SCSI_TGT is not set +-# CONFIG_SCSI_NETLINK is not set +-# CONFIG_SCSI_PROC_FS is not set +- +-# +-# SCSI support type (disk, tape, CD-ROM) +-# +-# CONFIG_BLK_DEV_SD is not set +-# CONFIG_CHR_DEV_ST is not set +-# CONFIG_CHR_DEV_OSST is not set +-# CONFIG_BLK_DEV_SR is not set +-# CONFIG_CHR_DEV_SG is not set +-# CONFIG_CHR_DEV_SCH is not set +- +-# +-# Some SCSI devices (e.g. CD jukebox) support multiple LUNs +-# +-# CONFIG_SCSI_MULTI_LUN is not set +-# CONFIG_SCSI_CONSTANTS is not set +-# CONFIG_SCSI_LOGGING is not set +-# CONFIG_SCSI_SCAN_ASYNC is not set +-CONFIG_SCSI_WAIT_SCAN=m +- +-# +-# SCSI Transports +-# +-# CONFIG_SCSI_SPI_ATTRS is not set +-# CONFIG_SCSI_FC_ATTRS is not set +-# CONFIG_SCSI_ISCSI_ATTRS is not set +-# CONFIG_SCSI_SAS_LIBSAS is not set +-# CONFIG_SCSI_SRP_ATTRS is not set +-CONFIG_SCSI_LOWLEVEL=y +-# CONFIG_ISCSI_TCP is not set +-# CONFIG_BLK_DEV_3W_XXXX_RAID is not set +-# CONFIG_SCSI_3W_9XXX is not set +-# CONFIG_SCSI_ACARD is not set +-# CONFIG_SCSI_AACRAID is not set +-# CONFIG_SCSI_AIC7XXX is not set +-# CONFIG_SCSI_AIC7XXX_OLD is not set +-# CONFIG_SCSI_AIC79XX is not set +-# CONFIG_SCSI_AIC94XX is not set +-# CONFIG_SCSI_DPT_I2O is not set +-# CONFIG_SCSI_ADVANSYS is not set +-# CONFIG_SCSI_ARCMSR is not set +-# CONFIG_MEGARAID_NEWGEN is not set +-# CONFIG_MEGARAID_LEGACY is not set +-# CONFIG_MEGARAID_SAS is not set +-# CONFIG_SCSI_HPTIOP is not set +-# CONFIG_SCSI_BUSLOGIC is not set +-# CONFIG_SCSI_DMX3191D is not set +-# CONFIG_SCSI_EATA is not set +-# CONFIG_SCSI_FUTURE_DOMAIN is not set +-# CONFIG_SCSI_GDTH is not set +-# CONFIG_SCSI_IPS is not set +-# CONFIG_SCSI_INITIO is not set +-# CONFIG_SCSI_INIA100 is not set +-# CONFIG_SCSI_STEX is not set +-# CONFIG_SCSI_SYM53C8XX_2 is not set +-# CONFIG_SCSI_IPR is not set +-# CONFIG_SCSI_QLOGIC_1280 is not set +-# CONFIG_SCSI_QLA_FC is not set +-# CONFIG_SCSI_QLA_ISCSI is not set +-# CONFIG_SCSI_LPFC is not set +-# CONFIG_SCSI_DC395x is not set +-# CONFIG_SCSI_DC390T is not set +-# CONFIG_SCSI_NSP32 is not set +-# CONFIG_SCSI_DEBUG is not set +-# CONFIG_SCSI_SRP is not set +-CONFIG_ATA=y +-# CONFIG_ATA_NONSTANDARD is not set +-# CONFIG_SATA_AHCI is not set +-# CONFIG_SATA_SVW is not set +-# CONFIG_ATA_PIIX is not set +-# CONFIG_SATA_MV is not set +-# CONFIG_SATA_NV is not set +-# CONFIG_PDC_ADMA is not set +-# CONFIG_SATA_QSTOR is not set +-# CONFIG_SATA_PROMISE is not set +-# CONFIG_SATA_SX4 is not set +-# CONFIG_SATA_SIL is not set +-# CONFIG_SATA_SIL24 is not set +-# CONFIG_SATA_SIS is not set +-# CONFIG_SATA_ULI is not set +-# CONFIG_SATA_VIA is not set +-# CONFIG_SATA_VITESSE is not set +-# CONFIG_SATA_INIC162X is not set +-# CONFIG_PATA_ALI is not set +-# CONFIG_PATA_AMD is not set +-# CONFIG_PATA_ARTOP is not set +-# CONFIG_PATA_ATIIXP is not set +-# CONFIG_PATA_CMD640_PCI is not set +-# CONFIG_PATA_CMD64X is not set +-# CONFIG_PATA_CS5520 is not set +-# CONFIG_PATA_CS5530 is not set +-# CONFIG_PATA_CYPRESS is not set +-# CONFIG_PATA_EFAR is not set +-# CONFIG_ATA_GENERIC is not set +-# CONFIG_PATA_HPT366 is not set +-# CONFIG_PATA_HPT37X is not set +-# CONFIG_PATA_HPT3X2N is not set +-# CONFIG_PATA_HPT3X3 is not set +-# CONFIG_PATA_IT821X is not set +-# CONFIG_PATA_IT8213 is not set +-# CONFIG_PATA_JMICRON is not set +-# CONFIG_PATA_TRIFLEX is not set +-# CONFIG_PATA_MARVELL is not set +-CONFIG_PATA_MPC52xx=y +-# CONFIG_PATA_MPIIX is not set +-# CONFIG_PATA_OLDPIIX is not set +-# CONFIG_PATA_NETCELL is not set +-# CONFIG_PATA_NS87410 is not set +-# CONFIG_PATA_NS87415 is not set +-# CONFIG_PATA_OPTI is not set +-# CONFIG_PATA_OPTIDMA is not set +-# CONFIG_PATA_PDC_OLD is not set +-# CONFIG_PATA_RADISYS is not set +-# CONFIG_PATA_RZ1000 is not set +-# CONFIG_PATA_SC1200 is not set +-# CONFIG_PATA_SERVERWORKS is not set +-# CONFIG_PATA_PDC2027X is not set +-# CONFIG_PATA_SIL680 is not set +-# CONFIG_PATA_SIS is not set +-# CONFIG_PATA_VIA is not set +-# CONFIG_PATA_WINBOND is not set +-# CONFIG_PATA_PLATFORM is not set +-# CONFIG_MD is not set +-# CONFIG_FUSION is not set +- +-# +-# IEEE 1394 (FireWire) support +-# +-# CONFIG_FIREWIRE is not set +-# CONFIG_IEEE1394 is not set +-# CONFIG_I2O is not set +-# CONFIG_MACINTOSH_DRIVERS is not set +-CONFIG_NETDEVICES=y +-# CONFIG_NETDEVICES_MULTIQUEUE is not set +-# CONFIG_DUMMY is not set +-# CONFIG_BONDING is not set +-# CONFIG_MACVLAN is not set +-# CONFIG_EQUALIZER is not set +-# CONFIG_TUN is not set +-# CONFIG_VETH is not set +-# CONFIG_IP1000 is not set +-# CONFIG_ARCNET is not set +-# CONFIG_NET_ETHERNET is not set +-CONFIG_NETDEV_1000=y +-# CONFIG_ACENIC is not set +-# CONFIG_DL2K is not set +-# CONFIG_E1000 is not set +-# CONFIG_E1000E is not set +-# CONFIG_NS83820 is not set +-# CONFIG_HAMACHI is not set +-# CONFIG_YELLOWFIN is not set +-# CONFIG_R8169 is not set +-# CONFIG_SIS190 is not set +-# CONFIG_SKGE is not set +-# CONFIG_SKY2 is not set +-# CONFIG_SK98LIN is not set +-# CONFIG_VIA_VELOCITY is not set +-# CONFIG_TIGON3 is not set +-# CONFIG_BNX2 is not set +-# CONFIG_MV643XX_ETH is not set +-# CONFIG_QLA3XXX is not set +-# CONFIG_ATL1 is not set +-CONFIG_NETDEV_10000=y +-# CONFIG_CHELSIO_T1 is not set +-# CONFIG_CHELSIO_T3 is not set +-# CONFIG_IXGBE is not set +-# CONFIG_IXGB is not set +-# CONFIG_S2IO is not set +-# CONFIG_MYRI10GE is not set +-# CONFIG_NETXEN_NIC is not set +-# CONFIG_NIU is not set +-# CONFIG_MLX4_CORE is not set +-# CONFIG_TEHUTI is not set +-# CONFIG_TR is not set +- +-# +-# Wireless LAN +-# +-# CONFIG_WLAN_PRE80211 is not set +-# CONFIG_WLAN_80211 is not set +-# CONFIG_WAN is not set +-# CONFIG_FDDI is not set +-# CONFIG_HIPPI is not set +-# CONFIG_PPP is not set +-# CONFIG_SLIP is not set +-# CONFIG_NET_FC is not set +-# CONFIG_SHAPER is not set +-# CONFIG_NETCONSOLE is not set +-# CONFIG_NETPOLL is not set +-# CONFIG_NET_POLL_CONTROLLER is not set +-# CONFIG_ISDN is not set +-# CONFIG_PHONE is not set +- +-# +-# Input device support +-# +-# CONFIG_INPUT is not set +- +-# +-# Hardware I/O ports +-# +-# CONFIG_SERIO is not set +-# CONFIG_GAMEPORT is not set +- +-# +-# Character devices +-# +-# CONFIG_VT is not set +-# CONFIG_SERIAL_NONSTANDARD is not set +- +-# +-# Serial drivers +-# +-# CONFIG_SERIAL_8250 is not set +- +-# +-# Non-8250 serial port support +-# +-# CONFIG_SERIAL_UARTLITE is not set +-CONFIG_SERIAL_CORE=y +-CONFIG_SERIAL_CORE_CONSOLE=y +-CONFIG_SERIAL_MPC52xx=y +-CONFIG_SERIAL_MPC52xx_CONSOLE=y +-CONFIG_SERIAL_MPC52xx_CONSOLE_BAUD=9600 +-# CONFIG_SERIAL_JSM is not set +-CONFIG_UNIX98_PTYS=y +-CONFIG_LEGACY_PTYS=y +-CONFIG_LEGACY_PTY_COUNT=256 +-# CONFIG_IPMI_HANDLER is not set +-# CONFIG_HW_RANDOM is not set +-# CONFIG_NVRAM is not set +-# CONFIG_GEN_RTC is not set +-# CONFIG_R3964 is not set +-# CONFIG_APPLICOM is not set +-# CONFIG_RAW_DRIVER is not set +-# CONFIG_TCG_TPM is not set +-CONFIG_DEVPORT=y +-# CONFIG_I2C is not set +- +-# +-# SPI support +-# +-# CONFIG_SPI is not set +-# CONFIG_SPI_MASTER is not set +-# CONFIG_W1 is not set +-# CONFIG_POWER_SUPPLY is not set +-# CONFIG_HWMON is not set +-# CONFIG_WATCHDOG is not set +- +-# +-# Sonics Silicon Backplane +-# +-CONFIG_SSB_POSSIBLE=y +-# CONFIG_SSB is not set +- +-# +-# Multifunction device drivers +-# +-# CONFIG_MFD_SM501 is not set +- +-# +-# Multimedia devices +-# +-# CONFIG_VIDEO_DEV is not set +-# CONFIG_DVB_CORE is not set +-# CONFIG_DAB is not set +- +-# +-# Graphics support +-# +-# CONFIG_AGP is not set +-# CONFIG_DRM is not set +-# CONFIG_VGASTATE is not set +-CONFIG_VIDEO_OUTPUT_CONTROL=m +-# CONFIG_FB is not set +-# CONFIG_BACKLIGHT_LCD_SUPPORT is not set +- +-# +-# Display device support +-# +-# CONFIG_DISPLAY_SUPPORT is not set +- +-# +-# Sound +-# +-# CONFIG_SOUND is not set +-CONFIG_USB_SUPPORT=y +-CONFIG_USB_ARCH_HAS_HCD=y +-CONFIG_USB_ARCH_HAS_OHCI=y +-CONFIG_USB_ARCH_HAS_EHCI=y +-# CONFIG_USB is not set +- +-# +-# NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' +-# +- +-# +-# USB Gadget Support +-# +-# CONFIG_USB_GADGET is not set +-# CONFIG_MMC is not set +-# CONFIG_NEW_LEDS is not set +-# CONFIG_INFINIBAND is not set +-# CONFIG_EDAC is not set +-# CONFIG_RTC_CLASS is not set +- +-# +-# Userspace I/O +-# +-# CONFIG_UIO is not set +- +-# +-# File systems +-# +-CONFIG_EXT2_FS=y +-# CONFIG_EXT2_FS_XATTR is not set +-# CONFIG_EXT2_FS_XIP is not set +-CONFIG_EXT3_FS=y +-CONFIG_EXT3_FS_XATTR=y +-# CONFIG_EXT3_FS_POSIX_ACL is not set +-# CONFIG_EXT3_FS_SECURITY is not set +-# CONFIG_EXT4DEV_FS is not set +-CONFIG_JBD=y +-CONFIG_FS_MBCACHE=y +-# CONFIG_REISERFS_FS is not set +-# CONFIG_JFS_FS is not set +-# CONFIG_FS_POSIX_ACL is not set +-# CONFIG_XFS_FS is not set +-# CONFIG_GFS2_FS is not set +-# CONFIG_OCFS2_FS is not set +-# CONFIG_MINIX_FS is not set +-# CONFIG_ROMFS_FS is not set +-CONFIG_INOTIFY=y +-CONFIG_INOTIFY_USER=y +-# CONFIG_QUOTA is not set +-CONFIG_DNOTIFY=y +-# CONFIG_AUTOFS_FS is not set +-# CONFIG_AUTOFS4_FS is not set +-# CONFIG_FUSE_FS is not set +- +-# +-# CD-ROM/DVD Filesystems +-# +-# CONFIG_ISO9660_FS is not set +-# CONFIG_UDF_FS is not set +- +-# +-# DOS/FAT/NT Filesystems +-# +-# CONFIG_MSDOS_FS is not set +-# CONFIG_VFAT_FS is not set +-# CONFIG_NTFS_FS is not set +- +-# +-# Pseudo filesystems +-# +-CONFIG_PROC_FS=y +-CONFIG_PROC_KCORE=y +-CONFIG_PROC_SYSCTL=y +-CONFIG_SYSFS=y +-CONFIG_TMPFS=y +-# CONFIG_TMPFS_POSIX_ACL is not set +-# CONFIG_HUGETLB_PAGE is not set +-# CONFIG_CONFIGFS_FS is not set +- +-# +-# Miscellaneous filesystems +-# +-# CONFIG_ADFS_FS is not set +-# CONFIG_AFFS_FS is not set +-# CONFIG_HFS_FS is not set +-# CONFIG_HFSPLUS_FS is not set +-# CONFIG_BEFS_FS is not set +-# CONFIG_BFS_FS is not set +-# CONFIG_EFS_FS is not set +-# CONFIG_CRAMFS is not set +-# CONFIG_VXFS_FS is not set +-# CONFIG_HPFS_FS is not set +-# CONFIG_QNX4FS_FS is not set +-# CONFIG_SYSV_FS is not set +-# CONFIG_UFS_FS is not set +-CONFIG_NETWORK_FILESYSTEMS=y +-# CONFIG_NFS_FS is not set +-# CONFIG_NFSD is not set +-# CONFIG_SMB_FS is not set +-# CONFIG_CIFS is not set +-# CONFIG_NCP_FS is not set +-# CONFIG_CODA_FS is not set +-# CONFIG_AFS_FS is not set +- +-# +-# Partition Types +-# +-# CONFIG_PARTITION_ADVANCED is not set +-CONFIG_MSDOS_PARTITION=y +-# CONFIG_NLS is not set +-# CONFIG_DLM is not set +-# CONFIG_UCC_SLOW is not set +- +-# +-# Library routines +-# +-# CONFIG_CRC_CCITT is not set +-# CONFIG_CRC16 is not set +-# CONFIG_CRC_ITU_T is not set +-# CONFIG_CRC32 is not set +-# CONFIG_CRC7 is not set +-# CONFIG_LIBCRC32C is not set +-CONFIG_PLIST=y +-CONFIG_HAS_IOMEM=y +-CONFIG_HAS_IOPORT=y +-CONFIG_HAS_DMA=y +-# CONFIG_INSTRUMENTATION is not set +- +-# +-# Kernel hacking +-# +-CONFIG_PRINTK_TIME=y +-CONFIG_ENABLE_WARN_DEPRECATED=y +-CONFIG_ENABLE_MUST_CHECK=y +-# CONFIG_MAGIC_SYSRQ is not set +-# CONFIG_UNUSED_SYMBOLS is not set +-# CONFIG_DEBUG_FS is not set +-# CONFIG_HEADERS_CHECK is not set +-CONFIG_DEBUG_KERNEL=y +-# CONFIG_DEBUG_SHIRQ is not set +-CONFIG_DETECT_SOFTLOCKUP=y +-CONFIG_SCHED_DEBUG=y +-# CONFIG_SCHEDSTATS is not set +-# CONFIG_TIMER_STATS is not set +-# CONFIG_SLUB_DEBUG_ON is not set +-# CONFIG_DEBUG_RT_MUTEXES is not set +-# CONFIG_RT_MUTEX_TESTER is not set +-# CONFIG_DEBUG_SPINLOCK is not set +-# CONFIG_DEBUG_MUTEXES is not set +-# CONFIG_DEBUG_SPINLOCK_SLEEP is not set +-# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set +-# CONFIG_DEBUG_KOBJECT is not set +-# CONFIG_DEBUG_BUGVERBOSE is not set +-CONFIG_DEBUG_INFO=y +-# CONFIG_DEBUG_VM is not set +-# CONFIG_DEBUG_LIST is not set +-# CONFIG_DEBUG_SG is not set +-CONFIG_FORCED_INLINING=y +-# CONFIG_BOOT_PRINTK_DELAY is not set +-# CONFIG_RCU_TORTURE_TEST is not set +-# CONFIG_FAULT_INJECTION is not set +-# CONFIG_SAMPLES is not set +-# CONFIG_DEBUG_STACKOVERFLOW is not set +-# CONFIG_DEBUG_STACK_USAGE is not set +-# CONFIG_DEBUG_PAGEALLOC is not set +-# CONFIG_DEBUGGER is not set +-# CONFIG_BDI_SWITCH is not set +-# CONFIG_BOOTX_TEXT is not set +-# CONFIG_PPC_EARLY_DEBUG is not set +- +-# +-# Security options +-# +-# CONFIG_KEYS is not set +-# CONFIG_SECURITY is not set +-# CONFIG_SECURITY_FILE_CAPABILITIES is not set +-# CONFIG_CRYPTO is not set +-CONFIG_PPC_CLOCK=y +-CONFIG_PPC_LIB_RHEAP=y +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/makalu_defconfig powerpc.git/arch/powerpc/configs/makalu_defconfig +--- linux-2.6.24/arch/powerpc/configs/makalu_defconfig 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/makalu_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,812 @@ ++# ++# Automatically generated make config: don't edit ++# Linux kernel version: 2.6.24-rc6 ++# Mon Dec 24 11:18:32 2007 ++# ++# CONFIG_PPC64 is not set ++ ++# ++# Processor support ++# ++# CONFIG_6xx is not set ++# CONFIG_PPC_85xx is not set ++# CONFIG_PPC_8xx is not set ++CONFIG_40x=y ++# CONFIG_44x is not set ++# CONFIG_E200 is not set ++CONFIG_4xx=y ++# CONFIG_PPC_MM_SLICES is not set ++CONFIG_NOT_COHERENT_CACHE=y ++CONFIG_PPC32=y ++CONFIG_WORD_SIZE=32 ++CONFIG_PPC_MERGE=y ++CONFIG_MMU=y ++CONFIG_GENERIC_CMOS_UPDATE=y ++CONFIG_GENERIC_TIME=y ++CONFIG_GENERIC_TIME_VSYSCALL=y ++CONFIG_GENERIC_CLOCKEVENTS=y ++CONFIG_GENERIC_HARDIRQS=y ++CONFIG_IRQ_PER_CPU=y ++CONFIG_RWSEM_XCHGADD_ALGORITHM=y ++CONFIG_ARCH_HAS_ILOG2_U32=y ++CONFIG_GENERIC_HWEIGHT=y ++CONFIG_GENERIC_CALIBRATE_DELAY=y ++CONFIG_GENERIC_FIND_NEXT_BIT=y ++# CONFIG_ARCH_NO_VIRT_TO_BUS is not set ++CONFIG_PPC=y ++CONFIG_EARLY_PRINTK=y ++CONFIG_GENERIC_NVRAM=y ++CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y ++CONFIG_ARCH_MAY_HAVE_PC_FDC=y ++CONFIG_PPC_OF=y ++CONFIG_OF=y ++CONFIG_PPC_UDBG_16550=y ++# CONFIG_GENERIC_TBSYNC is not set ++CONFIG_AUDIT_ARCH=y ++CONFIG_GENERIC_BUG=y ++# CONFIG_DEFAULT_UIMAGE is not set ++CONFIG_PPC_DCR_NATIVE=y ++# CONFIG_PPC_DCR_MMIO is not set ++CONFIG_PPC_DCR=y ++CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" ++ ++# ++# General setup ++# ++CONFIG_EXPERIMENTAL=y ++CONFIG_BROKEN_ON_SMP=y ++CONFIG_INIT_ENV_ARG_LIMIT=32 ++CONFIG_LOCALVERSION="" ++CONFIG_LOCALVERSION_AUTO=y ++CONFIG_SWAP=y ++CONFIG_SYSVIPC=y ++CONFIG_SYSVIPC_SYSCTL=y ++CONFIG_POSIX_MQUEUE=y ++# CONFIG_BSD_PROCESS_ACCT is not set ++# CONFIG_TASKSTATS is not set ++# CONFIG_USER_NS is not set ++# CONFIG_PID_NS is not set ++# CONFIG_AUDIT is not set ++# CONFIG_IKCONFIG is not set ++CONFIG_LOG_BUF_SHIFT=14 ++# CONFIG_CGROUPS is not set ++# CONFIG_FAIR_GROUP_SCHED is not set ++CONFIG_SYSFS_DEPRECATED=y ++# CONFIG_RELAY is not set ++CONFIG_BLK_DEV_INITRD=y ++CONFIG_INITRAMFS_SOURCE="" ++# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set ++CONFIG_SYSCTL=y ++CONFIG_EMBEDDED=y ++CONFIG_SYSCTL_SYSCALL=y ++CONFIG_KALLSYMS=y ++CONFIG_KALLSYMS_ALL=y ++CONFIG_KALLSYMS_EXTRA_PASS=y ++CONFIG_HOTPLUG=y ++CONFIG_PRINTK=y ++CONFIG_BUG=y ++CONFIG_ELF_CORE=y ++CONFIG_BASE_FULL=y ++CONFIG_FUTEX=y ++CONFIG_ANON_INODES=y ++CONFIG_EPOLL=y ++CONFIG_SIGNALFD=y ++CONFIG_EVENTFD=y ++CONFIG_SHMEM=y ++CONFIG_VM_EVENT_COUNTERS=y ++CONFIG_SLUB_DEBUG=y ++# CONFIG_SLAB is not set ++CONFIG_SLUB=y ++# CONFIG_SLOB is not set ++CONFIG_RT_MUTEXES=y ++# CONFIG_TINY_SHMEM is not set ++CONFIG_BASE_SMALL=0 ++CONFIG_MODULES=y ++CONFIG_MODULE_UNLOAD=y ++# CONFIG_MODULE_FORCE_UNLOAD is not set ++# CONFIG_MODVERSIONS is not set ++# CONFIG_MODULE_SRCVERSION_ALL is not set ++CONFIG_KMOD=y ++CONFIG_BLOCK=y ++CONFIG_LBD=y ++# CONFIG_BLK_DEV_IO_TRACE is not set ++# CONFIG_LSF is not set ++# CONFIG_BLK_DEV_BSG is not set ++ ++# ++# IO Schedulers ++# ++CONFIG_IOSCHED_NOOP=y ++CONFIG_IOSCHED_AS=y ++CONFIG_IOSCHED_DEADLINE=y ++CONFIG_IOSCHED_CFQ=y ++CONFIG_DEFAULT_AS=y ++# CONFIG_DEFAULT_DEADLINE is not set ++# CONFIG_DEFAULT_CFQ is not set ++# CONFIG_DEFAULT_NOOP is not set ++CONFIG_DEFAULT_IOSCHED="anticipatory" ++CONFIG_PPC4xx_PCI_EXPRESS=y ++ ++# ++# Platform support ++# ++# CONFIG_PPC_MPC52xx is not set ++# CONFIG_PPC_MPC5200 is not set ++# CONFIG_PPC_CELL is not set ++# CONFIG_PPC_CELL_NATIVE is not set ++# CONFIG_PQ2ADS is not set ++# CONFIG_EP405 is not set ++# CONFIG_KILAUEA is not set ++CONFIG_MAKALU=y ++# CONFIG_WALNUT is not set ++# CONFIG_XILINX_VIRTEX_GENERIC_BOARD is not set ++CONFIG_405EX=y ++# CONFIG_MPIC is not set ++# CONFIG_MPIC_WEIRD is not set ++# CONFIG_PPC_I8259 is not set ++# CONFIG_PPC_RTAS is not set ++# CONFIG_MMIO_NVRAM is not set ++# CONFIG_PPC_MPC106 is not set ++# CONFIG_PPC_970_NAP is not set ++# CONFIG_PPC_INDIRECT_IO is not set ++# CONFIG_GENERIC_IOMAP is not set ++# CONFIG_CPU_FREQ is not set ++# CONFIG_CPM2 is not set ++# CONFIG_FSL_ULI1575 is not set ++ ++# ++# Kernel options ++# ++# CONFIG_HIGHMEM is not set ++# CONFIG_TICK_ONESHOT is not set ++# CONFIG_NO_HZ is not set ++# CONFIG_HIGH_RES_TIMERS is not set ++CONFIG_GENERIC_CLOCKEVENTS_BUILD=y ++# CONFIG_HZ_100 is not set ++CONFIG_HZ_250=y ++# CONFIG_HZ_300 is not set ++# CONFIG_HZ_1000 is not set ++CONFIG_HZ=250 ++CONFIG_PREEMPT_NONE=y ++# CONFIG_PREEMPT_VOLUNTARY is not set ++# CONFIG_PREEMPT is not set ++CONFIG_BINFMT_ELF=y ++# CONFIG_BINFMT_MISC is not set ++# CONFIG_MATH_EMULATION is not set ++CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y ++CONFIG_ARCH_FLATMEM_ENABLE=y ++CONFIG_ARCH_POPULATES_NODE_MAP=y ++CONFIG_SELECT_MEMORY_MODEL=y ++CONFIG_FLATMEM_MANUAL=y ++# CONFIG_DISCONTIGMEM_MANUAL is not set ++# CONFIG_SPARSEMEM_MANUAL is not set ++CONFIG_FLATMEM=y ++CONFIG_FLAT_NODE_MEM_MAP=y ++# CONFIG_SPARSEMEM_STATIC is not set ++# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set ++CONFIG_SPLIT_PTLOCK_CPUS=4 ++# CONFIG_RESOURCES_64BIT is not set ++CONFIG_ZONE_DMA_FLAG=1 ++CONFIG_BOUNCE=y ++CONFIG_VIRT_TO_BUS=y ++CONFIG_PROC_DEVICETREE=y ++# CONFIG_CMDLINE_BOOL is not set ++# CONFIG_PM is not set ++CONFIG_SUSPEND_UP_POSSIBLE=y ++CONFIG_HIBERNATION_UP_POSSIBLE=y ++CONFIG_SECCOMP=y ++CONFIG_WANT_DEVICE_TREE=y ++CONFIG_DEVICE_TREE="kilauea.dts" ++CONFIG_ISA_DMA_API=y ++ ++# ++# Bus options ++# ++CONFIG_ZONE_DMA=y ++CONFIG_PPC_INDIRECT_PCI=y ++CONFIG_PCI=y ++CONFIG_PCI_DOMAINS=y ++CONFIG_PCI_SYSCALL=y ++# CONFIG_PCIEPORTBUS is not set ++CONFIG_ARCH_SUPPORTS_MSI=y ++# CONFIG_PCI_MSI is not set ++CONFIG_PCI_LEGACY=y ++# CONFIG_PCI_DEBUG is not set ++# CONFIG_PCCARD is not set ++# CONFIG_HOTPLUG_PCI is not set ++ ++# ++# Advanced setup ++# ++# CONFIG_ADVANCED_OPTIONS is not set ++ ++# ++# Default settings for advanced configuration options are used ++# ++CONFIG_HIGHMEM_START=0xfe000000 ++CONFIG_LOWMEM_SIZE=0x30000000 ++CONFIG_KERNEL_START=0xc0000000 ++CONFIG_TASK_SIZE=0xc0000000 ++CONFIG_CONSISTENT_START=0xff100000 ++CONFIG_CONSISTENT_SIZE=0x00200000 ++CONFIG_BOOT_LOAD=0x00400000 ++ ++# ++# Networking ++# ++CONFIG_NET=y ++ ++# ++# Networking options ++# ++CONFIG_PACKET=y ++# CONFIG_PACKET_MMAP is not set ++CONFIG_UNIX=y ++# CONFIG_NET_KEY is not set ++CONFIG_INET=y ++# CONFIG_IP_MULTICAST is not set ++# CONFIG_IP_ADVANCED_ROUTER is not set ++CONFIG_IP_FIB_HASH=y ++CONFIG_IP_PNP=y ++CONFIG_IP_PNP_DHCP=y ++CONFIG_IP_PNP_BOOTP=y ++# CONFIG_IP_PNP_RARP is not set ++# CONFIG_NET_IPIP is not set ++# CONFIG_NET_IPGRE is not set ++# CONFIG_ARPD is not set ++# CONFIG_SYN_COOKIES is not set ++# CONFIG_INET_AH is not set ++# CONFIG_INET_ESP is not set ++# CONFIG_INET_IPCOMP is not set ++# CONFIG_INET_XFRM_TUNNEL is not set ++# CONFIG_INET_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_TRANSPORT is not set ++# CONFIG_INET_XFRM_MODE_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_BEET is not set ++# CONFIG_INET_LRO is not set ++CONFIG_INET_DIAG=y ++CONFIG_INET_TCP_DIAG=y ++# CONFIG_TCP_CONG_ADVANCED is not set ++CONFIG_TCP_CONG_CUBIC=y ++CONFIG_DEFAULT_TCP_CONG="cubic" ++# CONFIG_TCP_MD5SIG is not set ++# CONFIG_IPV6 is not set ++# CONFIG_INET6_XFRM_TUNNEL is not set ++# CONFIG_INET6_TUNNEL is not set ++# CONFIG_NETWORK_SECMARK is not set ++# CONFIG_NETFILTER is not set ++# CONFIG_IP_DCCP is not set ++# CONFIG_IP_SCTP is not set ++# CONFIG_TIPC is not set ++# CONFIG_ATM is not set ++# CONFIG_BRIDGE is not set ++# CONFIG_VLAN_8021Q is not set ++# CONFIG_DECNET is not set ++# CONFIG_LLC2 is not set ++# CONFIG_IPX is not set ++# CONFIG_ATALK is not set ++# CONFIG_X25 is not set ++# CONFIG_LAPB is not set ++# CONFIG_ECONET is not set ++# CONFIG_WAN_ROUTER is not set ++# CONFIG_NET_SCHED is not set ++ ++# ++# Network testing ++# ++# CONFIG_NET_PKTGEN is not set ++# CONFIG_HAMRADIO is not set ++# CONFIG_IRDA is not set ++# CONFIG_BT is not set ++# CONFIG_AF_RXRPC is not set ++ ++# ++# Wireless ++# ++# CONFIG_CFG80211 is not set ++# CONFIG_WIRELESS_EXT is not set ++# CONFIG_MAC80211 is not set ++# CONFIG_IEEE80211 is not set ++# CONFIG_RFKILL is not set ++# CONFIG_NET_9P is not set ++ ++# ++# Device Drivers ++# ++ ++# ++# Generic Driver Options ++# ++CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" ++CONFIG_STANDALONE=y ++CONFIG_PREVENT_FIRMWARE_BUILD=y ++CONFIG_FW_LOADER=y ++# CONFIG_DEBUG_DRIVER is not set ++# CONFIG_DEBUG_DEVRES is not set ++# CONFIG_SYS_HYPERVISOR is not set ++CONFIG_CONNECTOR=y ++CONFIG_PROC_EVENTS=y ++CONFIG_MTD=y ++# CONFIG_MTD_DEBUG is not set ++# CONFIG_MTD_CONCAT is not set ++CONFIG_MTD_PARTITIONS=y ++# CONFIG_MTD_REDBOOT_PARTS is not set ++CONFIG_MTD_CMDLINE_PARTS=y ++ ++# ++# User Modules And Translation Layers ++# ++CONFIG_MTD_CHAR=y ++CONFIG_MTD_BLKDEVS=m ++CONFIG_MTD_BLOCK=m ++# CONFIG_MTD_BLOCK_RO is not set ++# CONFIG_FTL is not set ++# CONFIG_NFTL is not set ++# CONFIG_INFTL is not set ++# CONFIG_RFD_FTL is not set ++# CONFIG_SSFDC is not set ++# CONFIG_MTD_OOPS is not set ++ ++# ++# RAM/ROM/Flash chip drivers ++# ++CONFIG_MTD_CFI=y ++CONFIG_MTD_JEDECPROBE=y ++CONFIG_MTD_GEN_PROBE=y ++# CONFIG_MTD_CFI_ADV_OPTIONS is not set ++CONFIG_MTD_MAP_BANK_WIDTH_1=y ++CONFIG_MTD_MAP_BANK_WIDTH_2=y ++CONFIG_MTD_MAP_BANK_WIDTH_4=y ++# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set ++CONFIG_MTD_CFI_I1=y ++CONFIG_MTD_CFI_I2=y ++# CONFIG_MTD_CFI_I4 is not set ++# CONFIG_MTD_CFI_I8 is not set ++# CONFIG_MTD_CFI_INTELEXT is not set ++CONFIG_MTD_CFI_AMDSTD=y ++# CONFIG_MTD_CFI_STAA is not set ++CONFIG_MTD_CFI_UTIL=y ++# CONFIG_MTD_RAM is not set ++# CONFIG_MTD_ROM is not set ++# CONFIG_MTD_ABSENT is not set ++ ++# ++# Mapping drivers for chip access ++# ++# CONFIG_MTD_COMPLEX_MAPPINGS is not set ++# CONFIG_MTD_PHYSMAP is not set ++CONFIG_MTD_PHYSMAP_OF=y ++# CONFIG_MTD_INTEL_VR_NOR is not set ++# CONFIG_MTD_PLATRAM is not set ++ ++# ++# Self-contained MTD device drivers ++# ++# CONFIG_MTD_PMC551 is not set ++# CONFIG_MTD_SLRAM is not set ++# CONFIG_MTD_PHRAM is not set ++# CONFIG_MTD_MTDRAM is not set ++# CONFIG_MTD_BLOCK2MTD is not set ++ ++# ++# Disk-On-Chip Device Drivers ++# ++# CONFIG_MTD_DOC2000 is not set ++# CONFIG_MTD_DOC2001 is not set ++# CONFIG_MTD_DOC2001PLUS is not set ++# CONFIG_MTD_NAND is not set ++# CONFIG_MTD_ONENAND is not set ++ ++# ++# UBI - Unsorted block images ++# ++# CONFIG_MTD_UBI is not set ++CONFIG_OF_DEVICE=y ++# CONFIG_PARPORT is not set ++CONFIG_BLK_DEV=y ++# CONFIG_BLK_DEV_FD is not set ++# CONFIG_BLK_CPQ_DA is not set ++# CONFIG_BLK_CPQ_CISS_DA is not set ++# CONFIG_BLK_DEV_DAC960 is not set ++# CONFIG_BLK_DEV_UMEM is not set ++# CONFIG_BLK_DEV_COW_COMMON is not set ++# CONFIG_BLK_DEV_LOOP is not set ++# CONFIG_BLK_DEV_NBD is not set ++# CONFIG_BLK_DEV_SX8 is not set ++CONFIG_BLK_DEV_RAM=y ++CONFIG_BLK_DEV_RAM_COUNT=16 ++CONFIG_BLK_DEV_RAM_SIZE=35000 ++CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024 ++# CONFIG_CDROM_PKTCDVD is not set ++# CONFIG_ATA_OVER_ETH is not set ++# CONFIG_XILINX_SYSACE is not set ++# CONFIG_MISC_DEVICES is not set ++# CONFIG_IDE is not set ++ ++# ++# SCSI device support ++# ++# CONFIG_RAID_ATTRS is not set ++# CONFIG_SCSI is not set ++# CONFIG_SCSI_DMA is not set ++# CONFIG_SCSI_NETLINK is not set ++# CONFIG_ATA is not set ++# CONFIG_MD is not set ++# CONFIG_FUSION is not set ++ ++# ++# IEEE 1394 (FireWire) support ++# ++# CONFIG_FIREWIRE is not set ++# CONFIG_IEEE1394 is not set ++# CONFIG_I2O is not set ++# CONFIG_MACINTOSH_DRIVERS is not set ++CONFIG_NETDEVICES=y ++# CONFIG_NETDEVICES_MULTIQUEUE is not set ++# CONFIG_DUMMY is not set ++# CONFIG_BONDING is not set ++# CONFIG_MACVLAN is not set ++# CONFIG_EQUALIZER is not set ++# CONFIG_TUN is not set ++# CONFIG_VETH is not set ++# CONFIG_IP1000 is not set ++# CONFIG_ARCNET is not set ++# CONFIG_PHYLIB is not set ++CONFIG_NET_ETHERNET=y ++# CONFIG_MII is not set ++# CONFIG_HAPPYMEAL is not set ++# CONFIG_SUNGEM is not set ++# CONFIG_CASSINI is not set ++# CONFIG_NET_VENDOR_3COM is not set ++# CONFIG_NET_TULIP is not set ++# CONFIG_HP100 is not set ++CONFIG_IBM_NEW_EMAC=y ++CONFIG_IBM_NEW_EMAC_RXB=256 ++CONFIG_IBM_NEW_EMAC_TXB=256 ++CONFIG_IBM_NEW_EMAC_POLL_WEIGHT=32 ++CONFIG_IBM_NEW_EMAC_RX_COPY_THRESHOLD=256 ++CONFIG_IBM_NEW_EMAC_RX_SKB_HEADROOM=0 ++# CONFIG_IBM_NEW_EMAC_DEBUG is not set ++# CONFIG_IBM_NEW_EMAC_ZMII is not set ++CONFIG_IBM_NEW_EMAC_RGMII=y ++# CONFIG_IBM_NEW_EMAC_TAH is not set ++CONFIG_IBM_NEW_EMAC_EMAC4=y ++# CONFIG_NET_PCI is not set ++# CONFIG_B44 is not set ++# CONFIG_NETDEV_1000 is not set ++# CONFIG_NETDEV_10000 is not set ++# CONFIG_TR is not set ++ ++# ++# Wireless LAN ++# ++# CONFIG_WLAN_PRE80211 is not set ++# CONFIG_WLAN_80211 is not set ++# CONFIG_WAN is not set ++# CONFIG_FDDI is not set ++# CONFIG_HIPPI is not set ++# CONFIG_PPP is not set ++# CONFIG_SLIP is not set ++# CONFIG_SHAPER is not set ++# CONFIG_NETCONSOLE is not set ++# CONFIG_NETPOLL is not set ++# CONFIG_NET_POLL_CONTROLLER is not set ++# CONFIG_ISDN is not set ++# CONFIG_PHONE is not set ++ ++# ++# Input device support ++# ++# CONFIG_INPUT is not set ++ ++# ++# Hardware I/O ports ++# ++# CONFIG_SERIO is not set ++# CONFIG_GAMEPORT is not set ++ ++# ++# Character devices ++# ++# CONFIG_VT is not set ++# CONFIG_SERIAL_NONSTANDARD is not set ++ ++# ++# Serial drivers ++# ++CONFIG_SERIAL_8250=y ++CONFIG_SERIAL_8250_CONSOLE=y ++CONFIG_SERIAL_8250_PCI=y ++CONFIG_SERIAL_8250_NR_UARTS=4 ++CONFIG_SERIAL_8250_RUNTIME_UARTS=4 ++CONFIG_SERIAL_8250_EXTENDED=y ++# CONFIG_SERIAL_8250_MANY_PORTS is not set ++CONFIG_SERIAL_8250_SHARE_IRQ=y ++# CONFIG_SERIAL_8250_DETECT_IRQ is not set ++# CONFIG_SERIAL_8250_RSA is not set ++ ++# ++# Non-8250 serial port support ++# ++# CONFIG_SERIAL_UARTLITE is not set ++CONFIG_SERIAL_CORE=y ++CONFIG_SERIAL_CORE_CONSOLE=y ++# CONFIG_SERIAL_JSM is not set ++CONFIG_SERIAL_OF_PLATFORM=y ++CONFIG_UNIX98_PTYS=y ++CONFIG_LEGACY_PTYS=y ++CONFIG_LEGACY_PTY_COUNT=256 ++# CONFIG_IPMI_HANDLER is not set ++# CONFIG_HW_RANDOM is not set ++# CONFIG_NVRAM is not set ++# CONFIG_GEN_RTC is not set ++# CONFIG_R3964 is not set ++# CONFIG_APPLICOM is not set ++# CONFIG_RAW_DRIVER is not set ++# CONFIG_TCG_TPM is not set ++CONFIG_DEVPORT=y ++# CONFIG_I2C is not set ++ ++# ++# SPI support ++# ++# CONFIG_SPI is not set ++# CONFIG_SPI_MASTER is not set ++# CONFIG_W1 is not set ++# CONFIG_POWER_SUPPLY is not set ++# CONFIG_HWMON is not set ++# CONFIG_WATCHDOG is not set ++ ++# ++# Sonics Silicon Backplane ++# ++CONFIG_SSB_POSSIBLE=y ++# CONFIG_SSB is not set ++ ++# ++# Multifunction device drivers ++# ++# CONFIG_MFD_SM501 is not set ++ ++# ++# Multimedia devices ++# ++# CONFIG_VIDEO_DEV is not set ++# CONFIG_DVB_CORE is not set ++# CONFIG_DAB is not set ++ ++# ++# Graphics support ++# ++# CONFIG_AGP is not set ++# CONFIG_DRM is not set ++# CONFIG_VGASTATE is not set ++# CONFIG_VIDEO_OUTPUT_CONTROL is not set ++# CONFIG_FB is not set ++# CONFIG_BACKLIGHT_LCD_SUPPORT is not set ++ ++# ++# Display device support ++# ++# CONFIG_DISPLAY_SUPPORT is not set ++ ++# ++# Sound ++# ++# CONFIG_SOUND is not set ++# CONFIG_USB_SUPPORT is not set ++# CONFIG_MMC is not set ++# CONFIG_NEW_LEDS is not set ++# CONFIG_INFINIBAND is not set ++# CONFIG_EDAC is not set ++# CONFIG_RTC_CLASS is not set ++ ++# ++# Userspace I/O ++# ++# CONFIG_UIO is not set ++ ++# ++# File systems ++# ++CONFIG_EXT2_FS=y ++# CONFIG_EXT2_FS_XATTR is not set ++# CONFIG_EXT2_FS_XIP is not set ++# CONFIG_EXT3_FS is not set ++# CONFIG_EXT4DEV_FS is not set ++# CONFIG_REISERFS_FS is not set ++# CONFIG_JFS_FS is not set ++# CONFIG_FS_POSIX_ACL is not set ++# CONFIG_XFS_FS is not set ++# CONFIG_GFS2_FS is not set ++# CONFIG_OCFS2_FS is not set ++# CONFIG_MINIX_FS is not set ++# CONFIG_ROMFS_FS is not set ++CONFIG_INOTIFY=y ++CONFIG_INOTIFY_USER=y ++# CONFIG_QUOTA is not set ++CONFIG_DNOTIFY=y ++# CONFIG_AUTOFS_FS is not set ++# CONFIG_AUTOFS4_FS is not set ++# CONFIG_FUSE_FS is not set ++ ++# ++# CD-ROM/DVD Filesystems ++# ++# CONFIG_ISO9660_FS is not set ++# CONFIG_UDF_FS is not set ++ ++# ++# DOS/FAT/NT Filesystems ++# ++# CONFIG_MSDOS_FS is not set ++# CONFIG_VFAT_FS is not set ++# CONFIG_NTFS_FS is not set ++ ++# ++# Pseudo filesystems ++# ++CONFIG_PROC_FS=y ++CONFIG_PROC_KCORE=y ++CONFIG_PROC_SYSCTL=y ++CONFIG_SYSFS=y ++CONFIG_TMPFS=y ++# CONFIG_TMPFS_POSIX_ACL is not set ++# CONFIG_HUGETLB_PAGE is not set ++# CONFIG_CONFIGFS_FS is not set ++ ++# ++# Miscellaneous filesystems ++# ++# CONFIG_ADFS_FS is not set ++# CONFIG_AFFS_FS is not set ++# CONFIG_HFS_FS is not set ++# CONFIG_HFSPLUS_FS is not set ++# CONFIG_BEFS_FS is not set ++# CONFIG_BFS_FS is not set ++# CONFIG_EFS_FS is not set ++# CONFIG_JFFS2_FS is not set ++CONFIG_CRAMFS=y ++# CONFIG_VXFS_FS is not set ++# CONFIG_HPFS_FS is not set ++# CONFIG_QNX4FS_FS is not set ++# CONFIG_SYSV_FS is not set ++# CONFIG_UFS_FS is not set ++CONFIG_NETWORK_FILESYSTEMS=y ++CONFIG_NFS_FS=y ++CONFIG_NFS_V3=y ++# CONFIG_NFS_V3_ACL is not set ++# CONFIG_NFS_V4 is not set ++# CONFIG_NFS_DIRECTIO is not set ++# CONFIG_NFSD is not set ++CONFIG_ROOT_NFS=y ++CONFIG_LOCKD=y ++CONFIG_LOCKD_V4=y ++CONFIG_NFS_COMMON=y ++CONFIG_SUNRPC=y ++# CONFIG_SUNRPC_BIND34 is not set ++# CONFIG_RPCSEC_GSS_KRB5 is not set ++# CONFIG_RPCSEC_GSS_SPKM3 is not set ++# CONFIG_SMB_FS is not set ++# CONFIG_CIFS is not set ++# CONFIG_NCP_FS is not set ++# CONFIG_CODA_FS is not set ++# CONFIG_AFS_FS is not set ++ ++# ++# Partition Types ++# ++# CONFIG_PARTITION_ADVANCED is not set ++CONFIG_MSDOS_PARTITION=y ++# CONFIG_NLS is not set ++# CONFIG_DLM is not set ++# CONFIG_UCC_SLOW is not set ++ ++# ++# Library routines ++# ++CONFIG_BITREVERSE=y ++# CONFIG_CRC_CCITT is not set ++# CONFIG_CRC16 is not set ++# CONFIG_CRC_ITU_T is not set ++CONFIG_CRC32=y ++# CONFIG_CRC7 is not set ++# CONFIG_LIBCRC32C is not set ++CONFIG_ZLIB_INFLATE=y ++CONFIG_PLIST=y ++CONFIG_HAS_IOMEM=y ++CONFIG_HAS_IOPORT=y ++CONFIG_HAS_DMA=y ++# CONFIG_INSTRUMENTATION is not set ++ ++# ++# Kernel hacking ++# ++# CONFIG_PRINTK_TIME is not set ++CONFIG_ENABLE_WARN_DEPRECATED=y ++CONFIG_ENABLE_MUST_CHECK=y ++CONFIG_MAGIC_SYSRQ=y ++# CONFIG_UNUSED_SYMBOLS is not set ++# CONFIG_DEBUG_FS is not set ++# CONFIG_HEADERS_CHECK is not set ++CONFIG_DEBUG_KERNEL=y ++# CONFIG_DEBUG_SHIRQ is not set ++CONFIG_DETECT_SOFTLOCKUP=y ++CONFIG_SCHED_DEBUG=y ++# CONFIG_SCHEDSTATS is not set ++# CONFIG_TIMER_STATS is not set ++# CONFIG_SLUB_DEBUG_ON is not set ++# CONFIG_DEBUG_RT_MUTEXES is not set ++# CONFIG_RT_MUTEX_TESTER is not set ++# CONFIG_DEBUG_SPINLOCK is not set ++# CONFIG_DEBUG_MUTEXES is not set ++# CONFIG_DEBUG_SPINLOCK_SLEEP is not set ++# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set ++# CONFIG_DEBUG_KOBJECT is not set ++CONFIG_DEBUG_BUGVERBOSE=y ++# CONFIG_DEBUG_INFO is not set ++# CONFIG_DEBUG_VM is not set ++# CONFIG_DEBUG_LIST is not set ++# CONFIG_DEBUG_SG is not set ++CONFIG_FORCED_INLINING=y ++# CONFIG_BOOT_PRINTK_DELAY is not set ++# CONFIG_RCU_TORTURE_TEST is not set ++# CONFIG_FAULT_INJECTION is not set ++# CONFIG_SAMPLES is not set ++# CONFIG_DEBUG_STACKOVERFLOW is not set ++# CONFIG_DEBUG_STACK_USAGE is not set ++# CONFIG_DEBUG_PAGEALLOC is not set ++# CONFIG_DEBUGGER is not set ++# CONFIG_BDI_SWITCH is not set ++# CONFIG_PPC_EARLY_DEBUG is not set ++ ++# ++# Security options ++# ++# CONFIG_KEYS is not set ++# CONFIG_SECURITY is not set ++# CONFIG_SECURITY_FILE_CAPABILITIES is not set ++CONFIG_CRYPTO=y ++CONFIG_CRYPTO_ALGAPI=y ++CONFIG_CRYPTO_BLKCIPHER=y ++CONFIG_CRYPTO_MANAGER=y ++# CONFIG_CRYPTO_HMAC is not set ++# CONFIG_CRYPTO_XCBC is not set ++# CONFIG_CRYPTO_NULL is not set ++# CONFIG_CRYPTO_MD4 is not set ++CONFIG_CRYPTO_MD5=y ++# CONFIG_CRYPTO_SHA1 is not set ++# CONFIG_CRYPTO_SHA256 is not set ++# CONFIG_CRYPTO_SHA512 is not set ++# CONFIG_CRYPTO_WP512 is not set ++# CONFIG_CRYPTO_TGR192 is not set ++# CONFIG_CRYPTO_GF128MUL is not set ++CONFIG_CRYPTO_ECB=y ++CONFIG_CRYPTO_CBC=y ++CONFIG_CRYPTO_PCBC=y ++# CONFIG_CRYPTO_LRW is not set ++# CONFIG_CRYPTO_XTS is not set ++# CONFIG_CRYPTO_CRYPTD is not set ++CONFIG_CRYPTO_DES=y ++# CONFIG_CRYPTO_FCRYPT is not set ++# CONFIG_CRYPTO_BLOWFISH is not set ++# CONFIG_CRYPTO_TWOFISH is not set ++# CONFIG_CRYPTO_SERPENT is not set ++# CONFIG_CRYPTO_AES is not set ++# CONFIG_CRYPTO_CAST5 is not set ++# CONFIG_CRYPTO_CAST6 is not set ++# CONFIG_CRYPTO_TEA is not set ++# CONFIG_CRYPTO_ARC4 is not set ++# CONFIG_CRYPTO_KHAZAD is not set ++# CONFIG_CRYPTO_ANUBIS is not set ++# CONFIG_CRYPTO_SEED is not set ++# CONFIG_CRYPTO_DEFLATE is not set ++# CONFIG_CRYPTO_MICHAEL_MIC is not set ++# CONFIG_CRYPTO_CRC32C is not set ++# CONFIG_CRYPTO_CAMELLIA is not set ++# CONFIG_CRYPTO_TEST is not set ++# CONFIG_CRYPTO_AUTHENC is not set ++CONFIG_CRYPTO_HW=y ++# CONFIG_PPC_CLOCK is not set +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/mpc5200_defconfig powerpc.git/arch/powerpc/configs/mpc5200_defconfig +--- linux-2.6.24/arch/powerpc/configs/mpc5200_defconfig 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/mpc5200_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,1286 @@ ++# ++# Automatically generated make config: don't edit ++# Linux kernel version: 2.6.24-rc6 ++# Fri Jan 18 14:19:54 2008 ++# ++# CONFIG_PPC64 is not set ++ ++# ++# Processor support ++# ++CONFIG_6xx=y ++# CONFIG_PPC_85xx is not set ++# CONFIG_PPC_8xx is not set ++# CONFIG_40x is not set ++# CONFIG_44x is not set ++# CONFIG_E200 is not set ++CONFIG_PPC_FPU=y ++# CONFIG_ALTIVEC is not set ++CONFIG_PPC_STD_MMU=y ++CONFIG_PPC_STD_MMU_32=y ++# CONFIG_PPC_MM_SLICES is not set ++# CONFIG_SMP is not set ++CONFIG_PPC32=y ++CONFIG_WORD_SIZE=32 ++CONFIG_PPC_MERGE=y ++CONFIG_MMU=y ++CONFIG_GENERIC_CMOS_UPDATE=y ++CONFIG_GENERIC_TIME=y ++CONFIG_GENERIC_TIME_VSYSCALL=y ++CONFIG_GENERIC_CLOCKEVENTS=y ++CONFIG_GENERIC_HARDIRQS=y ++CONFIG_IRQ_PER_CPU=y ++CONFIG_RWSEM_XCHGADD_ALGORITHM=y ++CONFIG_ARCH_HAS_ILOG2_U32=y ++CONFIG_GENERIC_HWEIGHT=y ++CONFIG_GENERIC_CALIBRATE_DELAY=y ++CONFIG_GENERIC_FIND_NEXT_BIT=y ++# CONFIG_ARCH_NO_VIRT_TO_BUS is not set ++CONFIG_PPC=y ++CONFIG_EARLY_PRINTK=y ++CONFIG_GENERIC_NVRAM=y ++CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y ++CONFIG_ARCH_MAY_HAVE_PC_FDC=y ++CONFIG_PPC_OF=y ++CONFIG_OF=y ++# CONFIG_PPC_UDBG_16550 is not set ++# CONFIG_GENERIC_TBSYNC is not set ++CONFIG_AUDIT_ARCH=y ++CONFIG_GENERIC_BUG=y ++# CONFIG_DEFAULT_UIMAGE is not set ++# CONFIG_PPC_DCR_NATIVE is not set ++# CONFIG_PPC_DCR_MMIO is not set ++CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" ++ ++# ++# General setup ++# ++CONFIG_EXPERIMENTAL=y ++CONFIG_BROKEN_ON_SMP=y ++CONFIG_INIT_ENV_ARG_LIMIT=32 ++CONFIG_LOCALVERSION="" ++CONFIG_LOCALVERSION_AUTO=y ++CONFIG_SWAP=y ++CONFIG_SYSVIPC=y ++CONFIG_SYSVIPC_SYSCTL=y ++# CONFIG_POSIX_MQUEUE is not set ++# CONFIG_BSD_PROCESS_ACCT is not set ++# CONFIG_TASKSTATS is not set ++# CONFIG_USER_NS is not set ++# CONFIG_PID_NS is not set ++# CONFIG_AUDIT is not set ++# CONFIG_IKCONFIG is not set ++CONFIG_LOG_BUF_SHIFT=14 ++# CONFIG_CGROUPS is not set ++CONFIG_FAIR_GROUP_SCHED=y ++CONFIG_FAIR_USER_SCHED=y ++# CONFIG_FAIR_CGROUP_SCHED is not set ++CONFIG_SYSFS_DEPRECATED=y ++# CONFIG_RELAY is not set ++CONFIG_BLK_DEV_INITRD=y ++CONFIG_INITRAMFS_SOURCE="" ++# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set ++CONFIG_SYSCTL=y ++CONFIG_EMBEDDED=y ++# CONFIG_SYSCTL_SYSCALL is not set ++# CONFIG_KALLSYMS is not set ++CONFIG_HOTPLUG=y ++CONFIG_PRINTK=y ++CONFIG_BUG=y ++CONFIG_ELF_CORE=y ++CONFIG_BASE_FULL=y ++CONFIG_FUTEX=y ++CONFIG_ANON_INODES=y ++# CONFIG_EPOLL is not set ++CONFIG_SIGNALFD=y ++CONFIG_EVENTFD=y ++CONFIG_SHMEM=y ++CONFIG_VM_EVENT_COUNTERS=y ++CONFIG_SLUB_DEBUG=y ++# CONFIG_SLAB is not set ++CONFIG_SLUB=y ++# CONFIG_SLOB is not set ++CONFIG_RT_MUTEXES=y ++# CONFIG_TINY_SHMEM is not set ++CONFIG_BASE_SMALL=0 ++CONFIG_MODULES=y ++CONFIG_MODULE_UNLOAD=y ++# CONFIG_MODULE_FORCE_UNLOAD is not set ++# CONFIG_MODVERSIONS is not set ++# CONFIG_MODULE_SRCVERSION_ALL is not set ++# CONFIG_KMOD is not set ++CONFIG_BLOCK=y ++# CONFIG_LBD is not set ++# CONFIG_BLK_DEV_IO_TRACE is not set ++# CONFIG_LSF is not set ++# CONFIG_BLK_DEV_BSG is not set ++ ++# ++# IO Schedulers ++# ++CONFIG_IOSCHED_NOOP=y ++CONFIG_IOSCHED_AS=y ++CONFIG_IOSCHED_DEADLINE=y ++CONFIG_IOSCHED_CFQ=y ++CONFIG_DEFAULT_AS=y ++# CONFIG_DEFAULT_DEADLINE is not set ++# CONFIG_DEFAULT_CFQ is not set ++# CONFIG_DEFAULT_NOOP is not set ++CONFIG_DEFAULT_IOSCHED="anticipatory" ++ ++# ++# Platform support ++# ++CONFIG_PPC_MULTIPLATFORM=y ++# CONFIG_PPC_82xx is not set ++# CONFIG_PPC_83xx is not set ++# CONFIG_PPC_86xx is not set ++CONFIG_CLASSIC32=y ++# CONFIG_PPC_CHRP is not set ++CONFIG_PPC_MPC52xx=y ++CONFIG_PPC_MPC5200=y ++CONFIG_PPC_MPC5200_BUGFIX=y ++CONFIG_PPC_MPC5200_SIMPLE=y ++CONFIG_PPC_EFIKA=y ++CONFIG_PPC_LITE5200=y ++# CONFIG_PPC_PMAC is not set ++# CONFIG_PPC_CELL is not set ++# CONFIG_PPC_CELL_NATIVE is not set ++# CONFIG_PQ2ADS is not set ++# CONFIG_EMBEDDED6xx is not set ++CONFIG_PPC_NATIVE=y ++# CONFIG_UDBG_RTAS_CONSOLE is not set ++# CONFIG_MPIC is not set ++# CONFIG_MPIC_WEIRD is not set ++# CONFIG_PPC_I8259 is not set ++CONFIG_PPC_RTAS=y ++# CONFIG_RTAS_ERROR_LOGGING is not set ++CONFIG_RTAS_PROC=y ++# CONFIG_MMIO_NVRAM is not set ++# CONFIG_PPC_MPC106 is not set ++# CONFIG_PPC_970_NAP is not set ++# CONFIG_PPC_INDIRECT_IO is not set ++# CONFIG_GENERIC_IOMAP is not set ++# CONFIG_CPU_FREQ is not set ++# CONFIG_TAU is not set ++# CONFIG_CPM2 is not set ++# CONFIG_FSL_ULI1575 is not set ++CONFIG_PPC_BESTCOMM=y ++CONFIG_PPC_BESTCOMM_ATA=y ++CONFIG_PPC_BESTCOMM_FEC=y ++CONFIG_PPC_BESTCOMM_GEN_BD=y ++ ++# ++# Kernel options ++# ++# CONFIG_HIGHMEM is not set ++CONFIG_TICK_ONESHOT=y ++CONFIG_NO_HZ=y ++CONFIG_HIGH_RES_TIMERS=y ++CONFIG_GENERIC_CLOCKEVENTS_BUILD=y ++# CONFIG_HZ_100 is not set ++CONFIG_HZ_250=y ++# CONFIG_HZ_300 is not set ++# CONFIG_HZ_1000 is not set ++CONFIG_HZ=250 ++CONFIG_PREEMPT_NONE=y ++# CONFIG_PREEMPT_VOLUNTARY is not set ++# CONFIG_PREEMPT is not set ++CONFIG_BINFMT_ELF=y ++# CONFIG_BINFMT_MISC is not set ++CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y ++# CONFIG_KEXEC is not set ++CONFIG_ARCH_FLATMEM_ENABLE=y ++CONFIG_ARCH_POPULATES_NODE_MAP=y ++CONFIG_SELECT_MEMORY_MODEL=y ++CONFIG_FLATMEM_MANUAL=y ++# CONFIG_DISCONTIGMEM_MANUAL is not set ++# CONFIG_SPARSEMEM_MANUAL is not set ++CONFIG_FLATMEM=y ++CONFIG_FLAT_NODE_MEM_MAP=y ++# CONFIG_SPARSEMEM_STATIC is not set ++# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set ++CONFIG_SPLIT_PTLOCK_CPUS=4 ++# CONFIG_RESOURCES_64BIT is not set ++CONFIG_ZONE_DMA_FLAG=1 ++CONFIG_BOUNCE=y ++CONFIG_VIRT_TO_BUS=y ++CONFIG_PROC_DEVICETREE=y ++# CONFIG_CMDLINE_BOOL is not set ++CONFIG_PM=y ++# CONFIG_PM_LEGACY is not set ++# CONFIG_PM_DEBUG is not set ++CONFIG_PM_SLEEP=y ++CONFIG_SUSPEND_UP_POSSIBLE=y ++CONFIG_SUSPEND=y ++CONFIG_HIBERNATION_UP_POSSIBLE=y ++# CONFIG_HIBERNATION is not set ++CONFIG_SECCOMP=y ++CONFIG_WANT_DEVICE_TREE=y ++CONFIG_DEVICE_TREE="" ++CONFIG_ISA_DMA_API=y ++ ++# ++# Bus options ++# ++CONFIG_ZONE_DMA=y ++CONFIG_GENERIC_ISA_DMA=y ++# CONFIG_PPC_INDIRECT_PCI is not set ++CONFIG_FSL_SOC=y ++CONFIG_PCI=y ++CONFIG_PCI_DOMAINS=y ++CONFIG_PCI_SYSCALL=y ++# CONFIG_PCIEPORTBUS is not set ++CONFIG_ARCH_SUPPORTS_MSI=y ++# CONFIG_PCI_MSI is not set ++CONFIG_PCI_LEGACY=y ++# CONFIG_PCI_DEBUG is not set ++# CONFIG_PCCARD is not set ++# CONFIG_HOTPLUG_PCI is not set ++ ++# ++# Advanced setup ++# ++# CONFIG_ADVANCED_OPTIONS is not set ++ ++# ++# Default settings for advanced configuration options are used ++# ++CONFIG_HIGHMEM_START=0xfe000000 ++CONFIG_LOWMEM_SIZE=0x30000000 ++CONFIG_KERNEL_START=0xc0000000 ++CONFIG_TASK_SIZE=0xc0000000 ++CONFIG_BOOT_LOAD=0x00800000 ++ ++# ++# Networking ++# ++CONFIG_NET=y ++ ++# ++# Networking options ++# ++CONFIG_PACKET=y ++# CONFIG_PACKET_MMAP is not set ++CONFIG_UNIX=y ++CONFIG_XFRM=y ++CONFIG_XFRM_USER=m ++# CONFIG_XFRM_SUB_POLICY is not set ++# CONFIG_XFRM_MIGRATE is not set ++# CONFIG_NET_KEY is not set ++CONFIG_INET=y ++CONFIG_IP_MULTICAST=y ++# CONFIG_IP_ADVANCED_ROUTER is not set ++CONFIG_IP_FIB_HASH=y ++CONFIG_IP_PNP=y ++CONFIG_IP_PNP_DHCP=y ++CONFIG_IP_PNP_BOOTP=y ++# CONFIG_IP_PNP_RARP is not set ++# CONFIG_NET_IPIP is not set ++# CONFIG_NET_IPGRE is not set ++# CONFIG_IP_MROUTE is not set ++# CONFIG_ARPD is not set ++CONFIG_SYN_COOKIES=y ++# CONFIG_INET_AH is not set ++# CONFIG_INET_ESP is not set ++# CONFIG_INET_IPCOMP is not set ++# CONFIG_INET_XFRM_TUNNEL is not set ++# CONFIG_INET_TUNNEL is not set ++CONFIG_INET_XFRM_MODE_TRANSPORT=y ++CONFIG_INET_XFRM_MODE_TUNNEL=y ++CONFIG_INET_XFRM_MODE_BEET=y ++# CONFIG_INET_LRO is not set ++CONFIG_INET_DIAG=y ++CONFIG_INET_TCP_DIAG=y ++# CONFIG_TCP_CONG_ADVANCED is not set ++CONFIG_TCP_CONG_CUBIC=y ++CONFIG_DEFAULT_TCP_CONG="cubic" ++# CONFIG_TCP_MD5SIG is not set ++# CONFIG_IPV6 is not set ++# CONFIG_INET6_XFRM_TUNNEL is not set ++# CONFIG_INET6_TUNNEL is not set ++# CONFIG_NETWORK_SECMARK is not set ++# CONFIG_NETFILTER is not set ++# CONFIG_IP_DCCP is not set ++# CONFIG_IP_SCTP is not set ++# CONFIG_TIPC is not set ++# CONFIG_ATM is not set ++# CONFIG_BRIDGE is not set ++# CONFIG_VLAN_8021Q is not set ++# CONFIG_DECNET is not set ++# CONFIG_LLC2 is not set ++# CONFIG_IPX is not set ++# CONFIG_ATALK is not set ++# CONFIG_X25 is not set ++# CONFIG_LAPB is not set ++# CONFIG_ECONET is not set ++# CONFIG_WAN_ROUTER is not set ++# CONFIG_NET_SCHED is not set ++ ++# ++# Network testing ++# ++# CONFIG_NET_PKTGEN is not set ++# CONFIG_HAMRADIO is not set ++# CONFIG_IRDA is not set ++# CONFIG_BT is not set ++# CONFIG_AF_RXRPC is not set ++ ++# ++# Wireless ++# ++# CONFIG_CFG80211 is not set ++# CONFIG_WIRELESS_EXT is not set ++# CONFIG_MAC80211 is not set ++# CONFIG_IEEE80211 is not set ++# CONFIG_RFKILL is not set ++# CONFIG_NET_9P is not set ++ ++# ++# Device Drivers ++# ++ ++# ++# Generic Driver Options ++# ++CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" ++CONFIG_STANDALONE=y ++CONFIG_PREVENT_FIRMWARE_BUILD=y ++# CONFIG_FW_LOADER is not set ++# CONFIG_DEBUG_DRIVER is not set ++# CONFIG_DEBUG_DEVRES is not set ++# CONFIG_SYS_HYPERVISOR is not set ++# CONFIG_CONNECTOR is not set ++CONFIG_MTD=y ++# CONFIG_MTD_DEBUG is not set ++CONFIG_MTD_CONCAT=y ++CONFIG_MTD_PARTITIONS=y ++# CONFIG_MTD_REDBOOT_PARTS is not set ++CONFIG_MTD_CMDLINE_PARTS=y ++ ++# ++# User Modules And Translation Layers ++# ++CONFIG_MTD_CHAR=y ++CONFIG_MTD_BLKDEVS=y ++CONFIG_MTD_BLOCK=y ++# CONFIG_FTL is not set ++# CONFIG_NFTL is not set ++# CONFIG_INFTL is not set ++# CONFIG_RFD_FTL is not set ++# CONFIG_SSFDC is not set ++# CONFIG_MTD_OOPS is not set ++ ++# ++# RAM/ROM/Flash chip drivers ++# ++CONFIG_MTD_CFI=y ++# CONFIG_MTD_JEDECPROBE is not set ++CONFIG_MTD_GEN_PROBE=y ++# CONFIG_MTD_CFI_ADV_OPTIONS is not set ++CONFIG_MTD_MAP_BANK_WIDTH_1=y ++CONFIG_MTD_MAP_BANK_WIDTH_2=y ++CONFIG_MTD_MAP_BANK_WIDTH_4=y ++# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set ++CONFIG_MTD_CFI_I1=y ++CONFIG_MTD_CFI_I2=y ++# CONFIG_MTD_CFI_I4 is not set ++# CONFIG_MTD_CFI_I8 is not set ++# CONFIG_MTD_CFI_INTELEXT is not set ++CONFIG_MTD_CFI_AMDSTD=y ++# CONFIG_MTD_CFI_STAA is not set ++CONFIG_MTD_CFI_UTIL=y ++CONFIG_MTD_RAM=y ++CONFIG_MTD_ROM=y ++# CONFIG_MTD_ABSENT is not set ++ ++# ++# Mapping drivers for chip access ++# ++# CONFIG_MTD_COMPLEX_MAPPINGS is not set ++# CONFIG_MTD_PHYSMAP is not set ++CONFIG_MTD_PHYSMAP_OF=y ++# CONFIG_MTD_INTEL_VR_NOR is not set ++# CONFIG_MTD_PLATRAM is not set ++ ++# ++# Self-contained MTD device drivers ++# ++# CONFIG_MTD_PMC551 is not set ++# CONFIG_MTD_SLRAM is not set ++# CONFIG_MTD_PHRAM is not set ++# CONFIG_MTD_MTDRAM is not set ++# CONFIG_MTD_BLOCK2MTD is not set ++ ++# ++# Disk-On-Chip Device Drivers ++# ++# CONFIG_MTD_DOC2000 is not set ++# CONFIG_MTD_DOC2001 is not set ++# CONFIG_MTD_DOC2001PLUS is not set ++# CONFIG_MTD_NAND is not set ++# CONFIG_MTD_ONENAND is not set ++ ++# ++# UBI - Unsorted block images ++# ++# CONFIG_MTD_UBI is not set ++CONFIG_OF_DEVICE=y ++# CONFIG_PARPORT is not set ++CONFIG_BLK_DEV=y ++# CONFIG_BLK_DEV_FD is not set ++# CONFIG_BLK_CPQ_DA is not set ++# CONFIG_BLK_CPQ_CISS_DA is not set ++# CONFIG_BLK_DEV_DAC960 is not set ++# CONFIG_BLK_DEV_UMEM is not set ++# CONFIG_BLK_DEV_COW_COMMON is not set ++CONFIG_BLK_DEV_LOOP=y ++# CONFIG_BLK_DEV_CRYPTOLOOP is not set ++# CONFIG_BLK_DEV_NBD is not set ++# CONFIG_BLK_DEV_SX8 is not set ++# CONFIG_BLK_DEV_UB is not set ++CONFIG_BLK_DEV_RAM=y ++CONFIG_BLK_DEV_RAM_COUNT=16 ++CONFIG_BLK_DEV_RAM_SIZE=32768 ++CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024 ++# CONFIG_CDROM_PKTCDVD is not set ++# CONFIG_ATA_OVER_ETH is not set ++CONFIG_MISC_DEVICES=y ++# CONFIG_PHANTOM is not set ++# CONFIG_EEPROM_93CX6 is not set ++# CONFIG_SGI_IOC4 is not set ++# CONFIG_TIFM_CORE is not set ++# CONFIG_IDE is not set ++ ++# ++# SCSI device support ++# ++# CONFIG_RAID_ATTRS is not set ++CONFIG_SCSI=y ++CONFIG_SCSI_DMA=y ++CONFIG_SCSI_TGT=y ++# CONFIG_SCSI_NETLINK is not set ++CONFIG_SCSI_PROC_FS=y ++ ++# ++# SCSI support type (disk, tape, CD-ROM) ++# ++CONFIG_BLK_DEV_SD=y ++# CONFIG_CHR_DEV_ST is not set ++# CONFIG_CHR_DEV_OSST is not set ++# CONFIG_BLK_DEV_SR is not set ++CONFIG_CHR_DEV_SG=y ++# CONFIG_CHR_DEV_SCH is not set ++ ++# ++# Some SCSI devices (e.g. CD jukebox) support multiple LUNs ++# ++# CONFIG_SCSI_MULTI_LUN is not set ++# CONFIG_SCSI_CONSTANTS is not set ++# CONFIG_SCSI_LOGGING is not set ++# CONFIG_SCSI_SCAN_ASYNC is not set ++CONFIG_SCSI_WAIT_SCAN=m ++ ++# ++# SCSI Transports ++# ++# CONFIG_SCSI_SPI_ATTRS is not set ++# CONFIG_SCSI_FC_ATTRS is not set ++# CONFIG_SCSI_ISCSI_ATTRS is not set ++# CONFIG_SCSI_SAS_LIBSAS is not set ++# CONFIG_SCSI_SRP_ATTRS is not set ++CONFIG_SCSI_LOWLEVEL=y ++# CONFIG_ISCSI_TCP is not set ++# CONFIG_BLK_DEV_3W_XXXX_RAID is not set ++# CONFIG_SCSI_3W_9XXX is not set ++# CONFIG_SCSI_ACARD is not set ++# CONFIG_SCSI_AACRAID is not set ++# CONFIG_SCSI_AIC7XXX is not set ++# CONFIG_SCSI_AIC7XXX_OLD is not set ++# CONFIG_SCSI_AIC79XX is not set ++# CONFIG_SCSI_AIC94XX is not set ++# CONFIG_SCSI_DPT_I2O is not set ++# CONFIG_SCSI_ADVANSYS is not set ++# CONFIG_SCSI_ARCMSR is not set ++# CONFIG_MEGARAID_NEWGEN is not set ++# CONFIG_MEGARAID_LEGACY is not set ++# CONFIG_MEGARAID_SAS is not set ++# CONFIG_SCSI_HPTIOP is not set ++# CONFIG_SCSI_BUSLOGIC is not set ++# CONFIG_SCSI_DMX3191D is not set ++# CONFIG_SCSI_EATA is not set ++# CONFIG_SCSI_FUTURE_DOMAIN is not set ++# CONFIG_SCSI_GDTH is not set ++# CONFIG_SCSI_IPS is not set ++# CONFIG_SCSI_INITIO is not set ++# CONFIG_SCSI_INIA100 is not set ++# CONFIG_SCSI_STEX is not set ++# CONFIG_SCSI_SYM53C8XX_2 is not set ++# CONFIG_SCSI_IPR is not set ++# CONFIG_SCSI_QLOGIC_1280 is not set ++# CONFIG_SCSI_QLA_FC is not set ++# CONFIG_SCSI_QLA_ISCSI is not set ++# CONFIG_SCSI_LPFC is not set ++# CONFIG_SCSI_DC395x is not set ++# CONFIG_SCSI_DC390T is not set ++# CONFIG_SCSI_NSP32 is not set ++# CONFIG_SCSI_DEBUG is not set ++# CONFIG_SCSI_SRP is not set ++CONFIG_ATA=y ++# CONFIG_ATA_NONSTANDARD is not set ++# CONFIG_SATA_AHCI is not set ++# CONFIG_SATA_SVW is not set ++# CONFIG_ATA_PIIX is not set ++# CONFIG_SATA_MV is not set ++# CONFIG_SATA_NV is not set ++# CONFIG_PDC_ADMA is not set ++# CONFIG_SATA_QSTOR is not set ++# CONFIG_SATA_PROMISE is not set ++# CONFIG_SATA_SX4 is not set ++# CONFIG_SATA_SIL is not set ++# CONFIG_SATA_SIL24 is not set ++# CONFIG_SATA_SIS is not set ++# CONFIG_SATA_ULI is not set ++# CONFIG_SATA_VIA is not set ++# CONFIG_SATA_VITESSE is not set ++# CONFIG_SATA_INIC162X is not set ++# CONFIG_PATA_ALI is not set ++# CONFIG_PATA_AMD is not set ++# CONFIG_PATA_ARTOP is not set ++# CONFIG_PATA_ATIIXP is not set ++# CONFIG_PATA_CMD640_PCI is not set ++# CONFIG_PATA_CMD64X is not set ++# CONFIG_PATA_CS5520 is not set ++# CONFIG_PATA_CS5530 is not set ++# CONFIG_PATA_CYPRESS is not set ++# CONFIG_PATA_EFAR is not set ++# CONFIG_ATA_GENERIC is not set ++# CONFIG_PATA_HPT366 is not set ++# CONFIG_PATA_HPT37X is not set ++# CONFIG_PATA_HPT3X2N is not set ++# CONFIG_PATA_HPT3X3 is not set ++# CONFIG_PATA_IT821X is not set ++# CONFIG_PATA_IT8213 is not set ++# CONFIG_PATA_JMICRON is not set ++# CONFIG_PATA_TRIFLEX is not set ++# CONFIG_PATA_MARVELL is not set ++CONFIG_PATA_MPC52xx=y ++# CONFIG_PATA_MPIIX is not set ++# CONFIG_PATA_OLDPIIX is not set ++# CONFIG_PATA_NETCELL is not set ++# CONFIG_PATA_NS87410 is not set ++# CONFIG_PATA_NS87415 is not set ++# CONFIG_PATA_OPTI is not set ++# CONFIG_PATA_OPTIDMA is not set ++# CONFIG_PATA_PDC_OLD is not set ++# CONFIG_PATA_RADISYS is not set ++# CONFIG_PATA_RZ1000 is not set ++# CONFIG_PATA_SC1200 is not set ++# CONFIG_PATA_SERVERWORKS is not set ++# CONFIG_PATA_PDC2027X is not set ++# CONFIG_PATA_SIL680 is not set ++# CONFIG_PATA_SIS is not set ++# CONFIG_PATA_VIA is not set ++# CONFIG_PATA_WINBOND is not set ++CONFIG_PATA_PLATFORM=y ++# CONFIG_PATA_OF_PLATFORM is not set ++# CONFIG_MD is not set ++# CONFIG_FUSION is not set ++ ++# ++# IEEE 1394 (FireWire) support ++# ++# CONFIG_FIREWIRE is not set ++# CONFIG_IEEE1394 is not set ++# CONFIG_I2O is not set ++# CONFIG_MACINTOSH_DRIVERS is not set ++CONFIG_NETDEVICES=y ++# CONFIG_NETDEVICES_MULTIQUEUE is not set ++# CONFIG_DUMMY is not set ++# CONFIG_BONDING is not set ++# CONFIG_MACVLAN is not set ++# CONFIG_EQUALIZER is not set ++# CONFIG_TUN is not set ++# CONFIG_VETH is not set ++# CONFIG_IP1000 is not set ++# CONFIG_ARCNET is not set ++CONFIG_PHYLIB=y ++ ++# ++# MII PHY device drivers ++# ++# CONFIG_MARVELL_PHY is not set ++# CONFIG_DAVICOM_PHY is not set ++# CONFIG_QSEMI_PHY is not set ++# CONFIG_LXT_PHY is not set ++# CONFIG_CICADA_PHY is not set ++# CONFIG_VITESSE_PHY is not set ++# CONFIG_SMSC_PHY is not set ++# CONFIG_BROADCOM_PHY is not set ++# CONFIG_ICPLUS_PHY is not set ++# CONFIG_FIXED_PHY is not set ++# CONFIG_MDIO_BITBANG is not set ++CONFIG_NET_ETHERNET=y ++# CONFIG_MII is not set ++# CONFIG_HAPPYMEAL is not set ++# CONFIG_SUNGEM is not set ++# CONFIG_CASSINI is not set ++# CONFIG_NET_VENDOR_3COM is not set ++# CONFIG_NET_TULIP is not set ++# CONFIG_HP100 is not set ++# CONFIG_IBM_NEW_EMAC_ZMII is not set ++# CONFIG_IBM_NEW_EMAC_RGMII is not set ++# CONFIG_IBM_NEW_EMAC_TAH is not set ++# CONFIG_IBM_NEW_EMAC_EMAC4 is not set ++# CONFIG_NET_PCI is not set ++# CONFIG_B44 is not set ++CONFIG_FEC_MPC52xx=y ++CONFIG_FEC_MPC52xx_MDIO=y ++# CONFIG_NETDEV_1000 is not set ++# CONFIG_NETDEV_10000 is not set ++# CONFIG_TR is not set ++ ++# ++# Wireless LAN ++# ++# CONFIG_WLAN_PRE80211 is not set ++# CONFIG_WLAN_80211 is not set ++ ++# ++# USB Network Adapters ++# ++# CONFIG_USB_CATC is not set ++# CONFIG_USB_KAWETH is not set ++# CONFIG_USB_PEGASUS is not set ++# CONFIG_USB_RTL8150 is not set ++# CONFIG_USB_USBNET is not set ++# CONFIG_WAN is not set ++# CONFIG_FDDI is not set ++# CONFIG_HIPPI is not set ++# CONFIG_PPP is not set ++# CONFIG_SLIP is not set ++# CONFIG_NET_FC is not set ++# CONFIG_SHAPER is not set ++# CONFIG_NETCONSOLE is not set ++# CONFIG_NETPOLL is not set ++# CONFIG_NET_POLL_CONTROLLER is not set ++# CONFIG_ISDN is not set ++# CONFIG_PHONE is not set ++ ++# ++# Input device support ++# ++# CONFIG_INPUT is not set ++ ++# ++# Hardware I/O ports ++# ++# CONFIG_SERIO is not set ++# CONFIG_GAMEPORT is not set ++ ++# ++# Character devices ++# ++# CONFIG_VT is not set ++# CONFIG_SERIAL_NONSTANDARD is not set ++ ++# ++# Serial drivers ++# ++# CONFIG_SERIAL_8250 is not set ++ ++# ++# Non-8250 serial port support ++# ++# CONFIG_SERIAL_UARTLITE is not set ++CONFIG_SERIAL_CORE=y ++CONFIG_SERIAL_CORE_CONSOLE=y ++CONFIG_SERIAL_MPC52xx=y ++CONFIG_SERIAL_MPC52xx_CONSOLE=y ++CONFIG_SERIAL_MPC52xx_CONSOLE_BAUD=115200 ++# CONFIG_SERIAL_JSM is not set ++CONFIG_UNIX98_PTYS=y ++CONFIG_LEGACY_PTYS=y ++CONFIG_LEGACY_PTY_COUNT=256 ++# CONFIG_HVC_RTAS is not set ++# CONFIG_IPMI_HANDLER is not set ++# CONFIG_HW_RANDOM is not set ++# CONFIG_NVRAM is not set ++CONFIG_GEN_RTC=y ++# CONFIG_GEN_RTC_X is not set ++# CONFIG_R3964 is not set ++# CONFIG_APPLICOM is not set ++# CONFIG_RAW_DRIVER is not set ++# CONFIG_TCG_TPM is not set ++CONFIG_DEVPORT=y ++CONFIG_I2C=y ++CONFIG_I2C_BOARDINFO=y ++CONFIG_I2C_CHARDEV=y ++ ++# ++# I2C Algorithms ++# ++# CONFIG_I2C_ALGOBIT is not set ++# CONFIG_I2C_ALGOPCF is not set ++# CONFIG_I2C_ALGOPCA is not set ++ ++# ++# I2C Hardware Bus support ++# ++# CONFIG_I2C_ALI1535 is not set ++# CONFIG_I2C_ALI1563 is not set ++# CONFIG_I2C_ALI15X3 is not set ++# CONFIG_I2C_AMD756 is not set ++# CONFIG_I2C_AMD8111 is not set ++# CONFIG_I2C_I801 is not set ++# CONFIG_I2C_I810 is not set ++# CONFIG_I2C_PIIX4 is not set ++CONFIG_I2C_MPC=y ++# CONFIG_I2C_NFORCE2 is not set ++# CONFIG_I2C_OCORES is not set ++# CONFIG_I2C_PARPORT_LIGHT is not set ++# CONFIG_I2C_PROSAVAGE is not set ++# CONFIG_I2C_SAVAGE4 is not set ++# CONFIG_I2C_SIMTEC is not set ++# CONFIG_I2C_SIS5595 is not set ++# CONFIG_I2C_SIS630 is not set ++# CONFIG_I2C_SIS96X is not set ++# CONFIG_I2C_TAOS_EVM is not set ++# CONFIG_I2C_STUB is not set ++# CONFIG_I2C_TINY_USB is not set ++# CONFIG_I2C_VIA is not set ++# CONFIG_I2C_VIAPRO is not set ++# CONFIG_I2C_VOODOO3 is not set ++ ++# ++# Miscellaneous I2C Chip support ++# ++# CONFIG_SENSORS_DS1337 is not set ++# CONFIG_SENSORS_DS1374 is not set ++# CONFIG_DS1682 is not set ++# CONFIG_SENSORS_EEPROM is not set ++# CONFIG_SENSORS_PCF8574 is not set ++# CONFIG_SENSORS_PCA9539 is not set ++# CONFIG_SENSORS_PCF8591 is not set ++# CONFIG_SENSORS_M41T00 is not set ++# CONFIG_SENSORS_MAX6875 is not set ++# CONFIG_SENSORS_TSL2550 is not set ++# CONFIG_I2C_DEBUG_CORE is not set ++# CONFIG_I2C_DEBUG_ALGO is not set ++# CONFIG_I2C_DEBUG_BUS is not set ++# CONFIG_I2C_DEBUG_CHIP is not set ++ ++# ++# SPI support ++# ++# CONFIG_SPI is not set ++# CONFIG_SPI_MASTER is not set ++# CONFIG_W1 is not set ++# CONFIG_POWER_SUPPLY is not set ++CONFIG_HWMON=y ++# CONFIG_HWMON_VID is not set ++# CONFIG_SENSORS_AD7418 is not set ++# CONFIG_SENSORS_ADM1021 is not set ++# CONFIG_SENSORS_ADM1025 is not set ++# CONFIG_SENSORS_ADM1026 is not set ++# CONFIG_SENSORS_ADM1029 is not set ++# CONFIG_SENSORS_ADM1031 is not set ++# CONFIG_SENSORS_ADM9240 is not set ++# CONFIG_SENSORS_ADT7470 is not set ++# CONFIG_SENSORS_ATXP1 is not set ++# CONFIG_SENSORS_DS1621 is not set ++# CONFIG_SENSORS_I5K_AMB is not set ++# CONFIG_SENSORS_F71805F is not set ++# CONFIG_SENSORS_F71882FG is not set ++# CONFIG_SENSORS_F75375S is not set ++# CONFIG_SENSORS_GL518SM is not set ++# CONFIG_SENSORS_GL520SM is not set ++# CONFIG_SENSORS_IT87 is not set ++# CONFIG_SENSORS_LM63 is not set ++# CONFIG_SENSORS_LM75 is not set ++# CONFIG_SENSORS_LM77 is not set ++# CONFIG_SENSORS_LM78 is not set ++# CONFIG_SENSORS_LM80 is not set ++# CONFIG_SENSORS_LM83 is not set ++# CONFIG_SENSORS_LM85 is not set ++# CONFIG_SENSORS_LM87 is not set ++# CONFIG_SENSORS_LM90 is not set ++# CONFIG_SENSORS_LM92 is not set ++# CONFIG_SENSORS_LM93 is not set ++# CONFIG_SENSORS_MAX1619 is not set ++# CONFIG_SENSORS_MAX6650 is not set ++# CONFIG_SENSORS_PC87360 is not set ++# CONFIG_SENSORS_PC87427 is not set ++# CONFIG_SENSORS_SIS5595 is not set ++# CONFIG_SENSORS_DME1737 is not set ++# CONFIG_SENSORS_SMSC47M1 is not set ++# CONFIG_SENSORS_SMSC47M192 is not set ++# CONFIG_SENSORS_SMSC47B397 is not set ++# CONFIG_SENSORS_THMC50 is not set ++# CONFIG_SENSORS_VIA686A is not set ++# CONFIG_SENSORS_VT1211 is not set ++# CONFIG_SENSORS_VT8231 is not set ++# CONFIG_SENSORS_W83781D is not set ++# CONFIG_SENSORS_W83791D is not set ++# CONFIG_SENSORS_W83792D is not set ++# CONFIG_SENSORS_W83793 is not set ++# CONFIG_SENSORS_W83L785TS is not set ++# CONFIG_SENSORS_W83627HF is not set ++# CONFIG_SENSORS_W83627EHF is not set ++# CONFIG_HWMON_DEBUG_CHIP is not set ++CONFIG_WATCHDOG=y ++# CONFIG_WATCHDOG_NOWAYOUT is not set ++ ++# ++# Watchdog Device Drivers ++# ++# CONFIG_SOFT_WATCHDOG is not set ++# CONFIG_MPC5200_WDT is not set ++# CONFIG_WATCHDOG_RTAS is not set ++ ++# ++# PCI-based Watchdog Cards ++# ++# CONFIG_PCIPCWATCHDOG is not set ++# CONFIG_WDTPCI is not set ++ ++# ++# USB-based Watchdog Cards ++# ++# CONFIG_USBPCWATCHDOG is not set ++ ++# ++# Sonics Silicon Backplane ++# ++CONFIG_SSB_POSSIBLE=y ++# CONFIG_SSB is not set ++ ++# ++# Multifunction device drivers ++# ++# CONFIG_MFD_SM501 is not set ++ ++# ++# Multimedia devices ++# ++# CONFIG_VIDEO_DEV is not set ++# CONFIG_DVB_CORE is not set ++CONFIG_DAB=y ++# CONFIG_USB_DABUSB is not set ++ ++# ++# Graphics support ++# ++# CONFIG_AGP is not set ++# CONFIG_DRM is not set ++# CONFIG_VGASTATE is not set ++CONFIG_VIDEO_OUTPUT_CONTROL=m ++# CONFIG_FB is not set ++# CONFIG_BACKLIGHT_LCD_SUPPORT is not set ++ ++# ++# Display device support ++# ++# CONFIG_DISPLAY_SUPPORT is not set ++ ++# ++# Sound ++# ++# CONFIG_SOUND is not set ++CONFIG_USB_SUPPORT=y ++CONFIG_USB_ARCH_HAS_HCD=y ++CONFIG_USB_ARCH_HAS_OHCI=y ++CONFIG_USB_ARCH_HAS_EHCI=y ++CONFIG_USB=y ++# CONFIG_USB_DEBUG is not set ++ ++# ++# Miscellaneous USB options ++# ++CONFIG_USB_DEVICEFS=y ++# CONFIG_USB_DEVICE_CLASS is not set ++# CONFIG_USB_DYNAMIC_MINORS is not set ++# CONFIG_USB_SUSPEND is not set ++# CONFIG_USB_PERSIST is not set ++# CONFIG_USB_OTG is not set ++ ++# ++# USB Host Controller Drivers ++# ++# CONFIG_USB_EHCI_HCD is not set ++# CONFIG_USB_ISP116X_HCD is not set ++CONFIG_USB_OHCI_HCD=y ++CONFIG_USB_OHCI_HCD_PPC_SOC=y ++CONFIG_USB_OHCI_HCD_PPC_OF=y ++CONFIG_USB_OHCI_HCD_PPC_OF_BE=y ++# CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set ++CONFIG_USB_OHCI_HCD_PCI=y ++CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y ++CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y ++CONFIG_USB_OHCI_LITTLE_ENDIAN=y ++# CONFIG_USB_UHCI_HCD is not set ++# CONFIG_USB_SL811_HCD is not set ++# CONFIG_USB_R8A66597_HCD is not set ++ ++# ++# USB Device Class drivers ++# ++# CONFIG_USB_ACM is not set ++# CONFIG_USB_PRINTER is not set ++ ++# ++# NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' ++# ++ ++# ++# may also be needed; see USB_STORAGE Help for more information ++# ++CONFIG_USB_STORAGE=y ++# CONFIG_USB_STORAGE_DEBUG is not set ++# CONFIG_USB_STORAGE_DATAFAB is not set ++# CONFIG_USB_STORAGE_FREECOM is not set ++# CONFIG_USB_STORAGE_ISD200 is not set ++# CONFIG_USB_STORAGE_DPCM is not set ++# CONFIG_USB_STORAGE_USBAT is not set ++# CONFIG_USB_STORAGE_SDDR09 is not set ++# CONFIG_USB_STORAGE_SDDR55 is not set ++# CONFIG_USB_STORAGE_JUMPSHOT is not set ++# CONFIG_USB_STORAGE_ALAUDA is not set ++# CONFIG_USB_STORAGE_KARMA is not set ++# CONFIG_USB_LIBUSUAL is not set ++ ++# ++# USB Imaging devices ++# ++# CONFIG_USB_MDC800 is not set ++# CONFIG_USB_MICROTEK is not set ++CONFIG_USB_MON=y ++ ++# ++# USB port drivers ++# ++ ++# ++# USB Serial Converter support ++# ++# CONFIG_USB_SERIAL is not set ++ ++# ++# USB Miscellaneous drivers ++# ++# CONFIG_USB_EMI62 is not set ++# CONFIG_USB_EMI26 is not set ++# CONFIG_USB_ADUTUX is not set ++# CONFIG_USB_AUERSWALD is not set ++# CONFIG_USB_RIO500 is not set ++# CONFIG_USB_LEGOTOWER is not set ++# CONFIG_USB_LCD is not set ++# CONFIG_USB_BERRY_CHARGE is not set ++# CONFIG_USB_LED is not set ++# CONFIG_USB_CYPRESS_CY7C63 is not set ++# CONFIG_USB_CYTHERM is not set ++# CONFIG_USB_PHIDGET is not set ++# CONFIG_USB_IDMOUSE is not set ++# CONFIG_USB_FTDI_ELAN is not set ++# CONFIG_USB_APPLEDISPLAY is not set ++# CONFIG_USB_LD is not set ++# CONFIG_USB_TRANCEVIBRATOR is not set ++# CONFIG_USB_IOWARRIOR is not set ++# CONFIG_USB_TEST is not set ++ ++# ++# USB DSL modem support ++# ++ ++# ++# USB Gadget Support ++# ++# CONFIG_USB_GADGET is not set ++# CONFIG_MMC is not set ++CONFIG_NEW_LEDS=y ++CONFIG_LEDS_CLASS=y ++ ++# ++# LED drivers ++# ++ ++# ++# LED Triggers ++# ++CONFIG_LEDS_TRIGGERS=y ++CONFIG_LEDS_TRIGGER_TIMER=y ++# CONFIG_LEDS_TRIGGER_HEARTBEAT is not set ++# CONFIG_INFINIBAND is not set ++# CONFIG_EDAC is not set ++# CONFIG_RTC_CLASS is not set ++ ++# ++# Userspace I/O ++# ++# CONFIG_UIO is not set ++ ++# ++# File systems ++# ++CONFIG_EXT2_FS=y ++# CONFIG_EXT2_FS_XATTR is not set ++# CONFIG_EXT2_FS_XIP is not set ++CONFIG_EXT3_FS=y ++CONFIG_EXT3_FS_XATTR=y ++# CONFIG_EXT3_FS_POSIX_ACL is not set ++# CONFIG_EXT3_FS_SECURITY is not set ++# CONFIG_EXT4DEV_FS is not set ++CONFIG_JBD=y ++CONFIG_FS_MBCACHE=y ++# CONFIG_REISERFS_FS is not set ++# CONFIG_JFS_FS is not set ++# CONFIG_FS_POSIX_ACL is not set ++# CONFIG_XFS_FS is not set ++# CONFIG_GFS2_FS is not set ++# CONFIG_OCFS2_FS is not set ++# CONFIG_MINIX_FS is not set ++# CONFIG_ROMFS_FS is not set ++CONFIG_INOTIFY=y ++CONFIG_INOTIFY_USER=y ++# CONFIG_QUOTA is not set ++CONFIG_DNOTIFY=y ++# CONFIG_AUTOFS_FS is not set ++# CONFIG_AUTOFS4_FS is not set ++# CONFIG_FUSE_FS is not set ++ ++# ++# CD-ROM/DVD Filesystems ++# ++# CONFIG_ISO9660_FS is not set ++# CONFIG_UDF_FS is not set ++ ++# ++# DOS/FAT/NT Filesystems ++# ++CONFIG_FAT_FS=y ++CONFIG_MSDOS_FS=y ++CONFIG_VFAT_FS=y ++CONFIG_FAT_DEFAULT_CODEPAGE=437 ++CONFIG_FAT_DEFAULT_IOCHARSET="iso8859-1" ++# CONFIG_NTFS_FS is not set ++ ++# ++# Pseudo filesystems ++# ++CONFIG_PROC_FS=y ++CONFIG_PROC_KCORE=y ++CONFIG_PROC_SYSCTL=y ++CONFIG_SYSFS=y ++CONFIG_TMPFS=y ++# CONFIG_TMPFS_POSIX_ACL is not set ++# CONFIG_HUGETLB_PAGE is not set ++# CONFIG_CONFIGFS_FS is not set ++ ++# ++# Miscellaneous filesystems ++# ++# CONFIG_ADFS_FS is not set ++# CONFIG_AFFS_FS is not set ++# CONFIG_HFS_FS is not set ++# CONFIG_HFSPLUS_FS is not set ++# CONFIG_BEFS_FS is not set ++# CONFIG_BFS_FS is not set ++# CONFIG_EFS_FS is not set ++CONFIG_JFFS2_FS=y ++CONFIG_JFFS2_FS_DEBUG=0 ++CONFIG_JFFS2_FS_WRITEBUFFER=y ++# CONFIG_JFFS2_FS_WBUF_VERIFY is not set ++# CONFIG_JFFS2_SUMMARY is not set ++# CONFIG_JFFS2_FS_XATTR is not set ++# CONFIG_JFFS2_COMPRESSION_OPTIONS is not set ++CONFIG_JFFS2_ZLIB=y ++# CONFIG_JFFS2_LZO is not set ++CONFIG_JFFS2_RTIME=y ++# CONFIG_JFFS2_RUBIN is not set ++CONFIG_CRAMFS=y ++# CONFIG_VXFS_FS is not set ++# CONFIG_HPFS_FS is not set ++# CONFIG_QNX4FS_FS is not set ++# CONFIG_SYSV_FS is not set ++# CONFIG_UFS_FS is not set ++CONFIG_NETWORK_FILESYSTEMS=y ++CONFIG_NFS_FS=y ++CONFIG_NFS_V3=y ++# CONFIG_NFS_V3_ACL is not set ++CONFIG_NFS_V4=y ++# CONFIG_NFS_DIRECTIO is not set ++# CONFIG_NFSD is not set ++CONFIG_ROOT_NFS=y ++CONFIG_LOCKD=y ++CONFIG_LOCKD_V4=y ++CONFIG_NFS_COMMON=y ++CONFIG_SUNRPC=y ++CONFIG_SUNRPC_GSS=y ++# CONFIG_SUNRPC_BIND34 is not set ++CONFIG_RPCSEC_GSS_KRB5=y ++# CONFIG_RPCSEC_GSS_SPKM3 is not set ++# CONFIG_SMB_FS is not set ++# CONFIG_CIFS is not set ++# CONFIG_NCP_FS is not set ++# CONFIG_CODA_FS is not set ++# CONFIG_AFS_FS is not set ++ ++# ++# Partition Types ++# ++# CONFIG_PARTITION_ADVANCED is not set ++CONFIG_MSDOS_PARTITION=y ++CONFIG_NLS=y ++CONFIG_NLS_DEFAULT="iso8859-1" ++CONFIG_NLS_CODEPAGE_437=y ++# CONFIG_NLS_CODEPAGE_737 is not set ++# CONFIG_NLS_CODEPAGE_775 is not set ++# CONFIG_NLS_CODEPAGE_850 is not set ++# CONFIG_NLS_CODEPAGE_852 is not set ++# CONFIG_NLS_CODEPAGE_855 is not set ++# CONFIG_NLS_CODEPAGE_857 is not set ++# CONFIG_NLS_CODEPAGE_860 is not set ++# CONFIG_NLS_CODEPAGE_861 is not set ++# CONFIG_NLS_CODEPAGE_862 is not set ++# CONFIG_NLS_CODEPAGE_863 is not set ++# CONFIG_NLS_CODEPAGE_864 is not set ++# CONFIG_NLS_CODEPAGE_865 is not set ++# CONFIG_NLS_CODEPAGE_866 is not set ++# CONFIG_NLS_CODEPAGE_869 is not set ++# CONFIG_NLS_CODEPAGE_936 is not set ++# CONFIG_NLS_CODEPAGE_950 is not set ++# CONFIG_NLS_CODEPAGE_932 is not set ++# CONFIG_NLS_CODEPAGE_949 is not set ++# CONFIG_NLS_CODEPAGE_874 is not set ++# CONFIG_NLS_ISO8859_8 is not set ++# CONFIG_NLS_CODEPAGE_1250 is not set ++# CONFIG_NLS_CODEPAGE_1251 is not set ++# CONFIG_NLS_ASCII is not set ++CONFIG_NLS_ISO8859_1=y ++# CONFIG_NLS_ISO8859_2 is not set ++# CONFIG_NLS_ISO8859_3 is not set ++# CONFIG_NLS_ISO8859_4 is not set ++# CONFIG_NLS_ISO8859_5 is not set ++# CONFIG_NLS_ISO8859_6 is not set ++# CONFIG_NLS_ISO8859_7 is not set ++# CONFIG_NLS_ISO8859_9 is not set ++# CONFIG_NLS_ISO8859_13 is not set ++# CONFIG_NLS_ISO8859_14 is not set ++# CONFIG_NLS_ISO8859_15 is not set ++# CONFIG_NLS_KOI8_R is not set ++# CONFIG_NLS_KOI8_U is not set ++# CONFIG_NLS_UTF8 is not set ++# CONFIG_DLM is not set ++# CONFIG_UCC_SLOW is not set ++ ++# ++# Library routines ++# ++CONFIG_BITREVERSE=y ++# CONFIG_CRC_CCITT is not set ++# CONFIG_CRC16 is not set ++# CONFIG_CRC_ITU_T is not set ++CONFIG_CRC32=y ++# CONFIG_CRC7 is not set ++# CONFIG_LIBCRC32C is not set ++CONFIG_ZLIB_INFLATE=y ++CONFIG_ZLIB_DEFLATE=y ++CONFIG_PLIST=y ++CONFIG_HAS_IOMEM=y ++CONFIG_HAS_IOPORT=y ++CONFIG_HAS_DMA=y ++# CONFIG_INSTRUMENTATION is not set ++ ++# ++# Kernel hacking ++# ++CONFIG_PRINTK_TIME=y ++CONFIG_ENABLE_WARN_DEPRECATED=y ++CONFIG_ENABLE_MUST_CHECK=y ++# CONFIG_MAGIC_SYSRQ is not set ++# CONFIG_UNUSED_SYMBOLS is not set ++# CONFIG_DEBUG_FS is not set ++# CONFIG_HEADERS_CHECK is not set ++CONFIG_DEBUG_KERNEL=y ++# CONFIG_DEBUG_SHIRQ is not set ++CONFIG_DETECT_SOFTLOCKUP=y ++CONFIG_SCHED_DEBUG=y ++# CONFIG_SCHEDSTATS is not set ++# CONFIG_TIMER_STATS is not set ++# CONFIG_SLUB_DEBUG_ON is not set ++# CONFIG_DEBUG_RT_MUTEXES is not set ++# CONFIG_RT_MUTEX_TESTER is not set ++# CONFIG_DEBUG_SPINLOCK is not set ++# CONFIG_DEBUG_MUTEXES is not set ++# CONFIG_DEBUG_SPINLOCK_SLEEP is not set ++# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set ++# CONFIG_DEBUG_KOBJECT is not set ++# CONFIG_DEBUG_BUGVERBOSE is not set ++CONFIG_DEBUG_INFO=y ++# CONFIG_DEBUG_VM is not set ++# CONFIG_DEBUG_LIST is not set ++# CONFIG_DEBUG_SG is not set ++CONFIG_FORCED_INLINING=y ++# CONFIG_BOOT_PRINTK_DELAY is not set ++# CONFIG_RCU_TORTURE_TEST is not set ++# CONFIG_FAULT_INJECTION is not set ++# CONFIG_SAMPLES is not set ++# CONFIG_DEBUG_STACKOVERFLOW is not set ++# CONFIG_DEBUG_STACK_USAGE is not set ++# CONFIG_DEBUG_PAGEALLOC is not set ++# CONFIG_DEBUGGER is not set ++# CONFIG_BDI_SWITCH is not set ++# CONFIG_BOOTX_TEXT is not set ++# CONFIG_PPC_EARLY_DEBUG is not set ++ ++# ++# Security options ++# ++# CONFIG_KEYS is not set ++# CONFIG_SECURITY is not set ++# CONFIG_SECURITY_FILE_CAPABILITIES is not set ++CONFIG_CRYPTO=y ++CONFIG_CRYPTO_ALGAPI=y ++CONFIG_CRYPTO_BLKCIPHER=y ++CONFIG_CRYPTO_MANAGER=y ++# CONFIG_CRYPTO_HMAC is not set ++# CONFIG_CRYPTO_XCBC is not set ++# CONFIG_CRYPTO_NULL is not set ++# CONFIG_CRYPTO_MD4 is not set ++CONFIG_CRYPTO_MD5=y ++# CONFIG_CRYPTO_SHA1 is not set ++# CONFIG_CRYPTO_SHA256 is not set ++# CONFIG_CRYPTO_SHA512 is not set ++# CONFIG_CRYPTO_WP512 is not set ++# CONFIG_CRYPTO_TGR192 is not set ++# CONFIG_CRYPTO_GF128MUL is not set ++# CONFIG_CRYPTO_ECB is not set ++CONFIG_CRYPTO_CBC=y ++# CONFIG_CRYPTO_PCBC is not set ++# CONFIG_CRYPTO_LRW is not set ++# CONFIG_CRYPTO_XTS is not set ++# CONFIG_CRYPTO_CRYPTD is not set ++CONFIG_CRYPTO_DES=y ++# CONFIG_CRYPTO_FCRYPT is not set ++# CONFIG_CRYPTO_BLOWFISH is not set ++# CONFIG_CRYPTO_TWOFISH is not set ++# CONFIG_CRYPTO_SERPENT is not set ++# CONFIG_CRYPTO_AES is not set ++# CONFIG_CRYPTO_CAST5 is not set ++# CONFIG_CRYPTO_CAST6 is not set ++# CONFIG_CRYPTO_TEA is not set ++# CONFIG_CRYPTO_ARC4 is not set ++# CONFIG_CRYPTO_KHAZAD is not set ++# CONFIG_CRYPTO_ANUBIS is not set ++# CONFIG_CRYPTO_SEED is not set ++# CONFIG_CRYPTO_DEFLATE is not set ++# CONFIG_CRYPTO_MICHAEL_MIC is not set ++# CONFIG_CRYPTO_CRC32C is not set ++# CONFIG_CRYPTO_CAMELLIA is not set ++# CONFIG_CRYPTO_TEST is not set ++# CONFIG_CRYPTO_AUTHENC is not set ++CONFIG_CRYPTO_HW=y ++CONFIG_PPC_CLOCK=y ++CONFIG_PPC_LIB_RHEAP=y +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/mpc8313_rdb_defconfig powerpc.git/arch/powerpc/configs/mpc8313_rdb_defconfig +--- linux-2.6.24/arch/powerpc/configs/mpc8313_rdb_defconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/mpc8313_rdb_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -1,7 +1,7 @@ + # + # Automatically generated make config: don't edit +-# Linux kernel version: 2.6.24-rc4 +-# Thu Dec 6 16:48:31 2007 ++# Linux kernel version: 2.6.24-rc6 ++# Thu Jan 17 16:35:55 2008 + # + # CONFIG_PPC64 is not set + +@@ -144,6 +144,7 @@ + # CONFIG_MPC834x_MDS is not set + # CONFIG_MPC834x_ITX is not set + # CONFIG_MPC836x_MDS is not set ++# CONFIG_MPC837x_MDS is not set + CONFIG_PPC_MPC831x=y + # CONFIG_MPIC is not set + # CONFIG_MPIC_WEIRD is not set +@@ -336,15 +337,16 @@ + CONFIG_MTD=y + # CONFIG_MTD_DEBUG is not set + # CONFIG_MTD_CONCAT is not set +-# CONFIG_MTD_PARTITIONS is not set ++CONFIG_MTD_PARTITIONS=y ++# CONFIG_MTD_REDBOOT_PARTS is not set ++# CONFIG_MTD_CMDLINE_PARTS is not set + + # + # User Modules And Translation Layers + # + CONFIG_MTD_CHAR=y +-# CONFIG_MTD_BLKDEVS is not set +-# CONFIG_MTD_BLOCK is not set +-# CONFIG_MTD_BLOCK_RO is not set ++CONFIG_MTD_BLKDEVS=y ++CONFIG_MTD_BLOCK=y + # CONFIG_FTL is not set + # CONFIG_NFTL is not set + # CONFIG_INFTL is not set +@@ -381,11 +383,8 @@ + # Mapping drivers for chip access + # + # CONFIG_MTD_COMPLEX_MAPPINGS is not set +-CONFIG_MTD_PHYSMAP=y +-CONFIG_MTD_PHYSMAP_START=0xfe000000 +-CONFIG_MTD_PHYSMAP_LEN=0x1000000 +-CONFIG_MTD_PHYSMAP_BANKWIDTH=2 +-# CONFIG_MTD_PHYSMAP_OF is not set ++# CONFIG_MTD_PHYSMAP is not set ++CONFIG_MTD_PHYSMAP_OF=y + # CONFIG_MTD_INTEL_VR_NOR is not set + # CONFIG_MTD_PLATRAM is not set + +@@ -406,7 +405,16 @@ + # CONFIG_MTD_DOC2000 is not set + # CONFIG_MTD_DOC2001 is not set + # CONFIG_MTD_DOC2001PLUS is not set +-# CONFIG_MTD_NAND is not set ++CONFIG_MTD_NAND=y ++CONFIG_MTD_NAND_VERIFY_WRITE=y ++# CONFIG_MTD_NAND_ECC_SMC is not set ++# CONFIG_MTD_NAND_MUSEUM_IDS is not set ++CONFIG_MTD_NAND_IDS=y ++# CONFIG_MTD_NAND_DISKONCHIP is not set ++# CONFIG_MTD_NAND_CAFE is not set ++# CONFIG_MTD_NAND_NANDSIM is not set ++# CONFIG_MTD_NAND_PLATFORM is not set ++# CONFIG_MTD_ALAUDA is not set + # CONFIG_MTD_ONENAND is not set + + # +@@ -1178,7 +1186,17 @@ + # CONFIG_BEFS_FS is not set + # CONFIG_BFS_FS is not set + # CONFIG_EFS_FS is not set +-# CONFIG_JFFS2_FS is not set ++CONFIG_JFFS2_FS=y ++CONFIG_JFFS2_FS_DEBUG=0 ++CONFIG_JFFS2_FS_WRITEBUFFER=y ++# CONFIG_JFFS2_FS_WBUF_VERIFY is not set ++# CONFIG_JFFS2_SUMMARY is not set ++# CONFIG_JFFS2_FS_XATTR is not set ++# CONFIG_JFFS2_COMPRESSION_OPTIONS is not set ++CONFIG_JFFS2_ZLIB=y ++# CONFIG_JFFS2_LZO is not set ++CONFIG_JFFS2_RTIME=y ++# CONFIG_JFFS2_RUBIN is not set + # CONFIG_CRAMFS is not set + # CONFIG_VXFS_FS is not set + # CONFIG_HPFS_FS is not set +@@ -1242,6 +1260,8 @@ + CONFIG_CRC32=y + # CONFIG_CRC7 is not set + # CONFIG_LIBCRC32C is not set ++CONFIG_ZLIB_INFLATE=y ++CONFIG_ZLIB_DEFLATE=y + CONFIG_PLIST=y + CONFIG_HAS_IOMEM=y + CONFIG_HAS_IOPORT=y +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/mpc834x_itx_defconfig powerpc.git/arch/powerpc/configs/mpc834x_itx_defconfig +--- linux-2.6.24/arch/powerpc/configs/mpc834x_itx_defconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/mpc834x_itx_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -570,7 +570,8 @@ + # CONFIG_PATA_SIS is not set + # CONFIG_PATA_VIA is not set + # CONFIG_PATA_WINBOND is not set +-# CONFIG_PATA_PLATFORM is not set ++CONFIG_PATA_PLATFORM=y ++CONFIG_PATA_OF_PLATFORM=y + CONFIG_MD=y + CONFIG_BLK_DEV_MD=y + CONFIG_MD_LINEAR=y +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/mpc837x_mds_defconfig powerpc.git/arch/powerpc/configs/mpc837x_mds_defconfig +--- linux-2.6.24/arch/powerpc/configs/mpc837x_mds_defconfig 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/mpc837x_mds_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,878 @@ ++# ++# Automatically generated make config: don't edit ++# Linux kernel version: 2.6.23 ++# Wed Oct 10 16:31:39 2007 ++# ++# CONFIG_PPC64 is not set ++ ++# ++# Processor support ++# ++CONFIG_6xx=y ++# CONFIG_PPC_85xx is not set ++# CONFIG_PPC_8xx is not set ++# CONFIG_40x is not set ++# CONFIG_44x is not set ++# CONFIG_E200 is not set ++CONFIG_83xx=y ++CONFIG_PPC_FPU=y ++CONFIG_PPC_STD_MMU=y ++CONFIG_PPC_STD_MMU_32=y ++# CONFIG_PPC_MM_SLICES is not set ++# CONFIG_SMP is not set ++CONFIG_PPC32=y ++CONFIG_PPC_MERGE=y ++CONFIG_MMU=y ++CONFIG_GENERIC_HARDIRQS=y ++CONFIG_IRQ_PER_CPU=y ++CONFIG_RWSEM_XCHGADD_ALGORITHM=y ++CONFIG_ARCH_HAS_ILOG2_U32=y ++CONFIG_GENERIC_HWEIGHT=y ++CONFIG_GENERIC_CALIBRATE_DELAY=y ++CONFIG_GENERIC_FIND_NEXT_BIT=y ++# CONFIG_ARCH_NO_VIRT_TO_BUS is not set ++CONFIG_PPC=y ++CONFIG_EARLY_PRINTK=y ++CONFIG_GENERIC_NVRAM=y ++CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y ++CONFIG_ARCH_MAY_HAVE_PC_FDC=y ++CONFIG_PPC_OF=y ++CONFIG_OF=y ++CONFIG_PPC_UDBG_16550=y ++# CONFIG_GENERIC_TBSYNC is not set ++CONFIG_AUDIT_ARCH=y ++CONFIG_GENERIC_BUG=y ++CONFIG_DEFAULT_UIMAGE=y ++# CONFIG_PPC_DCR_NATIVE is not set ++# CONFIG_PPC_DCR_MMIO is not set ++CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" ++ ++# ++# General setup ++# ++CONFIG_EXPERIMENTAL=y ++CONFIG_BROKEN_ON_SMP=y ++CONFIG_INIT_ENV_ARG_LIMIT=32 ++CONFIG_LOCALVERSION="" ++CONFIG_LOCALVERSION_AUTO=y ++CONFIG_SWAP=y ++CONFIG_SYSVIPC=y ++CONFIG_SYSVIPC_SYSCTL=y ++# CONFIG_POSIX_MQUEUE is not set ++# CONFIG_BSD_PROCESS_ACCT is not set ++# CONFIG_TASKSTATS is not set ++# CONFIG_USER_NS is not set ++# CONFIG_AUDIT is not set ++# CONFIG_IKCONFIG is not set ++CONFIG_LOG_BUF_SHIFT=14 ++CONFIG_SYSFS_DEPRECATED=y ++# CONFIG_RELAY is not set ++CONFIG_BLK_DEV_INITRD=y ++CONFIG_INITRAMFS_SOURCE="" ++# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set ++CONFIG_SYSCTL=y ++CONFIG_EMBEDDED=y ++CONFIG_SYSCTL_SYSCALL=y ++CONFIG_KALLSYMS=y ++# CONFIG_KALLSYMS_EXTRA_PASS is not set ++CONFIG_HOTPLUG=y ++CONFIG_PRINTK=y ++CONFIG_BUG=y ++CONFIG_ELF_CORE=y ++CONFIG_BASE_FULL=y ++CONFIG_FUTEX=y ++CONFIG_ANON_INODES=y ++# CONFIG_EPOLL is not set ++CONFIG_SIGNALFD=y ++CONFIG_EVENTFD=y ++CONFIG_SHMEM=y ++CONFIG_VM_EVENT_COUNTERS=y ++CONFIG_SLAB=y ++# CONFIG_SLUB is not set ++# CONFIG_SLOB is not set ++CONFIG_RT_MUTEXES=y ++# CONFIG_TINY_SHMEM is not set ++CONFIG_BASE_SMALL=0 ++CONFIG_MODULES=y ++CONFIG_MODULE_UNLOAD=y ++# CONFIG_MODULE_FORCE_UNLOAD is not set ++# CONFIG_MODVERSIONS is not set ++# CONFIG_MODULE_SRCVERSION_ALL is not set ++# CONFIG_KMOD is not set ++CONFIG_BLOCK=y ++# CONFIG_LBD is not set ++# CONFIG_BLK_DEV_IO_TRACE is not set ++# CONFIG_LSF is not set ++# CONFIG_BLK_DEV_BSG is not set ++ ++# ++# IO Schedulers ++# ++CONFIG_IOSCHED_NOOP=y ++CONFIG_IOSCHED_AS=y ++CONFIG_IOSCHED_DEADLINE=y ++CONFIG_IOSCHED_CFQ=y ++CONFIG_DEFAULT_AS=y ++# CONFIG_DEFAULT_DEADLINE is not set ++# CONFIG_DEFAULT_CFQ is not set ++# CONFIG_DEFAULT_NOOP is not set ++CONFIG_DEFAULT_IOSCHED="anticipatory" ++ ++# ++# Platform support ++# ++# CONFIG_PPC_MULTIPLATFORM is not set ++# CONFIG_EMBEDDED6xx is not set ++# CONFIG_PPC_82xx is not set ++CONFIG_PPC_83xx=y ++# CONFIG_PPC_86xx is not set ++# CONFIG_PPC_MPC52xx is not set ++# CONFIG_PPC_MPC5200 is not set ++# CONFIG_PPC_CELL is not set ++# CONFIG_PPC_CELL_NATIVE is not set ++# CONFIG_PQ2ADS is not set ++# CONFIG_MPC8313_RDB is not set ++# CONFIG_MPC832x_MDS is not set ++# CONFIG_MPC832x_RDB is not set ++# CONFIG_MPC834x_MDS is not set ++# CONFIG_MPC834x_ITX is not set ++# CONFIG_MPC836x_MDS is not set ++CONFIG_MPC837x_MDS=y ++CONFIG_PPC_MPC837x=y ++# CONFIG_MPIC is not set ++# CONFIG_MPIC_WEIRD is not set ++# CONFIG_PPC_I8259 is not set ++# CONFIG_PPC_RTAS is not set ++# CONFIG_MMIO_NVRAM is not set ++# CONFIG_PPC_MPC106 is not set ++# CONFIG_PPC_970_NAP is not set ++# CONFIG_PPC_INDIRECT_IO is not set ++# CONFIG_GENERIC_IOMAP is not set ++# CONFIG_CPU_FREQ is not set ++# CONFIG_CPM2 is not set ++# CONFIG_FSL_ULI1575 is not set ++CONFIG_FSL_SERDES=y ++ ++# ++# Kernel options ++# ++# CONFIG_HIGHMEM is not set ++# CONFIG_HZ_100 is not set ++CONFIG_HZ_250=y ++# CONFIG_HZ_300 is not set ++# CONFIG_HZ_1000 is not set ++CONFIG_HZ=250 ++CONFIG_PREEMPT_NONE=y ++# CONFIG_PREEMPT_VOLUNTARY is not set ++# CONFIG_PREEMPT is not set ++CONFIG_BINFMT_ELF=y ++# CONFIG_BINFMT_MISC is not set ++CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y ++CONFIG_ARCH_FLATMEM_ENABLE=y ++CONFIG_ARCH_POPULATES_NODE_MAP=y ++CONFIG_SELECT_MEMORY_MODEL=y ++CONFIG_FLATMEM_MANUAL=y ++# CONFIG_DISCONTIGMEM_MANUAL is not set ++# CONFIG_SPARSEMEM_MANUAL is not set ++CONFIG_FLATMEM=y ++CONFIG_FLAT_NODE_MEM_MAP=y ++# CONFIG_SPARSEMEM_STATIC is not set ++CONFIG_SPLIT_PTLOCK_CPUS=4 ++# CONFIG_RESOURCES_64BIT is not set ++CONFIG_ZONE_DMA_FLAG=1 ++CONFIG_BOUNCE=y ++CONFIG_VIRT_TO_BUS=y ++CONFIG_PROC_DEVICETREE=y ++# CONFIG_CMDLINE_BOOL is not set ++# CONFIG_PM is not set ++CONFIG_SUSPEND_UP_POSSIBLE=y ++CONFIG_HIBERNATION_UP_POSSIBLE=y ++CONFIG_SECCOMP=y ++CONFIG_WANT_DEVICE_TREE=y ++CONFIG_DEVICE_TREE="" ++CONFIG_ISA_DMA_API=y ++ ++# ++# Bus options ++# ++CONFIG_ZONE_DMA=y ++CONFIG_GENERIC_ISA_DMA=y ++CONFIG_PPC_INDIRECT_PCI=y ++CONFIG_FSL_SOC=y ++# CONFIG_PCI is not set ++# CONFIG_PCI_DOMAINS is not set ++# CONFIG_PCI_SYSCALL is not set ++# CONFIG_ARCH_SUPPORTS_MSI is not set ++ ++# ++# PCCARD (PCMCIA/CardBus) support ++# ++# CONFIG_PCCARD is not set ++ ++# ++# Advanced setup ++# ++# CONFIG_ADVANCED_OPTIONS is not set ++ ++# ++# Default settings for advanced configuration options are used ++# ++CONFIG_HIGHMEM_START=0xfe000000 ++CONFIG_LOWMEM_SIZE=0x30000000 ++CONFIG_KERNEL_START=0xc0000000 ++CONFIG_TASK_SIZE=0x80000000 ++CONFIG_BOOT_LOAD=0x00800000 ++ ++# ++# Networking ++# ++CONFIG_NET=y ++ ++# ++# Networking options ++# ++CONFIG_PACKET=y ++# CONFIG_PACKET_MMAP is not set ++CONFIG_UNIX=y ++CONFIG_XFRM=y ++CONFIG_XFRM_USER=m ++# CONFIG_XFRM_SUB_POLICY is not set ++# CONFIG_XFRM_MIGRATE is not set ++# CONFIG_NET_KEY is not set ++CONFIG_INET=y ++CONFIG_IP_MULTICAST=y ++# CONFIG_IP_ADVANCED_ROUTER is not set ++CONFIG_IP_FIB_HASH=y ++CONFIG_IP_PNP=y ++CONFIG_IP_PNP_DHCP=y ++CONFIG_IP_PNP_BOOTP=y ++# CONFIG_IP_PNP_RARP is not set ++# CONFIG_NET_IPIP is not set ++# CONFIG_NET_IPGRE is not set ++# CONFIG_IP_MROUTE is not set ++# CONFIG_ARPD is not set ++CONFIG_SYN_COOKIES=y ++# CONFIG_INET_AH is not set ++# CONFIG_INET_ESP is not set ++# CONFIG_INET_IPCOMP is not set ++# CONFIG_INET_XFRM_TUNNEL is not set ++# CONFIG_INET_TUNNEL is not set ++CONFIG_INET_XFRM_MODE_TRANSPORT=y ++CONFIG_INET_XFRM_MODE_TUNNEL=y ++CONFIG_INET_XFRM_MODE_BEET=y ++CONFIG_INET_DIAG=y ++CONFIG_INET_TCP_DIAG=y ++# CONFIG_TCP_CONG_ADVANCED is not set ++CONFIG_TCP_CONG_CUBIC=y ++CONFIG_DEFAULT_TCP_CONG="cubic" ++# CONFIG_TCP_MD5SIG is not set ++# CONFIG_IPV6 is not set ++# CONFIG_INET6_XFRM_TUNNEL is not set ++# CONFIG_INET6_TUNNEL is not set ++# CONFIG_NETWORK_SECMARK is not set ++# CONFIG_NETFILTER is not set ++# CONFIG_IP_DCCP is not set ++# CONFIG_IP_SCTP is not set ++# CONFIG_TIPC is not set ++# CONFIG_ATM is not set ++# CONFIG_BRIDGE is not set ++# CONFIG_VLAN_8021Q is not set ++# CONFIG_DECNET is not set ++# CONFIG_LLC2 is not set ++# CONFIG_IPX is not set ++# CONFIG_ATALK is not set ++# CONFIG_X25 is not set ++# CONFIG_LAPB is not set ++# CONFIG_ECONET is not set ++# CONFIG_WAN_ROUTER is not set ++ ++# ++# QoS and/or fair queueing ++# ++# CONFIG_NET_SCHED is not set ++ ++# ++# Network testing ++# ++# CONFIG_NET_PKTGEN is not set ++# CONFIG_HAMRADIO is not set ++# CONFIG_IRDA is not set ++# CONFIG_BT is not set ++# CONFIG_AF_RXRPC is not set ++ ++# ++# Wireless ++# ++# CONFIG_CFG80211 is not set ++# CONFIG_WIRELESS_EXT is not set ++# CONFIG_MAC80211 is not set ++# CONFIG_IEEE80211 is not set ++# CONFIG_RFKILL is not set ++# CONFIG_NET_9P is not set ++ ++# ++# Device Drivers ++# ++ ++# ++# Generic Driver Options ++# ++CONFIG_STANDALONE=y ++CONFIG_PREVENT_FIRMWARE_BUILD=y ++# CONFIG_FW_LOADER is not set ++# CONFIG_SYS_HYPERVISOR is not set ++# CONFIG_CONNECTOR is not set ++# CONFIG_MTD is not set ++CONFIG_OF_DEVICE=y ++# CONFIG_PARPORT is not set ++CONFIG_BLK_DEV=y ++# CONFIG_BLK_DEV_FD is not set ++# CONFIG_BLK_DEV_COW_COMMON is not set ++CONFIG_BLK_DEV_LOOP=y ++# CONFIG_BLK_DEV_CRYPTOLOOP is not set ++# CONFIG_BLK_DEV_NBD is not set ++CONFIG_BLK_DEV_RAM=y ++CONFIG_BLK_DEV_RAM_COUNT=16 ++CONFIG_BLK_DEV_RAM_SIZE=32768 ++CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024 ++# CONFIG_CDROM_PKTCDVD is not set ++# CONFIG_ATA_OVER_ETH is not set ++CONFIG_MISC_DEVICES=y ++# CONFIG_EEPROM_93CX6 is not set ++# CONFIG_IDE is not set ++ ++# ++# SCSI device support ++# ++# CONFIG_RAID_ATTRS is not set ++CONFIG_SCSI=y ++CONFIG_SCSI_DMA=y ++# CONFIG_SCSI_TGT is not set ++# CONFIG_SCSI_NETLINK is not set ++CONFIG_SCSI_PROC_FS=y ++ ++# ++# SCSI support type (disk, tape, CD-ROM) ++# ++CONFIG_BLK_DEV_SD=y ++# CONFIG_CHR_DEV_ST is not set ++# CONFIG_CHR_DEV_OSST is not set ++# CONFIG_BLK_DEV_SR is not set ++CONFIG_CHR_DEV_SG=y ++# CONFIG_CHR_DEV_SCH is not set ++ ++# ++# Some SCSI devices (e.g. CD jukebox) support multiple LUNs ++# ++# CONFIG_SCSI_MULTI_LUN is not set ++# CONFIG_SCSI_CONSTANTS is not set ++# CONFIG_SCSI_LOGGING is not set ++# CONFIG_SCSI_SCAN_ASYNC is not set ++CONFIG_SCSI_WAIT_SCAN=m ++ ++# ++# SCSI Transports ++# ++# CONFIG_SCSI_SPI_ATTRS is not set ++# CONFIG_SCSI_FC_ATTRS is not set ++# CONFIG_SCSI_ISCSI_ATTRS is not set ++# CONFIG_SCSI_SAS_LIBSAS is not set ++CONFIG_SCSI_LOWLEVEL=y ++# CONFIG_ISCSI_TCP is not set ++# CONFIG_SCSI_DEBUG is not set ++CONFIG_ATA=y ++# CONFIG_ATA_NONSTANDARD is not set ++CONFIG_SATA_FSL=y ++# CONFIG_PATA_PLATFORM is not set ++# CONFIG_MD is not set ++# CONFIG_MACINTOSH_DRIVERS is not set ++CONFIG_NETDEVICES=y ++# CONFIG_NETDEVICES_MULTIQUEUE is not set ++# CONFIG_DUMMY is not set ++# CONFIG_BONDING is not set ++# CONFIG_MACVLAN is not set ++# CONFIG_EQUALIZER is not set ++# CONFIG_TUN is not set ++CONFIG_PHYLIB=y ++ ++# ++# MII PHY device drivers ++# ++CONFIG_MARVELL_PHY=y ++# CONFIG_DAVICOM_PHY is not set ++# CONFIG_QSEMI_PHY is not set ++# CONFIG_LXT_PHY is not set ++# CONFIG_CICADA_PHY is not set ++# CONFIG_VITESSE_PHY is not set ++# CONFIG_SMSC_PHY is not set ++# CONFIG_BROADCOM_PHY is not set ++# CONFIG_ICPLUS_PHY is not set ++# CONFIG_FIXED_PHY is not set ++CONFIG_NET_ETHERNET=y ++CONFIG_MII=y ++CONFIG_NETDEV_1000=y ++CONFIG_GIANFAR=y ++# CONFIG_GFAR_NAPI is not set ++CONFIG_NETDEV_10000=y ++ ++# ++# Wireless LAN ++# ++# CONFIG_WLAN_PRE80211 is not set ++# CONFIG_WLAN_80211 is not set ++# CONFIG_WAN is not set ++# CONFIG_PPP is not set ++# CONFIG_SLIP is not set ++# CONFIG_SHAPER is not set ++# CONFIG_NETCONSOLE is not set ++# CONFIG_NETPOLL is not set ++# CONFIG_NET_POLL_CONTROLLER is not set ++# CONFIG_ISDN is not set ++# CONFIG_PHONE is not set ++ ++# ++# Input device support ++# ++CONFIG_INPUT=y ++# CONFIG_INPUT_FF_MEMLESS is not set ++# CONFIG_INPUT_POLLDEV is not set ++ ++# ++# Userland interfaces ++# ++# CONFIG_INPUT_MOUSEDEV is not set ++# CONFIG_INPUT_JOYDEV is not set ++# CONFIG_INPUT_TSDEV is not set ++# CONFIG_INPUT_EVDEV is not set ++# CONFIG_INPUT_EVBUG is not set ++ ++# ++# Input Device Drivers ++# ++# CONFIG_INPUT_KEYBOARD is not set ++# CONFIG_INPUT_MOUSE is not set ++# CONFIG_INPUT_JOYSTICK is not set ++# CONFIG_INPUT_TABLET is not set ++# CONFIG_INPUT_TOUCHSCREEN is not set ++# CONFIG_INPUT_MISC is not set ++ ++# ++# Hardware I/O ports ++# ++# CONFIG_SERIO is not set ++# CONFIG_GAMEPORT is not set ++ ++# ++# Character devices ++# ++# CONFIG_VT is not set ++# CONFIG_SERIAL_NONSTANDARD is not set ++ ++# ++# Serial drivers ++# ++CONFIG_SERIAL_8250=y ++CONFIG_SERIAL_8250_CONSOLE=y ++CONFIG_SERIAL_8250_NR_UARTS=4 ++CONFIG_SERIAL_8250_RUNTIME_UARTS=4 ++# CONFIG_SERIAL_8250_EXTENDED is not set ++ ++# ++# Non-8250 serial port support ++# ++# CONFIG_SERIAL_UARTLITE is not set ++CONFIG_SERIAL_CORE=y ++CONFIG_SERIAL_CORE_CONSOLE=y ++# CONFIG_SERIAL_OF_PLATFORM is not set ++CONFIG_UNIX98_PTYS=y ++CONFIG_LEGACY_PTYS=y ++CONFIG_LEGACY_PTY_COUNT=256 ++# CONFIG_IPMI_HANDLER is not set ++CONFIG_WATCHDOG=y ++# CONFIG_WATCHDOG_NOWAYOUT is not set ++ ++# ++# Watchdog Device Drivers ++# ++# CONFIG_SOFT_WATCHDOG is not set ++CONFIG_83xx_WDT=y ++# CONFIG_HW_RANDOM is not set ++# CONFIG_NVRAM is not set ++CONFIG_GEN_RTC=y ++# CONFIG_GEN_RTC_X is not set ++# CONFIG_R3964 is not set ++# CONFIG_RAW_DRIVER is not set ++# CONFIG_TCG_TPM is not set ++CONFIG_I2C=y ++CONFIG_I2C_BOARDINFO=y ++CONFIG_I2C_CHARDEV=y ++ ++# ++# I2C Algorithms ++# ++# CONFIG_I2C_ALGOBIT is not set ++# CONFIG_I2C_ALGOPCF is not set ++# CONFIG_I2C_ALGOPCA is not set ++ ++# ++# I2C Hardware Bus support ++# ++CONFIG_I2C_MPC=y ++# CONFIG_I2C_OCORES is not set ++# CONFIG_I2C_PARPORT_LIGHT is not set ++# CONFIG_I2C_SIMTEC is not set ++# CONFIG_I2C_TAOS_EVM is not set ++# CONFIG_I2C_STUB is not set ++ ++# ++# Miscellaneous I2C Chip support ++# ++# CONFIG_SENSORS_DS1337 is not set ++# CONFIG_SENSORS_DS1374 is not set ++# CONFIG_DS1682 is not set ++# CONFIG_SENSORS_EEPROM is not set ++# CONFIG_SENSORS_PCF8574 is not set ++# CONFIG_SENSORS_PCA9539 is not set ++# CONFIG_SENSORS_PCF8591 is not set ++# CONFIG_SENSORS_M41T00 is not set ++# CONFIG_SENSORS_MAX6875 is not set ++# CONFIG_SENSORS_TSL2550 is not set ++# CONFIG_I2C_DEBUG_CORE is not set ++# CONFIG_I2C_DEBUG_ALGO is not set ++# CONFIG_I2C_DEBUG_BUS is not set ++# CONFIG_I2C_DEBUG_CHIP is not set ++ ++# ++# SPI support ++# ++# CONFIG_SPI is not set ++# CONFIG_SPI_MASTER is not set ++# CONFIG_W1 is not set ++# CONFIG_POWER_SUPPLY is not set ++CONFIG_HWMON=y ++# CONFIG_HWMON_VID is not set ++# CONFIG_SENSORS_ABITUGURU is not set ++# CONFIG_SENSORS_ABITUGURU3 is not set ++# CONFIG_SENSORS_AD7418 is not set ++# CONFIG_SENSORS_ADM1021 is not set ++# CONFIG_SENSORS_ADM1025 is not set ++# CONFIG_SENSORS_ADM1026 is not set ++# CONFIG_SENSORS_ADM1029 is not set ++# CONFIG_SENSORS_ADM1031 is not set ++# CONFIG_SENSORS_ADM9240 is not set ++# CONFIG_SENSORS_ASB100 is not set ++# CONFIG_SENSORS_ATXP1 is not set ++# CONFIG_SENSORS_DS1621 is not set ++# CONFIG_SENSORS_F71805F is not set ++# CONFIG_SENSORS_FSCHER is not set ++# CONFIG_SENSORS_FSCPOS is not set ++# CONFIG_SENSORS_GL518SM is not set ++# CONFIG_SENSORS_GL520SM is not set ++# CONFIG_SENSORS_IT87 is not set ++# CONFIG_SENSORS_LM63 is not set ++# CONFIG_SENSORS_LM75 is not set ++# CONFIG_SENSORS_LM77 is not set ++# CONFIG_SENSORS_LM78 is not set ++# CONFIG_SENSORS_LM80 is not set ++# CONFIG_SENSORS_LM83 is not set ++# CONFIG_SENSORS_LM85 is not set ++# CONFIG_SENSORS_LM87 is not set ++# CONFIG_SENSORS_LM90 is not set ++# CONFIG_SENSORS_LM92 is not set ++# CONFIG_SENSORS_LM93 is not set ++# CONFIG_SENSORS_MAX1619 is not set ++# CONFIG_SENSORS_MAX6650 is not set ++# CONFIG_SENSORS_PC87360 is not set ++# CONFIG_SENSORS_PC87427 is not set ++# CONFIG_SENSORS_DME1737 is not set ++# CONFIG_SENSORS_SMSC47M1 is not set ++# CONFIG_SENSORS_SMSC47M192 is not set ++# CONFIG_SENSORS_SMSC47B397 is not set ++# CONFIG_SENSORS_THMC50 is not set ++# CONFIG_SENSORS_VT1211 is not set ++# CONFIG_SENSORS_W83781D is not set ++# CONFIG_SENSORS_W83791D is not set ++# CONFIG_SENSORS_W83792D is not set ++# CONFIG_SENSORS_W83793 is not set ++# CONFIG_SENSORS_W83L785TS is not set ++# CONFIG_SENSORS_W83627HF is not set ++# CONFIG_SENSORS_W83627EHF is not set ++# CONFIG_HWMON_DEBUG_CHIP is not set ++ ++# ++# Multifunction device drivers ++# ++# CONFIG_MFD_SM501 is not set ++ ++# ++# Multimedia devices ++# ++# CONFIG_VIDEO_DEV is not set ++# CONFIG_DVB_CORE is not set ++CONFIG_DAB=y ++ ++# ++# Graphics support ++# ++# CONFIG_BACKLIGHT_LCD_SUPPORT is not set ++ ++# ++# Display device support ++# ++# CONFIG_DISPLAY_SUPPORT is not set ++# CONFIG_VGASTATE is not set ++CONFIG_VIDEO_OUTPUT_CONTROL=m ++# CONFIG_FB is not set ++# CONFIG_FB_IBM_GXT4500 is not set ++ ++# ++# Sound ++# ++# CONFIG_SOUND is not set ++CONFIG_HID_SUPPORT=y ++CONFIG_HID=y ++# CONFIG_HID_DEBUG is not set ++CONFIG_USB_SUPPORT=y ++CONFIG_USB_ARCH_HAS_HCD=y ++# CONFIG_USB_ARCH_HAS_OHCI is not set ++CONFIG_USB_ARCH_HAS_EHCI=y ++# CONFIG_USB is not set ++ ++# ++# NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' ++# ++ ++# ++# USB Gadget Support ++# ++# CONFIG_USB_GADGET is not set ++# CONFIG_MMC is not set ++# CONFIG_NEW_LEDS is not set ++# CONFIG_EDAC is not set ++# CONFIG_RTC_CLASS is not set ++ ++# ++# DMA Engine support ++# ++# CONFIG_DMA_ENGINE is not set ++ ++# ++# DMA Clients ++# ++ ++# ++# DMA Devices ++# ++ ++# ++# Userspace I/O ++# ++# CONFIG_UIO is not set ++ ++# ++# File systems ++# ++CONFIG_EXT2_FS=y ++# CONFIG_EXT2_FS_XATTR is not set ++# CONFIG_EXT2_FS_XIP is not set ++CONFIG_EXT3_FS=y ++CONFIG_EXT3_FS_XATTR=y ++# CONFIG_EXT3_FS_POSIX_ACL is not set ++# CONFIG_EXT3_FS_SECURITY is not set ++# CONFIG_EXT4DEV_FS is not set ++CONFIG_JBD=y ++# CONFIG_JBD_DEBUG is not set ++CONFIG_FS_MBCACHE=y ++# CONFIG_REISERFS_FS is not set ++# CONFIG_JFS_FS is not set ++# CONFIG_FS_POSIX_ACL is not set ++# CONFIG_XFS_FS is not set ++# CONFIG_GFS2_FS is not set ++# CONFIG_OCFS2_FS is not set ++# CONFIG_MINIX_FS is not set ++# CONFIG_ROMFS_FS is not set ++CONFIG_INOTIFY=y ++CONFIG_INOTIFY_USER=y ++# CONFIG_QUOTA is not set ++CONFIG_DNOTIFY=y ++# CONFIG_AUTOFS_FS is not set ++# CONFIG_AUTOFS4_FS is not set ++# CONFIG_FUSE_FS is not set ++ ++# ++# CD-ROM/DVD Filesystems ++# ++# CONFIG_ISO9660_FS is not set ++# CONFIG_UDF_FS is not set ++ ++# ++# DOS/FAT/NT Filesystems ++# ++# CONFIG_MSDOS_FS is not set ++# CONFIG_VFAT_FS is not set ++# CONFIG_NTFS_FS is not set ++ ++# ++# Pseudo filesystems ++# ++CONFIG_PROC_FS=y ++CONFIG_PROC_KCORE=y ++CONFIG_PROC_SYSCTL=y ++CONFIG_SYSFS=y ++CONFIG_TMPFS=y ++# CONFIG_TMPFS_POSIX_ACL is not set ++# CONFIG_HUGETLB_PAGE is not set ++CONFIG_RAMFS=y ++# CONFIG_CONFIGFS_FS is not set ++ ++# ++# Miscellaneous filesystems ++# ++# CONFIG_ADFS_FS is not set ++# CONFIG_AFFS_FS is not set ++# CONFIG_HFS_FS is not set ++# CONFIG_HFSPLUS_FS is not set ++# CONFIG_BEFS_FS is not set ++# CONFIG_BFS_FS is not set ++# CONFIG_EFS_FS is not set ++# CONFIG_CRAMFS is not set ++# CONFIG_VXFS_FS is not set ++# CONFIG_HPFS_FS is not set ++# CONFIG_QNX4FS_FS is not set ++# CONFIG_SYSV_FS is not set ++# CONFIG_UFS_FS is not set ++ ++# ++# Network File Systems ++# ++CONFIG_NFS_FS=y ++CONFIG_NFS_V3=y ++# CONFIG_NFS_V3_ACL is not set ++CONFIG_NFS_V4=y ++# CONFIG_NFS_DIRECTIO is not set ++# CONFIG_NFSD is not set ++CONFIG_ROOT_NFS=y ++CONFIG_LOCKD=y ++CONFIG_LOCKD_V4=y ++CONFIG_NFS_COMMON=y ++CONFIG_SUNRPC=y ++CONFIG_SUNRPC_GSS=y ++# CONFIG_SUNRPC_BIND34 is not set ++CONFIG_RPCSEC_GSS_KRB5=y ++# CONFIG_RPCSEC_GSS_SPKM3 is not set ++# CONFIG_SMB_FS is not set ++# CONFIG_CIFS is not set ++# CONFIG_NCP_FS is not set ++# CONFIG_CODA_FS is not set ++# CONFIG_AFS_FS is not set ++ ++# ++# Partition Types ++# ++CONFIG_PARTITION_ADVANCED=y ++# CONFIG_ACORN_PARTITION is not set ++# CONFIG_OSF_PARTITION is not set ++# CONFIG_AMIGA_PARTITION is not set ++# CONFIG_ATARI_PARTITION is not set ++# CONFIG_MAC_PARTITION is not set ++CONFIG_MSDOS_PARTITION=y ++# CONFIG_BSD_DISKLABEL is not set ++# CONFIG_MINIX_SUBPARTITION is not set ++# CONFIG_SOLARIS_X86_PARTITION is not set ++# CONFIG_UNIXWARE_DISKLABEL is not set ++# CONFIG_LDM_PARTITION is not set ++# CONFIG_SGI_PARTITION is not set ++# CONFIG_ULTRIX_PARTITION is not set ++# CONFIG_SUN_PARTITION is not set ++# CONFIG_KARMA_PARTITION is not set ++# CONFIG_EFI_PARTITION is not set ++# CONFIG_SYSV68_PARTITION is not set ++ ++# ++# Native Language Support ++# ++# CONFIG_NLS is not set ++ ++# ++# Distributed Lock Manager ++# ++# CONFIG_DLM is not set ++# CONFIG_UCC_SLOW is not set ++ ++# ++# Library routines ++# ++CONFIG_BITREVERSE=y ++# CONFIG_CRC_CCITT is not set ++# CONFIG_CRC16 is not set ++# CONFIG_CRC_ITU_T is not set ++CONFIG_CRC32=y ++# CONFIG_CRC7 is not set ++# CONFIG_LIBCRC32C is not set ++CONFIG_PLIST=y ++CONFIG_HAS_IOMEM=y ++CONFIG_HAS_IOPORT=y ++CONFIG_HAS_DMA=y ++ ++# ++# Instrumentation Support ++# ++# CONFIG_PROFILING is not set ++# CONFIG_KPROBES is not set ++ ++# ++# Kernel hacking ++# ++# CONFIG_PRINTK_TIME is not set ++CONFIG_ENABLE_MUST_CHECK=y ++# CONFIG_MAGIC_SYSRQ is not set ++# CONFIG_UNUSED_SYMBOLS is not set ++# CONFIG_DEBUG_FS is not set ++# CONFIG_HEADERS_CHECK is not set ++# CONFIG_DEBUG_KERNEL is not set ++# CONFIG_DEBUG_BUGVERBOSE is not set ++# CONFIG_PPC_EARLY_DEBUG is not set ++ ++# ++# Security options ++# ++# CONFIG_KEYS is not set ++# CONFIG_SECURITY is not set ++CONFIG_CRYPTO=y ++CONFIG_CRYPTO_ALGAPI=y ++CONFIG_CRYPTO_BLKCIPHER=y ++CONFIG_CRYPTO_MANAGER=y ++# CONFIG_CRYPTO_HMAC is not set ++# CONFIG_CRYPTO_XCBC is not set ++# CONFIG_CRYPTO_NULL is not set ++# CONFIG_CRYPTO_MD4 is not set ++CONFIG_CRYPTO_MD5=y ++# CONFIG_CRYPTO_SHA1 is not set ++# CONFIG_CRYPTO_SHA256 is not set ++# CONFIG_CRYPTO_SHA512 is not set ++# CONFIG_CRYPTO_WP512 is not set ++# CONFIG_CRYPTO_TGR192 is not set ++# CONFIG_CRYPTO_GF128MUL is not set ++CONFIG_CRYPTO_ECB=m ++CONFIG_CRYPTO_CBC=y ++CONFIG_CRYPTO_PCBC=m ++# CONFIG_CRYPTO_LRW is not set ++# CONFIG_CRYPTO_CRYPTD is not set ++CONFIG_CRYPTO_DES=y ++# CONFIG_CRYPTO_FCRYPT is not set ++# CONFIG_CRYPTO_BLOWFISH is not set ++# CONFIG_CRYPTO_TWOFISH is not set ++# CONFIG_CRYPTO_SERPENT is not set ++# CONFIG_CRYPTO_AES is not set ++# CONFIG_CRYPTO_CAST5 is not set ++# CONFIG_CRYPTO_CAST6 is not set ++# CONFIG_CRYPTO_TEA is not set ++# CONFIG_CRYPTO_ARC4 is not set ++# CONFIG_CRYPTO_KHAZAD is not set ++# CONFIG_CRYPTO_ANUBIS is not set ++# CONFIG_CRYPTO_DEFLATE is not set ++# CONFIG_CRYPTO_MICHAEL_MIC is not set ++# CONFIG_CRYPTO_CRC32C is not set ++# CONFIG_CRYPTO_CAMELLIA is not set ++# CONFIG_CRYPTO_TEST is not set ++CONFIG_CRYPTO_HW=y +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/mpc8610_hpcd_defconfig powerpc.git/arch/powerpc/configs/mpc8610_hpcd_defconfig +--- linux-2.6.24/arch/powerpc/configs/mpc8610_hpcd_defconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/mpc8610_hpcd_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -696,7 +696,7 @@ + CONFIG_SERIAL_CORE=y + CONFIG_SERIAL_CORE_CONSOLE=y + # CONFIG_SERIAL_JSM is not set +-CONFIG_SERIAL_OF_PLATFORM=y ++# CONFIG_SERIAL_OF_PLATFORM is not set + CONFIG_UNIX98_PTYS=y + # CONFIG_LEGACY_PTYS is not set + # CONFIG_IPMI_HANDLER is not set +@@ -708,7 +708,60 @@ + # CONFIG_RAW_DRIVER is not set + # CONFIG_TCG_TPM is not set + CONFIG_DEVPORT=y +-# CONFIG_I2C is not set ++CONFIG_I2C=y ++CONFIG_I2C_BOARDINFO=y ++# CONFIG_I2C_CHARDEV is not set ++ ++# ++# I2C Algorithms ++# ++# CONFIG_I2C_ALGOBIT is not set ++# CONFIG_I2C_ALGOPCF is not set ++# CONFIG_I2C_ALGOPCA is not set ++ ++# ++# I2C Hardware Bus support ++# ++# CONFIG_I2C_ALI1535 is not set ++# CONFIG_I2C_ALI1563 is not set ++# CONFIG_I2C_ALI15X3 is not set ++# CONFIG_I2C_AMD756 is not set ++# CONFIG_I2C_AMD8111 is not set ++# CONFIG_I2C_I801 is not set ++# CONFIG_I2C_I810 is not set ++# CONFIG_I2C_PIIX4 is not set ++CONFIG_I2C_MPC=y ++# CONFIG_I2C_NFORCE2 is not set ++# CONFIG_I2C_OCORES is not set ++# CONFIG_I2C_PARPORT_LIGHT is not set ++# CONFIG_I2C_PROSAVAGE is not set ++# CONFIG_I2C_SAVAGE4 is not set ++# CONFIG_I2C_SIMTEC is not set ++# CONFIG_I2C_SIS5595 is not set ++# CONFIG_I2C_SIS630 is not set ++# CONFIG_I2C_SIS96X is not set ++# CONFIG_I2C_TAOS_EVM is not set ++# CONFIG_I2C_VIA is not set ++# CONFIG_I2C_VIAPRO is not set ++# CONFIG_I2C_VOODOO3 is not set ++ ++# ++# Miscellaneous I2C Chip support ++# ++# CONFIG_SENSORS_DS1337 is not set ++# CONFIG_SENSORS_DS1374 is not set ++# CONFIG_DS1682 is not set ++# CONFIG_SENSORS_EEPROM is not set ++# CONFIG_SENSORS_PCF8574 is not set ++# CONFIG_SENSORS_PCA9539 is not set ++# CONFIG_SENSORS_PCF8591 is not set ++# CONFIG_SENSORS_M41T00 is not set ++# CONFIG_SENSORS_MAX6875 is not set ++# CONFIG_SENSORS_TSL2550 is not set ++# CONFIG_I2C_DEBUG_CORE is not set ++# CONFIG_I2C_DEBUG_ALGO is not set ++# CONFIG_I2C_DEBUG_BUS is not set ++# CONFIG_I2C_DEBUG_CHIP is not set + + # + # SPI support +@@ -763,7 +816,119 @@ + # + # Sound + # +-# CONFIG_SOUND is not set ++CONFIG_SOUND=y ++ ++# ++# Advanced Linux Sound Architecture ++# ++CONFIG_SND=y ++CONFIG_SND_TIMER=y ++CONFIG_SND_PCM=y ++# CONFIG_SND_SEQUENCER is not set ++CONFIG_SND_OSSEMUL=y ++CONFIG_SND_MIXER_OSS=y ++CONFIG_SND_PCM_OSS=y ++# CONFIG_SND_PCM_OSS_PLUGINS is not set ++# CONFIG_SND_DYNAMIC_MINORS is not set ++# CONFIG_SND_SUPPORT_OLD_API is not set ++CONFIG_SND_VERBOSE_PROCFS=y ++# CONFIG_SND_VERBOSE_PRINTK is not set ++# CONFIG_SND_DEBUG is not set ++ ++# ++# Generic devices ++# ++# CONFIG_SND_DUMMY is not set ++# CONFIG_SND_MTPAV is not set ++# CONFIG_SND_SERIAL_U16550 is not set ++# CONFIG_SND_MPU401 is not set ++ ++# ++# PCI devices ++# ++# CONFIG_SND_AD1889 is not set ++# CONFIG_SND_ALS300 is not set ++# CONFIG_SND_ALS4000 is not set ++# CONFIG_SND_ALI5451 is not set ++# CONFIG_SND_ATIIXP is not set ++# CONFIG_SND_ATIIXP_MODEM is not set ++# CONFIG_SND_AU8810 is not set ++# CONFIG_SND_AU8820 is not set ++# CONFIG_SND_AU8830 is not set ++# CONFIG_SND_AZT3328 is not set ++# CONFIG_SND_BT87X is not set ++# CONFIG_SND_CA0106 is not set ++# CONFIG_SND_CMIPCI is not set ++# CONFIG_SND_CS4281 is not set ++# CONFIG_SND_CS46XX is not set ++# CONFIG_SND_CS5530 is not set ++# CONFIG_SND_DARLA20 is not set ++# CONFIG_SND_GINA20 is not set ++# CONFIG_SND_LAYLA20 is not set ++# CONFIG_SND_DARLA24 is not set ++# CONFIG_SND_GINA24 is not set ++# CONFIG_SND_LAYLA24 is not set ++# CONFIG_SND_MONA is not set ++# CONFIG_SND_MIA is not set ++# CONFIG_SND_ECHO3G is not set ++# CONFIG_SND_INDIGO is not set ++# CONFIG_SND_INDIGOIO is not set ++# CONFIG_SND_INDIGODJ is not set ++# CONFIG_SND_EMU10K1 is not set ++# CONFIG_SND_EMU10K1X is not set ++# CONFIG_SND_ENS1370 is not set ++# CONFIG_SND_ENS1371 is not set ++# CONFIG_SND_ES1938 is not set ++# CONFIG_SND_ES1968 is not set ++# CONFIG_SND_FM801 is not set ++# CONFIG_SND_HDA_INTEL is not set ++# CONFIG_SND_HDSP is not set ++# CONFIG_SND_HDSPM is not set ++# CONFIG_SND_ICE1712 is not set ++# CONFIG_SND_ICE1724 is not set ++# CONFIG_SND_INTEL8X0 is not set ++# CONFIG_SND_INTEL8X0M is not set ++# CONFIG_SND_KORG1212 is not set ++# CONFIG_SND_MAESTRO3 is not set ++# CONFIG_SND_MIXART is not set ++# CONFIG_SND_NM256 is not set ++# CONFIG_SND_PCXHR is not set ++# CONFIG_SND_RIPTIDE is not set ++# CONFIG_SND_RME32 is not set ++# CONFIG_SND_RME96 is not set ++# CONFIG_SND_RME9652 is not set ++# CONFIG_SND_SONICVIBES is not set ++# CONFIG_SND_TRIDENT is not set ++# CONFIG_SND_VIA82XX is not set ++# CONFIG_SND_VIA82XX_MODEM is not set ++# CONFIG_SND_VX222 is not set ++# CONFIG_SND_YMFPCI is not set ++ ++# ++# ALSA PowerMac devices ++# ++ ++# ++# ALSA PowerPC devices ++# ++ ++# ++# System on Chip audio support ++# ++CONFIG_SND_SOC=y ++ ++# ++# SoC Audio support for SuperH ++# ++ ++# ++# ALSA SoC audio for Freescale SOCs ++# ++CONFIG_SND_SOC_MPC8610=y ++CONFIG_SND_SOC_MPC8610_HPCD=y ++CONFIG_SND_SOC_CS4270=y ++CONFIG_SND_SOC_CS4270_VD33_ERRATA=y ++ + CONFIG_HID_SUPPORT=y + CONFIG_HID=y + # CONFIG_HID_DEBUG is not set +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/pasemi_defconfig powerpc.git/arch/powerpc/configs/pasemi_defconfig +--- linux-2.6.24/arch/powerpc/configs/pasemi_defconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/pasemi_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -1,7 +1,7 @@ + # + # Automatically generated make config: don't edit +-# Linux kernel version: 2.6.24-rc4 +-# Thu Dec 6 16:49:03 2007 ++# Linux kernel version: 2.6.24-rc6 ++# Tue Jan 15 10:26:10 2008 + # + CONFIG_PPC64=y + +@@ -152,7 +152,6 @@ + CONFIG_PPC_PASEMI_IOMMU=y + # CONFIG_PPC_PASEMI_IOMMU_DMA_FORCE is not set + CONFIG_PPC_PASEMI_MDIO=y +-CONFIG_ELECTRA_IDE=y + # CONFIG_PPC_CELLEB is not set + # CONFIG_PPC_PS3 is not set + # CONFIG_PPC_CELL is not set +@@ -256,7 +255,7 @@ + CONFIG_PCI_SYSCALL=y + # CONFIG_PCIEPORTBUS is not set + CONFIG_ARCH_SUPPORTS_MSI=y +-# CONFIG_PCI_MSI is not set ++CONFIG_PCI_MSI=y + CONFIG_PCI_LEGACY=y + # CONFIG_PCI_DEBUG is not set + CONFIG_PCCARD=y +@@ -663,7 +662,26 @@ + # CONFIG_PATA_VIA is not set + # CONFIG_PATA_WINBOND is not set + CONFIG_PATA_PLATFORM=y +-# CONFIG_MD is not set ++CONFIG_PATA_OF_PLATFORM=y ++CONFIG_MD=y ++CONFIG_BLK_DEV_MD=y ++CONFIG_MD_LINEAR=y ++CONFIG_MD_RAID0=y ++CONFIG_MD_RAID1=y ++CONFIG_MD_RAID10=y ++CONFIG_MD_RAID456=y ++CONFIG_MD_RAID5_RESHAPE=y ++# CONFIG_MD_MULTIPATH is not set ++# CONFIG_MD_FAULTY is not set ++CONFIG_BLK_DEV_DM=y ++# CONFIG_DM_DEBUG is not set ++CONFIG_DM_CRYPT=y ++# CONFIG_DM_SNAPSHOT is not set ++# CONFIG_DM_MIRROR is not set ++# CONFIG_DM_ZERO is not set ++# CONFIG_DM_MULTIPATH is not set ++# CONFIG_DM_DELAY is not set ++# CONFIG_DM_UEVENT is not set + # CONFIG_FUSION is not set + + # +@@ -1686,6 +1704,10 @@ + # CONFIG_KEYS is not set + # CONFIG_SECURITY is not set + # CONFIG_SECURITY_FILE_CAPABILITIES is not set ++CONFIG_XOR_BLOCKS=y ++CONFIG_ASYNC_CORE=y ++CONFIG_ASYNC_MEMCPY=y ++CONFIG_ASYNC_XOR=y + CONFIG_CRYPTO=y + CONFIG_CRYPTO_ALGAPI=y + CONFIG_CRYPTO_BLKCIPHER=y +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/ppc64_defconfig powerpc.git/arch/powerpc/configs/ppc64_defconfig +--- linux-2.6.24/arch/powerpc/configs/ppc64_defconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/ppc64_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -1,7 +1,7 @@ + # + # Automatically generated make config: don't edit + # Linux kernel version: 2.6.24-rc4 +-# Thu Dec 6 16:49:07 2007 ++# Fri Dec 21 14:47:29 2007 + # + CONFIG_PPC64=y + +@@ -211,7 +211,7 @@ + CONFIG_MPIC_U3_HT_IRQS=y + CONFIG_MPIC_BROKEN_REGREAD=y + CONFIG_IBMVIO=y +-# CONFIG_IBMEBUS is not set ++CONFIG_IBMEBUS=y + # CONFIG_PPC_MPC106 is not set + CONFIG_PPC_970_NAP=y + CONFIG_PPC_INDIRECT_IO=y +@@ -375,7 +375,7 @@ + CONFIG_INET_XFRM_MODE_TRANSPORT=y + CONFIG_INET_XFRM_MODE_TUNNEL=y + CONFIG_INET_XFRM_MODE_BEET=y +-# CONFIG_INET_LRO is not set ++CONFIG_INET_LRO=m + CONFIG_INET_DIAG=y + CONFIG_INET_TCP_DIAG=y + # CONFIG_TCP_CONG_ADVANCED is not set +@@ -929,6 +929,7 @@ + CONFIG_NETDEV_10000=y + # CONFIG_CHELSIO_T1 is not set + # CONFIG_CHELSIO_T3 is not set ++CONFIG_EHEA=m + # CONFIG_IXGBE is not set + CONFIG_IXGB=m + # CONFIG_IXGB_NAPI is not set +@@ -1558,6 +1559,7 @@ + CONFIG_INFINIBAND_MTHCA=m + CONFIG_INFINIBAND_MTHCA_DEBUG=y + # CONFIG_INFINIBAND_IPATH is not set ++CONFIG_INFINIBAND_EHCA=m + # CONFIG_INFINIBAND_AMSO1100 is not set + # CONFIG_MLX4_INFINIBAND is not set + CONFIG_INFINIBAND_IPOIB=m +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/ps3_defconfig powerpc.git/arch/powerpc/configs/ps3_defconfig +--- linux-2.6.24/arch/powerpc/configs/ps3_defconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/ps3_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -1,7 +1,7 @@ + # + # Automatically generated make config: don't edit +-# Linux kernel version: 2.6.24-rc4 +-# Tue Dec 4 22:49:57 2007 ++# Linux kernel version: 2.6.24-rc8 ++# Wed Jan 16 14:31:21 2008 + # + CONFIG_PPC64=y + +@@ -103,6 +103,7 @@ + CONFIG_SLAB=y + # CONFIG_SLUB is not set + # CONFIG_SLOB is not set ++CONFIG_SLABINFO=y + CONFIG_RT_MUTEXES=y + # CONFIG_TINY_SHMEM is not set + CONFIG_BASE_SMALL=0 +@@ -154,7 +155,6 @@ + # CONFIG_PS3_ADVANCED is not set + CONFIG_PS3_HTAB_SIZE=20 + # CONFIG_PS3_DYNAMIC_DMA is not set +-CONFIG_PS3_USE_LPAR_ADDR=y + CONFIG_PS3_VUART=y + CONFIG_PS3_PS3AV=y + CONFIG_PS3_SYS_MANAGER=y +@@ -162,6 +162,7 @@ + CONFIG_PS3_DISK=y + CONFIG_PS3_ROM=y + CONFIG_PS3_FLASH=y ++CONFIG_PS3_LPM=m + CONFIG_PPC_CELL=y + # CONFIG_PPC_CELL_NATIVE is not set + # CONFIG_PPC_IBM_CELL_BLADE is not set +@@ -225,7 +226,7 @@ + # CONFIG_SPARSEMEM_STATIC is not set + CONFIG_SPARSEMEM_EXTREME=y + CONFIG_SPARSEMEM_VMEMMAP_ENABLE=y +-CONFIG_SPARSEMEM_VMEMMAP=y ++# CONFIG_SPARSEMEM_VMEMMAP is not set + CONFIG_MEMORY_HOTPLUG=y + CONFIG_MEMORY_HOTPLUG_SPARSE=y + CONFIG_SPLIT_PTLOCK_CPUS=4 +@@ -338,7 +339,26 @@ + # CONFIG_NET_PKTGEN is not set + # CONFIG_HAMRADIO is not set + # CONFIG_IRDA is not set +-# CONFIG_BT is not set ++CONFIG_BT=m ++CONFIG_BT_L2CAP=m ++CONFIG_BT_SCO=m ++CONFIG_BT_RFCOMM=m ++CONFIG_BT_RFCOMM_TTY=y ++CONFIG_BT_BNEP=m ++CONFIG_BT_BNEP_MC_FILTER=y ++CONFIG_BT_BNEP_PROTO_FILTER=y ++CONFIG_BT_HIDP=m ++ ++# ++# Bluetooth device drivers ++# ++CONFIG_BT_HCIUSB=m ++CONFIG_BT_HCIUSB_SCO=y ++# CONFIG_BT_HCIUART is not set ++# CONFIG_BT_HCIBCM203X is not set ++# CONFIG_BT_HCIBPA10X is not set ++# CONFIG_BT_HCIBFUSB is not set ++# CONFIG_BT_HCIVHCI is not set + # CONFIG_AF_RXRPC is not set + + # +@@ -666,14 +686,14 @@ + # + # Sound + # +-CONFIG_SOUND=y ++CONFIG_SOUND=m + + # + # Advanced Linux Sound Architecture + # +-CONFIG_SND=y +-CONFIG_SND_TIMER=y +-CONFIG_SND_PCM=y ++CONFIG_SND=m ++CONFIG_SND_TIMER=m ++CONFIG_SND_PCM=m + # CONFIG_SND_SEQUENCER is not set + # CONFIG_SND_MIXER_OSS is not set + # CONFIG_SND_PCM_OSS is not set +@@ -702,7 +722,7 @@ + # + # ALSA PowerPC devices + # +-CONFIG_SND_PS3=y ++CONFIG_SND_PS3=m + CONFIG_SND_PS3_DEFAULT_START_DELAY=2000 + + # +@@ -747,7 +767,7 @@ + CONFIG_USB_ARCH_HAS_HCD=y + CONFIG_USB_ARCH_HAS_OHCI=y + CONFIG_USB_ARCH_HAS_EHCI=y +-CONFIG_USB=y ++CONFIG_USB=m + # CONFIG_USB_DEBUG is not set + + # +@@ -761,13 +781,13 @@ + # + # USB Host Controller Drivers + # +-CONFIG_USB_EHCI_HCD=y ++CONFIG_USB_EHCI_HCD=m + # CONFIG_USB_EHCI_SPLIT_ISO is not set + # CONFIG_USB_EHCI_ROOT_HUB_TT is not set + # CONFIG_USB_EHCI_TT_NEWSCHED is not set + CONFIG_USB_EHCI_BIG_ENDIAN_MMIO=y + # CONFIG_USB_ISP116X_HCD is not set +-CONFIG_USB_OHCI_HCD=y ++CONFIG_USB_OHCI_HCD=m + # CONFIG_USB_OHCI_HCD_PPC_OF is not set + # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set + CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y +@@ -1033,7 +1053,8 @@ + CONFIG_HAS_IOPORT=y + CONFIG_HAS_DMA=y + CONFIG_INSTRUMENTATION=y +-# CONFIG_PROFILING is not set ++CONFIG_PROFILING=y ++CONFIG_OPROFILE=m + # CONFIG_KPROBES is not set + # CONFIG_MARKERS is not set + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/rainier_defconfig powerpc.git/arch/powerpc/configs/rainier_defconfig +--- linux-2.6.24/arch/powerpc/configs/rainier_defconfig 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/rainier_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,873 @@ ++# ++# Automatically generated make config: don't edit ++# Linux kernel version: 2.6.24-rc6 ++# Mon Dec 24 11:22:40 2007 ++# ++# CONFIG_PPC64 is not set ++ ++# ++# Processor support ++# ++# CONFIG_6xx is not set ++# CONFIG_PPC_85xx is not set ++# CONFIG_PPC_8xx is not set ++# CONFIG_40x is not set ++CONFIG_44x=y ++# CONFIG_E200 is not set ++CONFIG_4xx=y ++CONFIG_BOOKE=y ++CONFIG_PTE_64BIT=y ++CONFIG_PHYS_64BIT=y ++# CONFIG_PPC_MM_SLICES is not set ++CONFIG_NOT_COHERENT_CACHE=y ++CONFIG_PPC32=y ++CONFIG_WORD_SIZE=32 ++CONFIG_PPC_MERGE=y ++CONFIG_MMU=y ++CONFIG_GENERIC_CMOS_UPDATE=y ++CONFIG_GENERIC_TIME=y ++CONFIG_GENERIC_TIME_VSYSCALL=y ++CONFIG_GENERIC_CLOCKEVENTS=y ++CONFIG_GENERIC_HARDIRQS=y ++CONFIG_IRQ_PER_CPU=y ++CONFIG_RWSEM_XCHGADD_ALGORITHM=y ++CONFIG_ARCH_HAS_ILOG2_U32=y ++CONFIG_GENERIC_HWEIGHT=y ++CONFIG_GENERIC_CALIBRATE_DELAY=y ++CONFIG_GENERIC_FIND_NEXT_BIT=y ++# CONFIG_ARCH_NO_VIRT_TO_BUS is not set ++CONFIG_PPC=y ++CONFIG_EARLY_PRINTK=y ++CONFIG_GENERIC_NVRAM=y ++CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y ++CONFIG_ARCH_MAY_HAVE_PC_FDC=y ++CONFIG_PPC_OF=y ++CONFIG_OF=y ++CONFIG_PPC_UDBG_16550=y ++# CONFIG_GENERIC_TBSYNC is not set ++CONFIG_AUDIT_ARCH=y ++CONFIG_GENERIC_BUG=y ++# CONFIG_DEFAULT_UIMAGE is not set ++CONFIG_PPC_DCR_NATIVE=y ++# CONFIG_PPC_DCR_MMIO is not set ++CONFIG_PPC_DCR=y ++CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" ++ ++# ++# General setup ++# ++CONFIG_EXPERIMENTAL=y ++CONFIG_BROKEN_ON_SMP=y ++CONFIG_INIT_ENV_ARG_LIMIT=32 ++CONFIG_LOCALVERSION="" ++CONFIG_LOCALVERSION_AUTO=y ++CONFIG_SWAP=y ++CONFIG_SYSVIPC=y ++CONFIG_SYSVIPC_SYSCTL=y ++CONFIG_POSIX_MQUEUE=y ++# CONFIG_BSD_PROCESS_ACCT is not set ++# CONFIG_TASKSTATS is not set ++# CONFIG_USER_NS is not set ++# CONFIG_PID_NS is not set ++# CONFIG_AUDIT is not set ++# CONFIG_IKCONFIG is not set ++CONFIG_LOG_BUF_SHIFT=14 ++# CONFIG_CGROUPS is not set ++CONFIG_FAIR_GROUP_SCHED=y ++CONFIG_FAIR_USER_SCHED=y ++# CONFIG_FAIR_CGROUP_SCHED is not set ++CONFIG_SYSFS_DEPRECATED=y ++# CONFIG_RELAY is not set ++CONFIG_BLK_DEV_INITRD=y ++CONFIG_INITRAMFS_SOURCE="" ++# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set ++CONFIG_SYSCTL=y ++CONFIG_EMBEDDED=y ++CONFIG_SYSCTL_SYSCALL=y ++CONFIG_KALLSYMS=y ++# CONFIG_KALLSYMS_ALL is not set ++# CONFIG_KALLSYMS_EXTRA_PASS is not set ++CONFIG_HOTPLUG=y ++CONFIG_PRINTK=y ++CONFIG_BUG=y ++CONFIG_ELF_CORE=y ++CONFIG_BASE_FULL=y ++CONFIG_FUTEX=y ++CONFIG_ANON_INODES=y ++CONFIG_EPOLL=y ++CONFIG_SIGNALFD=y ++CONFIG_EVENTFD=y ++CONFIG_SHMEM=y ++CONFIG_VM_EVENT_COUNTERS=y ++CONFIG_SLUB_DEBUG=y ++# CONFIG_SLAB is not set ++CONFIG_SLUB=y ++# CONFIG_SLOB is not set ++CONFIG_RT_MUTEXES=y ++# CONFIG_TINY_SHMEM is not set ++CONFIG_BASE_SMALL=0 ++CONFIG_MODULES=y ++CONFIG_MODULE_UNLOAD=y ++# CONFIG_MODULE_FORCE_UNLOAD is not set ++# CONFIG_MODVERSIONS is not set ++# CONFIG_MODULE_SRCVERSION_ALL is not set ++CONFIG_KMOD=y ++CONFIG_BLOCK=y ++CONFIG_LBD=y ++# CONFIG_BLK_DEV_IO_TRACE is not set ++# CONFIG_LSF is not set ++# CONFIG_BLK_DEV_BSG is not set ++ ++# ++# IO Schedulers ++# ++CONFIG_IOSCHED_NOOP=y ++CONFIG_IOSCHED_AS=y ++CONFIG_IOSCHED_DEADLINE=y ++CONFIG_IOSCHED_CFQ=y ++CONFIG_DEFAULT_AS=y ++# CONFIG_DEFAULT_DEADLINE is not set ++# CONFIG_DEFAULT_CFQ is not set ++# CONFIG_DEFAULT_NOOP is not set ++CONFIG_DEFAULT_IOSCHED="anticipatory" ++# CONFIG_PPC4xx_PCI_EXPRESS is not set ++ ++# ++# Platform support ++# ++# CONFIG_PPC_MPC52xx is not set ++# CONFIG_PPC_MPC5200 is not set ++# CONFIG_PPC_CELL is not set ++# CONFIG_PPC_CELL_NATIVE is not set ++# CONFIG_PQ2ADS is not set ++# CONFIG_BAMBOO is not set ++# CONFIG_EBONY is not set ++# CONFIG_SEQUOIA is not set ++# CONFIG_TAISHAN is not set ++# CONFIG_KATMAI is not set ++CONFIG_RAINIER=y ++CONFIG_440GRX=y ++# CONFIG_MPIC is not set ++# CONFIG_MPIC_WEIRD is not set ++# CONFIG_PPC_I8259 is not set ++# CONFIG_PPC_RTAS is not set ++# CONFIG_MMIO_NVRAM is not set ++# CONFIG_PPC_MPC106 is not set ++# CONFIG_PPC_970_NAP is not set ++# CONFIG_PPC_INDIRECT_IO is not set ++# CONFIG_GENERIC_IOMAP is not set ++# CONFIG_CPU_FREQ is not set ++# CONFIG_CPM2 is not set ++# CONFIG_FSL_ULI1575 is not set ++ ++# ++# Kernel options ++# ++# CONFIG_HIGHMEM is not set ++# CONFIG_TICK_ONESHOT is not set ++# CONFIG_NO_HZ is not set ++# CONFIG_HIGH_RES_TIMERS is not set ++CONFIG_GENERIC_CLOCKEVENTS_BUILD=y ++# CONFIG_HZ_100 is not set ++CONFIG_HZ_250=y ++# CONFIG_HZ_300 is not set ++# CONFIG_HZ_1000 is not set ++CONFIG_HZ=250 ++CONFIG_PREEMPT_NONE=y ++# CONFIG_PREEMPT_VOLUNTARY is not set ++# CONFIG_PREEMPT is not set ++CONFIG_BINFMT_ELF=y ++# CONFIG_BINFMT_MISC is not set ++CONFIG_MATH_EMULATION=y ++CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y ++CONFIG_ARCH_FLATMEM_ENABLE=y ++CONFIG_ARCH_POPULATES_NODE_MAP=y ++CONFIG_SELECT_MEMORY_MODEL=y ++CONFIG_FLATMEM_MANUAL=y ++# CONFIG_DISCONTIGMEM_MANUAL is not set ++# CONFIG_SPARSEMEM_MANUAL is not set ++CONFIG_FLATMEM=y ++CONFIG_FLAT_NODE_MEM_MAP=y ++# CONFIG_SPARSEMEM_STATIC is not set ++# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set ++CONFIG_SPLIT_PTLOCK_CPUS=4 ++CONFIG_RESOURCES_64BIT=y ++CONFIG_ZONE_DMA_FLAG=1 ++CONFIG_BOUNCE=y ++CONFIG_VIRT_TO_BUS=y ++CONFIG_PROC_DEVICETREE=y ++CONFIG_CMDLINE_BOOL=y ++CONFIG_CMDLINE="" ++CONFIG_SECCOMP=y ++CONFIG_WANT_DEVICE_TREE=y ++CONFIG_DEVICE_TREE="rainier.dts" ++CONFIG_ISA_DMA_API=y ++ ++# ++# Bus options ++# ++CONFIG_ZONE_DMA=y ++CONFIG_PPC_INDIRECT_PCI=y ++CONFIG_PCI=y ++CONFIG_PCI_DOMAINS=y ++CONFIG_PCI_SYSCALL=y ++# CONFIG_PCIEPORTBUS is not set ++CONFIG_ARCH_SUPPORTS_MSI=y ++# CONFIG_PCI_MSI is not set ++CONFIG_PCI_LEGACY=y ++# CONFIG_PCI_DEBUG is not set ++# CONFIG_PCCARD is not set ++# CONFIG_HOTPLUG_PCI is not set ++ ++# ++# Advanced setup ++# ++# CONFIG_ADVANCED_OPTIONS is not set ++ ++# ++# Default settings for advanced configuration options are used ++# ++CONFIG_HIGHMEM_START=0xfe000000 ++CONFIG_LOWMEM_SIZE=0x30000000 ++CONFIG_KERNEL_START=0xc0000000 ++CONFIG_TASK_SIZE=0xc0000000 ++CONFIG_CONSISTENT_START=0xff100000 ++CONFIG_CONSISTENT_SIZE=0x00200000 ++CONFIG_BOOT_LOAD=0x01000000 ++ ++# ++# Networking ++# ++CONFIG_NET=y ++ ++# ++# Networking options ++# ++CONFIG_PACKET=y ++# CONFIG_PACKET_MMAP is not set ++CONFIG_UNIX=y ++# CONFIG_NET_KEY is not set ++CONFIG_INET=y ++# CONFIG_IP_MULTICAST is not set ++# CONFIG_IP_ADVANCED_ROUTER is not set ++CONFIG_IP_FIB_HASH=y ++CONFIG_IP_PNP=y ++CONFIG_IP_PNP_DHCP=y ++CONFIG_IP_PNP_BOOTP=y ++# CONFIG_IP_PNP_RARP is not set ++# CONFIG_NET_IPIP is not set ++# CONFIG_NET_IPGRE is not set ++# CONFIG_ARPD is not set ++# CONFIG_SYN_COOKIES is not set ++# CONFIG_INET_AH is not set ++# CONFIG_INET_ESP is not set ++# CONFIG_INET_IPCOMP is not set ++# CONFIG_INET_XFRM_TUNNEL is not set ++# CONFIG_INET_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_TRANSPORT is not set ++# CONFIG_INET_XFRM_MODE_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_BEET is not set ++# CONFIG_INET_LRO is not set ++CONFIG_INET_DIAG=y ++CONFIG_INET_TCP_DIAG=y ++# CONFIG_TCP_CONG_ADVANCED is not set ++CONFIG_TCP_CONG_CUBIC=y ++CONFIG_DEFAULT_TCP_CONG="cubic" ++# CONFIG_TCP_MD5SIG is not set ++# CONFIG_IPV6 is not set ++# CONFIG_INET6_XFRM_TUNNEL is not set ++# CONFIG_INET6_TUNNEL is not set ++# CONFIG_NETWORK_SECMARK is not set ++# CONFIG_NETFILTER is not set ++# CONFIG_IP_DCCP is not set ++# CONFIG_IP_SCTP is not set ++# CONFIG_TIPC is not set ++# CONFIG_ATM is not set ++# CONFIG_BRIDGE is not set ++# CONFIG_VLAN_8021Q is not set ++# CONFIG_DECNET is not set ++# CONFIG_LLC2 is not set ++# CONFIG_IPX is not set ++# CONFIG_ATALK is not set ++# CONFIG_X25 is not set ++# CONFIG_LAPB is not set ++# CONFIG_ECONET is not set ++# CONFIG_WAN_ROUTER is not set ++# CONFIG_NET_SCHED is not set ++ ++# ++# Network testing ++# ++# CONFIG_NET_PKTGEN is not set ++# CONFIG_HAMRADIO is not set ++# CONFIG_IRDA is not set ++# CONFIG_BT is not set ++# CONFIG_AF_RXRPC is not set ++ ++# ++# Wireless ++# ++# CONFIG_CFG80211 is not set ++# CONFIG_WIRELESS_EXT is not set ++# CONFIG_MAC80211 is not set ++# CONFIG_IEEE80211 is not set ++# CONFIG_RFKILL is not set ++# CONFIG_NET_9P is not set ++ ++# ++# Device Drivers ++# ++ ++# ++# Generic Driver Options ++# ++CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" ++CONFIG_STANDALONE=y ++CONFIG_PREVENT_FIRMWARE_BUILD=y ++CONFIG_FW_LOADER=y ++# CONFIG_DEBUG_DRIVER is not set ++# CONFIG_DEBUG_DEVRES is not set ++# CONFIG_SYS_HYPERVISOR is not set ++CONFIG_CONNECTOR=y ++CONFIG_PROC_EVENTS=y ++CONFIG_MTD=y ++# CONFIG_MTD_DEBUG is not set ++# CONFIG_MTD_CONCAT is not set ++CONFIG_MTD_PARTITIONS=y ++# CONFIG_MTD_REDBOOT_PARTS is not set ++CONFIG_MTD_CMDLINE_PARTS=y ++ ++# ++# User Modules And Translation Layers ++# ++CONFIG_MTD_CHAR=y ++# CONFIG_MTD_BLKDEVS is not set ++# CONFIG_MTD_BLOCK is not set ++# CONFIG_MTD_BLOCK_RO is not set ++# CONFIG_FTL is not set ++# CONFIG_NFTL is not set ++# CONFIG_INFTL is not set ++# CONFIG_RFD_FTL is not set ++# CONFIG_SSFDC is not set ++# CONFIG_MTD_OOPS is not set ++ ++# ++# RAM/ROM/Flash chip drivers ++# ++CONFIG_MTD_CFI=y ++CONFIG_MTD_JEDECPROBE=y ++CONFIG_MTD_GEN_PROBE=y ++# CONFIG_MTD_CFI_ADV_OPTIONS is not set ++CONFIG_MTD_MAP_BANK_WIDTH_1=y ++CONFIG_MTD_MAP_BANK_WIDTH_2=y ++CONFIG_MTD_MAP_BANK_WIDTH_4=y ++# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set ++CONFIG_MTD_CFI_I1=y ++CONFIG_MTD_CFI_I2=y ++# CONFIG_MTD_CFI_I4 is not set ++# CONFIG_MTD_CFI_I8 is not set ++CONFIG_MTD_CFI_INTELEXT=y ++CONFIG_MTD_CFI_AMDSTD=y ++# CONFIG_MTD_CFI_STAA is not set ++CONFIG_MTD_CFI_UTIL=y ++# CONFIG_MTD_RAM is not set ++# CONFIG_MTD_ROM is not set ++# CONFIG_MTD_ABSENT is not set ++ ++# ++# Mapping drivers for chip access ++# ++# CONFIG_MTD_COMPLEX_MAPPINGS is not set ++# CONFIG_MTD_PHYSMAP is not set ++CONFIG_MTD_PHYSMAP_OF=y ++# CONFIG_MTD_INTEL_VR_NOR is not set ++# CONFIG_MTD_PLATRAM is not set ++ ++# ++# Self-contained MTD device drivers ++# ++# CONFIG_MTD_PMC551 is not set ++# CONFIG_MTD_SLRAM is not set ++# CONFIG_MTD_PHRAM is not set ++# CONFIG_MTD_MTDRAM is not set ++# CONFIG_MTD_BLOCK2MTD is not set ++ ++# ++# Disk-On-Chip Device Drivers ++# ++# CONFIG_MTD_DOC2000 is not set ++# CONFIG_MTD_DOC2001 is not set ++# CONFIG_MTD_DOC2001PLUS is not set ++# CONFIG_MTD_NAND is not set ++# CONFIG_MTD_ONENAND is not set ++ ++# ++# UBI - Unsorted block images ++# ++# CONFIG_MTD_UBI is not set ++CONFIG_OF_DEVICE=y ++# CONFIG_PARPORT is not set ++CONFIG_BLK_DEV=y ++# CONFIG_BLK_DEV_FD is not set ++# CONFIG_BLK_CPQ_DA is not set ++# CONFIG_BLK_CPQ_CISS_DA is not set ++# CONFIG_BLK_DEV_DAC960 is not set ++# CONFIG_BLK_DEV_UMEM is not set ++# CONFIG_BLK_DEV_COW_COMMON is not set ++# CONFIG_BLK_DEV_LOOP is not set ++# CONFIG_BLK_DEV_NBD is not set ++# CONFIG_BLK_DEV_SX8 is not set ++CONFIG_BLK_DEV_RAM=y ++CONFIG_BLK_DEV_RAM_COUNT=16 ++CONFIG_BLK_DEV_RAM_SIZE=35000 ++CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024 ++# CONFIG_CDROM_PKTCDVD is not set ++# CONFIG_ATA_OVER_ETH is not set ++# CONFIG_XILINX_SYSACE is not set ++CONFIG_MISC_DEVICES=y ++# CONFIG_PHANTOM is not set ++# CONFIG_EEPROM_93CX6 is not set ++# CONFIG_SGI_IOC4 is not set ++# CONFIG_TIFM_CORE is not set ++# CONFIG_IDE is not set ++ ++# ++# SCSI device support ++# ++# CONFIG_RAID_ATTRS is not set ++# CONFIG_SCSI is not set ++# CONFIG_SCSI_DMA is not set ++# CONFIG_SCSI_NETLINK is not set ++# CONFIG_ATA is not set ++# CONFIG_MD is not set ++# CONFIG_FUSION is not set ++ ++# ++# IEEE 1394 (FireWire) support ++# ++# CONFIG_FIREWIRE is not set ++# CONFIG_IEEE1394 is not set ++# CONFIG_I2O is not set ++CONFIG_MACINTOSH_DRIVERS=y ++# CONFIG_MAC_EMUMOUSEBTN is not set ++# CONFIG_WINDFARM is not set ++CONFIG_NETDEVICES=y ++# CONFIG_NETDEVICES_MULTIQUEUE is not set ++# CONFIG_DUMMY is not set ++# CONFIG_BONDING is not set ++# CONFIG_MACVLAN is not set ++# CONFIG_EQUALIZER is not set ++# CONFIG_TUN is not set ++# CONFIG_VETH is not set ++# CONFIG_IP1000 is not set ++# CONFIG_ARCNET is not set ++# CONFIG_NET_ETHERNET is not set ++CONFIG_IBM_NEW_EMAC_ZMII=y ++CONFIG_IBM_NEW_EMAC_RGMII=y ++CONFIG_IBM_NEW_EMAC_EMAC4=y ++CONFIG_NETDEV_1000=y ++# CONFIG_ACENIC is not set ++# CONFIG_DL2K is not set ++# CONFIG_E1000 is not set ++# CONFIG_E1000E is not set ++# CONFIG_NS83820 is not set ++# CONFIG_HAMACHI is not set ++# CONFIG_YELLOWFIN is not set ++# CONFIG_R8169 is not set ++# CONFIG_SIS190 is not set ++# CONFIG_SKGE is not set ++# CONFIG_SKY2 is not set ++# CONFIG_SK98LIN is not set ++# CONFIG_VIA_VELOCITY is not set ++# CONFIG_TIGON3 is not set ++# CONFIG_BNX2 is not set ++# CONFIG_QLA3XXX is not set ++# CONFIG_ATL1 is not set ++CONFIG_NETDEV_10000=y ++# CONFIG_CHELSIO_T1 is not set ++# CONFIG_CHELSIO_T3 is not set ++# CONFIG_IXGBE is not set ++# CONFIG_IXGB is not set ++# CONFIG_S2IO is not set ++# CONFIG_MYRI10GE is not set ++# CONFIG_NETXEN_NIC is not set ++# CONFIG_NIU is not set ++# CONFIG_MLX4_CORE is not set ++# CONFIG_TEHUTI is not set ++# CONFIG_TR is not set ++ ++# ++# Wireless LAN ++# ++# CONFIG_WLAN_PRE80211 is not set ++# CONFIG_WLAN_80211 is not set ++# CONFIG_WAN is not set ++# CONFIG_FDDI is not set ++# CONFIG_HIPPI is not set ++# CONFIG_PPP is not set ++# CONFIG_SLIP is not set ++# CONFIG_SHAPER is not set ++# CONFIG_NETCONSOLE is not set ++# CONFIG_NETPOLL is not set ++# CONFIG_NET_POLL_CONTROLLER is not set ++# CONFIG_ISDN is not set ++# CONFIG_PHONE is not set ++ ++# ++# Input device support ++# ++# CONFIG_INPUT is not set ++ ++# ++# Hardware I/O ports ++# ++# CONFIG_SERIO is not set ++# CONFIG_GAMEPORT is not set ++ ++# ++# Character devices ++# ++# CONFIG_VT is not set ++# CONFIG_SERIAL_NONSTANDARD is not set ++ ++# ++# Serial drivers ++# ++CONFIG_SERIAL_8250=y ++CONFIG_SERIAL_8250_CONSOLE=y ++# CONFIG_SERIAL_8250_PCI is not set ++CONFIG_SERIAL_8250_NR_UARTS=4 ++CONFIG_SERIAL_8250_RUNTIME_UARTS=4 ++CONFIG_SERIAL_8250_EXTENDED=y ++# CONFIG_SERIAL_8250_MANY_PORTS is not set ++CONFIG_SERIAL_8250_SHARE_IRQ=y ++# CONFIG_SERIAL_8250_DETECT_IRQ is not set ++# CONFIG_SERIAL_8250_RSA is not set ++ ++# ++# Non-8250 serial port support ++# ++# CONFIG_SERIAL_UARTLITE is not set ++CONFIG_SERIAL_CORE=y ++CONFIG_SERIAL_CORE_CONSOLE=y ++# CONFIG_SERIAL_JSM is not set ++CONFIG_SERIAL_OF_PLATFORM=y ++CONFIG_UNIX98_PTYS=y ++CONFIG_LEGACY_PTYS=y ++CONFIG_LEGACY_PTY_COUNT=256 ++# CONFIG_IPMI_HANDLER is not set ++# CONFIG_HW_RANDOM is not set ++# CONFIG_NVRAM is not set ++# CONFIG_GEN_RTC is not set ++# CONFIG_R3964 is not set ++# CONFIG_APPLICOM is not set ++# CONFIG_RAW_DRIVER is not set ++# CONFIG_TCG_TPM is not set ++CONFIG_DEVPORT=y ++# CONFIG_I2C is not set ++ ++# ++# SPI support ++# ++# CONFIG_SPI is not set ++# CONFIG_SPI_MASTER is not set ++# CONFIG_W1 is not set ++# CONFIG_POWER_SUPPLY is not set ++# CONFIG_HWMON is not set ++# CONFIG_WATCHDOG is not set ++ ++# ++# Sonics Silicon Backplane ++# ++CONFIG_SSB_POSSIBLE=y ++# CONFIG_SSB is not set ++ ++# ++# Multifunction device drivers ++# ++# CONFIG_MFD_SM501 is not set ++ ++# ++# Multimedia devices ++# ++# CONFIG_VIDEO_DEV is not set ++# CONFIG_DVB_CORE is not set ++CONFIG_DAB=y ++ ++# ++# Graphics support ++# ++# CONFIG_AGP is not set ++# CONFIG_DRM is not set ++# CONFIG_VGASTATE is not set ++CONFIG_VIDEO_OUTPUT_CONTROL=m ++# CONFIG_FB is not set ++# CONFIG_BACKLIGHT_LCD_SUPPORT is not set ++ ++# ++# Display device support ++# ++# CONFIG_DISPLAY_SUPPORT is not set ++ ++# ++# Sound ++# ++# CONFIG_SOUND is not set ++CONFIG_USB_SUPPORT=y ++CONFIG_USB_ARCH_HAS_HCD=y ++CONFIG_USB_ARCH_HAS_OHCI=y ++CONFIG_USB_ARCH_HAS_EHCI=y ++# CONFIG_USB is not set ++ ++# ++# NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' ++# ++ ++# ++# USB Gadget Support ++# ++# CONFIG_USB_GADGET is not set ++# CONFIG_MMC is not set ++# CONFIG_NEW_LEDS is not set ++# CONFIG_INFINIBAND is not set ++# CONFIG_EDAC is not set ++# CONFIG_RTC_CLASS is not set ++ ++# ++# Userspace I/O ++# ++# CONFIG_UIO is not set ++ ++# ++# File systems ++# ++CONFIG_EXT2_FS=y ++# CONFIG_EXT2_FS_XATTR is not set ++# CONFIG_EXT2_FS_XIP is not set ++# CONFIG_EXT3_FS is not set ++# CONFIG_EXT4DEV_FS is not set ++# CONFIG_REISERFS_FS is not set ++# CONFIG_JFS_FS is not set ++# CONFIG_FS_POSIX_ACL is not set ++# CONFIG_XFS_FS is not set ++# CONFIG_GFS2_FS is not set ++# CONFIG_OCFS2_FS is not set ++# CONFIG_MINIX_FS is not set ++# CONFIG_ROMFS_FS is not set ++CONFIG_INOTIFY=y ++CONFIG_INOTIFY_USER=y ++# CONFIG_QUOTA is not set ++CONFIG_DNOTIFY=y ++# CONFIG_AUTOFS_FS is not set ++# CONFIG_AUTOFS4_FS is not set ++# CONFIG_FUSE_FS is not set ++ ++# ++# CD-ROM/DVD Filesystems ++# ++# CONFIG_ISO9660_FS is not set ++# CONFIG_UDF_FS is not set ++ ++# ++# DOS/FAT/NT Filesystems ++# ++# CONFIG_MSDOS_FS is not set ++# CONFIG_VFAT_FS is not set ++# CONFIG_NTFS_FS is not set ++ ++# ++# Pseudo filesystems ++# ++CONFIG_PROC_FS=y ++CONFIG_PROC_KCORE=y ++CONFIG_PROC_SYSCTL=y ++CONFIG_SYSFS=y ++CONFIG_TMPFS=y ++# CONFIG_TMPFS_POSIX_ACL is not set ++# CONFIG_HUGETLB_PAGE is not set ++# CONFIG_CONFIGFS_FS is not set ++ ++# ++# Miscellaneous filesystems ++# ++# CONFIG_ADFS_FS is not set ++# CONFIG_AFFS_FS is not set ++# CONFIG_HFS_FS is not set ++# CONFIG_HFSPLUS_FS is not set ++# CONFIG_BEFS_FS is not set ++# CONFIG_BFS_FS is not set ++# CONFIG_EFS_FS is not set ++CONFIG_JFFS2_FS=y ++CONFIG_JFFS2_FS_DEBUG=0 ++CONFIG_JFFS2_FS_WRITEBUFFER=y ++# CONFIG_JFFS2_FS_WBUF_VERIFY is not set ++# CONFIG_JFFS2_SUMMARY is not set ++# CONFIG_JFFS2_FS_XATTR is not set ++# CONFIG_JFFS2_COMPRESSION_OPTIONS is not set ++CONFIG_JFFS2_ZLIB=y ++# CONFIG_JFFS2_LZO is not set ++CONFIG_JFFS2_RTIME=y ++# CONFIG_JFFS2_RUBIN is not set ++CONFIG_CRAMFS=y ++# CONFIG_VXFS_FS is not set ++# CONFIG_HPFS_FS is not set ++# CONFIG_QNX4FS_FS is not set ++# CONFIG_SYSV_FS is not set ++# CONFIG_UFS_FS is not set ++CONFIG_NETWORK_FILESYSTEMS=y ++CONFIG_NFS_FS=y ++CONFIG_NFS_V3=y ++# CONFIG_NFS_V3_ACL is not set ++# CONFIG_NFS_V4 is not set ++# CONFIG_NFS_DIRECTIO is not set ++# CONFIG_NFSD is not set ++CONFIG_ROOT_NFS=y ++CONFIG_LOCKD=y ++CONFIG_LOCKD_V4=y ++CONFIG_NFS_COMMON=y ++CONFIG_SUNRPC=y ++# CONFIG_SUNRPC_BIND34 is not set ++# CONFIG_RPCSEC_GSS_KRB5 is not set ++# CONFIG_RPCSEC_GSS_SPKM3 is not set ++# CONFIG_SMB_FS is not set ++# CONFIG_CIFS is not set ++# CONFIG_NCP_FS is not set ++# CONFIG_CODA_FS is not set ++# CONFIG_AFS_FS is not set ++ ++# ++# Partition Types ++# ++# CONFIG_PARTITION_ADVANCED is not set ++CONFIG_MSDOS_PARTITION=y ++# CONFIG_NLS is not set ++# CONFIG_DLM is not set ++# CONFIG_UCC_SLOW is not set ++ ++# ++# Library routines ++# ++CONFIG_BITREVERSE=y ++# CONFIG_CRC_CCITT is not set ++# CONFIG_CRC16 is not set ++# CONFIG_CRC_ITU_T is not set ++CONFIG_CRC32=y ++# CONFIG_CRC7 is not set ++# CONFIG_LIBCRC32C is not set ++CONFIG_ZLIB_INFLATE=y ++CONFIG_ZLIB_DEFLATE=y ++CONFIG_PLIST=y ++CONFIG_HAS_IOMEM=y ++CONFIG_HAS_IOPORT=y ++CONFIG_HAS_DMA=y ++CONFIG_INSTRUMENTATION=y ++# CONFIG_PROFILING is not set ++# CONFIG_KPROBES is not set ++# CONFIG_MARKERS is not set ++ ++# ++# Kernel hacking ++# ++# CONFIG_PRINTK_TIME is not set ++CONFIG_ENABLE_WARN_DEPRECATED=y ++CONFIG_ENABLE_MUST_CHECK=y ++CONFIG_MAGIC_SYSRQ=y ++# CONFIG_UNUSED_SYMBOLS is not set ++# CONFIG_DEBUG_FS is not set ++# CONFIG_HEADERS_CHECK is not set ++CONFIG_DEBUG_KERNEL=y ++# CONFIG_DEBUG_SHIRQ is not set ++CONFIG_DETECT_SOFTLOCKUP=y ++CONFIG_SCHED_DEBUG=y ++# CONFIG_SCHEDSTATS is not set ++# CONFIG_TIMER_STATS is not set ++# CONFIG_SLUB_DEBUG_ON is not set ++# CONFIG_DEBUG_RT_MUTEXES is not set ++# CONFIG_RT_MUTEX_TESTER is not set ++# CONFIG_DEBUG_SPINLOCK is not set ++# CONFIG_DEBUG_MUTEXES is not set ++# CONFIG_DEBUG_SPINLOCK_SLEEP is not set ++# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set ++# CONFIG_DEBUG_KOBJECT is not set ++# CONFIG_DEBUG_BUGVERBOSE is not set ++# CONFIG_DEBUG_INFO is not set ++# CONFIG_DEBUG_VM is not set ++# CONFIG_DEBUG_LIST is not set ++# CONFIG_DEBUG_SG is not set ++CONFIG_FORCED_INLINING=y ++# CONFIG_BOOT_PRINTK_DELAY is not set ++# CONFIG_RCU_TORTURE_TEST is not set ++# CONFIG_FAULT_INJECTION is not set ++# CONFIG_SAMPLES is not set ++# CONFIG_DEBUG_STACKOVERFLOW is not set ++# CONFIG_DEBUG_STACK_USAGE is not set ++# CONFIG_DEBUG_PAGEALLOC is not set ++CONFIG_DEBUGGER=y ++# CONFIG_KGDB is not set ++# CONFIG_XMON is not set ++# CONFIG_BDI_SWITCH is not set ++CONFIG_PPC_EARLY_DEBUG=y ++# CONFIG_PPC_EARLY_DEBUG_LPAR is not set ++# CONFIG_PPC_EARLY_DEBUG_G5 is not set ++# CONFIG_PPC_EARLY_DEBUG_RTAS_PANEL is not set ++# CONFIG_PPC_EARLY_DEBUG_RTAS_CONSOLE is not set ++# CONFIG_PPC_EARLY_DEBUG_MAPLE is not set ++# CONFIG_PPC_EARLY_DEBUG_ISERIES is not set ++# CONFIG_PPC_EARLY_DEBUG_PAS_REALMODE is not set ++# CONFIG_PPC_EARLY_DEBUG_BEAT is not set ++CONFIG_PPC_EARLY_DEBUG_44x=y ++# CONFIG_PPC_EARLY_DEBUG_40x is not set ++# CONFIG_PPC_EARLY_DEBUG_CPM is not set ++CONFIG_PPC_EARLY_DEBUG_44x_PHYSLOW=0xef600300 ++CONFIG_PPC_EARLY_DEBUG_44x_PHYSHIGH=0x1 ++ ++# ++# Security options ++# ++# CONFIG_KEYS is not set ++# CONFIG_SECURITY is not set ++# CONFIG_SECURITY_FILE_CAPABILITIES is not set ++CONFIG_CRYPTO=y ++CONFIG_CRYPTO_ALGAPI=y ++CONFIG_CRYPTO_BLKCIPHER=y ++CONFIG_CRYPTO_MANAGER=y ++# CONFIG_CRYPTO_HMAC is not set ++# CONFIG_CRYPTO_XCBC is not set ++# CONFIG_CRYPTO_NULL is not set ++# CONFIG_CRYPTO_MD4 is not set ++CONFIG_CRYPTO_MD5=y ++# CONFIG_CRYPTO_SHA1 is not set ++# CONFIG_CRYPTO_SHA256 is not set ++# CONFIG_CRYPTO_SHA512 is not set ++# CONFIG_CRYPTO_WP512 is not set ++# CONFIG_CRYPTO_TGR192 is not set ++# CONFIG_CRYPTO_GF128MUL is not set ++CONFIG_CRYPTO_ECB=y ++CONFIG_CRYPTO_CBC=y ++CONFIG_CRYPTO_PCBC=y ++# CONFIG_CRYPTO_LRW is not set ++# CONFIG_CRYPTO_XTS is not set ++# CONFIG_CRYPTO_CRYPTD is not set ++CONFIG_CRYPTO_DES=y ++# CONFIG_CRYPTO_FCRYPT is not set ++# CONFIG_CRYPTO_BLOWFISH is not set ++# CONFIG_CRYPTO_TWOFISH is not set ++# CONFIG_CRYPTO_SERPENT is not set ++# CONFIG_CRYPTO_AES is not set ++# CONFIG_CRYPTO_CAST5 is not set ++# CONFIG_CRYPTO_CAST6 is not set ++# CONFIG_CRYPTO_TEA is not set ++# CONFIG_CRYPTO_ARC4 is not set ++# CONFIG_CRYPTO_KHAZAD is not set ++# CONFIG_CRYPTO_ANUBIS is not set ++# CONFIG_CRYPTO_SEED is not set ++# CONFIG_CRYPTO_DEFLATE is not set ++# CONFIG_CRYPTO_MICHAEL_MIC is not set ++# CONFIG_CRYPTO_CRC32C is not set ++# CONFIG_CRYPTO_CAMELLIA is not set ++# CONFIG_CRYPTO_TEST is not set ++# CONFIG_CRYPTO_AUTHENC is not set ++CONFIG_CRYPTO_HW=y ++# CONFIG_PPC_CLOCK is not set +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/sequoia_defconfig powerpc.git/arch/powerpc/configs/sequoia_defconfig +--- linux-2.6.24/arch/powerpc/configs/sequoia_defconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/sequoia_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -1,7 +1,7 @@ + # + # Automatically generated make config: don't edit +-# Linux kernel version: 2.6.24-rc4 +-# Thu Dec 6 16:49:17 2007 ++# Linux kernel version: 2.6.24-rc6 ++# Mon Dec 24 11:23:22 2007 + # + # CONFIG_PPC64 is not set + +@@ -129,6 +129,7 @@ + # CONFIG_DEFAULT_CFQ is not set + # CONFIG_DEFAULT_NOOP is not set + CONFIG_DEFAULT_IOSCHED="anticipatory" ++# CONFIG_PPC4xx_PCI_EXPRESS is not set + + # + # Platform support +@@ -141,8 +142,10 @@ + # CONFIG_BAMBOO is not set + # CONFIG_EBONY is not set + CONFIG_SEQUOIA=y ++# CONFIG_TAISHAN is not set ++# CONFIG_KATMAI is not set ++# CONFIG_RAINIER is not set + CONFIG_440EPX=y +-CONFIG_440A=y + # CONFIG_MPIC is not set + # CONFIG_MPIC_WEIRD is not set + # CONFIG_PPC_I8259 is not set +@@ -446,9 +449,7 @@ + # CONFIG_FIREWIRE is not set + # CONFIG_IEEE1394 is not set + # CONFIG_I2O is not set +-CONFIG_MACINTOSH_DRIVERS=y +-# CONFIG_MAC_EMUMOUSEBTN is not set +-# CONFIG_WINDFARM is not set ++# CONFIG_MACINTOSH_DRIVERS is not set + CONFIG_NETDEVICES=y + # CONFIG_NETDEVICES_MULTIQUEUE is not set + # CONFIG_DUMMY is not set +@@ -459,10 +460,28 @@ + # CONFIG_VETH is not set + # CONFIG_IP1000 is not set + # CONFIG_ARCNET is not set +-# CONFIG_NET_ETHERNET is not set ++# CONFIG_PHYLIB is not set ++CONFIG_NET_ETHERNET=y ++# CONFIG_MII is not set ++# CONFIG_HAPPYMEAL is not set ++# CONFIG_SUNGEM is not set ++# CONFIG_CASSINI is not set ++# CONFIG_NET_VENDOR_3COM is not set ++# CONFIG_NET_TULIP is not set ++# CONFIG_HP100 is not set ++CONFIG_IBM_NEW_EMAC=y ++CONFIG_IBM_NEW_EMAC_RXB=128 ++CONFIG_IBM_NEW_EMAC_TXB=64 ++CONFIG_IBM_NEW_EMAC_POLL_WEIGHT=32 ++CONFIG_IBM_NEW_EMAC_RX_COPY_THRESHOLD=256 ++CONFIG_IBM_NEW_EMAC_RX_SKB_HEADROOM=0 ++# CONFIG_IBM_NEW_EMAC_DEBUG is not set + CONFIG_IBM_NEW_EMAC_ZMII=y + CONFIG_IBM_NEW_EMAC_RGMII=y ++# CONFIG_IBM_NEW_EMAC_TAH is not set + CONFIG_IBM_NEW_EMAC_EMAC4=y ++# CONFIG_NET_PCI is not set ++# CONFIG_B44 is not set + CONFIG_NETDEV_1000=y + # CONFIG_ACENIC is not set + # CONFIG_DL2K is not set +@@ -811,6 +830,7 @@ + # CONFIG_PPC_EARLY_DEBUG_PAS_REALMODE is not set + # CONFIG_PPC_EARLY_DEBUG_BEAT is not set + CONFIG_PPC_EARLY_DEBUG_44x=y ++# CONFIG_PPC_EARLY_DEBUG_40x is not set + # CONFIG_PPC_EARLY_DEBUG_CPM is not set + CONFIG_PPC_EARLY_DEBUG_44x_PHYSLOW=0xef600300 + CONFIG_PPC_EARLY_DEBUG_44x_PHYSHIGH=0x1 +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/storcenter_defconfig powerpc.git/arch/powerpc/configs/storcenter_defconfig +--- linux-2.6.24/arch/powerpc/configs/storcenter_defconfig 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/storcenter_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,1174 @@ ++# ++# Automatically generated make config: don't edit ++# Linux kernel version: 2.6.24-rc6 ++# Tue Jan 8 09:33:54 2008 ++# ++# CONFIG_PPC64 is not set ++ ++# ++# Processor support ++# ++CONFIG_6xx=y ++# CONFIG_PPC_85xx is not set ++# CONFIG_PPC_8xx is not set ++# CONFIG_40x is not set ++# CONFIG_44x is not set ++# CONFIG_E200 is not set ++CONFIG_PPC_FPU=y ++# CONFIG_ALTIVEC is not set ++CONFIG_PPC_STD_MMU=y ++CONFIG_PPC_STD_MMU_32=y ++# CONFIG_PPC_MM_SLICES is not set ++# CONFIG_SMP is not set ++CONFIG_PPC32=y ++CONFIG_WORD_SIZE=32 ++CONFIG_PPC_MERGE=y ++CONFIG_MMU=y ++CONFIG_GENERIC_CMOS_UPDATE=y ++CONFIG_GENERIC_TIME=y ++CONFIG_GENERIC_TIME_VSYSCALL=y ++CONFIG_GENERIC_CLOCKEVENTS=y ++CONFIG_GENERIC_HARDIRQS=y ++CONFIG_IRQ_PER_CPU=y ++CONFIG_RWSEM_XCHGADD_ALGORITHM=y ++CONFIG_ARCH_HAS_ILOG2_U32=y ++CONFIG_GENERIC_HWEIGHT=y ++CONFIG_GENERIC_CALIBRATE_DELAY=y ++CONFIG_GENERIC_FIND_NEXT_BIT=y ++# CONFIG_ARCH_NO_VIRT_TO_BUS is not set ++CONFIG_PPC=y ++CONFIG_EARLY_PRINTK=y ++CONFIG_GENERIC_NVRAM=y ++CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y ++CONFIG_ARCH_MAY_HAVE_PC_FDC=y ++CONFIG_PPC_OF=y ++CONFIG_OF=y ++CONFIG_PPC_UDBG_16550=y ++# CONFIG_GENERIC_TBSYNC is not set ++CONFIG_AUDIT_ARCH=y ++CONFIG_GENERIC_BUG=y ++# CONFIG_DEFAULT_UIMAGE is not set ++# CONFIG_PPC_DCR_NATIVE is not set ++# CONFIG_PPC_DCR_MMIO is not set ++CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" ++ ++# ++# General setup ++# ++CONFIG_EXPERIMENTAL=y ++CONFIG_BROKEN_ON_SMP=y ++CONFIG_INIT_ENV_ARG_LIMIT=32 ++CONFIG_LOCALVERSION="" ++CONFIG_LOCALVERSION_AUTO=y ++CONFIG_SWAP=y ++CONFIG_SYSVIPC=y ++CONFIG_SYSVIPC_SYSCTL=y ++# CONFIG_POSIX_MQUEUE is not set ++# CONFIG_BSD_PROCESS_ACCT is not set ++# CONFIG_TASKSTATS is not set ++# CONFIG_USER_NS is not set ++# CONFIG_PID_NS is not set ++# CONFIG_AUDIT is not set ++# CONFIG_IKCONFIG is not set ++CONFIG_LOG_BUF_SHIFT=14 ++# CONFIG_CGROUPS is not set ++CONFIG_FAIR_GROUP_SCHED=y ++CONFIG_FAIR_USER_SCHED=y ++# CONFIG_FAIR_CGROUP_SCHED is not set ++CONFIG_SYSFS_DEPRECATED=y ++# CONFIG_RELAY is not set ++# CONFIG_BLK_DEV_INITRD is not set ++CONFIG_CC_OPTIMIZE_FOR_SIZE=y ++CONFIG_SYSCTL=y ++CONFIG_EMBEDDED=y ++CONFIG_SYSCTL_SYSCALL=y ++# CONFIG_KALLSYMS is not set ++CONFIG_HOTPLUG=y ++CONFIG_PRINTK=y ++CONFIG_BUG=y ++CONFIG_ELF_CORE=y ++CONFIG_BASE_FULL=y ++CONFIG_FUTEX=y ++CONFIG_ANON_INODES=y ++CONFIG_EPOLL=y ++CONFIG_SIGNALFD=y ++CONFIG_EVENTFD=y ++CONFIG_SHMEM=y ++CONFIG_VM_EVENT_COUNTERS=y ++CONFIG_SLUB_DEBUG=y ++# CONFIG_SLAB is not set ++CONFIG_SLUB=y ++# CONFIG_SLOB is not set ++CONFIG_RT_MUTEXES=y ++# CONFIG_TINY_SHMEM is not set ++CONFIG_BASE_SMALL=0 ++CONFIG_MODULES=y ++CONFIG_MODULE_UNLOAD=y ++# CONFIG_MODULE_FORCE_UNLOAD is not set ++# CONFIG_MODVERSIONS is not set ++# CONFIG_MODULE_SRCVERSION_ALL is not set ++CONFIG_KMOD=y ++CONFIG_BLOCK=y ++CONFIG_LBD=y ++# CONFIG_BLK_DEV_IO_TRACE is not set ++# CONFIG_LSF is not set ++# CONFIG_BLK_DEV_BSG is not set ++ ++# ++# IO Schedulers ++# ++CONFIG_IOSCHED_NOOP=y ++CONFIG_IOSCHED_AS=y ++CONFIG_IOSCHED_DEADLINE=y ++CONFIG_IOSCHED_CFQ=y ++# CONFIG_DEFAULT_AS is not set ++# CONFIG_DEFAULT_DEADLINE is not set ++CONFIG_DEFAULT_CFQ=y ++# CONFIG_DEFAULT_NOOP is not set ++CONFIG_DEFAULT_IOSCHED="cfq" ++ ++# ++# Platform support ++# ++CONFIG_PPC_MULTIPLATFORM=y ++# CONFIG_PPC_82xx is not set ++# CONFIG_PPC_83xx is not set ++# CONFIG_PPC_86xx is not set ++CONFIG_CLASSIC32=y ++# CONFIG_PPC_CHRP is not set ++# CONFIG_PPC_MPC52xx is not set ++# CONFIG_PPC_MPC5200 is not set ++# CONFIG_PPC_EFIKA is not set ++# CONFIG_PPC_LITE5200 is not set ++# CONFIG_PPC_PMAC is not set ++# CONFIG_PPC_CELL is not set ++# CONFIG_PPC_CELL_NATIVE is not set ++# CONFIG_PQ2ADS is not set ++CONFIG_EMBEDDED6xx=y ++# CONFIG_LINKSTATION is not set ++CONFIG_STORCENTER=y ++# CONFIG_MPC7448HPC2 is not set ++# CONFIG_PPC_HOLLY is not set ++# CONFIG_PPC_PRPMC2800 is not set ++CONFIG_MPC10X_BRIDGE=y ++CONFIG_MPC10X_OPENPIC=y ++# CONFIG_MPC10X_STORE_GATHERING is not set ++CONFIG_MPIC=y ++# CONFIG_MPIC_WEIRD is not set ++# CONFIG_PPC_I8259 is not set ++# CONFIG_PPC_RTAS is not set ++# CONFIG_MMIO_NVRAM is not set ++# CONFIG_PPC_MPC106 is not set ++# CONFIG_PPC_970_NAP is not set ++# CONFIG_PPC_INDIRECT_IO is not set ++# CONFIG_GENERIC_IOMAP is not set ++# CONFIG_CPU_FREQ is not set ++# CONFIG_TAU is not set ++# CONFIG_CPM2 is not set ++# CONFIG_FSL_ULI1575 is not set ++ ++# ++# Kernel options ++# ++# CONFIG_HIGHMEM is not set ++# CONFIG_TICK_ONESHOT is not set ++# CONFIG_NO_HZ is not set ++# CONFIG_HIGH_RES_TIMERS is not set ++CONFIG_GENERIC_CLOCKEVENTS_BUILD=y ++CONFIG_HZ_100=y ++# CONFIG_HZ_250 is not set ++# CONFIG_HZ_300 is not set ++# CONFIG_HZ_1000 is not set ++CONFIG_HZ=100 ++CONFIG_PREEMPT_NONE=y ++# CONFIG_PREEMPT_VOLUNTARY is not set ++# CONFIG_PREEMPT is not set ++CONFIG_BINFMT_ELF=y ++CONFIG_BINFMT_MISC=y ++CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y ++# CONFIG_KEXEC is not set ++CONFIG_ARCH_FLATMEM_ENABLE=y ++CONFIG_ARCH_POPULATES_NODE_MAP=y ++CONFIG_SELECT_MEMORY_MODEL=y ++CONFIG_FLATMEM_MANUAL=y ++# CONFIG_DISCONTIGMEM_MANUAL is not set ++# CONFIG_SPARSEMEM_MANUAL is not set ++CONFIG_FLATMEM=y ++CONFIG_FLAT_NODE_MEM_MAP=y ++# CONFIG_SPARSEMEM_STATIC is not set ++# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set ++CONFIG_SPLIT_PTLOCK_CPUS=4 ++# CONFIG_RESOURCES_64BIT is not set ++CONFIG_ZONE_DMA_FLAG=1 ++CONFIG_BOUNCE=y ++CONFIG_VIRT_TO_BUS=y ++CONFIG_PROC_DEVICETREE=y ++CONFIG_CMDLINE_BOOL=y ++CONFIG_CMDLINE="console=ttyS0,115200" ++# CONFIG_PM is not set ++CONFIG_SUSPEND_UP_POSSIBLE=y ++CONFIG_HIBERNATION_UP_POSSIBLE=y ++# CONFIG_SECCOMP is not set ++CONFIG_WANT_DEVICE_TREE=y ++CONFIG_DEVICE_TREE="storcenter.dts" ++CONFIG_ISA_DMA_API=y ++ ++# ++# Bus options ++# ++CONFIG_ZONE_DMA=y ++CONFIG_GENERIC_ISA_DMA=y ++CONFIG_PPC_INDIRECT_PCI=y ++CONFIG_FSL_SOC=y ++CONFIG_PCI=y ++CONFIG_PCI_DOMAINS=y ++CONFIG_PCI_SYSCALL=y ++# CONFIG_PCIEPORTBUS is not set ++CONFIG_ARCH_SUPPORTS_MSI=y ++# CONFIG_PCI_MSI is not set ++CONFIG_PCI_LEGACY=y ++# CONFIG_PCCARD is not set ++# CONFIG_HOTPLUG_PCI is not set ++ ++# ++# Advanced setup ++# ++# CONFIG_ADVANCED_OPTIONS is not set ++ ++# ++# Default settings for advanced configuration options are used ++# ++CONFIG_HIGHMEM_START=0xfe000000 ++CONFIG_LOWMEM_SIZE=0x30000000 ++CONFIG_KERNEL_START=0xc0000000 ++CONFIG_TASK_SIZE=0xc0000000 ++CONFIG_BOOT_LOAD=0x00800000 ++ ++# ++# Networking ++# ++CONFIG_NET=y ++ ++# ++# Networking options ++# ++CONFIG_PACKET=m ++# CONFIG_PACKET_MMAP is not set ++CONFIG_UNIX=y ++# CONFIG_NET_KEY is not set ++CONFIG_INET=y ++CONFIG_IP_MULTICAST=y ++# CONFIG_IP_ADVANCED_ROUTER is not set ++CONFIG_IP_FIB_HASH=y ++CONFIG_IP_PNP=y ++CONFIG_IP_PNP_DHCP=y ++# CONFIG_IP_PNP_BOOTP is not set ++# CONFIG_IP_PNP_RARP is not set ++# CONFIG_NET_IPIP is not set ++# CONFIG_NET_IPGRE is not set ++# CONFIG_IP_MROUTE is not set ++# CONFIG_ARPD is not set ++# CONFIG_SYN_COOKIES is not set ++# CONFIG_INET_AH is not set ++# CONFIG_INET_ESP is not set ++# CONFIG_INET_IPCOMP is not set ++# CONFIG_INET_XFRM_TUNNEL is not set ++# CONFIG_INET_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_TRANSPORT is not set ++# CONFIG_INET_XFRM_MODE_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_BEET is not set ++# CONFIG_INET_LRO is not set ++CONFIG_INET_DIAG=y ++CONFIG_INET_TCP_DIAG=y ++# CONFIG_TCP_CONG_ADVANCED is not set ++CONFIG_TCP_CONG_CUBIC=y ++CONFIG_DEFAULT_TCP_CONG="cubic" ++# CONFIG_TCP_MD5SIG is not set ++# CONFIG_IPV6 is not set ++# CONFIG_INET6_XFRM_TUNNEL is not set ++# CONFIG_INET6_TUNNEL is not set ++# CONFIG_NETWORK_SECMARK is not set ++# CONFIG_NETFILTER is not set ++# CONFIG_IP_DCCP is not set ++# CONFIG_IP_SCTP is not set ++# CONFIG_TIPC is not set ++# CONFIG_ATM is not set ++# CONFIG_BRIDGE is not set ++# CONFIG_VLAN_8021Q is not set ++# CONFIG_DECNET is not set ++# CONFIG_LLC2 is not set ++# CONFIG_IPX is not set ++# CONFIG_ATALK is not set ++# CONFIG_X25 is not set ++# CONFIG_LAPB is not set ++# CONFIG_ECONET is not set ++# CONFIG_WAN_ROUTER is not set ++# CONFIG_NET_SCHED is not set ++ ++# ++# Network testing ++# ++# CONFIG_NET_PKTGEN is not set ++# CONFIG_HAMRADIO is not set ++# CONFIG_IRDA is not set ++# CONFIG_BT is not set ++# CONFIG_AF_RXRPC is not set ++ ++# ++# Wireless ++# ++# CONFIG_CFG80211 is not set ++# CONFIG_WIRELESS_EXT is not set ++# CONFIG_MAC80211 is not set ++# CONFIG_IEEE80211 is not set ++# CONFIG_RFKILL is not set ++# CONFIG_NET_9P is not set ++ ++# ++# Device Drivers ++# ++ ++# ++# Generic Driver Options ++# ++CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" ++CONFIG_STANDALONE=y ++CONFIG_PREVENT_FIRMWARE_BUILD=y ++# CONFIG_FW_LOADER is not set ++# CONFIG_SYS_HYPERVISOR is not set ++# CONFIG_CONNECTOR is not set ++CONFIG_MTD=y ++# CONFIG_MTD_DEBUG is not set ++# CONFIG_MTD_CONCAT is not set ++CONFIG_MTD_PARTITIONS=y ++# CONFIG_MTD_REDBOOT_PARTS is not set ++# CONFIG_MTD_CMDLINE_PARTS is not set ++ ++# ++# User Modules And Translation Layers ++# ++CONFIG_MTD_CHAR=y ++CONFIG_MTD_BLKDEVS=y ++CONFIG_MTD_BLOCK=y ++CONFIG_FTL=y ++CONFIG_NFTL=y ++CONFIG_NFTL_RW=y ++# CONFIG_INFTL is not set ++# CONFIG_RFD_FTL is not set ++# CONFIG_SSFDC is not set ++# CONFIG_MTD_OOPS is not set ++ ++# ++# RAM/ROM/Flash chip drivers ++# ++CONFIG_MTD_CFI=y ++# CONFIG_MTD_JEDECPROBE is not set ++CONFIG_MTD_GEN_PROBE=y ++# CONFIG_MTD_CFI_ADV_OPTIONS is not set ++CONFIG_MTD_MAP_BANK_WIDTH_1=y ++CONFIG_MTD_MAP_BANK_WIDTH_2=y ++CONFIG_MTD_MAP_BANK_WIDTH_4=y ++# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set ++CONFIG_MTD_CFI_I1=y ++CONFIG_MTD_CFI_I2=y ++# CONFIG_MTD_CFI_I4 is not set ++# CONFIG_MTD_CFI_I8 is not set ++# CONFIG_MTD_CFI_INTELEXT is not set ++CONFIG_MTD_CFI_AMDSTD=y ++# CONFIG_MTD_CFI_STAA is not set ++CONFIG_MTD_CFI_UTIL=y ++# CONFIG_MTD_RAM is not set ++# CONFIG_MTD_ROM is not set ++# CONFIG_MTD_ABSENT is not set ++ ++# ++# Mapping drivers for chip access ++# ++# CONFIG_MTD_COMPLEX_MAPPINGS is not set ++CONFIG_MTD_PHYSMAP=y ++CONFIG_MTD_PHYSMAP_START=0xFF800000 ++CONFIG_MTD_PHYSMAP_LEN=0x00800000 ++CONFIG_MTD_PHYSMAP_BANKWIDTH=1 ++# CONFIG_MTD_PHYSMAP_OF is not set ++# CONFIG_MTD_INTEL_VR_NOR is not set ++# CONFIG_MTD_PLATRAM is not set ++ ++# ++# Self-contained MTD device drivers ++# ++# CONFIG_MTD_PMC551 is not set ++# CONFIG_MTD_SLRAM is not set ++# CONFIG_MTD_PHRAM is not set ++# CONFIG_MTD_MTDRAM is not set ++# CONFIG_MTD_BLOCK2MTD is not set ++ ++# ++# Disk-On-Chip Device Drivers ++# ++# CONFIG_MTD_DOC2000 is not set ++# CONFIG_MTD_DOC2001 is not set ++# CONFIG_MTD_DOC2001PLUS is not set ++# CONFIG_MTD_NAND is not set ++# CONFIG_MTD_ONENAND is not set ++ ++# ++# UBI - Unsorted block images ++# ++# CONFIG_MTD_UBI is not set ++CONFIG_OF_DEVICE=y ++# CONFIG_PARPORT is not set ++CONFIG_BLK_DEV=y ++# CONFIG_BLK_DEV_FD is not set ++# CONFIG_BLK_CPQ_DA is not set ++# CONFIG_BLK_CPQ_CISS_DA is not set ++# CONFIG_BLK_DEV_DAC960 is not set ++# CONFIG_BLK_DEV_UMEM is not set ++# CONFIG_BLK_DEV_COW_COMMON is not set ++# CONFIG_BLK_DEV_LOOP is not set ++# CONFIG_BLK_DEV_NBD is not set ++# CONFIG_BLK_DEV_SX8 is not set ++# CONFIG_BLK_DEV_UB is not set ++# CONFIG_BLK_DEV_RAM is not set ++# CONFIG_CDROM_PKTCDVD is not set ++# CONFIG_ATA_OVER_ETH is not set ++CONFIG_MISC_DEVICES=y ++# CONFIG_PHANTOM is not set ++# CONFIG_EEPROM_93CX6 is not set ++# CONFIG_SGI_IOC4 is not set ++# CONFIG_TIFM_CORE is not set ++CONFIG_IDE=y ++CONFIG_IDE_MAX_HWIFS=4 ++CONFIG_BLK_DEV_IDE=y ++ ++# ++# Please see Documentation/ide.txt for help/info on IDE drives ++# ++# CONFIG_BLK_DEV_IDE_SATA is not set ++CONFIG_BLK_DEV_IDEDISK=y ++CONFIG_IDEDISK_MULTI_MODE=y ++# CONFIG_BLK_DEV_IDECD is not set ++# CONFIG_BLK_DEV_IDETAPE is not set ++# CONFIG_BLK_DEV_IDEFLOPPY is not set ++# CONFIG_BLK_DEV_IDESCSI is not set ++# CONFIG_IDE_TASK_IOCTL is not set ++CONFIG_IDE_PROC_FS=y ++ ++# ++# IDE chipset support/bugfixes ++# ++CONFIG_IDE_GENERIC=y ++# CONFIG_BLK_DEV_PLATFORM is not set ++ ++# ++# PCI IDE chipsets support ++# ++CONFIG_BLK_DEV_IDEPCI=y ++# CONFIG_IDEPCI_SHARE_IRQ is not set ++CONFIG_IDEPCI_PCIBUS_ORDER=y ++# CONFIG_BLK_DEV_GENERIC is not set ++# CONFIG_BLK_DEV_OPTI621 is not set ++CONFIG_BLK_DEV_IDEDMA_PCI=y ++# CONFIG_BLK_DEV_AEC62XX is not set ++# CONFIG_BLK_DEV_ALI15X3 is not set ++# CONFIG_BLK_DEV_AMD74XX is not set ++# CONFIG_BLK_DEV_CMD64X is not set ++# CONFIG_BLK_DEV_TRIFLEX is not set ++# CONFIG_BLK_DEV_CY82C693 is not set ++# CONFIG_BLK_DEV_CS5520 is not set ++# CONFIG_BLK_DEV_CS5530 is not set ++# CONFIG_BLK_DEV_HPT34X is not set ++# CONFIG_BLK_DEV_HPT366 is not set ++# CONFIG_BLK_DEV_JMICRON is not set ++# CONFIG_BLK_DEV_SC1200 is not set ++# CONFIG_BLK_DEV_PIIX is not set ++# CONFIG_BLK_DEV_IT8213 is not set ++# CONFIG_BLK_DEV_IT821X is not set ++# CONFIG_BLK_DEV_NS87415 is not set ++# CONFIG_BLK_DEV_PDC202XX_OLD is not set ++# CONFIG_BLK_DEV_PDC202XX_NEW is not set ++# CONFIG_BLK_DEV_SVWKS is not set ++# CONFIG_BLK_DEV_SIIMAGE is not set ++# CONFIG_BLK_DEV_SL82C105 is not set ++# CONFIG_BLK_DEV_SLC90E66 is not set ++# CONFIG_BLK_DEV_TRM290 is not set ++CONFIG_BLK_DEV_VIA82CXXX=y ++# CONFIG_BLK_DEV_TC86C001 is not set ++# CONFIG_IDE_ARM is not set ++CONFIG_BLK_DEV_IDEDMA=y ++CONFIG_IDE_ARCH_OBSOLETE_INIT=y ++# CONFIG_BLK_DEV_HD is not set ++ ++# ++# SCSI device support ++# ++# CONFIG_RAID_ATTRS is not set ++CONFIG_SCSI=y ++CONFIG_SCSI_DMA=y ++# CONFIG_SCSI_TGT is not set ++# CONFIG_SCSI_NETLINK is not set ++CONFIG_SCSI_PROC_FS=y ++ ++# ++# SCSI support type (disk, tape, CD-ROM) ++# ++CONFIG_BLK_DEV_SD=y ++# CONFIG_CHR_DEV_ST is not set ++# CONFIG_CHR_DEV_OSST is not set ++CONFIG_BLK_DEV_SR=y ++# CONFIG_BLK_DEV_SR_VENDOR is not set ++# CONFIG_CHR_DEV_SG is not set ++# CONFIG_CHR_DEV_SCH is not set ++ ++# ++# Some SCSI devices (e.g. CD jukebox) support multiple LUNs ++# ++# CONFIG_SCSI_MULTI_LUN is not set ++# CONFIG_SCSI_CONSTANTS is not set ++# CONFIG_SCSI_LOGGING is not set ++# CONFIG_SCSI_SCAN_ASYNC is not set ++CONFIG_SCSI_WAIT_SCAN=m ++ ++# ++# SCSI Transports ++# ++CONFIG_SCSI_SPI_ATTRS=y ++# CONFIG_SCSI_FC_ATTRS is not set ++# CONFIG_SCSI_ISCSI_ATTRS is not set ++# CONFIG_SCSI_SAS_LIBSAS is not set ++# CONFIG_SCSI_SRP_ATTRS is not set ++CONFIG_SCSI_LOWLEVEL=y ++# CONFIG_ISCSI_TCP is not set ++# CONFIG_BLK_DEV_3W_XXXX_RAID is not set ++# CONFIG_SCSI_3W_9XXX is not set ++# CONFIG_SCSI_ACARD is not set ++# CONFIG_SCSI_AACRAID is not set ++# CONFIG_SCSI_AIC7XXX is not set ++# CONFIG_SCSI_AIC7XXX_OLD is not set ++# CONFIG_SCSI_AIC79XX is not set ++# CONFIG_SCSI_AIC94XX is not set ++# CONFIG_SCSI_DPT_I2O is not set ++# CONFIG_SCSI_ADVANSYS is not set ++# CONFIG_SCSI_ARCMSR is not set ++# CONFIG_MEGARAID_NEWGEN is not set ++# CONFIG_MEGARAID_LEGACY is not set ++# CONFIG_MEGARAID_SAS is not set ++# CONFIG_SCSI_HPTIOP is not set ++# CONFIG_SCSI_BUSLOGIC is not set ++# CONFIG_SCSI_DMX3191D is not set ++# CONFIG_SCSI_EATA is not set ++# CONFIG_SCSI_FUTURE_DOMAIN is not set ++# CONFIG_SCSI_GDTH is not set ++# CONFIG_SCSI_IPS is not set ++# CONFIG_SCSI_INITIO is not set ++# CONFIG_SCSI_INIA100 is not set ++# CONFIG_SCSI_STEX is not set ++# CONFIG_SCSI_SYM53C8XX_2 is not set ++# CONFIG_SCSI_QLOGIC_1280 is not set ++# CONFIG_SCSI_QLA_FC is not set ++# CONFIG_SCSI_QLA_ISCSI is not set ++# CONFIG_SCSI_LPFC is not set ++# CONFIG_SCSI_DC395x is not set ++# CONFIG_SCSI_DC390T is not set ++# CONFIG_SCSI_NSP32 is not set ++# CONFIG_SCSI_DEBUG is not set ++# CONFIG_SCSI_SRP is not set ++# CONFIG_ATA is not set ++CONFIG_MD=y ++CONFIG_BLK_DEV_MD=y ++CONFIG_MD_LINEAR=y ++CONFIG_MD_RAID0=y ++CONFIG_MD_RAID1=y ++# CONFIG_MD_RAID10 is not set ++CONFIG_MD_RAID456=y ++CONFIG_MD_RAID5_RESHAPE=y ++# CONFIG_MD_MULTIPATH is not set ++# CONFIG_MD_FAULTY is not set ++# CONFIG_BLK_DEV_DM is not set ++# CONFIG_FUSION is not set ++ ++# ++# IEEE 1394 (FireWire) support ++# ++# CONFIG_FIREWIRE is not set ++# CONFIG_IEEE1394 is not set ++# CONFIG_I2O is not set ++# CONFIG_MACINTOSH_DRIVERS is not set ++CONFIG_NETDEVICES=y ++# CONFIG_NETDEVICES_MULTIQUEUE is not set ++CONFIG_DUMMY=m ++# CONFIG_BONDING is not set ++# CONFIG_MACVLAN is not set ++# CONFIG_EQUALIZER is not set ++# CONFIG_TUN is not set ++# CONFIG_VETH is not set ++# CONFIG_IP1000 is not set ++# CONFIG_ARCNET is not set ++# CONFIG_NET_ETHERNET is not set ++CONFIG_NETDEV_1000=y ++# CONFIG_ACENIC is not set ++# CONFIG_DL2K is not set ++# CONFIG_E1000 is not set ++# CONFIG_E1000E is not set ++# CONFIG_NS83820 is not set ++# CONFIG_HAMACHI is not set ++# CONFIG_YELLOWFIN is not set ++CONFIG_R8169=y ++# CONFIG_R8169_NAPI is not set ++# CONFIG_SIS190 is not set ++# CONFIG_SKGE is not set ++# CONFIG_SKY2 is not set ++# CONFIG_SK98LIN is not set ++# CONFIG_VIA_VELOCITY is not set ++# CONFIG_TIGON3 is not set ++# CONFIG_BNX2 is not set ++# CONFIG_MV643XX_ETH is not set ++# CONFIG_QLA3XXX is not set ++# CONFIG_ATL1 is not set ++# CONFIG_NETDEV_10000 is not set ++# CONFIG_TR is not set ++ ++# ++# Wireless LAN ++# ++# CONFIG_WLAN_PRE80211 is not set ++# CONFIG_WLAN_80211 is not set ++ ++# ++# USB Network Adapters ++# ++# CONFIG_USB_CATC is not set ++# CONFIG_USB_KAWETH is not set ++# CONFIG_USB_PEGASUS is not set ++# CONFIG_USB_RTL8150 is not set ++# CONFIG_USB_USBNET is not set ++# CONFIG_WAN is not set ++# CONFIG_FDDI is not set ++# CONFIG_HIPPI is not set ++# CONFIG_PPP is not set ++# CONFIG_SLIP is not set ++# CONFIG_NET_FC is not set ++# CONFIG_SHAPER is not set ++# CONFIG_NETCONSOLE is not set ++# CONFIG_NETPOLL is not set ++# CONFIG_NET_POLL_CONTROLLER is not set ++# CONFIG_ISDN is not set ++# CONFIG_PHONE is not set ++ ++# ++# Input device support ++# ++# CONFIG_INPUT is not set ++ ++# ++# Hardware I/O ports ++# ++# CONFIG_SERIO is not set ++# CONFIG_GAMEPORT is not set ++ ++# ++# Character devices ++# ++# CONFIG_VT is not set ++# CONFIG_SERIAL_NONSTANDARD is not set ++ ++# ++# Serial drivers ++# ++CONFIG_SERIAL_8250=y ++CONFIG_SERIAL_8250_CONSOLE=y ++# CONFIG_SERIAL_8250_PCI is not set ++CONFIG_SERIAL_8250_NR_UARTS=2 ++CONFIG_SERIAL_8250_RUNTIME_UARTS=2 ++# CONFIG_SERIAL_8250_EXTENDED is not set ++ ++# ++# Non-8250 serial port support ++# ++# CONFIG_SERIAL_UARTLITE is not set ++CONFIG_SERIAL_CORE=y ++CONFIG_SERIAL_CORE_CONSOLE=y ++# CONFIG_SERIAL_JSM is not set ++# CONFIG_SERIAL_OF_PLATFORM is not set ++CONFIG_UNIX98_PTYS=y ++CONFIG_LEGACY_PTYS=y ++CONFIG_LEGACY_PTY_COUNT=256 ++# CONFIG_IPMI_HANDLER is not set ++CONFIG_HW_RANDOM=m ++CONFIG_NVRAM=y ++CONFIG_GEN_RTC=y ++# CONFIG_GEN_RTC_X is not set ++# CONFIG_R3964 is not set ++# CONFIG_APPLICOM is not set ++# CONFIG_RAW_DRIVER is not set ++# CONFIG_TCG_TPM is not set ++CONFIG_DEVPORT=y ++CONFIG_I2C=y ++CONFIG_I2C_BOARDINFO=y ++CONFIG_I2C_CHARDEV=y ++ ++# ++# I2C Algorithms ++# ++# CONFIG_I2C_ALGOBIT is not set ++# CONFIG_I2C_ALGOPCF is not set ++# CONFIG_I2C_ALGOPCA is not set ++ ++# ++# I2C Hardware Bus support ++# ++# CONFIG_I2C_ALI1535 is not set ++# CONFIG_I2C_ALI1563 is not set ++# CONFIG_I2C_ALI15X3 is not set ++# CONFIG_I2C_AMD756 is not set ++# CONFIG_I2C_AMD8111 is not set ++# CONFIG_I2C_I801 is not set ++# CONFIG_I2C_I810 is not set ++# CONFIG_I2C_PIIX4 is not set ++CONFIG_I2C_MPC=y ++# CONFIG_I2C_NFORCE2 is not set ++# CONFIG_I2C_OCORES is not set ++# CONFIG_I2C_PARPORT_LIGHT is not set ++# CONFIG_I2C_PROSAVAGE is not set ++# CONFIG_I2C_SAVAGE4 is not set ++# CONFIG_I2C_SIMTEC is not set ++# CONFIG_I2C_SIS5595 is not set ++# CONFIG_I2C_SIS630 is not set ++# CONFIG_I2C_SIS96X is not set ++# CONFIG_I2C_TAOS_EVM is not set ++# CONFIG_I2C_STUB is not set ++# CONFIG_I2C_TINY_USB is not set ++# CONFIG_I2C_VIA is not set ++# CONFIG_I2C_VIAPRO is not set ++# CONFIG_I2C_VOODOO3 is not set ++ ++# ++# Miscellaneous I2C Chip support ++# ++# CONFIG_SENSORS_DS1337 is not set ++# CONFIG_SENSORS_DS1374 is not set ++# CONFIG_DS1682 is not set ++# CONFIG_SENSORS_EEPROM is not set ++# CONFIG_SENSORS_PCF8574 is not set ++# CONFIG_SENSORS_PCA9539 is not set ++# CONFIG_SENSORS_PCF8591 is not set ++# CONFIG_SENSORS_M41T00 is not set ++# CONFIG_SENSORS_MAX6875 is not set ++# CONFIG_SENSORS_TSL2550 is not set ++# CONFIG_I2C_DEBUG_CORE is not set ++# CONFIG_I2C_DEBUG_ALGO is not set ++# CONFIG_I2C_DEBUG_BUS is not set ++# CONFIG_I2C_DEBUG_CHIP is not set ++ ++# ++# SPI support ++# ++# CONFIG_SPI is not set ++# CONFIG_SPI_MASTER is not set ++# CONFIG_W1 is not set ++# CONFIG_POWER_SUPPLY is not set ++# CONFIG_HWMON is not set ++# CONFIG_WATCHDOG is not set ++ ++# ++# Sonics Silicon Backplane ++# ++CONFIG_SSB_POSSIBLE=y ++# CONFIG_SSB is not set ++ ++# ++# Multifunction device drivers ++# ++# CONFIG_MFD_SM501 is not set ++ ++# ++# Multimedia devices ++# ++# CONFIG_VIDEO_DEV is not set ++# CONFIG_DVB_CORE is not set ++# CONFIG_DAB is not set ++ ++# ++# Graphics support ++# ++# CONFIG_AGP is not set ++# CONFIG_DRM is not set ++# CONFIG_VGASTATE is not set ++# CONFIG_VIDEO_OUTPUT_CONTROL is not set ++# CONFIG_FB is not set ++# CONFIG_BACKLIGHT_LCD_SUPPORT is not set ++ ++# ++# Display device support ++# ++# CONFIG_DISPLAY_SUPPORT is not set ++ ++# ++# Sound ++# ++# CONFIG_SOUND is not set ++CONFIG_USB_SUPPORT=y ++CONFIG_USB_ARCH_HAS_HCD=y ++CONFIG_USB_ARCH_HAS_OHCI=y ++CONFIG_USB_ARCH_HAS_EHCI=y ++CONFIG_USB=y ++# CONFIG_USB_DEBUG is not set ++ ++# ++# Miscellaneous USB options ++# ++CONFIG_USB_DEVICEFS=y ++CONFIG_USB_DEVICE_CLASS=y ++# CONFIG_USB_DYNAMIC_MINORS is not set ++# CONFIG_USB_OTG is not set ++ ++# ++# USB Host Controller Drivers ++# ++CONFIG_USB_EHCI_HCD=y ++# CONFIG_USB_EHCI_SPLIT_ISO is not set ++# CONFIG_USB_EHCI_ROOT_HUB_TT is not set ++# CONFIG_USB_EHCI_TT_NEWSCHED is not set ++# CONFIG_USB_ISP116X_HCD is not set ++CONFIG_USB_OHCI_HCD=y ++# CONFIG_USB_OHCI_HCD_PPC_OF is not set ++# CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set ++# CONFIG_USB_OHCI_BIG_ENDIAN_MMIO is not set ++CONFIG_USB_OHCI_LITTLE_ENDIAN=y ++# CONFIG_USB_UHCI_HCD is not set ++# CONFIG_USB_SL811_HCD is not set ++# CONFIG_USB_R8A66597_HCD is not set ++ ++# ++# USB Device Class drivers ++# ++# CONFIG_USB_ACM is not set ++# CONFIG_USB_PRINTER is not set ++ ++# ++# NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' ++# ++ ++# ++# may also be needed; see USB_STORAGE Help for more information ++# ++CONFIG_USB_STORAGE=y ++# CONFIG_USB_STORAGE_DEBUG is not set ++# CONFIG_USB_STORAGE_DATAFAB is not set ++# CONFIG_USB_STORAGE_FREECOM is not set ++# CONFIG_USB_STORAGE_ISD200 is not set ++# CONFIG_USB_STORAGE_DPCM is not set ++# CONFIG_USB_STORAGE_USBAT is not set ++# CONFIG_USB_STORAGE_SDDR09 is not set ++# CONFIG_USB_STORAGE_SDDR55 is not set ++# CONFIG_USB_STORAGE_JUMPSHOT is not set ++# CONFIG_USB_STORAGE_ALAUDA is not set ++# CONFIG_USB_STORAGE_KARMA is not set ++# CONFIG_USB_LIBUSUAL is not set ++ ++# ++# USB Imaging devices ++# ++# CONFIG_USB_MDC800 is not set ++# CONFIG_USB_MICROTEK is not set ++# CONFIG_USB_MON is not set ++ ++# ++# USB port drivers ++# ++ ++# ++# USB Serial Converter support ++# ++# CONFIG_USB_SERIAL is not set ++ ++# ++# USB Miscellaneous drivers ++# ++# CONFIG_USB_EMI62 is not set ++# CONFIG_USB_EMI26 is not set ++# CONFIG_USB_ADUTUX is not set ++# CONFIG_USB_AUERSWALD is not set ++# CONFIG_USB_RIO500 is not set ++# CONFIG_USB_LEGOTOWER is not set ++# CONFIG_USB_LCD is not set ++# CONFIG_USB_BERRY_CHARGE is not set ++# CONFIG_USB_LED is not set ++# CONFIG_USB_CYPRESS_CY7C63 is not set ++# CONFIG_USB_CYTHERM is not set ++# CONFIG_USB_PHIDGET is not set ++# CONFIG_USB_IDMOUSE is not set ++# CONFIG_USB_FTDI_ELAN is not set ++# CONFIG_USB_APPLEDISPLAY is not set ++# CONFIG_USB_SISUSBVGA is not set ++# CONFIG_USB_LD is not set ++# CONFIG_USB_TRANCEVIBRATOR is not set ++# CONFIG_USB_IOWARRIOR is not set ++# CONFIG_USB_TEST is not set ++ ++# ++# USB DSL modem support ++# ++ ++# ++# USB Gadget Support ++# ++# CONFIG_USB_GADGET is not set ++# CONFIG_MMC is not set ++# CONFIG_NEW_LEDS is not set ++# CONFIG_INFINIBAND is not set ++# CONFIG_EDAC is not set ++CONFIG_RTC_LIB=y ++CONFIG_RTC_CLASS=y ++CONFIG_RTC_HCTOSYS=y ++CONFIG_RTC_HCTOSYS_DEVICE="rtc0" ++# CONFIG_RTC_DEBUG is not set ++ ++# ++# RTC interfaces ++# ++CONFIG_RTC_INTF_SYSFS=y ++CONFIG_RTC_INTF_PROC=y ++CONFIG_RTC_INTF_DEV=y ++# CONFIG_RTC_INTF_DEV_UIE_EMUL is not set ++# CONFIG_RTC_DRV_TEST is not set ++ ++# ++# I2C RTC drivers ++# ++CONFIG_RTC_DRV_DS1307=y ++# CONFIG_RTC_DRV_DS1374 is not set ++# CONFIG_RTC_DRV_DS1672 is not set ++# CONFIG_RTC_DRV_MAX6900 is not set ++# CONFIG_RTC_DRV_RS5C372 is not set ++# CONFIG_RTC_DRV_ISL1208 is not set ++# CONFIG_RTC_DRV_X1205 is not set ++# CONFIG_RTC_DRV_PCF8563 is not set ++# CONFIG_RTC_DRV_PCF8583 is not set ++# CONFIG_RTC_DRV_M41T80 is not set ++ ++# ++# SPI RTC drivers ++# ++ ++# ++# Platform RTC drivers ++# ++# CONFIG_RTC_DRV_CMOS is not set ++# CONFIG_RTC_DRV_DS1553 is not set ++# CONFIG_RTC_DRV_STK17TA8 is not set ++# CONFIG_RTC_DRV_DS1742 is not set ++# CONFIG_RTC_DRV_M48T86 is not set ++# CONFIG_RTC_DRV_M48T59 is not set ++# CONFIG_RTC_DRV_V3020 is not set ++ ++# ++# on-CPU RTC drivers ++# ++ ++# ++# Userspace I/O ++# ++# CONFIG_UIO is not set ++ ++# ++# File systems ++# ++CONFIG_EXT2_FS=y ++# CONFIG_EXT2_FS_XATTR is not set ++# CONFIG_EXT2_FS_XIP is not set ++CONFIG_EXT3_FS=y ++CONFIG_EXT3_FS_XATTR=y ++# CONFIG_EXT3_FS_POSIX_ACL is not set ++# CONFIG_EXT3_FS_SECURITY is not set ++# CONFIG_EXT4DEV_FS is not set ++CONFIG_JBD=y ++CONFIG_FS_MBCACHE=y ++# CONFIG_REISERFS_FS is not set ++# CONFIG_JFS_FS is not set ++# CONFIG_FS_POSIX_ACL is not set ++CONFIG_XFS_FS=m ++# CONFIG_XFS_QUOTA is not set ++# CONFIG_XFS_SECURITY is not set ++# CONFIG_XFS_POSIX_ACL is not set ++# CONFIG_XFS_RT is not set ++# CONFIG_GFS2_FS is not set ++# CONFIG_OCFS2_FS is not set ++# CONFIG_MINIX_FS is not set ++# CONFIG_ROMFS_FS is not set ++CONFIG_INOTIFY=y ++CONFIG_INOTIFY_USER=y ++# CONFIG_QUOTA is not set ++CONFIG_DNOTIFY=y ++# CONFIG_AUTOFS_FS is not set ++# CONFIG_AUTOFS4_FS is not set ++# CONFIG_FUSE_FS is not set ++ ++# ++# CD-ROM/DVD Filesystems ++# ++# CONFIG_ISO9660_FS is not set ++# CONFIG_UDF_FS is not set ++ ++# ++# DOS/FAT/NT Filesystems ++# ++# CONFIG_MSDOS_FS is not set ++# CONFIG_VFAT_FS is not set ++# CONFIG_NTFS_FS is not set ++ ++# ++# Pseudo filesystems ++# ++CONFIG_PROC_FS=y ++CONFIG_PROC_KCORE=y ++CONFIG_PROC_SYSCTL=y ++CONFIG_SYSFS=y ++CONFIG_TMPFS=y ++# CONFIG_TMPFS_POSIX_ACL is not set ++# CONFIG_HUGETLB_PAGE is not set ++# CONFIG_CONFIGFS_FS is not set ++ ++# ++# Miscellaneous filesystems ++# ++# CONFIG_ADFS_FS is not set ++# CONFIG_AFFS_FS is not set ++# CONFIG_HFS_FS is not set ++# CONFIG_HFSPLUS_FS is not set ++# CONFIG_BEFS_FS is not set ++# CONFIG_BFS_FS is not set ++# CONFIG_EFS_FS is not set ++CONFIG_JFFS2_FS=y ++CONFIG_JFFS2_FS_DEBUG=0 ++CONFIG_JFFS2_FS_WRITEBUFFER=y ++# CONFIG_JFFS2_FS_WBUF_VERIFY is not set ++# CONFIG_JFFS2_SUMMARY is not set ++# CONFIG_JFFS2_FS_XATTR is not set ++# CONFIG_JFFS2_COMPRESSION_OPTIONS is not set ++CONFIG_JFFS2_ZLIB=y ++# CONFIG_JFFS2_LZO is not set ++CONFIG_JFFS2_RTIME=y ++# CONFIG_JFFS2_RUBIN is not set ++# CONFIG_CRAMFS is not set ++# CONFIG_VXFS_FS is not set ++# CONFIG_HPFS_FS is not set ++# CONFIG_QNX4FS_FS is not set ++# CONFIG_SYSV_FS is not set ++# CONFIG_UFS_FS is not set ++# CONFIG_NETWORK_FILESYSTEMS is not set ++ ++# ++# Partition Types ++# ++CONFIG_PARTITION_ADVANCED=y ++# CONFIG_ACORN_PARTITION is not set ++# CONFIG_OSF_PARTITION is not set ++# CONFIG_AMIGA_PARTITION is not set ++# CONFIG_ATARI_PARTITION is not set ++# CONFIG_MAC_PARTITION is not set ++CONFIG_MSDOS_PARTITION=y ++# CONFIG_BSD_DISKLABEL is not set ++# CONFIG_MINIX_SUBPARTITION is not set ++# CONFIG_SOLARIS_X86_PARTITION is not set ++# CONFIG_UNIXWARE_DISKLABEL is not set ++# CONFIG_LDM_PARTITION is not set ++# CONFIG_SGI_PARTITION is not set ++# CONFIG_ULTRIX_PARTITION is not set ++# CONFIG_SUN_PARTITION is not set ++# CONFIG_KARMA_PARTITION is not set ++# CONFIG_EFI_PARTITION is not set ++# CONFIG_SYSV68_PARTITION is not set ++CONFIG_NLS=y ++CONFIG_NLS_DEFAULT="utf8" ++CONFIG_NLS_CODEPAGE_437=y ++# CONFIG_NLS_CODEPAGE_737 is not set ++# CONFIG_NLS_CODEPAGE_775 is not set ++# CONFIG_NLS_CODEPAGE_850 is not set ++# CONFIG_NLS_CODEPAGE_852 is not set ++# CONFIG_NLS_CODEPAGE_855 is not set ++# CONFIG_NLS_CODEPAGE_857 is not set ++# CONFIG_NLS_CODEPAGE_860 is not set ++# CONFIG_NLS_CODEPAGE_861 is not set ++# CONFIG_NLS_CODEPAGE_862 is not set ++# CONFIG_NLS_CODEPAGE_863 is not set ++# CONFIG_NLS_CODEPAGE_864 is not set ++# CONFIG_NLS_CODEPAGE_865 is not set ++# CONFIG_NLS_CODEPAGE_866 is not set ++# CONFIG_NLS_CODEPAGE_869 is not set ++# CONFIG_NLS_CODEPAGE_936 is not set ++# CONFIG_NLS_CODEPAGE_950 is not set ++# CONFIG_NLS_CODEPAGE_932 is not set ++# CONFIG_NLS_CODEPAGE_949 is not set ++# CONFIG_NLS_CODEPAGE_874 is not set ++# CONFIG_NLS_ISO8859_8 is not set ++# CONFIG_NLS_CODEPAGE_1250 is not set ++# CONFIG_NLS_CODEPAGE_1251 is not set ++# CONFIG_NLS_ASCII is not set ++CONFIG_NLS_ISO8859_1=y ++# CONFIG_NLS_ISO8859_2 is not set ++# CONFIG_NLS_ISO8859_3 is not set ++# CONFIG_NLS_ISO8859_4 is not set ++# CONFIG_NLS_ISO8859_5 is not set ++# CONFIG_NLS_ISO8859_6 is not set ++# CONFIG_NLS_ISO8859_7 is not set ++# CONFIG_NLS_ISO8859_9 is not set ++# CONFIG_NLS_ISO8859_13 is not set ++# CONFIG_NLS_ISO8859_14 is not set ++# CONFIG_NLS_ISO8859_15 is not set ++# CONFIG_NLS_KOI8_R is not set ++# CONFIG_NLS_KOI8_U is not set ++CONFIG_NLS_UTF8=y ++# CONFIG_DLM is not set ++# CONFIG_UCC_SLOW is not set ++ ++# ++# Library routines ++# ++CONFIG_BITREVERSE=y ++# CONFIG_CRC_CCITT is not set ++# CONFIG_CRC16 is not set ++# CONFIG_CRC_ITU_T is not set ++CONFIG_CRC32=y ++# CONFIG_CRC7 is not set ++# CONFIG_LIBCRC32C is not set ++CONFIG_ZLIB_INFLATE=y ++CONFIG_ZLIB_DEFLATE=y ++CONFIG_PLIST=y ++CONFIG_HAS_IOMEM=y ++CONFIG_HAS_IOPORT=y ++CONFIG_HAS_DMA=y ++CONFIG_INSTRUMENTATION=y ++# CONFIG_PROFILING is not set ++# CONFIG_MARKERS is not set ++ ++# ++# Kernel hacking ++# ++# CONFIG_PRINTK_TIME is not set ++# CONFIG_ENABLE_WARN_DEPRECATED is not set ++# CONFIG_ENABLE_MUST_CHECK is not set ++# CONFIG_MAGIC_SYSRQ is not set ++# CONFIG_UNUSED_SYMBOLS is not set ++# CONFIG_DEBUG_FS is not set ++# CONFIG_HEADERS_CHECK is not set ++# CONFIG_DEBUG_KERNEL is not set ++# CONFIG_SLUB_DEBUG_ON is not set ++# CONFIG_DEBUG_BUGVERBOSE is not set ++# CONFIG_SAMPLES is not set ++# CONFIG_BOOTX_TEXT is not set ++# CONFIG_PPC_EARLY_DEBUG is not set ++ ++# ++# Security options ++# ++# CONFIG_KEYS is not set ++# CONFIG_SECURITY is not set ++# CONFIG_SECURITY_FILE_CAPABILITIES is not set ++CONFIG_XOR_BLOCKS=y ++CONFIG_ASYNC_CORE=y ++CONFIG_ASYNC_MEMCPY=y ++CONFIG_ASYNC_XOR=y ++# CONFIG_CRYPTO is not set ++# CONFIG_PPC_CLOCK is not set +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/taishan_defconfig powerpc.git/arch/powerpc/configs/taishan_defconfig +--- linux-2.6.24/arch/powerpc/configs/taishan_defconfig 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/taishan_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,790 @@ ++# ++# Automatically generated make config: don't edit ++# Linux kernel version: 2.6.24-rc6 ++# Mon Dec 24 11:23:39 2007 ++# ++# CONFIG_PPC64 is not set ++ ++# ++# Processor support ++# ++# CONFIG_6xx is not set ++# CONFIG_PPC_85xx is not set ++# CONFIG_PPC_8xx is not set ++# CONFIG_40x is not set ++CONFIG_44x=y ++# CONFIG_E200 is not set ++CONFIG_4xx=y ++CONFIG_BOOKE=y ++CONFIG_PTE_64BIT=y ++CONFIG_PHYS_64BIT=y ++# CONFIG_PPC_MM_SLICES is not set ++CONFIG_NOT_COHERENT_CACHE=y ++CONFIG_PPC32=y ++CONFIG_WORD_SIZE=32 ++CONFIG_PPC_MERGE=y ++CONFIG_MMU=y ++CONFIG_GENERIC_CMOS_UPDATE=y ++CONFIG_GENERIC_TIME=y ++CONFIG_GENERIC_TIME_VSYSCALL=y ++CONFIG_GENERIC_CLOCKEVENTS=y ++CONFIG_GENERIC_HARDIRQS=y ++CONFIG_IRQ_PER_CPU=y ++CONFIG_RWSEM_XCHGADD_ALGORITHM=y ++CONFIG_ARCH_HAS_ILOG2_U32=y ++CONFIG_GENERIC_HWEIGHT=y ++CONFIG_GENERIC_CALIBRATE_DELAY=y ++CONFIG_GENERIC_FIND_NEXT_BIT=y ++# CONFIG_ARCH_NO_VIRT_TO_BUS is not set ++CONFIG_PPC=y ++CONFIG_EARLY_PRINTK=y ++CONFIG_GENERIC_NVRAM=y ++CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y ++CONFIG_ARCH_MAY_HAVE_PC_FDC=y ++CONFIG_PPC_OF=y ++CONFIG_OF=y ++CONFIG_PPC_UDBG_16550=y ++# CONFIG_GENERIC_TBSYNC is not set ++CONFIG_AUDIT_ARCH=y ++CONFIG_GENERIC_BUG=y ++# CONFIG_DEFAULT_UIMAGE is not set ++CONFIG_PPC_DCR_NATIVE=y ++# CONFIG_PPC_DCR_MMIO is not set ++CONFIG_PPC_DCR=y ++CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" ++ ++# ++# General setup ++# ++CONFIG_EXPERIMENTAL=y ++CONFIG_BROKEN_ON_SMP=y ++CONFIG_INIT_ENV_ARG_LIMIT=32 ++CONFIG_LOCALVERSION="" ++CONFIG_LOCALVERSION_AUTO=y ++CONFIG_SWAP=y ++CONFIG_SYSVIPC=y ++CONFIG_SYSVIPC_SYSCTL=y ++CONFIG_POSIX_MQUEUE=y ++# CONFIG_BSD_PROCESS_ACCT is not set ++# CONFIG_TASKSTATS is not set ++# CONFIG_USER_NS is not set ++# CONFIG_PID_NS is not set ++# CONFIG_AUDIT is not set ++# CONFIG_IKCONFIG is not set ++CONFIG_LOG_BUF_SHIFT=14 ++# CONFIG_CGROUPS is not set ++CONFIG_FAIR_GROUP_SCHED=y ++CONFIG_FAIR_USER_SCHED=y ++# CONFIG_FAIR_CGROUP_SCHED is not set ++CONFIG_SYSFS_DEPRECATED=y ++# CONFIG_RELAY is not set ++CONFIG_BLK_DEV_INITRD=y ++CONFIG_INITRAMFS_SOURCE="" ++# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set ++CONFIG_SYSCTL=y ++CONFIG_EMBEDDED=y ++CONFIG_SYSCTL_SYSCALL=y ++CONFIG_KALLSYMS=y ++# CONFIG_KALLSYMS_ALL is not set ++# CONFIG_KALLSYMS_EXTRA_PASS is not set ++CONFIG_HOTPLUG=y ++CONFIG_PRINTK=y ++CONFIG_BUG=y ++CONFIG_ELF_CORE=y ++CONFIG_BASE_FULL=y ++CONFIG_FUTEX=y ++CONFIG_ANON_INODES=y ++CONFIG_EPOLL=y ++CONFIG_SIGNALFD=y ++CONFIG_EVENTFD=y ++CONFIG_SHMEM=y ++CONFIG_VM_EVENT_COUNTERS=y ++CONFIG_SLUB_DEBUG=y ++# CONFIG_SLAB is not set ++CONFIG_SLUB=y ++# CONFIG_SLOB is not set ++CONFIG_RT_MUTEXES=y ++# CONFIG_TINY_SHMEM is not set ++CONFIG_BASE_SMALL=0 ++CONFIG_MODULES=y ++CONFIG_MODULE_UNLOAD=y ++# CONFIG_MODULE_FORCE_UNLOAD is not set ++# CONFIG_MODVERSIONS is not set ++# CONFIG_MODULE_SRCVERSION_ALL is not set ++CONFIG_KMOD=y ++CONFIG_BLOCK=y ++CONFIG_LBD=y ++# CONFIG_BLK_DEV_IO_TRACE is not set ++# CONFIG_LSF is not set ++# CONFIG_BLK_DEV_BSG is not set ++ ++# ++# IO Schedulers ++# ++CONFIG_IOSCHED_NOOP=y ++CONFIG_IOSCHED_AS=y ++CONFIG_IOSCHED_DEADLINE=y ++CONFIG_IOSCHED_CFQ=y ++CONFIG_DEFAULT_AS=y ++# CONFIG_DEFAULT_DEADLINE is not set ++# CONFIG_DEFAULT_CFQ is not set ++# CONFIG_DEFAULT_NOOP is not set ++CONFIG_DEFAULT_IOSCHED="anticipatory" ++# CONFIG_PPC4xx_PCI_EXPRESS is not set ++ ++# ++# Platform support ++# ++# CONFIG_PPC_MPC52xx is not set ++# CONFIG_PPC_MPC5200 is not set ++# CONFIG_PPC_CELL is not set ++# CONFIG_PPC_CELL_NATIVE is not set ++# CONFIG_PQ2ADS is not set ++# CONFIG_BAMBOO is not set ++# CONFIG_EBONY is not set ++# CONFIG_SEQUOIA is not set ++CONFIG_TAISHAN=y ++# CONFIG_KATMAI is not set ++# CONFIG_RAINIER is not set ++CONFIG_440GX=y ++# CONFIG_MPIC is not set ++# CONFIG_MPIC_WEIRD is not set ++# CONFIG_PPC_I8259 is not set ++# CONFIG_PPC_RTAS is not set ++# CONFIG_MMIO_NVRAM is not set ++# CONFIG_PPC_MPC106 is not set ++# CONFIG_PPC_970_NAP is not set ++# CONFIG_PPC_INDIRECT_IO is not set ++# CONFIG_GENERIC_IOMAP is not set ++# CONFIG_CPU_FREQ is not set ++# CONFIG_CPM2 is not set ++# CONFIG_FSL_ULI1575 is not set ++ ++# ++# Kernel options ++# ++# CONFIG_HIGHMEM is not set ++# CONFIG_TICK_ONESHOT is not set ++# CONFIG_NO_HZ is not set ++# CONFIG_HIGH_RES_TIMERS is not set ++CONFIG_GENERIC_CLOCKEVENTS_BUILD=y ++# CONFIG_HZ_100 is not set ++CONFIG_HZ_250=y ++# CONFIG_HZ_300 is not set ++# CONFIG_HZ_1000 is not set ++CONFIG_HZ=250 ++CONFIG_PREEMPT_NONE=y ++# CONFIG_PREEMPT_VOLUNTARY is not set ++# CONFIG_PREEMPT is not set ++CONFIG_BINFMT_ELF=y ++# CONFIG_BINFMT_MISC is not set ++# CONFIG_MATH_EMULATION is not set ++CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y ++CONFIG_ARCH_FLATMEM_ENABLE=y ++CONFIG_ARCH_POPULATES_NODE_MAP=y ++CONFIG_SELECT_MEMORY_MODEL=y ++CONFIG_FLATMEM_MANUAL=y ++# CONFIG_DISCONTIGMEM_MANUAL is not set ++# CONFIG_SPARSEMEM_MANUAL is not set ++CONFIG_FLATMEM=y ++CONFIG_FLAT_NODE_MEM_MAP=y ++# CONFIG_SPARSEMEM_STATIC is not set ++# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set ++CONFIG_SPLIT_PTLOCK_CPUS=4 ++CONFIG_RESOURCES_64BIT=y ++CONFIG_ZONE_DMA_FLAG=1 ++CONFIG_BOUNCE=y ++CONFIG_VIRT_TO_BUS=y ++CONFIG_PROC_DEVICETREE=y ++CONFIG_CMDLINE_BOOL=y ++CONFIG_CMDLINE="" ++CONFIG_SECCOMP=y ++CONFIG_WANT_DEVICE_TREE=y ++CONFIG_DEVICE_TREE="taishan.dts" ++CONFIG_ISA_DMA_API=y ++ ++# ++# Bus options ++# ++CONFIG_ZONE_DMA=y ++CONFIG_PPC_INDIRECT_PCI=y ++CONFIG_PCI=y ++CONFIG_PCI_DOMAINS=y ++CONFIG_PCI_SYSCALL=y ++# CONFIG_PCIEPORTBUS is not set ++CONFIG_ARCH_SUPPORTS_MSI=y ++# CONFIG_PCI_MSI is not set ++CONFIG_PCI_LEGACY=y ++# CONFIG_PCI_DEBUG is not set ++# CONFIG_PCCARD is not set ++# CONFIG_HOTPLUG_PCI is not set ++ ++# ++# Advanced setup ++# ++# CONFIG_ADVANCED_OPTIONS is not set ++ ++# ++# Default settings for advanced configuration options are used ++# ++CONFIG_HIGHMEM_START=0xfe000000 ++CONFIG_LOWMEM_SIZE=0x30000000 ++CONFIG_KERNEL_START=0xc0000000 ++CONFIG_TASK_SIZE=0xc0000000 ++CONFIG_CONSISTENT_START=0xff100000 ++CONFIG_CONSISTENT_SIZE=0x00200000 ++CONFIG_BOOT_LOAD=0x01000000 ++ ++# ++# Networking ++# ++CONFIG_NET=y ++ ++# ++# Networking options ++# ++CONFIG_PACKET=y ++# CONFIG_PACKET_MMAP is not set ++CONFIG_UNIX=y ++# CONFIG_NET_KEY is not set ++CONFIG_INET=y ++# CONFIG_IP_MULTICAST is not set ++# CONFIG_IP_ADVANCED_ROUTER is not set ++CONFIG_IP_FIB_HASH=y ++CONFIG_IP_PNP=y ++CONFIG_IP_PNP_DHCP=y ++CONFIG_IP_PNP_BOOTP=y ++# CONFIG_IP_PNP_RARP is not set ++# CONFIG_NET_IPIP is not set ++# CONFIG_NET_IPGRE is not set ++# CONFIG_ARPD is not set ++# CONFIG_SYN_COOKIES is not set ++# CONFIG_INET_AH is not set ++# CONFIG_INET_ESP is not set ++# CONFIG_INET_IPCOMP is not set ++# CONFIG_INET_XFRM_TUNNEL is not set ++# CONFIG_INET_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_TRANSPORT is not set ++# CONFIG_INET_XFRM_MODE_TUNNEL is not set ++# CONFIG_INET_XFRM_MODE_BEET is not set ++# CONFIG_INET_LRO is not set ++CONFIG_INET_DIAG=y ++CONFIG_INET_TCP_DIAG=y ++# CONFIG_TCP_CONG_ADVANCED is not set ++CONFIG_TCP_CONG_CUBIC=y ++CONFIG_DEFAULT_TCP_CONG="cubic" ++# CONFIG_TCP_MD5SIG is not set ++# CONFIG_IPV6 is not set ++# CONFIG_INET6_XFRM_TUNNEL is not set ++# CONFIG_INET6_TUNNEL is not set ++# CONFIG_NETWORK_SECMARK is not set ++# CONFIG_NETFILTER is not set ++# CONFIG_IP_DCCP is not set ++# CONFIG_IP_SCTP is not set ++# CONFIG_TIPC is not set ++# CONFIG_ATM is not set ++# CONFIG_BRIDGE is not set ++# CONFIG_VLAN_8021Q is not set ++# CONFIG_DECNET is not set ++# CONFIG_LLC2 is not set ++# CONFIG_IPX is not set ++# CONFIG_ATALK is not set ++# CONFIG_X25 is not set ++# CONFIG_LAPB is not set ++# CONFIG_ECONET is not set ++# CONFIG_WAN_ROUTER is not set ++# CONFIG_NET_SCHED is not set ++ ++# ++# Network testing ++# ++# CONFIG_NET_PKTGEN is not set ++# CONFIG_HAMRADIO is not set ++# CONFIG_IRDA is not set ++# CONFIG_BT is not set ++# CONFIG_AF_RXRPC is not set ++ ++# ++# Wireless ++# ++# CONFIG_CFG80211 is not set ++# CONFIG_WIRELESS_EXT is not set ++# CONFIG_MAC80211 is not set ++# CONFIG_IEEE80211 is not set ++# CONFIG_RFKILL is not set ++# CONFIG_NET_9P is not set ++ ++# ++# Device Drivers ++# ++ ++# ++# Generic Driver Options ++# ++CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" ++CONFIG_STANDALONE=y ++CONFIG_PREVENT_FIRMWARE_BUILD=y ++CONFIG_FW_LOADER=y ++# CONFIG_DEBUG_DRIVER is not set ++# CONFIG_DEBUG_DEVRES is not set ++# CONFIG_SYS_HYPERVISOR is not set ++CONFIG_CONNECTOR=y ++CONFIG_PROC_EVENTS=y ++# CONFIG_MTD is not set ++CONFIG_OF_DEVICE=y ++# CONFIG_PARPORT is not set ++CONFIG_BLK_DEV=y ++# CONFIG_BLK_DEV_FD is not set ++# CONFIG_BLK_CPQ_DA is not set ++# CONFIG_BLK_CPQ_CISS_DA is not set ++# CONFIG_BLK_DEV_DAC960 is not set ++# CONFIG_BLK_DEV_UMEM is not set ++# CONFIG_BLK_DEV_COW_COMMON is not set ++# CONFIG_BLK_DEV_LOOP is not set ++# CONFIG_BLK_DEV_NBD is not set ++# CONFIG_BLK_DEV_SX8 is not set ++CONFIG_BLK_DEV_RAM=y ++CONFIG_BLK_DEV_RAM_COUNT=16 ++CONFIG_BLK_DEV_RAM_SIZE=35000 ++CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024 ++# CONFIG_CDROM_PKTCDVD is not set ++# CONFIG_ATA_OVER_ETH is not set ++# CONFIG_XILINX_SYSACE is not set ++CONFIG_MISC_DEVICES=y ++# CONFIG_PHANTOM is not set ++# CONFIG_EEPROM_93CX6 is not set ++# CONFIG_SGI_IOC4 is not set ++# CONFIG_TIFM_CORE is not set ++# CONFIG_IDE is not set ++ ++# ++# SCSI device support ++# ++# CONFIG_RAID_ATTRS is not set ++# CONFIG_SCSI is not set ++# CONFIG_SCSI_DMA is not set ++# CONFIG_SCSI_NETLINK is not set ++# CONFIG_ATA is not set ++# CONFIG_MD is not set ++# CONFIG_FUSION is not set ++ ++# ++# IEEE 1394 (FireWire) support ++# ++# CONFIG_FIREWIRE is not set ++# CONFIG_IEEE1394 is not set ++# CONFIG_I2O is not set ++CONFIG_MACINTOSH_DRIVERS=y ++# CONFIG_MAC_EMUMOUSEBTN is not set ++# CONFIG_WINDFARM is not set ++CONFIG_NETDEVICES=y ++# CONFIG_NETDEVICES_MULTIQUEUE is not set ++# CONFIG_DUMMY is not set ++# CONFIG_BONDING is not set ++# CONFIG_MACVLAN is not set ++# CONFIG_EQUALIZER is not set ++# CONFIG_TUN is not set ++# CONFIG_VETH is not set ++# CONFIG_IP1000 is not set ++# CONFIG_ARCNET is not set ++# CONFIG_PHYLIB is not set ++CONFIG_NET_ETHERNET=y ++# CONFIG_MII is not set ++# CONFIG_HAPPYMEAL is not set ++# CONFIG_SUNGEM is not set ++# CONFIG_CASSINI is not set ++# CONFIG_NET_VENDOR_3COM is not set ++# CONFIG_NET_TULIP is not set ++# CONFIG_HP100 is not set ++CONFIG_IBM_NEW_EMAC=y ++CONFIG_IBM_NEW_EMAC_RXB=128 ++CONFIG_IBM_NEW_EMAC_TXB=64 ++CONFIG_IBM_NEW_EMAC_POLL_WEIGHT=32 ++CONFIG_IBM_NEW_EMAC_RX_COPY_THRESHOLD=256 ++CONFIG_IBM_NEW_EMAC_RX_SKB_HEADROOM=0 ++# CONFIG_IBM_NEW_EMAC_DEBUG is not set ++CONFIG_IBM_NEW_EMAC_ZMII=y ++CONFIG_IBM_NEW_EMAC_RGMII=y ++CONFIG_IBM_NEW_EMAC_TAH=y ++CONFIG_IBM_NEW_EMAC_EMAC4=y ++# CONFIG_NET_PCI is not set ++# CONFIG_B44 is not set ++CONFIG_NETDEV_1000=y ++# CONFIG_ACENIC is not set ++# CONFIG_DL2K is not set ++# CONFIG_E1000 is not set ++# CONFIG_E1000E is not set ++# CONFIG_NS83820 is not set ++# CONFIG_HAMACHI is not set ++# CONFIG_YELLOWFIN is not set ++# CONFIG_R8169 is not set ++# CONFIG_SIS190 is not set ++# CONFIG_SKGE is not set ++# CONFIG_SKY2 is not set ++# CONFIG_SK98LIN is not set ++# CONFIG_VIA_VELOCITY is not set ++# CONFIG_TIGON3 is not set ++# CONFIG_BNX2 is not set ++# CONFIG_QLA3XXX is not set ++# CONFIG_ATL1 is not set ++CONFIG_NETDEV_10000=y ++# CONFIG_CHELSIO_T1 is not set ++# CONFIG_CHELSIO_T3 is not set ++# CONFIG_IXGBE is not set ++# CONFIG_IXGB is not set ++# CONFIG_S2IO is not set ++# CONFIG_MYRI10GE is not set ++# CONFIG_NETXEN_NIC is not set ++# CONFIG_NIU is not set ++# CONFIG_MLX4_CORE is not set ++# CONFIG_TEHUTI is not set ++# CONFIG_TR is not set ++ ++# ++# Wireless LAN ++# ++# CONFIG_WLAN_PRE80211 is not set ++# CONFIG_WLAN_80211 is not set ++# CONFIG_WAN is not set ++# CONFIG_FDDI is not set ++# CONFIG_HIPPI is not set ++# CONFIG_PPP is not set ++# CONFIG_SLIP is not set ++# CONFIG_SHAPER is not set ++# CONFIG_NETCONSOLE is not set ++# CONFIG_NETPOLL is not set ++# CONFIG_NET_POLL_CONTROLLER is not set ++# CONFIG_ISDN is not set ++# CONFIG_PHONE is not set ++ ++# ++# Input device support ++# ++# CONFIG_INPUT is not set ++ ++# ++# Hardware I/O ports ++# ++# CONFIG_SERIO is not set ++# CONFIG_GAMEPORT is not set ++ ++# ++# Character devices ++# ++# CONFIG_VT is not set ++# CONFIG_SERIAL_NONSTANDARD is not set ++ ++# ++# Serial drivers ++# ++CONFIG_SERIAL_8250=y ++CONFIG_SERIAL_8250_CONSOLE=y ++# CONFIG_SERIAL_8250_PCI is not set ++CONFIG_SERIAL_8250_NR_UARTS=4 ++CONFIG_SERIAL_8250_RUNTIME_UARTS=4 ++CONFIG_SERIAL_8250_EXTENDED=y ++# CONFIG_SERIAL_8250_MANY_PORTS is not set ++CONFIG_SERIAL_8250_SHARE_IRQ=y ++# CONFIG_SERIAL_8250_DETECT_IRQ is not set ++# CONFIG_SERIAL_8250_RSA is not set ++ ++# ++# Non-8250 serial port support ++# ++# CONFIG_SERIAL_UARTLITE is not set ++CONFIG_SERIAL_CORE=y ++CONFIG_SERIAL_CORE_CONSOLE=y ++# CONFIG_SERIAL_JSM is not set ++CONFIG_SERIAL_OF_PLATFORM=y ++CONFIG_UNIX98_PTYS=y ++CONFIG_LEGACY_PTYS=y ++CONFIG_LEGACY_PTY_COUNT=256 ++# CONFIG_IPMI_HANDLER is not set ++# CONFIG_HW_RANDOM is not set ++# CONFIG_NVRAM is not set ++# CONFIG_GEN_RTC is not set ++# CONFIG_R3964 is not set ++# CONFIG_APPLICOM is not set ++# CONFIG_RAW_DRIVER is not set ++# CONFIG_TCG_TPM is not set ++CONFIG_DEVPORT=y ++# CONFIG_I2C is not set ++ ++# ++# SPI support ++# ++# CONFIG_SPI is not set ++# CONFIG_SPI_MASTER is not set ++# CONFIG_W1 is not set ++# CONFIG_POWER_SUPPLY is not set ++# CONFIG_HWMON is not set ++# CONFIG_WATCHDOG is not set ++ ++# ++# Sonics Silicon Backplane ++# ++CONFIG_SSB_POSSIBLE=y ++# CONFIG_SSB is not set ++ ++# ++# Multifunction device drivers ++# ++# CONFIG_MFD_SM501 is not set ++ ++# ++# Multimedia devices ++# ++# CONFIG_VIDEO_DEV is not set ++# CONFIG_DVB_CORE is not set ++CONFIG_DAB=y ++ ++# ++# Graphics support ++# ++# CONFIG_AGP is not set ++# CONFIG_DRM is not set ++# CONFIG_VGASTATE is not set ++CONFIG_VIDEO_OUTPUT_CONTROL=m ++# CONFIG_FB is not set ++# CONFIG_BACKLIGHT_LCD_SUPPORT is not set ++ ++# ++# Display device support ++# ++# CONFIG_DISPLAY_SUPPORT is not set ++ ++# ++# Sound ++# ++# CONFIG_SOUND is not set ++CONFIG_USB_SUPPORT=y ++CONFIG_USB_ARCH_HAS_HCD=y ++CONFIG_USB_ARCH_HAS_OHCI=y ++CONFIG_USB_ARCH_HAS_EHCI=y ++# CONFIG_USB is not set ++ ++# ++# NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' ++# ++ ++# ++# USB Gadget Support ++# ++# CONFIG_USB_GADGET is not set ++# CONFIG_MMC is not set ++# CONFIG_NEW_LEDS is not set ++# CONFIG_INFINIBAND is not set ++# CONFIG_EDAC is not set ++# CONFIG_RTC_CLASS is not set ++ ++# ++# Userspace I/O ++# ++# CONFIG_UIO is not set ++ ++# ++# File systems ++# ++CONFIG_EXT2_FS=y ++# CONFIG_EXT2_FS_XATTR is not set ++# CONFIG_EXT2_FS_XIP is not set ++# CONFIG_EXT3_FS is not set ++# CONFIG_EXT4DEV_FS is not set ++# CONFIG_REISERFS_FS is not set ++# CONFIG_JFS_FS is not set ++# CONFIG_FS_POSIX_ACL is not set ++# CONFIG_XFS_FS is not set ++# CONFIG_GFS2_FS is not set ++# CONFIG_OCFS2_FS is not set ++# CONFIG_MINIX_FS is not set ++# CONFIG_ROMFS_FS is not set ++CONFIG_INOTIFY=y ++CONFIG_INOTIFY_USER=y ++# CONFIG_QUOTA is not set ++CONFIG_DNOTIFY=y ++# CONFIG_AUTOFS_FS is not set ++# CONFIG_AUTOFS4_FS is not set ++# CONFIG_FUSE_FS is not set ++ ++# ++# CD-ROM/DVD Filesystems ++# ++# CONFIG_ISO9660_FS is not set ++# CONFIG_UDF_FS is not set ++ ++# ++# DOS/FAT/NT Filesystems ++# ++# CONFIG_MSDOS_FS is not set ++# CONFIG_VFAT_FS is not set ++# CONFIG_NTFS_FS is not set ++ ++# ++# Pseudo filesystems ++# ++CONFIG_PROC_FS=y ++CONFIG_PROC_KCORE=y ++CONFIG_PROC_SYSCTL=y ++CONFIG_SYSFS=y ++CONFIG_TMPFS=y ++# CONFIG_TMPFS_POSIX_ACL is not set ++# CONFIG_HUGETLB_PAGE is not set ++# CONFIG_CONFIGFS_FS is not set ++ ++# ++# Miscellaneous filesystems ++# ++# CONFIG_ADFS_FS is not set ++# CONFIG_AFFS_FS is not set ++# CONFIG_HFS_FS is not set ++# CONFIG_HFSPLUS_FS is not set ++# CONFIG_BEFS_FS is not set ++# CONFIG_BFS_FS is not set ++# CONFIG_EFS_FS is not set ++CONFIG_CRAMFS=y ++# CONFIG_VXFS_FS is not set ++# CONFIG_HPFS_FS is not set ++# CONFIG_QNX4FS_FS is not set ++# CONFIG_SYSV_FS is not set ++# CONFIG_UFS_FS is not set ++CONFIG_NETWORK_FILESYSTEMS=y ++CONFIG_NFS_FS=y ++CONFIG_NFS_V3=y ++# CONFIG_NFS_V3_ACL is not set ++# CONFIG_NFS_V4 is not set ++# CONFIG_NFS_DIRECTIO is not set ++# CONFIG_NFSD is not set ++CONFIG_ROOT_NFS=y ++CONFIG_LOCKD=y ++CONFIG_LOCKD_V4=y ++CONFIG_NFS_COMMON=y ++CONFIG_SUNRPC=y ++# CONFIG_SUNRPC_BIND34 is not set ++# CONFIG_RPCSEC_GSS_KRB5 is not set ++# CONFIG_RPCSEC_GSS_SPKM3 is not set ++# CONFIG_SMB_FS is not set ++# CONFIG_CIFS is not set ++# CONFIG_NCP_FS is not set ++# CONFIG_CODA_FS is not set ++# CONFIG_AFS_FS is not set ++ ++# ++# Partition Types ++# ++# CONFIG_PARTITION_ADVANCED is not set ++CONFIG_MSDOS_PARTITION=y ++# CONFIG_NLS is not set ++# CONFIG_DLM is not set ++# CONFIG_UCC_SLOW is not set ++ ++# ++# Library routines ++# ++CONFIG_BITREVERSE=y ++# CONFIG_CRC_CCITT is not set ++# CONFIG_CRC16 is not set ++# CONFIG_CRC_ITU_T is not set ++CONFIG_CRC32=y ++# CONFIG_CRC7 is not set ++# CONFIG_LIBCRC32C is not set ++CONFIG_ZLIB_INFLATE=y ++CONFIG_PLIST=y ++CONFIG_HAS_IOMEM=y ++CONFIG_HAS_IOPORT=y ++CONFIG_HAS_DMA=y ++CONFIG_INSTRUMENTATION=y ++# CONFIG_PROFILING is not set ++# CONFIG_KPROBES is not set ++# CONFIG_MARKERS is not set ++ ++# ++# Kernel hacking ++# ++# CONFIG_PRINTK_TIME is not set ++CONFIG_ENABLE_WARN_DEPRECATED=y ++CONFIG_ENABLE_MUST_CHECK=y ++CONFIG_MAGIC_SYSRQ=y ++# CONFIG_UNUSED_SYMBOLS is not set ++# CONFIG_DEBUG_FS is not set ++# CONFIG_HEADERS_CHECK is not set ++CONFIG_DEBUG_KERNEL=y ++# CONFIG_DEBUG_SHIRQ is not set ++CONFIG_DETECT_SOFTLOCKUP=y ++CONFIG_SCHED_DEBUG=y ++# CONFIG_SCHEDSTATS is not set ++# CONFIG_TIMER_STATS is not set ++# CONFIG_SLUB_DEBUG_ON is not set ++# CONFIG_DEBUG_RT_MUTEXES is not set ++# CONFIG_RT_MUTEX_TESTER is not set ++# CONFIG_DEBUG_SPINLOCK is not set ++# CONFIG_DEBUG_MUTEXES is not set ++# CONFIG_DEBUG_SPINLOCK_SLEEP is not set ++# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set ++# CONFIG_DEBUG_KOBJECT is not set ++# CONFIG_DEBUG_BUGVERBOSE is not set ++# CONFIG_DEBUG_INFO is not set ++# CONFIG_DEBUG_VM is not set ++# CONFIG_DEBUG_LIST is not set ++# CONFIG_DEBUG_SG is not set ++CONFIG_FORCED_INLINING=y ++# CONFIG_BOOT_PRINTK_DELAY is not set ++# CONFIG_RCU_TORTURE_TEST is not set ++# CONFIG_FAULT_INJECTION is not set ++# CONFIG_SAMPLES is not set ++# CONFIG_DEBUG_STACKOVERFLOW is not set ++# CONFIG_DEBUG_STACK_USAGE is not set ++# CONFIG_DEBUG_PAGEALLOC is not set ++CONFIG_DEBUGGER=y ++# CONFIG_KGDB is not set ++# CONFIG_XMON is not set ++# CONFIG_BDI_SWITCH is not set ++# CONFIG_PPC_EARLY_DEBUG is not set ++ ++# ++# Security options ++# ++# CONFIG_KEYS is not set ++# CONFIG_SECURITY is not set ++# CONFIG_SECURITY_FILE_CAPABILITIES is not set ++CONFIG_CRYPTO=y ++CONFIG_CRYPTO_ALGAPI=y ++CONFIG_CRYPTO_BLKCIPHER=y ++CONFIG_CRYPTO_MANAGER=y ++# CONFIG_CRYPTO_HMAC is not set ++# CONFIG_CRYPTO_XCBC is not set ++# CONFIG_CRYPTO_NULL is not set ++# CONFIG_CRYPTO_MD4 is not set ++CONFIG_CRYPTO_MD5=y ++# CONFIG_CRYPTO_SHA1 is not set ++# CONFIG_CRYPTO_SHA256 is not set ++# CONFIG_CRYPTO_SHA512 is not set ++# CONFIG_CRYPTO_WP512 is not set ++# CONFIG_CRYPTO_TGR192 is not set ++# CONFIG_CRYPTO_GF128MUL is not set ++CONFIG_CRYPTO_ECB=y ++CONFIG_CRYPTO_CBC=y ++CONFIG_CRYPTO_PCBC=y ++# CONFIG_CRYPTO_LRW is not set ++# CONFIG_CRYPTO_XTS is not set ++# CONFIG_CRYPTO_CRYPTD is not set ++CONFIG_CRYPTO_DES=y ++# CONFIG_CRYPTO_FCRYPT is not set ++# CONFIG_CRYPTO_BLOWFISH is not set ++# CONFIG_CRYPTO_TWOFISH is not set ++# CONFIG_CRYPTO_SERPENT is not set ++# CONFIG_CRYPTO_AES is not set ++# CONFIG_CRYPTO_CAST5 is not set ++# CONFIG_CRYPTO_CAST6 is not set ++# CONFIG_CRYPTO_TEA is not set ++# CONFIG_CRYPTO_ARC4 is not set ++# CONFIG_CRYPTO_KHAZAD is not set ++# CONFIG_CRYPTO_ANUBIS is not set ++# CONFIG_CRYPTO_SEED is not set ++# CONFIG_CRYPTO_DEFLATE is not set ++# CONFIG_CRYPTO_MICHAEL_MIC is not set ++# CONFIG_CRYPTO_CRC32C is not set ++# CONFIG_CRYPTO_CAMELLIA is not set ++# CONFIG_CRYPTO_TEST is not set ++# CONFIG_CRYPTO_AUTHENC is not set ++CONFIG_CRYPTO_HW=y ++# CONFIG_PPC_CLOCK is not set +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/walnut_defconfig powerpc.git/arch/powerpc/configs/walnut_defconfig +--- linux-2.6.24/arch/powerpc/configs/walnut_defconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/walnut_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -1,7 +1,7 @@ + # + # Automatically generated make config: don't edit +-# Linux kernel version: 2.6.24-rc4 +-# Thu Dec 6 16:49:33 2007 ++# Linux kernel version: 2.6.24-rc6 ++# Mon Dec 24 11:23:58 2007 + # + # CONFIG_PPC64 is not set + +@@ -40,7 +40,7 @@ + CONFIG_ARCH_MAY_HAVE_PC_FDC=y + CONFIG_PPC_OF=y + CONFIG_OF=y +-# CONFIG_PPC_UDBG_16550 is not set ++CONFIG_PPC_UDBG_16550=y + # CONFIG_GENERIC_TBSYNC is not set + CONFIG_AUDIT_ARCH=y + CONFIG_GENERIC_BUG=y +@@ -127,6 +127,7 @@ + # CONFIG_DEFAULT_CFQ is not set + # CONFIG_DEFAULT_NOOP is not set + CONFIG_DEFAULT_IOSCHED="anticipatory" ++# CONFIG_PPC4xx_PCI_EXPRESS is not set + + # + # Platform support +@@ -136,7 +137,9 @@ + # CONFIG_PPC_CELL is not set + # CONFIG_PPC_CELL_NATIVE is not set + # CONFIG_PQ2ADS is not set ++# CONFIG_EP405 is not set + # CONFIG_KILAUEA is not set ++# CONFIG_MAKALU is not set + CONFIG_WALNUT=y + # CONFIG_XILINX_VIRTEX_GENERIC_BOARD is not set + CONFIG_405GP=y +@@ -204,11 +207,17 @@ + # Bus options + # + CONFIG_ZONE_DMA=y +-# CONFIG_PCI is not set +-# CONFIG_PCI_DOMAINS is not set +-# CONFIG_PCI_SYSCALL is not set +-# CONFIG_ARCH_SUPPORTS_MSI is not set ++CONFIG_PPC_INDIRECT_PCI=y ++CONFIG_PCI=y ++CONFIG_PCI_DOMAINS=y ++CONFIG_PCI_SYSCALL=y ++# CONFIG_PCIEPORTBUS is not set ++CONFIG_ARCH_SUPPORTS_MSI=y ++# CONFIG_PCI_MSI is not set ++# CONFIG_PCI_LEGACY is not set ++# CONFIG_PCI_DEBUG is not set + # CONFIG_PCCARD is not set ++# CONFIG_HOTPLUG_PCI is not set + + # + # Advanced setup +@@ -373,11 +382,13 @@ + # CONFIG_MTD_COMPLEX_MAPPINGS is not set + # CONFIG_MTD_PHYSMAP is not set + CONFIG_MTD_PHYSMAP_OF=y ++# CONFIG_MTD_INTEL_VR_NOR is not set + # CONFIG_MTD_PLATRAM is not set + + # + # Self-contained MTD device drivers + # ++# CONFIG_MTD_PMC551 is not set + # CONFIG_MTD_SLRAM is not set + # CONFIG_MTD_PHRAM is not set + # CONFIG_MTD_MTDRAM is not set +@@ -400,9 +411,14 @@ + # CONFIG_PARPORT is not set + CONFIG_BLK_DEV=y + # CONFIG_BLK_DEV_FD is not set ++# CONFIG_BLK_CPQ_DA is not set ++# CONFIG_BLK_CPQ_CISS_DA is not set ++# CONFIG_BLK_DEV_DAC960 is not set ++# CONFIG_BLK_DEV_UMEM is not set + # CONFIG_BLK_DEV_COW_COMMON is not set + # CONFIG_BLK_DEV_LOOP is not set + # CONFIG_BLK_DEV_NBD is not set ++# CONFIG_BLK_DEV_SX8 is not set + CONFIG_BLK_DEV_RAM=y + CONFIG_BLK_DEV_RAM_COUNT=16 + CONFIG_BLK_DEV_RAM_SIZE=35000 +@@ -411,7 +427,10 @@ + # CONFIG_ATA_OVER_ETH is not set + # CONFIG_XILINX_SYSACE is not set + CONFIG_MISC_DEVICES=y ++# CONFIG_PHANTOM is not set + # CONFIG_EEPROM_93CX6 is not set ++# CONFIG_SGI_IOC4 is not set ++# CONFIG_TIFM_CORE is not set + # CONFIG_IDE is not set + + # +@@ -423,6 +442,14 @@ + # CONFIG_SCSI_NETLINK is not set + # CONFIG_ATA is not set + # CONFIG_MD is not set ++# CONFIG_FUSION is not set ++ ++# ++# IEEE 1394 (FireWire) support ++# ++# CONFIG_FIREWIRE is not set ++# CONFIG_IEEE1394 is not set ++# CONFIG_I2O is not set + # CONFIG_MACINTOSH_DRIVERS is not set + CONFIG_NETDEVICES=y + # CONFIG_NETDEVICES_MULTIQUEUE is not set +@@ -432,9 +459,17 @@ + # CONFIG_EQUALIZER is not set + # CONFIG_TUN is not set + # CONFIG_VETH is not set ++# CONFIG_IP1000 is not set ++# CONFIG_ARCNET is not set + # CONFIG_PHYLIB is not set + CONFIG_NET_ETHERNET=y + # CONFIG_MII is not set ++# CONFIG_HAPPYMEAL is not set ++# CONFIG_SUNGEM is not set ++# CONFIG_CASSINI is not set ++# CONFIG_NET_VENDOR_3COM is not set ++# CONFIG_NET_TULIP is not set ++# CONFIG_HP100 is not set + CONFIG_IBM_NEW_EMAC=y + CONFIG_IBM_NEW_EMAC_RXB=128 + CONFIG_IBM_NEW_EMAC_TXB=64 +@@ -446,9 +481,38 @@ + # CONFIG_IBM_NEW_EMAC_RGMII is not set + # CONFIG_IBM_NEW_EMAC_TAH is not set + # CONFIG_IBM_NEW_EMAC_EMAC4 is not set ++# CONFIG_NET_PCI is not set + # CONFIG_B44 is not set + CONFIG_NETDEV_1000=y ++# CONFIG_ACENIC is not set ++# CONFIG_DL2K is not set ++# CONFIG_E1000 is not set ++# CONFIG_E1000E is not set ++# CONFIG_NS83820 is not set ++# CONFIG_HAMACHI is not set ++# CONFIG_YELLOWFIN is not set ++# CONFIG_R8169 is not set ++# CONFIG_SIS190 is not set ++# CONFIG_SKGE is not set ++# CONFIG_SKY2 is not set ++# CONFIG_SK98LIN is not set ++# CONFIG_VIA_VELOCITY is not set ++# CONFIG_TIGON3 is not set ++# CONFIG_BNX2 is not set ++# CONFIG_QLA3XXX is not set ++# CONFIG_ATL1 is not set + CONFIG_NETDEV_10000=y ++# CONFIG_CHELSIO_T1 is not set ++# CONFIG_CHELSIO_T3 is not set ++# CONFIG_IXGBE is not set ++# CONFIG_IXGB is not set ++# CONFIG_S2IO is not set ++# CONFIG_MYRI10GE is not set ++# CONFIG_NETXEN_NIC is not set ++# CONFIG_NIU is not set ++# CONFIG_MLX4_CORE is not set ++# CONFIG_TEHUTI is not set ++# CONFIG_TR is not set + + # + # Wireless LAN +@@ -456,6 +520,8 @@ + # CONFIG_WLAN_PRE80211 is not set + # CONFIG_WLAN_80211 is not set + # CONFIG_WAN is not set ++# CONFIG_FDDI is not set ++# CONFIG_HIPPI is not set + # CONFIG_PPP is not set + # CONFIG_SLIP is not set + # CONFIG_SHAPER is not set +@@ -487,6 +553,7 @@ + # + CONFIG_SERIAL_8250=y + CONFIG_SERIAL_8250_CONSOLE=y ++CONFIG_SERIAL_8250_PCI=y + CONFIG_SERIAL_8250_NR_UARTS=4 + CONFIG_SERIAL_8250_RUNTIME_UARTS=4 + CONFIG_SERIAL_8250_EXTENDED=y +@@ -501,6 +568,7 @@ + # CONFIG_SERIAL_UARTLITE is not set + CONFIG_SERIAL_CORE=y + CONFIG_SERIAL_CORE_CONSOLE=y ++# CONFIG_SERIAL_JSM is not set + CONFIG_SERIAL_OF_PLATFORM=y + CONFIG_UNIX98_PTYS=y + CONFIG_LEGACY_PTYS=y +@@ -510,8 +578,10 @@ + # CONFIG_NVRAM is not set + # CONFIG_GEN_RTC is not set + # CONFIG_R3964 is not set ++# CONFIG_APPLICOM is not set + # CONFIG_RAW_DRIVER is not set + # CONFIG_TCG_TPM is not set ++CONFIG_DEVPORT=y + # CONFIG_I2C is not set + + # +@@ -545,6 +615,8 @@ + # + # Graphics support + # ++# CONFIG_AGP is not set ++# CONFIG_DRM is not set + # CONFIG_VGASTATE is not set + CONFIG_VIDEO_OUTPUT_CONTROL=m + # CONFIG_FB is not set +@@ -560,9 +632,10 @@ + # + # CONFIG_SOUND is not set + CONFIG_USB_SUPPORT=y +-# CONFIG_USB_ARCH_HAS_HCD is not set +-# CONFIG_USB_ARCH_HAS_OHCI is not set +-# CONFIG_USB_ARCH_HAS_EHCI is not set ++CONFIG_USB_ARCH_HAS_HCD=y ++CONFIG_USB_ARCH_HAS_OHCI=y ++CONFIG_USB_ARCH_HAS_EHCI=y ++# CONFIG_USB is not set + + # + # NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' +@@ -574,6 +647,7 @@ + # CONFIG_USB_GADGET is not set + # CONFIG_MMC is not set + # CONFIG_NEW_LEDS is not set ++# CONFIG_INFINIBAND is not set + # CONFIG_EDAC is not set + # CONFIG_RTC_CLASS is not set + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/configs/warp_defconfig powerpc.git/arch/powerpc/configs/warp_defconfig +--- linux-2.6.24/arch/powerpc/configs/warp_defconfig 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/configs/warp_defconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,1057 @@ ++# ++# Automatically generated make config: don't edit ++# Linux kernel version: 2.6.24-rc6 ++# Tue Jan 8 12:23:23 2008 ++# ++# CONFIG_PPC64 is not set ++ ++# ++# Processor support ++# ++# CONFIG_6xx is not set ++# CONFIG_PPC_85xx is not set ++# CONFIG_PPC_8xx is not set ++# CONFIG_40x is not set ++CONFIG_44x=y ++# CONFIG_E200 is not set ++CONFIG_PPC_FPU=y ++CONFIG_4xx=y ++CONFIG_BOOKE=y ++CONFIG_PTE_64BIT=y ++CONFIG_PHYS_64BIT=y ++# CONFIG_PPC_MM_SLICES is not set ++CONFIG_NOT_COHERENT_CACHE=y ++CONFIG_PPC32=y ++CONFIG_WORD_SIZE=32 ++CONFIG_PPC_MERGE=y ++CONFIG_MMU=y ++CONFIG_GENERIC_CMOS_UPDATE=y ++CONFIG_GENERIC_TIME=y ++CONFIG_GENERIC_TIME_VSYSCALL=y ++CONFIG_GENERIC_CLOCKEVENTS=y ++CONFIG_GENERIC_HARDIRQS=y ++CONFIG_IRQ_PER_CPU=y ++CONFIG_RWSEM_XCHGADD_ALGORITHM=y ++CONFIG_ARCH_HAS_ILOG2_U32=y ++CONFIG_GENERIC_HWEIGHT=y ++CONFIG_GENERIC_CALIBRATE_DELAY=y ++CONFIG_GENERIC_FIND_NEXT_BIT=y ++# CONFIG_ARCH_NO_VIRT_TO_BUS is not set ++CONFIG_PPC=y ++CONFIG_EARLY_PRINTK=y ++CONFIG_GENERIC_NVRAM=y ++CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y ++CONFIG_ARCH_MAY_HAVE_PC_FDC=y ++CONFIG_PPC_OF=y ++CONFIG_OF=y ++CONFIG_PPC_UDBG_16550=y ++# CONFIG_GENERIC_TBSYNC is not set ++CONFIG_AUDIT_ARCH=y ++CONFIG_GENERIC_BUG=y ++# CONFIG_DEFAULT_UIMAGE is not set ++CONFIG_PPC_DCR_NATIVE=y ++# CONFIG_PPC_DCR_MMIO is not set ++CONFIG_PPC_DCR=y ++CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" ++ ++# ++# General setup ++# ++CONFIG_EXPERIMENTAL=y ++CONFIG_BROKEN_ON_SMP=y ++CONFIG_INIT_ENV_ARG_LIMIT=32 ++CONFIG_LOCALVERSION="-pika" ++# CONFIG_LOCALVERSION_AUTO is not set ++CONFIG_SWAP=y ++CONFIG_SYSVIPC=y ++CONFIG_SYSVIPC_SYSCTL=y ++# CONFIG_POSIX_MQUEUE is not set ++# CONFIG_BSD_PROCESS_ACCT is not set ++# CONFIG_TASKSTATS is not set ++# CONFIG_USER_NS is not set ++# CONFIG_PID_NS is not set ++# CONFIG_AUDIT is not set ++# CONFIG_IKCONFIG is not set ++CONFIG_LOG_BUF_SHIFT=14 ++# CONFIG_CGROUPS is not set ++CONFIG_FAIR_GROUP_SCHED=y ++CONFIG_FAIR_USER_SCHED=y ++# CONFIG_FAIR_CGROUP_SCHED is not set ++CONFIG_SYSFS_DEPRECATED=y ++# CONFIG_RELAY is not set ++CONFIG_BLK_DEV_INITRD=y ++CONFIG_INITRAMFS_SOURCE="" ++# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set ++CONFIG_SYSCTL=y ++CONFIG_EMBEDDED=y ++CONFIG_SYSCTL_SYSCALL=y ++CONFIG_KALLSYMS=y ++# CONFIG_KALLSYMS_ALL is not set ++# CONFIG_KALLSYMS_EXTRA_PASS is not set ++# CONFIG_HOTPLUG is not set ++CONFIG_PRINTK=y ++CONFIG_BUG=y ++CONFIG_ELF_CORE=y ++CONFIG_BASE_FULL=y ++CONFIG_FUTEX=y ++CONFIG_ANON_INODES=y ++CONFIG_EPOLL=y ++CONFIG_SIGNALFD=y ++CONFIG_EVENTFD=y ++CONFIG_SHMEM=y ++CONFIG_VM_EVENT_COUNTERS=y ++CONFIG_SLAB=y ++# CONFIG_SLUB is not set ++# CONFIG_SLOB is not set ++CONFIG_RT_MUTEXES=y ++# CONFIG_TINY_SHMEM is not set ++CONFIG_BASE_SMALL=0 ++CONFIG_MODULES=y ++CONFIG_MODULE_UNLOAD=y ++# CONFIG_MODULE_FORCE_UNLOAD is not set ++# CONFIG_MODVERSIONS is not set ++# CONFIG_MODULE_SRCVERSION_ALL is not set ++CONFIG_KMOD=y ++CONFIG_BLOCK=y ++# CONFIG_LBD is not set ++# CONFIG_BLK_DEV_IO_TRACE is not set ++# CONFIG_LSF is not set ++# CONFIG_BLK_DEV_BSG is not set ++ ++# ++# IO Schedulers ++# ++CONFIG_IOSCHED_NOOP=y ++CONFIG_IOSCHED_AS=y ++CONFIG_IOSCHED_DEADLINE=y ++CONFIG_IOSCHED_CFQ=y ++CONFIG_DEFAULT_AS=y ++# CONFIG_DEFAULT_DEADLINE is not set ++# CONFIG_DEFAULT_CFQ is not set ++# CONFIG_DEFAULT_NOOP is not set ++CONFIG_DEFAULT_IOSCHED="anticipatory" ++ ++# ++# Platform support ++# ++# CONFIG_PPC_MPC52xx is not set ++# CONFIG_PPC_MPC5200 is not set ++# CONFIG_PPC_CELL is not set ++# CONFIG_PPC_CELL_NATIVE is not set ++# CONFIG_PQ2ADS is not set ++# CONFIG_BAMBOO is not set ++# CONFIG_EBONY is not set ++# CONFIG_SEQUOIA is not set ++# CONFIG_TAISHAN is not set ++# CONFIG_KATMAI is not set ++# CONFIG_RAINIER is not set ++CONFIG_WARP=y ++CONFIG_440EP=y ++CONFIG_IBM440EP_ERR42=y ++# CONFIG_MPIC is not set ++# CONFIG_MPIC_WEIRD is not set ++# CONFIG_PPC_I8259 is not set ++# CONFIG_PPC_RTAS is not set ++# CONFIG_MMIO_NVRAM is not set ++# CONFIG_PPC_MPC106 is not set ++# CONFIG_PPC_970_NAP is not set ++# CONFIG_PPC_INDIRECT_IO is not set ++# CONFIG_GENERIC_IOMAP is not set ++# CONFIG_CPU_FREQ is not set ++# CONFIG_CPM2 is not set ++# CONFIG_FSL_ULI1575 is not set ++ ++# ++# Kernel options ++# ++# CONFIG_HIGHMEM is not set ++# CONFIG_TICK_ONESHOT is not set ++# CONFIG_NO_HZ is not set ++# CONFIG_HIGH_RES_TIMERS is not set ++CONFIG_GENERIC_CLOCKEVENTS_BUILD=y ++# CONFIG_HZ_100 is not set ++# CONFIG_HZ_250 is not set ++# CONFIG_HZ_300 is not set ++CONFIG_HZ_1000=y ++CONFIG_HZ=1000 ++CONFIG_PREEMPT_NONE=y ++# CONFIG_PREEMPT_VOLUNTARY is not set ++# CONFIG_PREEMPT is not set ++CONFIG_BINFMT_ELF=y ++# CONFIG_BINFMT_MISC is not set ++# CONFIG_MATH_EMULATION is not set ++CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y ++CONFIG_ARCH_FLATMEM_ENABLE=y ++CONFIG_ARCH_POPULATES_NODE_MAP=y ++CONFIG_SELECT_MEMORY_MODEL=y ++CONFIG_FLATMEM_MANUAL=y ++# CONFIG_DISCONTIGMEM_MANUAL is not set ++# CONFIG_SPARSEMEM_MANUAL is not set ++CONFIG_FLATMEM=y ++CONFIG_FLAT_NODE_MEM_MAP=y ++# CONFIG_SPARSEMEM_STATIC is not set ++# CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set ++CONFIG_SPLIT_PTLOCK_CPUS=4 ++CONFIG_RESOURCES_64BIT=y ++CONFIG_ZONE_DMA_FLAG=1 ++CONFIG_BOUNCE=y ++CONFIG_VIRT_TO_BUS=y ++CONFIG_PROC_DEVICETREE=y ++CONFIG_CMDLINE_BOOL=y ++CONFIG_CMDLINE="ip=on" ++CONFIG_SECCOMP=y ++CONFIG_WANT_DEVICE_TREE=y ++CONFIG_DEVICE_TREE="warp.dts" ++CONFIG_ISA_DMA_API=y ++ ++# ++# Bus options ++# ++CONFIG_ZONE_DMA=y ++# CONFIG_PCI is not set ++# CONFIG_PCI_DOMAINS is not set ++# CONFIG_PCI_SYSCALL is not set ++# CONFIG_ARCH_SUPPORTS_MSI is not set ++ ++# ++# Advanced setup ++# ++# CONFIG_ADVANCED_OPTIONS is not set ++ ++# ++# Default settings for advanced configuration options are used ++# ++CONFIG_HIGHMEM_START=0xfe000000 ++CONFIG_LOWMEM_SIZE=0x30000000 ++CONFIG_KERNEL_START=0xc0000000 ++CONFIG_TASK_SIZE=0xc0000000 ++CONFIG_CONSISTENT_START=0xff100000 ++CONFIG_CONSISTENT_SIZE=0x00200000 ++CONFIG_BOOT_LOAD=0x01000000 ++ ++# ++# Networking ++# ++CONFIG_NET=y ++ ++# ++# Networking options ++# ++CONFIG_PACKET=y ++# CONFIG_PACKET_MMAP is not set ++CONFIG_UNIX=y ++CONFIG_XFRM=y ++# CONFIG_XFRM_USER is not set ++# CONFIG_XFRM_SUB_POLICY is not set ++# CONFIG_XFRM_MIGRATE is not set ++# CONFIG_NET_KEY is not set ++CONFIG_INET=y ++# CONFIG_IP_MULTICAST is not set ++# CONFIG_IP_ADVANCED_ROUTER is not set ++CONFIG_IP_FIB_HASH=y ++CONFIG_IP_PNP=y ++CONFIG_IP_PNP_DHCP=y ++# CONFIG_IP_PNP_BOOTP is not set ++# CONFIG_IP_PNP_RARP is not set ++# CONFIG_NET_IPIP is not set ++# CONFIG_NET_IPGRE is not set ++# CONFIG_ARPD is not set ++# CONFIG_SYN_COOKIES is not set ++# CONFIG_INET_AH is not set ++# CONFIG_INET_ESP is not set ++# CONFIG_INET_IPCOMP is not set ++# CONFIG_INET_XFRM_TUNNEL is not set ++# CONFIG_INET_TUNNEL is not set ++CONFIG_INET_XFRM_MODE_TRANSPORT=y ++CONFIG_INET_XFRM_MODE_TUNNEL=y ++CONFIG_INET_XFRM_MODE_BEET=y ++# CONFIG_INET_LRO is not set ++CONFIG_INET_DIAG=y ++CONFIG_INET_TCP_DIAG=y ++# CONFIG_TCP_CONG_ADVANCED is not set ++CONFIG_TCP_CONG_CUBIC=y ++CONFIG_DEFAULT_TCP_CONG="cubic" ++# CONFIG_TCP_MD5SIG is not set ++# CONFIG_IP_VS is not set ++# CONFIG_IPV6 is not set ++# CONFIG_INET6_XFRM_TUNNEL is not set ++# CONFIG_INET6_TUNNEL is not set ++# CONFIG_NETWORK_SECMARK is not set ++CONFIG_NETFILTER=y ++# CONFIG_NETFILTER_DEBUG is not set ++ ++# ++# Core Netfilter Configuration ++# ++# CONFIG_NETFILTER_NETLINK is not set ++# CONFIG_NF_CONNTRACK_ENABLED is not set ++# CONFIG_NF_CONNTRACK is not set ++# CONFIG_NETFILTER_XTABLES is not set ++ ++# ++# IP: Netfilter Configuration ++# ++# CONFIG_IP_NF_QUEUE is not set ++# CONFIG_IP_NF_IPTABLES is not set ++# CONFIG_IP_NF_ARPTABLES is not set ++# CONFIG_IP_DCCP is not set ++# CONFIG_IP_SCTP is not set ++# CONFIG_TIPC is not set ++# CONFIG_ATM is not set ++# CONFIG_BRIDGE is not set ++CONFIG_VLAN_8021Q=y ++# CONFIG_DECNET is not set ++# CONFIG_LLC2 is not set ++# CONFIG_IPX is not set ++# CONFIG_ATALK is not set ++# CONFIG_X25 is not set ++# CONFIG_LAPB is not set ++# CONFIG_ECONET is not set ++# CONFIG_WAN_ROUTER is not set ++# CONFIG_NET_SCHED is not set ++ ++# ++# Network testing ++# ++# CONFIG_NET_PKTGEN is not set ++# CONFIG_HAMRADIO is not set ++# CONFIG_IRDA is not set ++# CONFIG_BT is not set ++# CONFIG_AF_RXRPC is not set ++ ++# ++# Wireless ++# ++# CONFIG_CFG80211 is not set ++# CONFIG_WIRELESS_EXT is not set ++# CONFIG_MAC80211 is not set ++# CONFIG_IEEE80211 is not set ++# CONFIG_RFKILL is not set ++# CONFIG_NET_9P is not set ++ ++# ++# Device Drivers ++# ++ ++# ++# Generic Driver Options ++# ++# CONFIG_STANDALONE is not set ++CONFIG_PREVENT_FIRMWARE_BUILD=y ++# CONFIG_DEBUG_DRIVER is not set ++# CONFIG_DEBUG_DEVRES is not set ++# CONFIG_SYS_HYPERVISOR is not set ++# CONFIG_CONNECTOR is not set ++CONFIG_MTD=y ++# CONFIG_MTD_DEBUG is not set ++# CONFIG_MTD_CONCAT is not set ++CONFIG_MTD_PARTITIONS=y ++# CONFIG_MTD_REDBOOT_PARTS is not set ++# CONFIG_MTD_CMDLINE_PARTS is not set ++ ++# ++# User Modules And Translation Layers ++# ++CONFIG_MTD_CHAR=y ++CONFIG_MTD_BLKDEVS=y ++CONFIG_MTD_BLOCK=y ++# CONFIG_FTL is not set ++# CONFIG_NFTL is not set ++# CONFIG_INFTL is not set ++# CONFIG_RFD_FTL is not set ++# CONFIG_SSFDC is not set ++CONFIG_MTD_OOPS=m ++ ++# ++# RAM/ROM/Flash chip drivers ++# ++CONFIG_MTD_CFI=y ++# CONFIG_MTD_JEDECPROBE is not set ++CONFIG_MTD_GEN_PROBE=y ++# CONFIG_MTD_CFI_ADV_OPTIONS is not set ++CONFIG_MTD_MAP_BANK_WIDTH_1=y ++CONFIG_MTD_MAP_BANK_WIDTH_2=y ++CONFIG_MTD_MAP_BANK_WIDTH_4=y ++# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set ++# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set ++CONFIG_MTD_CFI_I1=y ++CONFIG_MTD_CFI_I2=y ++# CONFIG_MTD_CFI_I4 is not set ++# CONFIG_MTD_CFI_I8 is not set ++# CONFIG_MTD_CFI_INTELEXT is not set ++CONFIG_MTD_CFI_AMDSTD=y ++# CONFIG_MTD_CFI_STAA is not set ++CONFIG_MTD_CFI_UTIL=y ++# CONFIG_MTD_RAM is not set ++# CONFIG_MTD_ROM is not set ++# CONFIG_MTD_ABSENT is not set ++ ++# ++# Mapping drivers for chip access ++# ++# CONFIG_MTD_COMPLEX_MAPPINGS is not set ++# CONFIG_MTD_PHYSMAP is not set ++CONFIG_MTD_PHYSMAP_OF=y ++# CONFIG_MTD_PLATRAM is not set ++ ++# ++# Self-contained MTD device drivers ++# ++# CONFIG_MTD_SLRAM is not set ++# CONFIG_MTD_PHRAM is not set ++# CONFIG_MTD_MTDRAM is not set ++# CONFIG_MTD_BLOCK2MTD is not set ++ ++# ++# Disk-On-Chip Device Drivers ++# ++# CONFIG_MTD_DOC2000 is not set ++# CONFIG_MTD_DOC2001 is not set ++# CONFIG_MTD_DOC2001PLUS is not set ++CONFIG_MTD_NAND=y ++# CONFIG_MTD_NAND_VERIFY_WRITE is not set ++CONFIG_MTD_NAND_ECC_SMC=y ++# CONFIG_MTD_NAND_MUSEUM_IDS is not set ++CONFIG_MTD_NAND_IDS=y ++CONFIG_MTD_NAND_NDFC=y ++# CONFIG_MTD_NAND_DISKONCHIP is not set ++# CONFIG_MTD_NAND_NANDSIM is not set ++# CONFIG_MTD_NAND_PLATFORM is not set ++# CONFIG_MTD_ALAUDA is not set ++# CONFIG_MTD_ONENAND is not set ++ ++# ++# UBI - Unsorted block images ++# ++# CONFIG_MTD_UBI is not set ++CONFIG_OF_DEVICE=y ++# CONFIG_PARPORT is not set ++CONFIG_BLK_DEV=y ++# CONFIG_BLK_DEV_FD is not set ++# CONFIG_BLK_DEV_COW_COMMON is not set ++# CONFIG_BLK_DEV_LOOP is not set ++# CONFIG_BLK_DEV_NBD is not set ++# CONFIG_BLK_DEV_UB is not set ++CONFIG_BLK_DEV_RAM=y ++CONFIG_BLK_DEV_RAM_COUNT=16 ++CONFIG_BLK_DEV_RAM_SIZE=4096 ++CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024 ++# CONFIG_CDROM_PKTCDVD is not set ++# CONFIG_ATA_OVER_ETH is not set ++# CONFIG_XILINX_SYSACE is not set ++CONFIG_MISC_DEVICES=y ++# CONFIG_EEPROM_93CX6 is not set ++# CONFIG_IDE is not set ++ ++# ++# SCSI device support ++# ++# CONFIG_RAID_ATTRS is not set ++CONFIG_SCSI=y ++CONFIG_SCSI_DMA=y ++# CONFIG_SCSI_TGT is not set ++# CONFIG_SCSI_NETLINK is not set ++CONFIG_SCSI_PROC_FS=y ++ ++# ++# SCSI support type (disk, tape, CD-ROM) ++# ++CONFIG_BLK_DEV_SD=y ++# CONFIG_CHR_DEV_ST is not set ++# CONFIG_CHR_DEV_OSST is not set ++# CONFIG_BLK_DEV_SR is not set ++# CONFIG_CHR_DEV_SG is not set ++# CONFIG_CHR_DEV_SCH is not set ++ ++# ++# Some SCSI devices (e.g. CD jukebox) support multiple LUNs ++# ++# CONFIG_SCSI_MULTI_LUN is not set ++# CONFIG_SCSI_CONSTANTS is not set ++# CONFIG_SCSI_LOGGING is not set ++# CONFIG_SCSI_SCAN_ASYNC is not set ++# CONFIG_SCSI_WAIT_SCAN is not set ++ ++# ++# SCSI Transports ++# ++CONFIG_SCSI_SPI_ATTRS=y ++# CONFIG_SCSI_FC_ATTRS is not set ++# CONFIG_SCSI_ISCSI_ATTRS is not set ++# CONFIG_SCSI_SAS_LIBSAS is not set ++# CONFIG_SCSI_SRP_ATTRS is not set ++# CONFIG_SCSI_LOWLEVEL is not set ++# CONFIG_ATA is not set ++# CONFIG_MD is not set ++# CONFIG_MACINTOSH_DRIVERS is not set ++CONFIG_NETDEVICES=y ++# CONFIG_NETDEVICES_MULTIQUEUE is not set ++# CONFIG_DUMMY is not set ++# CONFIG_BONDING is not set ++# CONFIG_MACVLAN is not set ++# CONFIG_EQUALIZER is not set ++# CONFIG_TUN is not set ++# CONFIG_VETH is not set ++# CONFIG_PHYLIB is not set ++CONFIG_NET_ETHERNET=y ++CONFIG_MII=y ++CONFIG_IBM_NEW_EMAC=y ++CONFIG_IBM_NEW_EMAC_RXB=128 ++CONFIG_IBM_NEW_EMAC_TXB=64 ++CONFIG_IBM_NEW_EMAC_POLL_WEIGHT=32 ++CONFIG_IBM_NEW_EMAC_RX_COPY_THRESHOLD=256 ++CONFIG_IBM_NEW_EMAC_RX_SKB_HEADROOM=0 ++# CONFIG_IBM_NEW_EMAC_DEBUG is not set ++CONFIG_IBM_NEW_EMAC_ZMII=y ++# CONFIG_IBM_NEW_EMAC_RGMII is not set ++# CONFIG_IBM_NEW_EMAC_TAH is not set ++# CONFIG_IBM_NEW_EMAC_EMAC4 is not set ++# CONFIG_B44 is not set ++# CONFIG_NETDEV_1000 is not set ++# CONFIG_NETDEV_10000 is not set ++ ++# ++# Wireless LAN ++# ++# CONFIG_WLAN_PRE80211 is not set ++# CONFIG_WLAN_80211 is not set ++ ++# ++# USB Network Adapters ++# ++# CONFIG_USB_CATC is not set ++# CONFIG_USB_KAWETH is not set ++# CONFIG_USB_PEGASUS is not set ++# CONFIG_USB_RTL8150 is not set ++# CONFIG_USB_USBNET is not set ++# CONFIG_WAN is not set ++# CONFIG_PPP is not set ++# CONFIG_SLIP is not set ++# CONFIG_SHAPER is not set ++# CONFIG_NETCONSOLE is not set ++# CONFIG_NETPOLL is not set ++# CONFIG_NET_POLL_CONTROLLER is not set ++# CONFIG_ISDN is not set ++# CONFIG_PHONE is not set ++ ++# ++# Input device support ++# ++# CONFIG_INPUT is not set ++ ++# ++# Hardware I/O ports ++# ++# CONFIG_SERIO is not set ++# CONFIG_GAMEPORT is not set ++ ++# ++# Character devices ++# ++# CONFIG_VT is not set ++# CONFIG_SERIAL_NONSTANDARD is not set ++ ++# ++# Serial drivers ++# ++CONFIG_SERIAL_8250=y ++CONFIG_SERIAL_8250_CONSOLE=y ++CONFIG_SERIAL_8250_NR_UARTS=4 ++CONFIG_SERIAL_8250_RUNTIME_UARTS=4 ++CONFIG_SERIAL_8250_EXTENDED=y ++# CONFIG_SERIAL_8250_MANY_PORTS is not set ++CONFIG_SERIAL_8250_SHARE_IRQ=y ++# CONFIG_SERIAL_8250_DETECT_IRQ is not set ++# CONFIG_SERIAL_8250_RSA is not set ++ ++# ++# Non-8250 serial port support ++# ++# CONFIG_SERIAL_UARTLITE is not set ++CONFIG_SERIAL_CORE=y ++CONFIG_SERIAL_CORE_CONSOLE=y ++# CONFIG_SERIAL_OF_PLATFORM is not set ++CONFIG_UNIX98_PTYS=y ++CONFIG_LEGACY_PTYS=y ++CONFIG_LEGACY_PTY_COUNT=256 ++# CONFIG_IPMI_HANDLER is not set ++CONFIG_HW_RANDOM=y ++# CONFIG_NVRAM is not set ++# CONFIG_GEN_RTC is not set ++# CONFIG_R3964 is not set ++# CONFIG_RAW_DRIVER is not set ++# CONFIG_TCG_TPM is not set ++CONFIG_I2C=y ++CONFIG_I2C_BOARDINFO=y ++# CONFIG_I2C_CHARDEV is not set ++ ++# ++# I2C Algorithms ++# ++# CONFIG_I2C_ALGOBIT is not set ++# CONFIG_I2C_ALGOPCF is not set ++# CONFIG_I2C_ALGOPCA is not set ++ ++# ++# I2C Hardware Bus support ++# ++CONFIG_I2C_IBM_IIC=y ++# CONFIG_I2C_MPC is not set ++# CONFIG_I2C_OCORES is not set ++# CONFIG_I2C_PARPORT_LIGHT is not set ++# CONFIG_I2C_SIMTEC is not set ++# CONFIG_I2C_TAOS_EVM is not set ++# CONFIG_I2C_STUB is not set ++# CONFIG_I2C_TINY_USB is not set ++ ++# ++# Miscellaneous I2C Chip support ++# ++# CONFIG_SENSORS_DS1337 is not set ++# CONFIG_SENSORS_DS1374 is not set ++# CONFIG_DS1682 is not set ++CONFIG_SENSORS_EEPROM=y ++# CONFIG_SENSORS_PCF8574 is not set ++# CONFIG_SENSORS_PCA9539 is not set ++# CONFIG_SENSORS_PCF8591 is not set ++# CONFIG_SENSORS_M41T00 is not set ++# CONFIG_SENSORS_MAX6875 is not set ++# CONFIG_SENSORS_TSL2550 is not set ++# CONFIG_I2C_DEBUG_CORE is not set ++# CONFIG_I2C_DEBUG_ALGO is not set ++# CONFIG_I2C_DEBUG_BUS is not set ++# CONFIG_I2C_DEBUG_CHIP is not set ++ ++# ++# SPI support ++# ++# CONFIG_SPI is not set ++# CONFIG_SPI_MASTER is not set ++# CONFIG_W1 is not set ++# CONFIG_POWER_SUPPLY is not set ++CONFIG_HWMON=y ++# CONFIG_HWMON_VID is not set ++CONFIG_SENSORS_AD7414=y ++# CONFIG_SENSORS_AD7418 is not set ++# CONFIG_SENSORS_ADM1021 is not set ++# CONFIG_SENSORS_ADM1025 is not set ++# CONFIG_SENSORS_ADM1026 is not set ++# CONFIG_SENSORS_ADM1029 is not set ++# CONFIG_SENSORS_ADM1031 is not set ++# CONFIG_SENSORS_ADM9240 is not set ++# CONFIG_SENSORS_ADT7470 is not set ++# CONFIG_SENSORS_ATXP1 is not set ++# CONFIG_SENSORS_DS1621 is not set ++# CONFIG_SENSORS_F71805F is not set ++# CONFIG_SENSORS_F71882FG is not set ++# CONFIG_SENSORS_F75375S is not set ++# CONFIG_SENSORS_GL518SM is not set ++# CONFIG_SENSORS_GL520SM is not set ++# CONFIG_SENSORS_IT87 is not set ++# CONFIG_SENSORS_LM63 is not set ++# CONFIG_SENSORS_LM75 is not set ++# CONFIG_SENSORS_LM77 is not set ++# CONFIG_SENSORS_LM78 is not set ++# CONFIG_SENSORS_LM80 is not set ++# CONFIG_SENSORS_LM83 is not set ++# CONFIG_SENSORS_LM85 is not set ++# CONFIG_SENSORS_LM87 is not set ++# CONFIG_SENSORS_LM90 is not set ++# CONFIG_SENSORS_LM92 is not set ++# CONFIG_SENSORS_LM93 is not set ++# CONFIG_SENSORS_MAX1619 is not set ++# CONFIG_SENSORS_MAX6650 is not set ++# CONFIG_SENSORS_PC87360 is not set ++# CONFIG_SENSORS_PC87427 is not set ++# CONFIG_SENSORS_DME1737 is not set ++# CONFIG_SENSORS_SMSC47M1 is not set ++# CONFIG_SENSORS_SMSC47M192 is not set ++# CONFIG_SENSORS_SMSC47B397 is not set ++# CONFIG_SENSORS_THMC50 is not set ++# CONFIG_SENSORS_VT1211 is not set ++# CONFIG_SENSORS_W83781D is not set ++# CONFIG_SENSORS_W83791D is not set ++# CONFIG_SENSORS_W83792D is not set ++# CONFIG_SENSORS_W83793 is not set ++# CONFIG_SENSORS_W83L785TS is not set ++# CONFIG_SENSORS_W83627HF is not set ++# CONFIG_SENSORS_W83627EHF is not set ++# CONFIG_HWMON_DEBUG_CHIP is not set ++# CONFIG_WATCHDOG is not set ++ ++# ++# Sonics Silicon Backplane ++# ++CONFIG_SSB_POSSIBLE=y ++# CONFIG_SSB is not set ++ ++# ++# Multifunction device drivers ++# ++# CONFIG_MFD_SM501 is not set ++ ++# ++# Multimedia devices ++# ++# CONFIG_VIDEO_DEV is not set ++# CONFIG_DVB_CORE is not set ++# CONFIG_DAB is not set ++ ++# ++# Graphics support ++# ++# CONFIG_VGASTATE is not set ++# CONFIG_VIDEO_OUTPUT_CONTROL is not set ++# CONFIG_FB is not set ++# CONFIG_BACKLIGHT_LCD_SUPPORT is not set ++ ++# ++# Display device support ++# ++# CONFIG_DISPLAY_SUPPORT is not set ++ ++# ++# Sound ++# ++# CONFIG_SOUND is not set ++CONFIG_USB_SUPPORT=y ++CONFIG_USB_ARCH_HAS_HCD=y ++CONFIG_USB_ARCH_HAS_OHCI=y ++# CONFIG_USB_ARCH_HAS_EHCI is not set ++CONFIG_USB=y ++# CONFIG_USB_DEBUG is not set ++ ++# ++# Miscellaneous USB options ++# ++# CONFIG_USB_DEVICEFS is not set ++CONFIG_USB_DEVICE_CLASS=y ++# CONFIG_USB_DYNAMIC_MINORS is not set ++# CONFIG_USB_OTG is not set ++ ++# ++# USB Host Controller Drivers ++# ++# CONFIG_USB_ISP116X_HCD is not set ++CONFIG_USB_OHCI_HCD=y ++CONFIG_USB_OHCI_HCD_PPC_OF=y ++CONFIG_USB_OHCI_HCD_PPC_OF_BE=y ++# CONFIG_USB_OHCI_HCD_PPC_OF_LE is not set ++CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y ++CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y ++CONFIG_USB_OHCI_LITTLE_ENDIAN=y ++# CONFIG_USB_SL811_HCD is not set ++# CONFIG_USB_R8A66597_HCD is not set ++ ++# ++# USB Device Class drivers ++# ++# CONFIG_USB_ACM is not set ++# CONFIG_USB_PRINTER is not set ++ ++# ++# NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' ++# ++ ++# ++# may also be needed; see USB_STORAGE Help for more information ++# ++CONFIG_USB_STORAGE=y ++# CONFIG_USB_STORAGE_DEBUG is not set ++# CONFIG_USB_STORAGE_DATAFAB is not set ++# CONFIG_USB_STORAGE_FREECOM is not set ++# CONFIG_USB_STORAGE_ISD200 is not set ++# CONFIG_USB_STORAGE_DPCM is not set ++# CONFIG_USB_STORAGE_USBAT is not set ++# CONFIG_USB_STORAGE_SDDR09 is not set ++# CONFIG_USB_STORAGE_SDDR55 is not set ++# CONFIG_USB_STORAGE_JUMPSHOT is not set ++# CONFIG_USB_STORAGE_ALAUDA is not set ++# CONFIG_USB_STORAGE_KARMA is not set ++# CONFIG_USB_LIBUSUAL is not set ++ ++# ++# USB Imaging devices ++# ++# CONFIG_USB_MDC800 is not set ++# CONFIG_USB_MICROTEK is not set ++CONFIG_USB_MON=y ++ ++# ++# USB port drivers ++# ++ ++# ++# USB Serial Converter support ++# ++# CONFIG_USB_SERIAL is not set ++ ++# ++# USB Miscellaneous drivers ++# ++# CONFIG_USB_EMI62 is not set ++# CONFIG_USB_EMI26 is not set ++# CONFIG_USB_ADUTUX is not set ++# CONFIG_USB_AUERSWALD is not set ++# CONFIG_USB_RIO500 is not set ++# CONFIG_USB_LEGOTOWER is not set ++# CONFIG_USB_LCD is not set ++# CONFIG_USB_BERRY_CHARGE is not set ++# CONFIG_USB_LED is not set ++# CONFIG_USB_CYPRESS_CY7C63 is not set ++# CONFIG_USB_CYTHERM is not set ++# CONFIG_USB_PHIDGET is not set ++# CONFIG_USB_IDMOUSE is not set ++# CONFIG_USB_FTDI_ELAN is not set ++# CONFIG_USB_APPLEDISPLAY is not set ++# CONFIG_USB_LD is not set ++# CONFIG_USB_TRANCEVIBRATOR is not set ++# CONFIG_USB_IOWARRIOR is not set ++ ++# ++# USB DSL modem support ++# ++ ++# ++# USB Gadget Support ++# ++# CONFIG_USB_GADGET is not set ++CONFIG_MMC=m ++# CONFIG_MMC_DEBUG is not set ++# CONFIG_MMC_UNSAFE_RESUME is not set ++ ++# ++# MMC/SD Card Drivers ++# ++CONFIG_MMC_BLOCK=m ++CONFIG_MMC_BLOCK_BOUNCE=y ++# CONFIG_SDIO_UART is not set ++ ++# ++# MMC/SD Host Controller Drivers ++# ++# CONFIG_MMC_WBSD is not set ++# CONFIG_NEW_LEDS is not set ++# CONFIG_EDAC is not set ++# CONFIG_RTC_CLASS is not set ++ ++# ++# Userspace I/O ++# ++# CONFIG_UIO is not set ++ ++# ++# File systems ++# ++CONFIG_EXT2_FS=y ++# CONFIG_EXT2_FS_XATTR is not set ++# CONFIG_EXT2_FS_XIP is not set ++# CONFIG_EXT3_FS is not set ++# CONFIG_EXT4DEV_FS is not set ++# CONFIG_REISERFS_FS is not set ++# CONFIG_JFS_FS is not set ++# CONFIG_FS_POSIX_ACL is not set ++# CONFIG_XFS_FS is not set ++# CONFIG_GFS2_FS is not set ++# CONFIG_OCFS2_FS is not set ++# CONFIG_MINIX_FS is not set ++# CONFIG_ROMFS_FS is not set ++CONFIG_INOTIFY=y ++CONFIG_INOTIFY_USER=y ++# CONFIG_QUOTA is not set ++CONFIG_DNOTIFY=y ++# CONFIG_AUTOFS_FS is not set ++# CONFIG_AUTOFS4_FS is not set ++# CONFIG_FUSE_FS is not set ++ ++# ++# CD-ROM/DVD Filesystems ++# ++# CONFIG_ISO9660_FS is not set ++# CONFIG_UDF_FS is not set ++ ++# ++# DOS/FAT/NT Filesystems ++# ++CONFIG_FAT_FS=y ++CONFIG_MSDOS_FS=y ++CONFIG_VFAT_FS=y ++CONFIG_FAT_DEFAULT_CODEPAGE=437 ++CONFIG_FAT_DEFAULT_IOCHARSET="iso8859-1" ++# CONFIG_NTFS_FS is not set ++ ++# ++# Pseudo filesystems ++# ++CONFIG_PROC_FS=y ++CONFIG_PROC_KCORE=y ++CONFIG_PROC_SYSCTL=y ++CONFIG_SYSFS=y ++# CONFIG_TMPFS is not set ++# CONFIG_HUGETLB_PAGE is not set ++# CONFIG_CONFIGFS_FS is not set ++ ++# ++# Miscellaneous filesystems ++# ++# CONFIG_ADFS_FS is not set ++# CONFIG_AFFS_FS is not set ++# CONFIG_HFS_FS is not set ++# CONFIG_HFSPLUS_FS is not set ++# CONFIG_BEFS_FS is not set ++# CONFIG_BFS_FS is not set ++# CONFIG_EFS_FS is not set ++CONFIG_JFFS2_FS=y ++CONFIG_JFFS2_FS_DEBUG=0 ++CONFIG_JFFS2_FS_WRITEBUFFER=y ++# CONFIG_JFFS2_FS_WBUF_VERIFY is not set ++# CONFIG_JFFS2_SUMMARY is not set ++# CONFIG_JFFS2_FS_XATTR is not set ++# CONFIG_JFFS2_COMPRESSION_OPTIONS is not set ++CONFIG_JFFS2_ZLIB=y ++# CONFIG_JFFS2_LZO is not set ++CONFIG_JFFS2_RTIME=y ++# CONFIG_JFFS2_RUBIN is not set ++CONFIG_CRAMFS=y ++# CONFIG_VXFS_FS is not set ++# CONFIG_HPFS_FS is not set ++# CONFIG_QNX4FS_FS is not set ++# CONFIG_SYSV_FS is not set ++# CONFIG_UFS_FS is not set ++CONFIG_NETWORK_FILESYSTEMS=y ++CONFIG_NFS_FS=y ++CONFIG_NFS_V3=y ++# CONFIG_NFS_V3_ACL is not set ++# CONFIG_NFS_V4 is not set ++# CONFIG_NFS_DIRECTIO is not set ++# CONFIG_NFSD is not set ++CONFIG_ROOT_NFS=y ++CONFIG_LOCKD=y ++CONFIG_LOCKD_V4=y ++CONFIG_NFS_COMMON=y ++CONFIG_SUNRPC=y ++# CONFIG_SUNRPC_BIND34 is not set ++# CONFIG_RPCSEC_GSS_KRB5 is not set ++# CONFIG_RPCSEC_GSS_SPKM3 is not set ++# CONFIG_SMB_FS is not set ++# CONFIG_CIFS is not set ++# CONFIG_NCP_FS is not set ++# CONFIG_CODA_FS is not set ++# CONFIG_AFS_FS is not set ++ ++# ++# Partition Types ++# ++# CONFIG_PARTITION_ADVANCED is not set ++CONFIG_MSDOS_PARTITION=y ++CONFIG_NLS=y ++CONFIG_NLS_DEFAULT="iso8859-1" ++CONFIG_NLS_CODEPAGE_437=y ++# CONFIG_NLS_CODEPAGE_737 is not set ++# CONFIG_NLS_CODEPAGE_775 is not set ++CONFIG_NLS_CODEPAGE_850=y ++# CONFIG_NLS_CODEPAGE_852 is not set ++# CONFIG_NLS_CODEPAGE_855 is not set ++# CONFIG_NLS_CODEPAGE_857 is not set ++# CONFIG_NLS_CODEPAGE_860 is not set ++# CONFIG_NLS_CODEPAGE_861 is not set ++# CONFIG_NLS_CODEPAGE_862 is not set ++# CONFIG_NLS_CODEPAGE_863 is not set ++# CONFIG_NLS_CODEPAGE_864 is not set ++# CONFIG_NLS_CODEPAGE_865 is not set ++# CONFIG_NLS_CODEPAGE_866 is not set ++# CONFIG_NLS_CODEPAGE_869 is not set ++# CONFIG_NLS_CODEPAGE_936 is not set ++# CONFIG_NLS_CODEPAGE_950 is not set ++# CONFIG_NLS_CODEPAGE_932 is not set ++# CONFIG_NLS_CODEPAGE_949 is not set ++# CONFIG_NLS_CODEPAGE_874 is not set ++# CONFIG_NLS_ISO8859_8 is not set ++# CONFIG_NLS_CODEPAGE_1250 is not set ++# CONFIG_NLS_CODEPAGE_1251 is not set ++CONFIG_NLS_ASCII=y ++CONFIG_NLS_ISO8859_1=y ++# CONFIG_NLS_ISO8859_2 is not set ++# CONFIG_NLS_ISO8859_3 is not set ++# CONFIG_NLS_ISO8859_4 is not set ++# CONFIG_NLS_ISO8859_5 is not set ++# CONFIG_NLS_ISO8859_6 is not set ++# CONFIG_NLS_ISO8859_7 is not set ++# CONFIG_NLS_ISO8859_9 is not set ++# CONFIG_NLS_ISO8859_13 is not set ++# CONFIG_NLS_ISO8859_14 is not set ++CONFIG_NLS_ISO8859_15=y ++# CONFIG_NLS_KOI8_R is not set ++# CONFIG_NLS_KOI8_U is not set ++CONFIG_NLS_UTF8=y ++# CONFIG_DLM is not set ++# CONFIG_UCC_SLOW is not set ++ ++# ++# Library routines ++# ++CONFIG_BITREVERSE=y ++CONFIG_CRC_CCITT=y ++# CONFIG_CRC16 is not set ++# CONFIG_CRC_ITU_T is not set ++CONFIG_CRC32=y ++# CONFIG_CRC7 is not set ++# CONFIG_LIBCRC32C is not set ++CONFIG_ZLIB_INFLATE=y ++CONFIG_ZLIB_DEFLATE=y ++CONFIG_PLIST=y ++CONFIG_HAS_IOMEM=y ++CONFIG_HAS_IOPORT=y ++CONFIG_HAS_DMA=y ++# CONFIG_INSTRUMENTATION is not set ++ ++# ++# Kernel hacking ++# ++# CONFIG_PRINTK_TIME is not set ++CONFIG_ENABLE_WARN_DEPRECATED=y ++CONFIG_ENABLE_MUST_CHECK=y ++CONFIG_MAGIC_SYSRQ=y ++# CONFIG_UNUSED_SYMBOLS is not set ++# CONFIG_DEBUG_FS is not set ++# CONFIG_HEADERS_CHECK is not set ++CONFIG_DEBUG_KERNEL=y ++# CONFIG_DEBUG_SHIRQ is not set ++CONFIG_DETECT_SOFTLOCKUP=y ++# CONFIG_SCHED_DEBUG is not set ++# CONFIG_SCHEDSTATS is not set ++# CONFIG_TIMER_STATS is not set ++# CONFIG_DEBUG_SLAB is not set ++# CONFIG_DEBUG_RT_MUTEXES is not set ++# CONFIG_RT_MUTEX_TESTER is not set ++# CONFIG_DEBUG_SPINLOCK is not set ++# CONFIG_DEBUG_MUTEXES is not set ++# CONFIG_DEBUG_SPINLOCK_SLEEP is not set ++# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set ++# CONFIG_DEBUG_KOBJECT is not set ++# CONFIG_DEBUG_BUGVERBOSE is not set ++CONFIG_DEBUG_INFO=y ++# CONFIG_DEBUG_VM is not set ++# CONFIG_DEBUG_LIST is not set ++# CONFIG_DEBUG_SG is not set ++CONFIG_FORCED_INLINING=y ++# CONFIG_BOOT_PRINTK_DELAY is not set ++# CONFIG_RCU_TORTURE_TEST is not set ++# CONFIG_FAULT_INJECTION is not set ++# CONFIG_SAMPLES is not set ++# CONFIG_DEBUG_STACKOVERFLOW is not set ++# CONFIG_DEBUG_STACK_USAGE is not set ++# CONFIG_DEBUG_PAGEALLOC is not set ++# CONFIG_DEBUGGER is not set ++CONFIG_BDI_SWITCH=y ++# CONFIG_PPC_EARLY_DEBUG is not set ++ ++# ++# Security options ++# ++# CONFIG_KEYS is not set ++# CONFIG_SECURITY is not set ++# CONFIG_SECURITY_FILE_CAPABILITIES is not set ++# CONFIG_CRYPTO is not set ++# CONFIG_PPC_CLOCK is not set +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/Makefile powerpc.git/arch/powerpc/kernel/Makefile +--- linux-2.6.24/arch/powerpc/kernel/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -3,7 +3,7 @@ + # + + ifeq ($(CONFIG_PPC64),y) +-EXTRA_CFLAGS += -mno-minimal-toc ++CFLAGS_prom_init.o += -mno-minimal-toc + endif + ifeq ($(CONFIG_PPC32),y) + CFLAGS_prom_init.o += -fPIC +@@ -70,6 +70,7 @@ + obj-$(CONFIG_PCI) += pci_$(CONFIG_WORD_SIZE).o $(pci64-y) \ + pci-common.o + obj-$(CONFIG_PCI_MSI) += msi.o ++obj-$(CONFIG_RAPIDIO) += rio.o + obj-$(CONFIG_KEXEC) += machine_kexec.o crash.o \ + machine_kexec_$(CONFIG_WORD_SIZE).o + obj-$(CONFIG_AUDIT) += audit.o +@@ -91,3 +92,13 @@ + + extra-$(CONFIG_PPC_FPU) += fpu.o + extra-$(CONFIG_PPC64) += entry_64.o ++ ++extra-y += systbl_chk.i ++$(obj)/systbl.o: systbl_chk ++ ++quiet_cmd_systbl_chk = CALL $< ++ cmd_systbl_chk = $(CONFIG_SHELL) $< $(obj)/systbl_chk.i ++ ++PHONY += systbl_chk ++systbl_chk: $(src)/systbl_chk.sh $(obj)/systbl_chk.i ++ $(call cmd,systbl_chk) +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/btext.c powerpc.git/arch/powerpc/kernel/btext.c +--- linux-2.6.24/arch/powerpc/kernel/btext.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/btext.c 2008-01-28 20:25:49.000000000 +0100 +@@ -236,7 +236,7 @@ + if (rc == 0 || !allow_nonstdout) + return rc; + +- for (np = NULL; (np = of_find_node_by_type(np, "display"));) { ++ for_each_node_by_type(np, "display") { + if (of_get_property(np, "linux,opened", NULL)) { + printk("trying %s ...\n", np->full_name); + rc = btext_initialize(np); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/cpu_setup_44x.S powerpc.git/arch/powerpc/kernel/cpu_setup_44x.S +--- linux-2.6.24/arch/powerpc/kernel/cpu_setup_44x.S 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/cpu_setup_44x.S 2008-01-28 20:25:49.000000000 +0100 +@@ -23,11 +23,24 @@ + mflr r4 + bl __init_fpu_44x + bl __plb_disable_wrp ++ bl __fixup_440A_mcheck + mtlr r4 + blr + _GLOBAL(__setup_cpu_440grx) +- b __plb_disable_wrp ++ mflr r4 ++ bl __plb_disable_wrp ++ bl __fixup_440A_mcheck ++ mtlr r4 ++ blr ++_GLOBAL(__setup_cpu_440gx) ++_GLOBAL(__setup_cpu_440spe) ++ b __fixup_440A_mcheck + ++ /* Temporary fixup for arch/ppc until we kill the whole thing */ ++#ifndef CONFIG_PPC_MERGE ++_GLOBAL(__fixup_440A_mcheck) ++ blr ++#endif + + /* enable APU between CPU and FPU */ + _GLOBAL(__init_fpu_44x) +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/cputable.c powerpc.git/arch/powerpc/kernel/cputable.c +--- linux-2.6.24/arch/powerpc/kernel/cputable.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/cputable.c 2008-01-28 20:25:49.000000000 +0100 +@@ -33,7 +33,9 @@ + #ifdef CONFIG_PPC32 + extern void __setup_cpu_440ep(unsigned long offset, struct cpu_spec* spec); + extern void __setup_cpu_440epx(unsigned long offset, struct cpu_spec* spec); ++extern void __setup_cpu_440gx(unsigned long offset, struct cpu_spec* spec); + extern void __setup_cpu_440grx(unsigned long offset, struct cpu_spec* spec); ++extern void __setup_cpu_440spe(unsigned long offset, struct cpu_spec* spec); + extern void __setup_cpu_603(unsigned long offset, struct cpu_spec* spec); + extern void __setup_cpu_604(unsigned long offset, struct cpu_spec* spec); + extern void __setup_cpu_750(unsigned long offset, struct cpu_spec* spec); +@@ -85,6 +87,7 @@ + .pmc_type = PPC_PMC_IBM, + .oprofile_cpu_type = "ppc64/power3", + .oprofile_type = PPC_OPROFILE_RS64, ++ .machine_check = machine_check_generic, + .platform = "power3", + }, + { /* Power3+ */ +@@ -99,6 +102,7 @@ + .pmc_type = PPC_PMC_IBM, + .oprofile_cpu_type = "ppc64/power3", + .oprofile_type = PPC_OPROFILE_RS64, ++ .machine_check = machine_check_generic, + .platform = "power3", + }, + { /* Northstar */ +@@ -113,6 +117,7 @@ + .pmc_type = PPC_PMC_IBM, + .oprofile_cpu_type = "ppc64/rs64", + .oprofile_type = PPC_OPROFILE_RS64, ++ .machine_check = machine_check_generic, + .platform = "rs64", + }, + { /* Pulsar */ +@@ -127,6 +132,7 @@ + .pmc_type = PPC_PMC_IBM, + .oprofile_cpu_type = "ppc64/rs64", + .oprofile_type = PPC_OPROFILE_RS64, ++ .machine_check = machine_check_generic, + .platform = "rs64", + }, + { /* I-star */ +@@ -141,6 +147,7 @@ + .pmc_type = PPC_PMC_IBM, + .oprofile_cpu_type = "ppc64/rs64", + .oprofile_type = PPC_OPROFILE_RS64, ++ .machine_check = machine_check_generic, + .platform = "rs64", + }, + { /* S-star */ +@@ -155,6 +162,7 @@ + .pmc_type = PPC_PMC_IBM, + .oprofile_cpu_type = "ppc64/rs64", + .oprofile_type = PPC_OPROFILE_RS64, ++ .machine_check = machine_check_generic, + .platform = "rs64", + }, + { /* Power4 */ +@@ -169,6 +177,7 @@ + .pmc_type = PPC_PMC_IBM, + .oprofile_cpu_type = "ppc64/power4", + .oprofile_type = PPC_OPROFILE_POWER4, ++ .machine_check = machine_check_generic, + .platform = "power4", + }, + { /* Power4+ */ +@@ -183,6 +192,7 @@ + .pmc_type = PPC_PMC_IBM, + .oprofile_cpu_type = "ppc64/power4", + .oprofile_type = PPC_OPROFILE_POWER4, ++ .machine_check = machine_check_generic, + .platform = "power4", + }, + { /* PPC970 */ +@@ -200,6 +210,7 @@ + .cpu_restore = __restore_cpu_ppc970, + .oprofile_cpu_type = "ppc64/970", + .oprofile_type = PPC_OPROFILE_POWER4, ++ .machine_check = machine_check_generic, + .platform = "ppc970", + }, + { /* PPC970FX */ +@@ -217,6 +228,7 @@ + .cpu_restore = __restore_cpu_ppc970, + .oprofile_cpu_type = "ppc64/970", + .oprofile_type = PPC_OPROFILE_POWER4, ++ .machine_check = machine_check_generic, + .platform = "ppc970", + }, + { /* PPC970MP DD1.0 - no DEEPNAP, use regular 970 init */ +@@ -234,6 +246,7 @@ + .cpu_restore = __restore_cpu_ppc970, + .oprofile_cpu_type = "ppc64/970MP", + .oprofile_type = PPC_OPROFILE_POWER4, ++ .machine_check = machine_check_generic, + .platform = "ppc970", + }, + { /* PPC970MP */ +@@ -251,6 +264,7 @@ + .cpu_restore = __restore_cpu_ppc970, + .oprofile_cpu_type = "ppc64/970MP", + .oprofile_type = PPC_OPROFILE_POWER4, ++ .machine_check = machine_check_generic, + .platform = "ppc970", + }, + { /* PPC970GX */ +@@ -267,6 +281,7 @@ + .cpu_setup = __setup_cpu_ppc970, + .oprofile_cpu_type = "ppc64/970", + .oprofile_type = PPC_OPROFILE_POWER4, ++ .machine_check = machine_check_generic, + .platform = "ppc970", + }, + { /* Power5 GR */ +@@ -286,6 +301,7 @@ + */ + .oprofile_mmcra_sihv = MMCRA_SIHV, + .oprofile_mmcra_sipr = MMCRA_SIPR, ++ .machine_check = machine_check_generic, + .platform = "power5", + }, + { /* Power5++ */ +@@ -301,6 +317,7 @@ + .oprofile_type = PPC_OPROFILE_POWER4, + .oprofile_mmcra_sihv = MMCRA_SIHV, + .oprofile_mmcra_sipr = MMCRA_SIPR, ++ .machine_check = machine_check_generic, + .platform = "power5+", + }, + { /* Power5 GS */ +@@ -317,6 +334,7 @@ + .oprofile_type = PPC_OPROFILE_POWER4, + .oprofile_mmcra_sihv = MMCRA_SIHV, + .oprofile_mmcra_sipr = MMCRA_SIPR, ++ .machine_check = machine_check_generic, + .platform = "power5+", + }, + { /* POWER6 in P5+ mode; 2.04-compliant processor */ +@@ -327,6 +345,7 @@ + .cpu_user_features = COMMON_USER_POWER5_PLUS, + .icache_bsize = 128, + .dcache_bsize = 128, ++ .machine_check = machine_check_generic, + .platform = "power5+", + }, + { /* Power6 */ +@@ -346,6 +365,7 @@ + .oprofile_mmcra_sipr = POWER6_MMCRA_SIPR, + .oprofile_mmcra_clear = POWER6_MMCRA_THRM | + POWER6_MMCRA_OTHER, ++ .machine_check = machine_check_generic, + .platform = "power6x", + }, + { /* 2.05-compliant processor, i.e. Power6 "architected" mode */ +@@ -356,6 +376,7 @@ + .cpu_user_features = COMMON_USER_POWER6, + .icache_bsize = 128, + .dcache_bsize = 128, ++ .machine_check = machine_check_generic, + .platform = "power6", + }, + { /* Cell Broadband Engine */ +@@ -372,6 +393,7 @@ + .pmc_type = PPC_PMC_IBM, + .oprofile_cpu_type = "ppc64/cell-be", + .oprofile_type = PPC_OPROFILE_CELL, ++ .machine_check = machine_check_generic, + .platform = "ppc-cell-be", + }, + { /* PA Semi PA6T */ +@@ -388,6 +410,7 @@ + .cpu_restore = __restore_cpu_pa6t, + .oprofile_cpu_type = "ppc64/pa6t", + .oprofile_type = PPC_OPROFILE_PA6T, ++ .machine_check = machine_check_generic, + .platform = "pa6t", + }, + { /* default match */ +@@ -400,6 +423,7 @@ + .dcache_bsize = 128, + .num_pmcs = 6, + .pmc_type = PPC_PMC_IBM, ++ .machine_check = machine_check_generic, + .platform = "power4", + } + #endif /* CONFIG_PPC64 */ +@@ -414,6 +438,7 @@ + PPC_FEATURE_UNIFIED_CACHE | PPC_FEATURE_NO_TB, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_generic, + .platform = "ppc601", + }, + { /* 603 */ +@@ -425,6 +450,7 @@ + .icache_bsize = 32, + .dcache_bsize = 32, + .cpu_setup = __setup_cpu_603, ++ .machine_check = machine_check_generic, + .platform = "ppc603", + }, + { /* 603e */ +@@ -436,6 +462,7 @@ + .icache_bsize = 32, + .dcache_bsize = 32, + .cpu_setup = __setup_cpu_603, ++ .machine_check = machine_check_generic, + .platform = "ppc603", + }, + { /* 603ev */ +@@ -447,6 +474,7 @@ + .icache_bsize = 32, + .dcache_bsize = 32, + .cpu_setup = __setup_cpu_603, ++ .machine_check = machine_check_generic, + .platform = "ppc603", + }, + { /* 604 */ +@@ -459,6 +487,7 @@ + .dcache_bsize = 32, + .num_pmcs = 2, + .cpu_setup = __setup_cpu_604, ++ .machine_check = machine_check_generic, + .platform = "ppc604", + }, + { /* 604e */ +@@ -471,6 +500,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_604, ++ .machine_check = machine_check_generic, + .platform = "ppc604", + }, + { /* 604r */ +@@ -483,6 +513,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_604, ++ .machine_check = machine_check_generic, + .platform = "ppc604", + }, + { /* 604ev */ +@@ -495,6 +526,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_604, ++ .machine_check = machine_check_generic, + .platform = "ppc604", + }, + { /* 740/750 (0x4202, don't support TAU ?) */ +@@ -507,6 +539,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_750, ++ .machine_check = machine_check_generic, + .platform = "ppc750", + }, + { /* 750CX (80100 and 8010x?) */ +@@ -519,6 +552,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_750cx, ++ .machine_check = machine_check_generic, + .platform = "ppc750", + }, + { /* 750CX (82201 and 82202) */ +@@ -531,6 +565,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_750cx, ++ .machine_check = machine_check_generic, + .platform = "ppc750", + }, + { /* 750CXe (82214) */ +@@ -543,6 +578,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_750cx, ++ .machine_check = machine_check_generic, + .platform = "ppc750", + }, + { /* 750CXe "Gekko" (83214) */ +@@ -555,6 +591,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_750cx, ++ .machine_check = machine_check_generic, + .platform = "ppc750", + }, + { /* 750CL */ +@@ -567,6 +604,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_750, ++ .machine_check = machine_check_generic, + .platform = "ppc750", + }, + { /* 745/755 */ +@@ -579,6 +617,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_750, ++ .machine_check = machine_check_generic, + .platform = "ppc750", + }, + { /* 750FX rev 1.x */ +@@ -591,6 +630,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_750, ++ .machine_check = machine_check_generic, + .platform = "ppc750", + }, + { /* 750FX rev 2.0 must disable HID0[DPM] */ +@@ -603,6 +643,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_750, ++ .machine_check = machine_check_generic, + .platform = "ppc750", + }, + { /* 750FX (All revs except 2.0) */ +@@ -615,6 +656,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_750fx, ++ .machine_check = machine_check_generic, + .platform = "ppc750", + }, + { /* 750GX */ +@@ -627,6 +669,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_750fx, ++ .machine_check = machine_check_generic, + .platform = "ppc750", + }, + { /* 740/750 (L2CR bit need fixup for 740) */ +@@ -639,6 +682,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_750, ++ .machine_check = machine_check_generic, + .platform = "ppc750", + }, + { /* 7400 rev 1.1 ? (no TAU) */ +@@ -652,6 +696,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_7400, ++ .machine_check = machine_check_generic, + .platform = "ppc7400", + }, + { /* 7400 */ +@@ -665,6 +710,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_7400, ++ .machine_check = machine_check_generic, + .platform = "ppc7400", + }, + { /* 7410 */ +@@ -678,6 +724,7 @@ + .dcache_bsize = 32, + .num_pmcs = 4, + .cpu_setup = __setup_cpu_7410, ++ .machine_check = machine_check_generic, + .platform = "ppc7400", + }, + { /* 7450 2.0 - no doze/nap */ +@@ -693,6 +740,7 @@ + .cpu_setup = __setup_cpu_745x, + .oprofile_cpu_type = "ppc/7450", + .oprofile_type = PPC_OPROFILE_G4, ++ .machine_check = machine_check_generic, + .platform = "ppc7450", + }, + { /* 7450 2.1 */ +@@ -708,6 +756,7 @@ + .cpu_setup = __setup_cpu_745x, + .oprofile_cpu_type = "ppc/7450", + .oprofile_type = PPC_OPROFILE_G4, ++ .machine_check = machine_check_generic, + .platform = "ppc7450", + }, + { /* 7450 2.3 and newer */ +@@ -723,6 +772,7 @@ + .cpu_setup = __setup_cpu_745x, + .oprofile_cpu_type = "ppc/7450", + .oprofile_type = PPC_OPROFILE_G4, ++ .machine_check = machine_check_generic, + .platform = "ppc7450", + }, + { /* 7455 rev 1.x */ +@@ -738,6 +788,7 @@ + .cpu_setup = __setup_cpu_745x, + .oprofile_cpu_type = "ppc/7450", + .oprofile_type = PPC_OPROFILE_G4, ++ .machine_check = machine_check_generic, + .platform = "ppc7450", + }, + { /* 7455 rev 2.0 */ +@@ -753,6 +804,7 @@ + .cpu_setup = __setup_cpu_745x, + .oprofile_cpu_type = "ppc/7450", + .oprofile_type = PPC_OPROFILE_G4, ++ .machine_check = machine_check_generic, + .platform = "ppc7450", + }, + { /* 7455 others */ +@@ -768,6 +820,7 @@ + .cpu_setup = __setup_cpu_745x, + .oprofile_cpu_type = "ppc/7450", + .oprofile_type = PPC_OPROFILE_G4, ++ .machine_check = machine_check_generic, + .platform = "ppc7450", + }, + { /* 7447/7457 Rev 1.0 */ +@@ -783,6 +836,7 @@ + .cpu_setup = __setup_cpu_745x, + .oprofile_cpu_type = "ppc/7450", + .oprofile_type = PPC_OPROFILE_G4, ++ .machine_check = machine_check_generic, + .platform = "ppc7450", + }, + { /* 7447/7457 Rev 1.1 */ +@@ -798,6 +852,7 @@ + .cpu_setup = __setup_cpu_745x, + .oprofile_cpu_type = "ppc/7450", + .oprofile_type = PPC_OPROFILE_G4, ++ .machine_check = machine_check_generic, + .platform = "ppc7450", + }, + { /* 7447/7457 Rev 1.2 and later */ +@@ -812,6 +867,7 @@ + .cpu_setup = __setup_cpu_745x, + .oprofile_cpu_type = "ppc/7450", + .oprofile_type = PPC_OPROFILE_G4, ++ .machine_check = machine_check_generic, + .platform = "ppc7450", + }, + { /* 7447A */ +@@ -827,6 +883,7 @@ + .cpu_setup = __setup_cpu_745x, + .oprofile_cpu_type = "ppc/7450", + .oprofile_type = PPC_OPROFILE_G4, ++ .machine_check = machine_check_generic, + .platform = "ppc7450", + }, + { /* 7448 */ +@@ -842,6 +899,7 @@ + .cpu_setup = __setup_cpu_745x, + .oprofile_cpu_type = "ppc/7450", + .oprofile_type = PPC_OPROFILE_G4, ++ .machine_check = machine_check_generic, + .platform = "ppc7450", + }, + { /* 82xx (8240, 8245, 8260 are all 603e cores) */ +@@ -853,6 +911,7 @@ + .icache_bsize = 32, + .dcache_bsize = 32, + .cpu_setup = __setup_cpu_603, ++ .machine_check = machine_check_generic, + .platform = "ppc603", + }, + { /* All G2_LE (603e core, plus some) have the same pvr */ +@@ -864,6 +923,7 @@ + .icache_bsize = 32, + .dcache_bsize = 32, + .cpu_setup = __setup_cpu_603, ++ .machine_check = machine_check_generic, + .platform = "ppc603", + }, + { /* e300c1 (a 603e core, plus some) on 83xx */ +@@ -875,6 +935,7 @@ + .icache_bsize = 32, + .dcache_bsize = 32, + .cpu_setup = __setup_cpu_603, ++ .machine_check = machine_check_generic, + .platform = "ppc603", + }, + { /* e300c2 (an e300c1 core, plus some, minus FPU) on 83xx */ +@@ -886,9 +947,10 @@ + .icache_bsize = 32, + .dcache_bsize = 32, + .cpu_setup = __setup_cpu_603, ++ .machine_check = machine_check_generic, + .platform = "ppc603", + }, +- { /* e300c3 on 83xx */ ++ { /* e300c3 (e300c1, plus one IU, half cache size) on 83xx */ + .pvr_mask = 0x7fff0000, + .pvr_value = 0x00850000, + .cpu_name = "e300c3", +@@ -899,6 +961,18 @@ + .cpu_setup = __setup_cpu_603, + .platform = "ppc603", + }, ++ { /* e300c4 (e300c1, plus one IU) */ ++ .pvr_mask = 0x7fff0000, ++ .pvr_value = 0x00860000, ++ .cpu_name = "e300c4", ++ .cpu_features = CPU_FTRS_E300, ++ .cpu_user_features = COMMON_USER, ++ .icache_bsize = 32, ++ .dcache_bsize = 32, ++ .cpu_setup = __setup_cpu_603, ++ .machine_check = machine_check_generic, ++ .platform = "ppc603", ++ }, + { /* default match, we assume split I/D cache & TB (non-601)... */ + .pvr_mask = 0x00000000, + .pvr_value = 0x00000000, +@@ -907,6 +981,7 @@ + .cpu_user_features = COMMON_USER, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_generic, + .platform = "ppc603", + }, + #endif /* CLASSIC_PPC */ +@@ -933,6 +1008,7 @@ + .cpu_user_features = PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU, + .icache_bsize = 16, + .dcache_bsize = 16, ++ .machine_check = machine_check_4xx, + .platform = "ppc403", + }, + { /* 403GCX */ +@@ -944,6 +1020,7 @@ + PPC_FEATURE_HAS_MMU | PPC_FEATURE_NO_TB, + .icache_bsize = 16, + .dcache_bsize = 16, ++ .machine_check = machine_check_4xx, + .platform = "ppc403", + }, + { /* 403G ?? */ +@@ -954,6 +1031,7 @@ + .cpu_user_features = PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU, + .icache_bsize = 16, + .dcache_bsize = 16, ++ .machine_check = machine_check_4xx, + .platform = "ppc403", + }, + { /* 405GP */ +@@ -965,6 +1043,7 @@ + PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc405", + }, + { /* STB 03xxx */ +@@ -976,6 +1055,7 @@ + PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc405", + }, + { /* STB 04xxx */ +@@ -987,6 +1067,7 @@ + PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc405", + }, + { /* NP405L */ +@@ -998,6 +1079,7 @@ + PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc405", + }, + { /* NP4GS3 */ +@@ -1009,6 +1091,7 @@ + PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc405", + }, + { /* NP405H */ +@@ -1020,6 +1103,7 @@ + PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc405", + }, + { /* 405GPr */ +@@ -1031,6 +1115,7 @@ + PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc405", + }, + { /* STBx25xx */ +@@ -1042,6 +1127,7 @@ + PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc405", + }, + { /* 405LP */ +@@ -1052,6 +1138,7 @@ + .cpu_user_features = PPC_FEATURE_32 | PPC_FEATURE_HAS_MMU, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc405", + }, + { /* Xilinx Virtex-II Pro */ +@@ -1063,6 +1150,7 @@ + PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc405", + }, + { /* Xilinx Virtex-4 FX */ +@@ -1074,6 +1162,7 @@ + PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc405", + }, + { /* 405EP */ +@@ -1085,17 +1174,31 @@ + PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc405", + }, + { /* 405EX */ +- .pvr_mask = 0xffff0000, +- .pvr_value = 0x12910000, ++ .pvr_mask = 0xffff0004, ++ .pvr_value = 0x12910004, + .cpu_name = "405EX", + .cpu_features = CPU_FTRS_40X, + .cpu_user_features = PPC_FEATURE_32 | + PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, ++ .platform = "ppc405", ++ }, ++ { /* 405EXr */ ++ .pvr_mask = 0xffff0004, ++ .pvr_value = 0x12910000, ++ .cpu_name = "405EXr", ++ .cpu_features = CPU_FTRS_40X, ++ .cpu_user_features = PPC_FEATURE_32 | ++ PPC_FEATURE_HAS_MMU | PPC_FEATURE_HAS_4xxMAC, ++ .icache_bsize = 32, ++ .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc405", + }, + +@@ -1109,6 +1212,7 @@ + .cpu_user_features = COMMON_USER_BOOKE, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc440", + }, + { /* Use logical PVR for 440EP (logical pvr = pvr | 0x8) */ +@@ -1120,6 +1224,7 @@ + .icache_bsize = 32, + .dcache_bsize = 32, + .cpu_setup = __setup_cpu_440ep, ++ .machine_check = machine_check_4xx, + .platform = "ppc440", + }, + { +@@ -1130,6 +1235,19 @@ + .cpu_user_features = COMMON_USER_BOOKE | PPC_FEATURE_HAS_FPU, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, ++ .platform = "ppc440", ++ }, ++ { /* Matches both physical and logical PVR for 440EP (logical pvr = pvr | 0x8) */ ++ .pvr_mask = 0xf0000ff7, ++ .pvr_value = 0x400008d4, ++ .cpu_name = "440EP Rev. C", ++ .cpu_features = CPU_FTRS_44X, ++ .cpu_user_features = COMMON_USER_BOOKE | PPC_FEATURE_HAS_FPU, ++ .icache_bsize = 32, ++ .dcache_bsize = 32, ++ .cpu_setup = __setup_cpu_440ep, ++ .machine_check = machine_check_4xx, + .platform = "ppc440", + }, + { /* Use logical PVR for 440EP (logical pvr = pvr | 0x8) */ +@@ -1141,6 +1259,7 @@ + .icache_bsize = 32, + .dcache_bsize = 32, + .cpu_setup = __setup_cpu_440ep, ++ .machine_check = machine_check_4xx, + .platform = "ppc440", + }, + { /* 440GRX */ +@@ -1152,6 +1271,7 @@ + .icache_bsize = 32, + .dcache_bsize = 32, + .cpu_setup = __setup_cpu_440grx, ++ .machine_check = machine_check_440A, + .platform = "ppc440", + }, + { /* Use logical PVR for 440EPx (logical pvr = pvr | 0x8) */ +@@ -1163,6 +1283,7 @@ + .icache_bsize = 32, + .dcache_bsize = 32, + .cpu_setup = __setup_cpu_440epx, ++ .machine_check = machine_check_440A, + .platform = "ppc440", + }, + { /* 440GP Rev. B */ +@@ -1173,6 +1294,7 @@ + .cpu_user_features = COMMON_USER_BOOKE, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc440gp", + }, + { /* 440GP Rev. C */ +@@ -1183,6 +1305,7 @@ + .cpu_user_features = COMMON_USER_BOOKE, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc440gp", + }, + { /* 440GX Rev. A */ +@@ -1193,6 +1316,8 @@ + .cpu_user_features = COMMON_USER_BOOKE, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .cpu_setup = __setup_cpu_440gx, ++ .machine_check = machine_check_440A, + .platform = "ppc440", + }, + { /* 440GX Rev. B */ +@@ -1203,6 +1328,8 @@ + .cpu_user_features = COMMON_USER_BOOKE, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .cpu_setup = __setup_cpu_440gx, ++ .machine_check = machine_check_440A, + .platform = "ppc440", + }, + { /* 440GX Rev. C */ +@@ -1213,6 +1340,8 @@ + .cpu_user_features = COMMON_USER_BOOKE, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .cpu_setup = __setup_cpu_440gx, ++ .machine_check = machine_check_440A, + .platform = "ppc440", + }, + { /* 440GX Rev. F */ +@@ -1223,6 +1352,8 @@ + .cpu_user_features = COMMON_USER_BOOKE, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .cpu_setup = __setup_cpu_440gx, ++ .machine_check = machine_check_440A, + .platform = "ppc440", + }, + { /* 440SP Rev. A */ +@@ -1233,6 +1364,7 @@ + .cpu_user_features = COMMON_USER_BOOKE, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .machine_check = machine_check_4xx, + .platform = "ppc440", + }, + { /* 440SPe Rev. A */ +@@ -1243,6 +1375,8 @@ + .cpu_user_features = COMMON_USER_BOOKE, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .cpu_setup = __setup_cpu_440spe, ++ .machine_check = machine_check_440A, + .platform = "ppc440", + }, + { /* 440SPe Rev. B */ +@@ -1253,10 +1387,13 @@ + .cpu_user_features = COMMON_USER_BOOKE, + .icache_bsize = 32, + .dcache_bsize = 32, ++ .cpu_setup = __setup_cpu_440spe, ++ .machine_check = machine_check_440A, + .platform = "ppc440", + }, + #endif /* CONFIG_44x */ + #ifdef CONFIG_FSL_BOOKE ++#ifdef CONFIG_E200 + { /* e200z5 */ + .pvr_mask = 0xfff00000, + .pvr_value = 0x81000000, +@@ -1267,6 +1404,7 @@ + PPC_FEATURE_HAS_EFP_SINGLE | + PPC_FEATURE_UNIFIED_CACHE, + .dcache_bsize = 32, ++ .machine_check = machine_check_e200, + .platform = "ppc5554", + }, + { /* e200z6 */ +@@ -1280,8 +1418,10 @@ + PPC_FEATURE_HAS_EFP_SINGLE_COMP | + PPC_FEATURE_UNIFIED_CACHE, + .dcache_bsize = 32, ++ .machine_check = machine_check_e200, + .platform = "ppc5554", + }, ++#elif defined(CONFIG_E500) + { /* e500 */ + .pvr_mask = 0xffff0000, + .pvr_value = 0x80200000, +@@ -1296,6 +1436,7 @@ + .num_pmcs = 4, + .oprofile_cpu_type = "ppc/e500", + .oprofile_type = PPC_OPROFILE_BOOKE, ++ .machine_check = machine_check_e500, + .platform = "ppc8540", + }, + { /* e500v2 */ +@@ -1313,9 +1454,11 @@ + .num_pmcs = 4, + .oprofile_cpu_type = "ppc/e500", + .oprofile_type = PPC_OPROFILE_BOOKE, ++ .machine_check = machine_check_e500, + .platform = "ppc8548", + }, + #endif ++#endif + #if !CLASSIC_PPC + { /* default match */ + .pvr_mask = 0x00000000, +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/crash.c powerpc.git/arch/powerpc/kernel/crash.c +--- linux-2.6.24/arch/powerpc/kernel/crash.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/crash.c 2008-01-28 20:25:49.000000000 +0100 +@@ -32,6 +32,8 @@ + #include <asm/lmb.h> + #include <asm/firmware.h> + #include <asm/smp.h> ++#include <asm/system.h> ++#include <asm/setjmp.h> + + #ifdef DEBUG + #include <asm/udbg.h> +@@ -45,6 +47,11 @@ + static cpumask_t cpus_in_crash = CPU_MASK_NONE; + cpumask_t cpus_in_sr = CPU_MASK_NONE; + ++#define CRASH_HANDLER_MAX 1 ++/* NULL terminated list of shutdown handles */ ++static crash_shutdown_t crash_shutdown_handles[CRASH_HANDLER_MAX+1]; ++static DEFINE_SPINLOCK(crash_handlers_lock); ++ + #ifdef CONFIG_SMP + static atomic_t enter_on_soft_reset = ATOMIC_INIT(0); + +@@ -285,9 +292,72 @@ + } + #endif /* CONFIG_SPU_BASE */ + ++/* ++ * Register a function to be called on shutdown. Only use this if you ++ * can't reset your device in the second kernel. ++ */ ++int crash_shutdown_register(crash_shutdown_t handler) ++{ ++ unsigned int i, rc; ++ ++ spin_lock(&crash_handlers_lock); ++ for (i = 0 ; i < CRASH_HANDLER_MAX; i++) ++ if (!crash_shutdown_handles[i]) { ++ /* Insert handle at first empty entry */ ++ crash_shutdown_handles[i] = handler; ++ rc = 0; ++ break; ++ } ++ ++ if (i == CRASH_HANDLER_MAX) { ++ printk(KERN_ERR "Crash shutdown handles full, " ++ "not registered.\n"); ++ rc = 1; ++ } ++ ++ spin_unlock(&crash_handlers_lock); ++ return rc; ++} ++EXPORT_SYMBOL(crash_shutdown_register); ++ ++int crash_shutdown_unregister(crash_shutdown_t handler) ++{ ++ unsigned int i, rc; ++ ++ spin_lock(&crash_handlers_lock); ++ for (i = 0 ; i < CRASH_HANDLER_MAX; i++) ++ if (crash_shutdown_handles[i] == handler) ++ break; ++ ++ if (i == CRASH_HANDLER_MAX) { ++ printk(KERN_ERR "Crash shutdown handle not found\n"); ++ rc = 1; ++ } else { ++ /* Shift handles down */ ++ for (; crash_shutdown_handles[i]; i++) ++ crash_shutdown_handles[i] = ++ crash_shutdown_handles[i+1]; ++ rc = 0; ++ } ++ ++ spin_unlock(&crash_handlers_lock); ++ return rc; ++} ++EXPORT_SYMBOL(crash_shutdown_unregister); ++ ++static unsigned long crash_shutdown_buf[JMP_BUF_LEN]; ++ ++static int handle_fault(struct pt_regs *regs) ++{ ++ longjmp(crash_shutdown_buf, 1); ++ return 0; ++} ++ + void default_machine_crash_shutdown(struct pt_regs *regs) + { +- unsigned int irq; ++ unsigned int i; ++ int (*old_handler)(struct pt_regs *regs); ++ + + /* + * This function is only called after the system +@@ -301,15 +371,36 @@ + */ + hard_irq_disable(); + +- for_each_irq(irq) { +- struct irq_desc *desc = irq_desc + irq; ++ for_each_irq(i) { ++ struct irq_desc *desc = irq_desc + i; + + if (desc->status & IRQ_INPROGRESS) +- desc->chip->eoi(irq); ++ desc->chip->eoi(i); + + if (!(desc->status & IRQ_DISABLED)) +- desc->chip->disable(irq); ++ desc->chip->disable(i); ++ } ++ ++ /* ++ * Call registered shutdown routines savely. Swap out ++ * __debugger_fault_handler, and replace on exit. ++ */ ++ old_handler = __debugger_fault_handler; ++ __debugger_fault_handler = handle_fault; ++ for (i = 0; crash_shutdown_handles[i]; i++) { ++ if (setjmp(crash_shutdown_buf) == 0) { ++ /* ++ * Insert syncs and delay to ensure ++ * instructions in the dangerous region don't ++ * leak away from this protected region. ++ */ ++ asm volatile("sync; isync"); ++ /* dangerous region */ ++ crash_shutdown_handles[i](); ++ asm volatile("sync; isync"); ++ } + } ++ __debugger_fault_handler = old_handler; + + /* + * Make a note of crashing cpu. Will be used in machine_kexec +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/dma_64.c powerpc.git/arch/powerpc/kernel/dma_64.c +--- linux-2.6.24/arch/powerpc/kernel/dma_64.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/dma_64.c 2008-01-28 20:25:49.000000000 +0100 +@@ -112,10 +112,16 @@ + /* + * Generic direct DMA implementation + * +- * This implementation supports a global offset that can be applied if +- * the address at which memory is visible to devices is not 0. ++ * This implementation supports a per-device offset that can be applied if ++ * the address at which memory is visible to devices is not 0. Platform code ++ * can set archdata.dma_data to an unsigned long holding the offset. By ++ * default the offset is zero. + */ +-unsigned long dma_direct_offset; ++ ++static unsigned long get_dma_direct_offset(struct device *dev) ++{ ++ return (unsigned long)dev->archdata.dma_data; ++} + + static void *dma_direct_alloc_coherent(struct device *dev, size_t size, + dma_addr_t *dma_handle, gfp_t flag) +@@ -124,13 +130,12 @@ + void *ret; + int node = dev->archdata.numa_node; + +- /* TODO: Maybe use the numa node here too ? */ + page = alloc_pages_node(node, flag, get_order(size)); + if (page == NULL) + return NULL; + ret = page_address(page); + memset(ret, 0, size); +- *dma_handle = virt_to_abs(ret) | dma_direct_offset; ++ *dma_handle = virt_to_abs(ret) + get_dma_direct_offset(dev); + + return ret; + } +@@ -145,7 +150,7 @@ + size_t size, + enum dma_data_direction direction) + { +- return virt_to_abs(ptr) | dma_direct_offset; ++ return virt_to_abs(ptr) + get_dma_direct_offset(dev); + } + + static void dma_direct_unmap_single(struct device *dev, dma_addr_t dma_addr, +@@ -161,7 +166,7 @@ + int i; + + for_each_sg(sgl, sg, nents, i) { +- sg->dma_address = sg_phys(sg) | dma_direct_offset; ++ sg->dma_address = sg_phys(sg) + get_dma_direct_offset(dev); + sg->dma_length = sg->length; + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/head_44x.S powerpc.git/arch/powerpc/kernel/head_44x.S +--- linux-2.6.24/arch/powerpc/kernel/head_44x.S 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/head_44x.S 2008-01-28 20:25:49.000000000 +0100 +@@ -289,11 +289,8 @@ + CRITICAL_EXCEPTION(0x0100, CriticalInput, unknown_exception) + + /* Machine Check Interrupt */ +-#ifdef CONFIG_440A +- MCHECK_EXCEPTION(0x0200, MachineCheck, machine_check_exception) +-#else + CRITICAL_EXCEPTION(0x0200, MachineCheck, machine_check_exception) +-#endif ++ MCHECK_EXCEPTION(0x0210, MachineCheckA, machine_check_exception) + + /* Data Storage Interrupt */ + START_EXCEPTION(DataStorage) +@@ -674,6 +671,15 @@ + */ + + /* ++ * Adjust the machine check IVOR on 440A cores ++ */ ++_GLOBAL(__fixup_440A_mcheck) ++ li r3,MachineCheckA@l ++ mtspr SPRN_IVOR1,r3 ++ sync ++ blr ++ ++/* + * extern void giveup_altivec(struct task_struct *prev) + * + * The 44x core does not have an AltiVec unit. +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/head_booke.h powerpc.git/arch/powerpc/kernel/head_booke.h +--- linux-2.6.24/arch/powerpc/kernel/head_booke.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/head_booke.h 2008-01-28 20:25:49.000000000 +0100 +@@ -166,7 +166,7 @@ + mfspr r5,SPRN_ESR; \ + stw r5,_ESR(r11); \ + addi r3,r1,STACK_FRAME_OVERHEAD; \ +- EXC_XFER_TEMPLATE(hdlr, n+2, (MSR_KERNEL & ~(MSR_ME|MSR_DE|MSR_CE)), \ ++ EXC_XFER_TEMPLATE(hdlr, n+4, (MSR_KERNEL & ~(MSR_ME|MSR_DE|MSR_CE)), \ + NOCOPY, mcheck_transfer_to_handler, \ + ret_from_mcheck_exc) + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/head_fsl_booke.S powerpc.git/arch/powerpc/kernel/head_fsl_booke.S +--- linux-2.6.24/arch/powerpc/kernel/head_fsl_booke.S 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/head_fsl_booke.S 2008-01-28 20:25:49.000000000 +0100 +@@ -73,8 +73,8 @@ + /* We try to not make any assumptions about how the boot loader + * setup or used the TLBs. We invalidate all mappings from the + * boot loader and load a single entry in TLB1[0] to map the +- * first 16M of kernel memory. Any boot info passed from the +- * bootloader needs to live in this first 16M. ++ * first 64M of kernel memory. Any boot info passed from the ++ * bootloader needs to live in this first 64M. + * + * Requirement on bootloader: + * - The page we're executing in needs to reside in TLB1 and +@@ -167,7 +167,7 @@ + mtspr SPRN_MAS0,r7 + tlbre + +- /* Just modify the entry ID and EPN for the temp mapping */ ++ /* Just modify the entry ID, EPN and RPN for the temp mapping */ + lis r7,0x1000 /* Set MAS0(TLBSEL) = 1 */ + rlwimi r7,r5,16,4,15 /* Setup MAS0 = TLBSEL | ESEL(r5) */ + mtspr SPRN_MAS0,r7 +@@ -177,9 +177,12 @@ + ori r6,r6,(MAS1_TSIZE(BOOKE_PAGESZ_4K))@l + mtspr SPRN_MAS1,r6 + mfspr r6,SPRN_MAS2 +- li r7,0 /* temp EPN = 0 */ ++ lis r7,PHYSICAL_START@h + rlwimi r7,r6,0,20,31 + mtspr SPRN_MAS2,r7 ++ mfspr r6,SPRN_MAS3 ++ rlwimi r7,r6,0,20,31 ++ mtspr SPRN_MAS3,r7 + tlbwe + + xori r6,r4,1 +@@ -222,11 +225,11 @@ + lis r6,0x1000 /* Set MAS0(TLBSEL) = TLB1(1), ESEL = 0 */ + mtspr SPRN_MAS0,r6 + lis r6,(MAS1_VALID|MAS1_IPROT)@h +- ori r6,r6,(MAS1_TSIZE(BOOKE_PAGESZ_16M))@l ++ ori r6,r6,(MAS1_TSIZE(BOOKE_PAGESZ_64M))@l + mtspr SPRN_MAS1,r6 + li r7,0 +- lis r6,KERNELBASE@h +- ori r6,r6,KERNELBASE@l ++ lis r6,PAGE_OFFSET@h ++ ori r6,r6,PAGE_OFFSET@l + rlwimi r6,r7,0,20,31 + mtspr SPRN_MAS2,r6 + li r7,(MAS3_SX|MAS3_SW|MAS3_SR) +@@ -234,6 +237,9 @@ + tlbwe + + /* 7. Jump to KERNELBASE mapping */ ++ lis r6,KERNELBASE@h ++ ori r6,r6,KERNELBASE@l ++ rlwimi r6,r7,0,20,31 + lis r7,MSR_KERNEL@h + ori r7,r7,MSR_KERNEL@l + bl 1f /* Find our address */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/ibmebus.c powerpc.git/arch/powerpc/kernel/ibmebus.c +--- linux-2.6.24/arch/powerpc/kernel/ibmebus.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/ibmebus.c 2008-01-28 20:25:49.000000000 +0100 +@@ -41,6 +41,7 @@ + #include <linux/kobject.h> + #include <linux/dma-mapping.h> + #include <linux/interrupt.h> ++#include <linux/of.h> + #include <linux/of_platform.h> + #include <asm/ibmebus.h> + #include <asm/abs_addr.h> +@@ -52,7 +53,7 @@ + struct bus_type ibmebus_bus_type; + + /* These devices will automatically be added to the bus during init */ +-static struct of_device_id builtin_matches[] = { ++static struct of_device_id __initdata builtin_matches[] = { + { .compatible = "IBM,lhca" }, + { .compatible = "IBM,lhea" }, + {}, +@@ -171,7 +172,7 @@ + + root = of_find_node_by_path("/"); + +- for (child = NULL; (child = of_get_next_child(root, child)); ) { ++ for_each_child_of_node(root, child) { + if (!of_match_node(matches, child)) + continue; + +@@ -197,16 +198,13 @@ + /* If the driver uses devices that ibmebus doesn't know, add them */ + ibmebus_create_devices(drv->match_table); + +- drv->driver.name = drv->name; +- drv->driver.bus = &ibmebus_bus_type; +- +- return driver_register(&drv->driver); ++ return of_register_driver(drv, &ibmebus_bus_type); + } + EXPORT_SYMBOL(ibmebus_register_driver); + + void ibmebus_unregister_driver(struct of_platform_driver *drv) + { +- driver_unregister(&drv->driver); ++ of_unregister_driver(drv); + } + EXPORT_SYMBOL(ibmebus_unregister_driver); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/iommu.c powerpc.git/arch/powerpc/kernel/iommu.c +--- linux-2.6.24/arch/powerpc/kernel/iommu.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/iommu.c 2008-01-28 20:25:49.000000000 +0100 +@@ -532,16 +532,14 @@ + return tbl; + } + +-void iommu_free_table(struct device_node *dn) ++void iommu_free_table(struct iommu_table *tbl, const char *node_name) + { +- struct pci_dn *pdn = dn->data; +- struct iommu_table *tbl = pdn->iommu_table; + unsigned long bitmap_sz, i; + unsigned int order; + + if (!tbl || !tbl->it_map) { + printk(KERN_ERR "%s: expected TCE map for %s\n", __FUNCTION__, +- dn->full_name); ++ node_name); + return; + } + +@@ -550,7 +548,7 @@ + for (i = 0; i < (tbl->it_size/64); i++) { + if (tbl->it_map[i] != 0) { + printk(KERN_WARNING "%s: Unexpected TCEs for %s\n", +- __FUNCTION__, dn->full_name); ++ __FUNCTION__, node_name); + break; + } + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/isa-bridge.c powerpc.git/arch/powerpc/kernel/isa-bridge.c +--- linux-2.6.24/arch/powerpc/kernel/isa-bridge.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/isa-bridge.c 2008-01-28 20:25:49.000000000 +0100 +@@ -108,7 +108,7 @@ + if (size > 0x10000) + size = 0x10000; + +- printk(KERN_ERR "no ISA IO ranges or unexpected isa range," ++ printk(KERN_ERR "no ISA IO ranges or unexpected isa range, " + "mapping 64k\n"); + + __ioremap_at(phb_io_base_phys, (void *)ISA_IO_BASE, +@@ -116,7 +116,7 @@ + return; + + inval_range: +- printk(KERN_ERR "no ISA IO ranges or unexpected isa range," ++ printk(KERN_ERR "no ISA IO ranges or unexpected isa range, " + "mapping 64k\n"); + __ioremap_at(phb_io_base_phys, (void *)ISA_IO_BASE, + 0x10000, _PAGE_NO_CACHE|_PAGE_GUARDED); +@@ -145,7 +145,7 @@ + for_each_node_by_type(np, "isa") { + /* Look for our hose being a parent */ + for (parent = of_get_parent(np); parent;) { +- if (parent == hose->arch_data) { ++ if (parent == hose->dn) { + of_node_put(parent); + break; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/legacy_serial.c powerpc.git/arch/powerpc/kernel/legacy_serial.c +--- linux-2.6.24/arch/powerpc/kernel/legacy_serial.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/legacy_serial.c 2008-01-28 20:25:49.000000000 +0100 +@@ -307,7 +307,7 @@ + } + + /* First fill our array with SOC ports */ +- for (np = NULL; (np = of_find_compatible_node(np, "serial", "ns16550")) != NULL;) { ++ for_each_compatible_node(np, "serial", "ns16550") { + struct device_node *soc = of_get_parent(np); + if (soc && !strcmp(soc->type, "soc")) { + index = add_legacy_soc_port(np, np); +@@ -318,7 +318,7 @@ + } + + /* First fill our array with ISA ports */ +- for (np = NULL; (np = of_find_node_by_type(np, "serial"));) { ++ for_each_node_by_type(np, "serial") { + struct device_node *isa = of_get_parent(np); + if (isa && !strcmp(isa->name, "isa")) { + index = add_legacy_isa_port(np, isa); +@@ -329,7 +329,7 @@ + } + + /* First fill our array with tsi-bridge ports */ +- for (np = NULL; (np = of_find_compatible_node(np, "serial", "ns16550")) != NULL;) { ++ for_each_compatible_node(np, "serial", "ns16550") { + struct device_node *tsi = of_get_parent(np); + if (tsi && !strcmp(tsi->type, "tsi-bridge")) { + index = add_legacy_soc_port(np, np); +@@ -340,7 +340,7 @@ + } + + /* First fill our array with opb bus ports */ +- for (np = NULL; (np = of_find_compatible_node(np, "serial", "ns16550")) != NULL;) { ++ for_each_compatible_node(np, "serial", "ns16550") { + struct device_node *opb = of_get_parent(np); + if (opb && (!strcmp(opb->type, "opb") || + of_device_is_compatible(opb, "ibm,opb"))) { +@@ -474,7 +474,7 @@ + + /* + * Before we register the platfrom serial devices, we need +- * to fixup their interrutps and their IO ports. ++ * to fixup their interrupts and their IO ports. + */ + DBG("Fixing serial ports interrupts and IO ports ...\n"); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/lparcfg.c powerpc.git/arch/powerpc/kernel/lparcfg.c +--- linux-2.6.24/arch/powerpc/kernel/lparcfg.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/lparcfg.c 2008-01-28 20:25:49.000000000 +0100 +@@ -41,7 +41,6 @@ + /* #define LPARCFG_DEBUG */ + + static struct proc_dir_entry *proc_ppc64_lparcfg; +-#define LPARCFG_BUFF_SIZE 4096 + + /* + * Track sum of all purrs across all processors. This is used to further +@@ -595,13 +594,6 @@ + ent = create_proc_entry("ppc64/lparcfg", mode, NULL); + if (ent) { + ent->proc_fops = &lparcfg_fops; +- ent->data = kmalloc(LPARCFG_BUFF_SIZE, GFP_KERNEL); +- if (!ent->data) { +- printk(KERN_ERR +- "Failed to allocate buffer for lparcfg\n"); +- remove_proc_entry("lparcfg", ent->parent); +- return -ENOMEM; +- } + } else { + printk(KERN_ERR "Failed to create ppc64/lparcfg\n"); + return -EIO; +@@ -613,10 +605,8 @@ + + void __exit lparcfg_cleanup(void) + { +- if (proc_ppc64_lparcfg) { +- kfree(proc_ppc64_lparcfg->data); ++ if (proc_ppc64_lparcfg) + remove_proc_entry("lparcfg", proc_ppc64_lparcfg->parent); +- } + } + + module_init(lparcfg_init); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/misc.S powerpc.git/arch/powerpc/kernel/misc.S +--- linux-2.6.24/arch/powerpc/kernel/misc.S 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/misc.S 2008-01-28 20:25:49.000000000 +0100 +@@ -8,12 +8,17 @@ + * Adapted for iSeries by Mike Corrigan (mikejc@us.ibm.com) + * PPC64 updates by Dave Engebretsen (engebret@us.ibm.com) + * ++ * setjmp/longjmp code by Paul Mackerras. ++ * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version + * 2 of the License, or (at your option) any later version. + */ + #include <asm/ppc_asm.h> ++#include <asm/unistd.h> ++#include <asm/asm-compat.h> ++#include <asm/asm-offsets.h> + + .text + +@@ -43,3 +48,71 @@ + add r3,r3,r5 + mtlr r0 + blr ++ ++_GLOBAL(kernel_execve) ++ li r0,__NR_execve ++ sc ++ bnslr ++ neg r3,r3 ++ blr ++ ++_GLOBAL(setjmp) ++ mflr r0 ++ PPC_STL r0,0(r3) ++ PPC_STL r1,SZL(r3) ++ PPC_STL r2,2*SZL(r3) ++ mfcr r0 ++ PPC_STL r0,3*SZL(r3) ++ PPC_STL r13,4*SZL(r3) ++ PPC_STL r14,5*SZL(r3) ++ PPC_STL r15,6*SZL(r3) ++ PPC_STL r16,7*SZL(r3) ++ PPC_STL r17,8*SZL(r3) ++ PPC_STL r18,9*SZL(r3) ++ PPC_STL r19,10*SZL(r3) ++ PPC_STL r20,11*SZL(r3) ++ PPC_STL r21,12*SZL(r3) ++ PPC_STL r22,13*SZL(r3) ++ PPC_STL r23,14*SZL(r3) ++ PPC_STL r24,15*SZL(r3) ++ PPC_STL r25,16*SZL(r3) ++ PPC_STL r26,17*SZL(r3) ++ PPC_STL r27,18*SZL(r3) ++ PPC_STL r28,19*SZL(r3) ++ PPC_STL r29,20*SZL(r3) ++ PPC_STL r30,21*SZL(r3) ++ PPC_STL r31,22*SZL(r3) ++ li r3,0 ++ blr ++ ++_GLOBAL(longjmp) ++ PPC_LCMPI r4,0 ++ bne 1f ++ li r4,1 ++1: PPC_LL r13,4*SZL(r3) ++ PPC_LL r14,5*SZL(r3) ++ PPC_LL r15,6*SZL(r3) ++ PPC_LL r16,7*SZL(r3) ++ PPC_LL r17,8*SZL(r3) ++ PPC_LL r18,9*SZL(r3) ++ PPC_LL r19,10*SZL(r3) ++ PPC_LL r20,11*SZL(r3) ++ PPC_LL r21,12*SZL(r3) ++ PPC_LL r22,13*SZL(r3) ++ PPC_LL r23,14*SZL(r3) ++ PPC_LL r24,15*SZL(r3) ++ PPC_LL r25,16*SZL(r3) ++ PPC_LL r26,17*SZL(r3) ++ PPC_LL r27,18*SZL(r3) ++ PPC_LL r28,19*SZL(r3) ++ PPC_LL r29,20*SZL(r3) ++ PPC_LL r30,21*SZL(r3) ++ PPC_LL r31,22*SZL(r3) ++ PPC_LL r0,3*SZL(r3) ++ mtcrf 0x38,r0 ++ PPC_LL r0,0(r3) ++ PPC_LL r1,SZL(r3) ++ PPC_LL r2,2*SZL(r3) ++ mtlr r0 ++ mr r3,r4 ++ blr +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/misc_32.S powerpc.git/arch/powerpc/kernel/misc_32.S +--- linux-2.6.24/arch/powerpc/kernel/misc_32.S 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/misc_32.S 2008-01-28 20:25:49.000000000 +0100 +@@ -206,6 +206,45 @@ + isync + blr /* Done */ + ++#ifdef CONFIG_40x ++ ++/* ++ * Do an IO access in real mode ++ */ ++_GLOBAL(real_readb) ++ mfmsr r7 ++ ori r0,r7,MSR_DR ++ xori r0,r0,MSR_DR ++ sync ++ mtmsr r0 ++ sync ++ isync ++ lbz r3,0(r3) ++ sync ++ mtmsr r7 ++ sync ++ isync ++ blr ++ ++ /* ++ * Do an IO access in real mode ++ */ ++_GLOBAL(real_writeb) ++ mfmsr r7 ++ ori r0,r7,MSR_DR ++ xori r0,r0,MSR_DR ++ sync ++ mtmsr r0 ++ sync ++ isync ++ stb r3,0(r4) ++ sync ++ mtmsr r7 ++ sync ++ isync ++ blr ++ ++#endif /* CONFIG_40x */ + + /* + * Flush MMU TLB +@@ -793,13 +832,6 @@ + addi r1,r1,16 + blr + +-_GLOBAL(kernel_execve) +- li r0,__NR_execve +- sc +- bnslr +- neg r3,r3 +- blr +- + /* + * This routine is just here to keep GCC happy - sigh... + */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/misc_64.S powerpc.git/arch/powerpc/kernel/misc_64.S +--- linux-2.6.24/arch/powerpc/kernel/misc_64.S 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/misc_64.S 2008-01-28 20:25:49.000000000 +0100 +@@ -518,13 +518,6 @@ + + #endif /* CONFIG_ALTIVEC */ + +-_GLOBAL(kernel_execve) +- li r0,__NR_execve +- sc +- bnslr +- neg r3,r3 +- blr +- + /* kexec_wait(phys_cpu) + * + * wait for the flag to change, indicating this kernel is going away but +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/module_32.c powerpc.git/arch/powerpc/kernel/module_32.c +--- linux-2.6.24/arch/powerpc/kernel/module_32.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/module_32.c 2008-01-28 20:25:49.000000000 +0100 +@@ -24,6 +24,7 @@ + #include <linux/kernel.h> + #include <linux/cache.h> + #include <linux/bug.h> ++#include <linux/sort.h> + + #include "setup.h" + +@@ -54,22 +55,60 @@ + addend) */ + static unsigned int count_relocs(const Elf32_Rela *rela, unsigned int num) + { +- unsigned int i, j, ret = 0; ++ unsigned int i, r_info, r_addend, _count_relocs; + +- /* Sure, this is order(n^2), but it's usually short, and not +- time critical */ +- for (i = 0; i < num; i++) { +- for (j = 0; j < i; j++) { +- /* If this addend appeared before, it's +- already been counted */ +- if (ELF32_R_SYM(rela[i].r_info) +- == ELF32_R_SYM(rela[j].r_info) +- && rela[i].r_addend == rela[j].r_addend) +- break; ++ _count_relocs = 0; ++ r_info = 0; ++ r_addend = 0; ++ for (i = 0; i < num; i++) ++ /* Only count 24-bit relocs, others don't need stubs */ ++ if (ELF32_R_TYPE(rela[i].r_info) == R_PPC_REL24 && ++ (r_info != ELF32_R_SYM(rela[i].r_info) || ++ r_addend != rela[i].r_addend)) { ++ _count_relocs++; ++ r_info = ELF32_R_SYM(rela[i].r_info); ++ r_addend = rela[i].r_addend; + } +- if (j == i) ret++; ++ ++ return _count_relocs; ++} ++ ++static int relacmp(const void *_x, const void *_y) ++{ ++ const Elf32_Rela *x, *y; ++ ++ y = (Elf32_Rela *)_x; ++ x = (Elf32_Rela *)_y; ++ ++ /* Compare the entire r_info (as opposed to ELF32_R_SYM(r_info) only) to ++ * make the comparison cheaper/faster. It won't affect the sorting or ++ * the counting algorithms' performance ++ */ ++ if (x->r_info < y->r_info) ++ return -1; ++ else if (x->r_info > y->r_info) ++ return 1; ++ else if (x->r_addend < y->r_addend) ++ return -1; ++ else if (x->r_addend > y->r_addend) ++ return 1; ++ else ++ return 0; ++} ++ ++static void relaswap(void *_x, void *_y, int size) ++{ ++ uint32_t *x, *y, tmp; ++ int i; ++ ++ y = (uint32_t *)_x; ++ x = (uint32_t *)_y; ++ ++ for (i = 0; i < sizeof(Elf32_Rela) / sizeof(uint32_t); i++) { ++ tmp = x[i]; ++ x[i] = y[i]; ++ y[i] = tmp; + } +- return ret; + } + + /* Get the potential trampolines size required of the init and +@@ -100,6 +139,16 @@ + DEBUGP("Ptr: %p. Number: %u\n", + (void *)hdr + sechdrs[i].sh_offset, + sechdrs[i].sh_size / sizeof(Elf32_Rela)); ++ ++ /* Sort the relocation information based on a symbol and ++ * addend key. This is a stable O(n*log n) complexity ++ * alogrithm but it will reduce the complexity of ++ * count_relocs() to linear complexity O(n) ++ */ ++ sort((void *)hdr + sechdrs[i].sh_offset, ++ sechdrs[i].sh_size / sizeof(Elf32_Rela), ++ sizeof(Elf32_Rela), relacmp, relaswap); ++ + ret += count_relocs((void *)hdr + + sechdrs[i].sh_offset, + sechdrs[i].sh_size +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/module_64.c powerpc.git/arch/powerpc/kernel/module_64.c +--- linux-2.6.24/arch/powerpc/kernel/module_64.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/module_64.c 2008-01-28 20:25:49.000000000 +0100 +@@ -24,6 +24,7 @@ + #include <asm/module.h> + #include <asm/uaccess.h> + #include <asm/firmware.h> ++#include <linux/sort.h> + + #include "setup.h" + +@@ -81,25 +82,23 @@ + different addend) */ + static unsigned int count_relocs(const Elf64_Rela *rela, unsigned int num) + { +- unsigned int i, j, ret = 0; ++ unsigned int i, r_info, r_addend, _count_relocs; + + /* FIXME: Only count external ones --RR */ +- /* Sure, this is order(n^2), but it's usually short, and not +- time critical */ +- for (i = 0; i < num; i++) { ++ _count_relocs = 0; ++ r_info = 0; ++ r_addend = 0; ++ for (i = 0; i < num; i++) + /* Only count 24-bit relocs, others don't need stubs */ +- if (ELF64_R_TYPE(rela[i].r_info) != R_PPC_REL24) +- continue; +- for (j = 0; j < i; j++) { +- /* If this addend appeared before, it's +- already been counted */ +- if (rela[i].r_info == rela[j].r_info +- && rela[i].r_addend == rela[j].r_addend) +- break; ++ if (ELF64_R_TYPE(rela[i].r_info) == R_PPC_REL24 && ++ (r_info != ELF64_R_SYM(rela[i].r_info) || ++ r_addend != rela[i].r_addend)) { ++ _count_relocs++; ++ r_info = ELF64_R_SYM(rela[i].r_info); ++ r_addend = rela[i].r_addend; + } +- if (j == i) ret++; +- } +- return ret; ++ ++ return _count_relocs; + } + + void *module_alloc(unsigned long size) +@@ -118,6 +117,44 @@ + table entries. */ + } + ++static int relacmp(const void *_x, const void *_y) ++{ ++ const Elf64_Rela *x, *y; ++ ++ y = (Elf64_Rela *)_x; ++ x = (Elf64_Rela *)_y; ++ ++ /* Compare the entire r_info (as opposed to ELF64_R_SYM(r_info) only) to ++ * make the comparison cheaper/faster. It won't affect the sorting or ++ * the counting algorithms' performance ++ */ ++ if (x->r_info < y->r_info) ++ return -1; ++ else if (x->r_info > y->r_info) ++ return 1; ++ else if (x->r_addend < y->r_addend) ++ return -1; ++ else if (x->r_addend > y->r_addend) ++ return 1; ++ else ++ return 0; ++} ++ ++static void relaswap(void *_x, void *_y, int size) ++{ ++ uint64_t *x, *y, tmp; ++ int i; ++ ++ y = (uint64_t *)_x; ++ x = (uint64_t *)_y; ++ ++ for (i = 0; i < sizeof(Elf64_Rela) / sizeof(uint64_t); i++) { ++ tmp = x[i]; ++ x[i] = y[i]; ++ y[i] = tmp; ++ } ++} ++ + /* Get size of potential trampolines required. */ + static unsigned long get_stubs_size(const Elf64_Ehdr *hdr, + const Elf64_Shdr *sechdrs) +@@ -133,6 +170,16 @@ + DEBUGP("Ptr: %p. Number: %lu\n", + (void *)sechdrs[i].sh_addr, + sechdrs[i].sh_size / sizeof(Elf64_Rela)); ++ ++ /* Sort the relocation information based on a symbol and ++ * addend key. This is a stable O(n*log n) complexity ++ * alogrithm but it will reduce the complexity of ++ * count_relocs() to linear complexity O(n) ++ */ ++ sort((void *)sechdrs[i].sh_addr, ++ sechdrs[i].sh_size / sizeof(Elf64_Rela), ++ sizeof(Elf64_Rela), relacmp, relaswap); ++ + relocs += count_relocs((void *)sechdrs[i].sh_addr, + sechdrs[i].sh_size + / sizeof(Elf64_Rela)); +@@ -343,7 +390,7 @@ + /* Simply set it */ + *(u32 *)location = value; + break; +- ++ + case R_PPC64_ADDR64: + /* Simply set it */ + *(unsigned long *)location = value; +@@ -399,7 +446,7 @@ + } + + /* Only replace bits 2 through 26 */ +- *(uint32_t *)location ++ *(uint32_t *)location + = (*(uint32_t *)location & ~0x03fffffc) + | (value & 0x03fffffc); + break; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/of_device.c powerpc.git/arch/powerpc/kernel/of_device.c +--- linux-2.6.24/arch/powerpc/kernel/of_device.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/of_device.c 2008-01-28 20:25:49.000000000 +0100 +@@ -5,10 +5,10 @@ + #include <linux/module.h> + #include <linux/mod_devicetable.h> + #include <linux/slab.h> ++#include <linux/of_device.h> + + #include <asm/errno.h> + #include <asm/dcr.h> +-#include <asm/of_device.h> + + static void of_device_make_bus_id(struct of_device *dev) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/of_platform.c powerpc.git/arch/powerpc/kernel/of_platform.c +--- linux-2.6.24/arch/powerpc/kernel/of_platform.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/of_platform.c 2008-01-28 20:25:49.000000000 +0100 +@@ -19,6 +19,7 @@ + #include <linux/mod_devicetable.h> + #include <linux/slab.h> + #include <linux/pci.h> ++#include <linux/of.h> + #include <linux/of_device.h> + #include <linux/of_platform.h> + +@@ -40,7 +41,7 @@ + * a bus type in the list + */ + +-static struct of_device_id of_default_bus_ids[] = { ++static const struct of_device_id of_default_bus_ids[] = { + { .type = "soc", }, + { .compatible = "soc", }, + { .type = "spider", }, +@@ -64,26 +65,6 @@ + + postcore_initcall(of_bus_driver_init); + +-int of_register_platform_driver(struct of_platform_driver *drv) +-{ +- /* initialize common driver fields */ +- if (!drv->driver.name) +- drv->driver.name = drv->name; +- if (!drv->driver.owner) +- drv->driver.owner = drv->owner; +- drv->driver.bus = &of_platform_bus_type; +- +- /* register with core */ +- return driver_register(&drv->driver); +-} +-EXPORT_SYMBOL(of_register_platform_driver); +- +-void of_unregister_platform_driver(struct of_platform_driver *drv) +-{ +- driver_unregister(&drv->driver); +-} +-EXPORT_SYMBOL(of_unregister_platform_driver); +- + struct of_device* of_platform_device_create(struct device_node *np, + const char *bus_id, + struct device *parent) +@@ -120,15 +101,15 @@ + * @matches: match table, NULL to use the default, OF_NO_DEEP_PROBE to + * disallow recursive creation of child busses + */ +-static int of_platform_bus_create(struct device_node *bus, +- struct of_device_id *matches, ++static int of_platform_bus_create(const struct device_node *bus, ++ const struct of_device_id *matches, + struct device *parent) + { + struct device_node *child; + struct of_device *dev; + int rc = 0; + +- for (child = NULL; (child = of_get_next_child(bus, child)); ) { ++ for_each_child_of_node(bus, child) { + pr_debug(" create child: %s\n", child->full_name); + dev = of_platform_device_create(child, NULL, parent); + if (dev == NULL) +@@ -157,7 +138,7 @@ + */ + + int of_platform_bus_probe(struct device_node *root, +- struct of_device_id *matches, ++ const struct of_device_id *matches, + struct device *parent) + { + struct device_node *child; +@@ -190,7 +171,7 @@ + rc = of_platform_bus_create(root, matches, &dev->dev); + goto bail; + } +- for (child = NULL; (child = of_get_next_child(root, child)); ) { ++ for_each_child_of_node(root, child) { + if (!of_match_node(matches, child)) + continue; + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/pci-common.c powerpc.git/arch/powerpc/kernel/pci-common.c +--- linux-2.6.24/arch/powerpc/kernel/pci-common.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/pci-common.c 2008-01-28 20:25:49.000000000 +0100 +@@ -48,32 +48,26 @@ + static DEFINE_SPINLOCK(hose_spinlock); + + /* XXX kill that some day ... */ +-int global_phb_number; /* Global phb counter */ ++static int global_phb_number; /* Global phb counter */ + +-extern struct list_head hose_list; ++/* ISA Memory physical address */ ++resource_size_t isa_mem_base; + +-/* +- * pci_controller(phb) initialized common variables. +- */ +-static void __devinit pci_setup_pci_controller(struct pci_controller *hose) +-{ +- memset(hose, 0, sizeof(struct pci_controller)); +- +- spin_lock(&hose_spinlock); +- hose->global_number = global_phb_number++; +- list_add_tail(&hose->list_node, &hose_list); +- spin_unlock(&hose_spinlock); +-} ++/* Default PCI flags is 0 */ ++unsigned int ppc_pci_flags; + +-struct pci_controller * pcibios_alloc_controller(struct device_node *dev) ++struct pci_controller *pcibios_alloc_controller(struct device_node *dev) + { + struct pci_controller *phb; + +- phb = alloc_maybe_bootmem(sizeof(struct pci_controller), GFP_KERNEL); ++ phb = zalloc_maybe_bootmem(sizeof(struct pci_controller), GFP_KERNEL); + if (phb == NULL) + return NULL; +- pci_setup_pci_controller(phb); +- phb->arch_data = dev; ++ spin_lock(&hose_spinlock); ++ phb->global_number = global_phb_number++; ++ list_add_tail(&phb->list_node, &hose_list); ++ spin_unlock(&hose_spinlock); ++ phb->dn = dev; + phb->is_dynamic = mem_init_done; + #ifdef CONFIG_PPC64 + if (dev) { +@@ -126,15 +120,10 @@ + */ + int pci_domain_nr(struct pci_bus *bus) + { +- if (firmware_has_feature(FW_FEATURE_ISERIES)) +- return 0; +- else { +- struct pci_controller *hose = pci_bus_to_host(bus); ++ struct pci_controller *hose = pci_bus_to_host(bus); + +- return hose->global_number; +- } ++ return hose->global_number; + } +- + EXPORT_SYMBOL(pci_domain_nr); + + #ifdef CONFIG_PPC_OF +@@ -153,7 +142,7 @@ + while(node) { + struct pci_controller *hose, *tmp; + list_for_each_entry_safe(hose, tmp, &hose_list, list_node) +- if (hose->arch_data == node) ++ if (hose->dn == node) + return hose; + node = node->parent; + } +@@ -201,6 +190,20 @@ + struct of_irq oirq; + unsigned int virq; + ++ /* The current device-tree that iSeries generates from the HV ++ * PCI informations doesn't contain proper interrupt routing, ++ * and all the fallback would do is print out crap, so we ++ * don't attempt to resolve the interrupts here at all, some ++ * iSeries specific fixup does it. ++ * ++ * In the long run, we will hopefully fix the generated device-tree ++ * instead. ++ */ ++#ifdef CONFIG_PPC_ISERIES ++ if (firmware_has_feature(FW_FEATURE_ISERIES)) ++ return -1; ++#endif ++ + DBG("Try to map irq for %s...\n", pci_name(pci_dev)); + + #ifdef DEBUG +@@ -222,10 +225,11 @@ + if (pin == 0) + return -1; + if (pci_read_config_byte(pci_dev, PCI_INTERRUPT_LINE, &line) || +- line == 0xff) { ++ line == 0xff || line == 0) { + return -1; + } +- DBG(" -> no map ! Using irq line %d from PCI config\n", line); ++ DBG(" -> no map ! Using line %d (pin %d) from PCI config\n", ++ line, pin); + + virq = irq_create_mapping(NULL, line); + if (virq != NO_IRQ) +@@ -475,3 +479,717 @@ + *start = rsrc->start - offset; + *end = rsrc->end - offset; + } ++ ++/** ++ * pci_process_bridge_OF_ranges - Parse PCI bridge resources from device tree ++ * @hose: newly allocated pci_controller to be setup ++ * @dev: device node of the host bridge ++ * @primary: set if primary bus (32 bits only, soon to be deprecated) ++ * ++ * This function will parse the "ranges" property of a PCI host bridge device ++ * node and setup the resource mapping of a pci controller based on its ++ * content. ++ * ++ * Life would be boring if it wasn't for a few issues that we have to deal ++ * with here: ++ * ++ * - We can only cope with one IO space range and up to 3 Memory space ++ * ranges. However, some machines (thanks Apple !) tend to split their ++ * space into lots of small contiguous ranges. So we have to coalesce. ++ * ++ * - We can only cope with all memory ranges having the same offset ++ * between CPU addresses and PCI addresses. Unfortunately, some bridges ++ * are setup for a large 1:1 mapping along with a small "window" which ++ * maps PCI address 0 to some arbitrary high address of the CPU space in ++ * order to give access to the ISA memory hole. ++ * The way out of here that I've chosen for now is to always set the ++ * offset based on the first resource found, then override it if we ++ * have a different offset and the previous was set by an ISA hole. ++ * ++ * - Some busses have IO space not starting at 0, which causes trouble with ++ * the way we do our IO resource renumbering. The code somewhat deals with ++ * it for 64 bits but I would expect problems on 32 bits. ++ * ++ * - Some 32 bits platforms such as 4xx can have physical space larger than ++ * 32 bits so we need to use 64 bits values for the parsing ++ */ ++void __devinit pci_process_bridge_OF_ranges(struct pci_controller *hose, ++ struct device_node *dev, ++ int primary) ++{ ++ const u32 *ranges; ++ int rlen; ++ int pna = of_n_addr_cells(dev); ++ int np = pna + 5; ++ int memno = 0, isa_hole = -1; ++ u32 pci_space; ++ unsigned long long pci_addr, cpu_addr, pci_next, cpu_next, size; ++ unsigned long long isa_mb = 0; ++ struct resource *res; ++ ++ printk(KERN_INFO "PCI host bridge %s %s ranges:\n", ++ dev->full_name, primary ? "(primary)" : ""); ++ ++ /* Get ranges property */ ++ ranges = of_get_property(dev, "ranges", &rlen); ++ if (ranges == NULL) ++ return; ++ ++ /* Parse it */ ++ while ((rlen -= np * 4) >= 0) { ++ /* Read next ranges element */ ++ pci_space = ranges[0]; ++ pci_addr = of_read_number(ranges + 1, 2); ++ cpu_addr = of_translate_address(dev, ranges + 3); ++ size = of_read_number(ranges + pna + 3, 2); ++ ranges += np; ++ if (cpu_addr == OF_BAD_ADDR || size == 0) ++ continue; ++ ++ /* Now consume following elements while they are contiguous */ ++ for (; rlen >= np * sizeof(u32); ++ ranges += np, rlen -= np * 4) { ++ if (ranges[0] != pci_space) ++ break; ++ pci_next = of_read_number(ranges + 1, 2); ++ cpu_next = of_translate_address(dev, ranges + 3); ++ if (pci_next != pci_addr + size || ++ cpu_next != cpu_addr + size) ++ break; ++ size += of_read_number(ranges + pna + 3, 2); ++ } ++ ++ /* Act based on address space type */ ++ res = NULL; ++ switch ((pci_space >> 24) & 0x3) { ++ case 1: /* PCI IO space */ ++ printk(KERN_INFO ++ " IO 0x%016llx..0x%016llx -> 0x%016llx\n", ++ cpu_addr, cpu_addr + size - 1, pci_addr); ++ ++ /* We support only one IO range */ ++ if (hose->pci_io_size) { ++ printk(KERN_INFO ++ " \\--> Skipped (too many) !\n"); ++ continue; ++ } ++#ifdef CONFIG_PPC32 ++ /* On 32 bits, limit I/O space to 16MB */ ++ if (size > 0x01000000) ++ size = 0x01000000; ++ ++ /* 32 bits needs to map IOs here */ ++ hose->io_base_virt = ioremap(cpu_addr, size); ++ ++ /* Expect trouble if pci_addr is not 0 */ ++ if (primary) ++ isa_io_base = ++ (unsigned long)hose->io_base_virt; ++#endif /* CONFIG_PPC32 */ ++ /* pci_io_size and io_base_phys always represent IO ++ * space starting at 0 so we factor in pci_addr ++ */ ++ hose->pci_io_size = pci_addr + size; ++ hose->io_base_phys = cpu_addr - pci_addr; ++ ++ /* Build resource */ ++ res = &hose->io_resource; ++ res->flags = IORESOURCE_IO; ++ res->start = pci_addr; ++ break; ++ case 2: /* PCI Memory space */ ++ printk(KERN_INFO ++ " MEM 0x%016llx..0x%016llx -> 0x%016llx %s\n", ++ cpu_addr, cpu_addr + size - 1, pci_addr, ++ (pci_space & 0x40000000) ? "Prefetch" : ""); ++ ++ /* We support only 3 memory ranges */ ++ if (memno >= 3) { ++ printk(KERN_INFO ++ " \\--> Skipped (too many) !\n"); ++ continue; ++ } ++ /* Handles ISA memory hole space here */ ++ if (pci_addr == 0) { ++ isa_mb = cpu_addr; ++ isa_hole = memno; ++ if (primary || isa_mem_base == 0) ++ isa_mem_base = cpu_addr; ++ } ++ ++ /* We get the PCI/Mem offset from the first range or ++ * the, current one if the offset came from an ISA ++ * hole. If they don't match, bugger. ++ */ ++ if (memno == 0 || ++ (isa_hole >= 0 && pci_addr != 0 && ++ hose->pci_mem_offset == isa_mb)) ++ hose->pci_mem_offset = cpu_addr - pci_addr; ++ else if (pci_addr != 0 && ++ hose->pci_mem_offset != cpu_addr - pci_addr) { ++ printk(KERN_INFO ++ " \\--> Skipped (offset mismatch) !\n"); ++ continue; ++ } ++ ++ /* Build resource */ ++ res = &hose->mem_resources[memno++]; ++ res->flags = IORESOURCE_MEM; ++ if (pci_space & 0x40000000) ++ res->flags |= IORESOURCE_PREFETCH; ++ res->start = cpu_addr; ++ break; ++ } ++ if (res != NULL) { ++ res->name = dev->full_name; ++ res->end = res->start + size - 1; ++ res->parent = NULL; ++ res->sibling = NULL; ++ res->child = NULL; ++ } ++ } ++ ++ /* Out of paranoia, let's put the ISA hole last if any */ ++ if (isa_hole >= 0 && memno > 0 && isa_hole != (memno-1)) { ++ struct resource tmp = hose->mem_resources[isa_hole]; ++ hose->mem_resources[isa_hole] = hose->mem_resources[memno-1]; ++ hose->mem_resources[memno-1] = tmp; ++ } ++} ++ ++/* Decide whether to display the domain number in /proc */ ++int pci_proc_domain(struct pci_bus *bus) ++{ ++ struct pci_controller *hose = pci_bus_to_host(bus); ++#ifdef CONFIG_PPC64 ++ return hose->buid != 0; ++#else ++ if (!(ppc_pci_flags & PPC_PCI_ENABLE_PROC_DOMAINS)) ++ return 0; ++ if (ppc_pci_flags & PPC_PCI_COMPAT_DOMAIN_0) ++ return hose->global_number != 0; ++ return 1; ++#endif ++} ++ ++void pcibios_resource_to_bus(struct pci_dev *dev, struct pci_bus_region *region, ++ struct resource *res) ++{ ++ resource_size_t offset = 0, mask = (resource_size_t)-1; ++ struct pci_controller *hose = pci_bus_to_host(dev->bus); ++ ++ if (!hose) ++ return; ++ if (res->flags & IORESOURCE_IO) { ++ offset = (unsigned long)hose->io_base_virt - _IO_BASE; ++ mask = 0xffffffffu; ++ } else if (res->flags & IORESOURCE_MEM) ++ offset = hose->pci_mem_offset; ++ ++ region->start = (res->start - offset) & mask; ++ region->end = (res->end - offset) & mask; ++} ++EXPORT_SYMBOL(pcibios_resource_to_bus); ++ ++void pcibios_bus_to_resource(struct pci_dev *dev, struct resource *res, ++ struct pci_bus_region *region) ++{ ++ resource_size_t offset = 0, mask = (resource_size_t)-1; ++ struct pci_controller *hose = pci_bus_to_host(dev->bus); ++ ++ if (!hose) ++ return; ++ if (res->flags & IORESOURCE_IO) { ++ offset = (unsigned long)hose->io_base_virt - _IO_BASE; ++ mask = 0xffffffffu; ++ } else if (res->flags & IORESOURCE_MEM) ++ offset = hose->pci_mem_offset; ++ res->start = (region->start + offset) & mask; ++ res->end = (region->end + offset) & mask; ++} ++EXPORT_SYMBOL(pcibios_bus_to_resource); ++ ++/* Fixup a bus resource into a linux resource */ ++static void __devinit fixup_resource(struct resource *res, struct pci_dev *dev) ++{ ++ struct pci_controller *hose = pci_bus_to_host(dev->bus); ++ resource_size_t offset = 0, mask = (resource_size_t)-1; ++ ++ if (res->flags & IORESOURCE_IO) { ++ offset = (unsigned long)hose->io_base_virt - _IO_BASE; ++ mask = 0xffffffffu; ++ } else if (res->flags & IORESOURCE_MEM) ++ offset = hose->pci_mem_offset; ++ ++ res->start = (res->start + offset) & mask; ++ res->end = (res->end + offset) & mask; ++ ++ pr_debug("PCI:%s %016llx-%016llx\n", ++ pci_name(dev), ++ (unsigned long long)res->start, ++ (unsigned long long)res->end); ++} ++ ++ ++/* This header fixup will do the resource fixup for all devices as they are ++ * probed, but not for bridge ranges ++ */ ++static void __devinit pcibios_fixup_resources(struct pci_dev *dev) ++{ ++ struct pci_controller *hose = pci_bus_to_host(dev->bus); ++ int i; ++ ++ if (!hose) { ++ printk(KERN_ERR "No host bridge for PCI dev %s !\n", ++ pci_name(dev)); ++ return; ++ } ++ for (i = 0; i < DEVICE_COUNT_RESOURCE; i++) { ++ struct resource *res = dev->resource + i; ++ if (!res->flags) ++ continue; ++ if (res->end == 0xffffffff) { ++ pr_debug("PCI:%s Resource %d %016llx-%016llx [%x] is unassigned\n", ++ pci_name(dev), i, ++ (unsigned long long)res->start, ++ (unsigned long long)res->end, ++ (unsigned int)res->flags); ++ res->end -= res->start; ++ res->start = 0; ++ res->flags |= IORESOURCE_UNSET; ++ continue; ++ } ++ ++ pr_debug("PCI:%s Resource %d %016llx-%016llx [%x] fixup...\n", ++ pci_name(dev), i, ++ (unsigned long long)res->start,\ ++ (unsigned long long)res->end, ++ (unsigned int)res->flags); ++ ++ fixup_resource(res, dev); ++ } ++ ++ /* Call machine specific resource fixup */ ++ if (ppc_md.pcibios_fixup_resources) ++ ppc_md.pcibios_fixup_resources(dev); ++} ++DECLARE_PCI_FIXUP_HEADER(PCI_ANY_ID, PCI_ANY_ID, pcibios_fixup_resources); ++ ++static void __devinit __pcibios_fixup_bus(struct pci_bus *bus) ++{ ++ struct pci_controller *hose = pci_bus_to_host(bus); ++ struct pci_dev *dev = bus->self; ++ ++ pr_debug("PCI: Fixup bus %d (%s)\n", bus->number, dev ? pci_name(dev) : "PHB"); ++ ++ /* Fixup PCI<->PCI bridges. Host bridges are handled separately, for ++ * now differently between 32 and 64 bits. ++ */ ++ if (dev != NULL) { ++ struct resource *res; ++ int i; ++ ++ for (i = 0; i < PCI_BUS_NUM_RESOURCES; ++i) { ++ if ((res = bus->resource[i]) == NULL) ++ continue; ++ if (!res->flags) ++ continue; ++ if (i >= 3 && bus->self->transparent) ++ continue; ++ /* On PowerMac, Apple leaves bridge windows open over ++ * an inaccessible region of memory space (0...fffff) ++ * which is somewhat bogus, but that's what they think ++ * means disabled... ++ * ++ * We clear those to force them to be reallocated later ++ * ++ * We detect such regions by the fact that the base is ++ * equal to the pci_mem_offset of the host bridge and ++ * their size is smaller than 1M. ++ */ ++ if (res->flags & IORESOURCE_MEM && ++ res->start == hose->pci_mem_offset && ++ res->end < 0x100000) { ++ printk(KERN_INFO ++ "PCI: Closing bogus Apple Firmware" ++ " region %d on bus 0x%02x\n", ++ i, bus->number); ++ res->flags = 0; ++ continue; ++ } ++ ++ pr_debug("PCI:%s Bus rsrc %d %016llx-%016llx [%x] fixup...\n", ++ pci_name(dev), i, ++ (unsigned long long)res->start,\ ++ (unsigned long long)res->end, ++ (unsigned int)res->flags); ++ ++ fixup_resource(res, dev); ++ } ++ } ++ ++ /* Additional setup that is different between 32 and 64 bits for now */ ++ pcibios_do_bus_setup(bus); ++ ++ /* Platform specific bus fixups */ ++ if (ppc_md.pcibios_fixup_bus) ++ ppc_md.pcibios_fixup_bus(bus); ++ ++ /* Read default IRQs and fixup if necessary */ ++ list_for_each_entry(dev, &bus->devices, bus_list) { ++ pci_read_irq_line(dev); ++ if (ppc_md.pci_irq_fixup) ++ ppc_md.pci_irq_fixup(dev); ++ } ++} ++ ++void __devinit pcibios_fixup_bus(struct pci_bus *bus) ++{ ++ /* When called from the generic PCI probe, read PCI<->PCI bridge ++ * bases before proceeding ++ */ ++ if (bus->self != NULL) ++ pci_read_bridge_bases(bus); ++ __pcibios_fixup_bus(bus); ++} ++EXPORT_SYMBOL(pcibios_fixup_bus); ++ ++/* When building a bus from the OF tree rather than probing, we need a ++ * slightly different version of the fixup which doesn't read the ++ * bridge bases using config space accesses ++ */ ++void __devinit pcibios_fixup_of_probed_bus(struct pci_bus *bus) ++{ ++ __pcibios_fixup_bus(bus); ++} ++ ++static int skip_isa_ioresource_align(struct pci_dev *dev) ++{ ++ if ((ppc_pci_flags & PPC_PCI_CAN_SKIP_ISA_ALIGN) && ++ !(dev->bus->bridge_ctl & PCI_BRIDGE_CTL_ISA)) ++ return 1; ++ return 0; ++} ++ ++/* ++ * We need to avoid collisions with `mirrored' VGA ports ++ * and other strange ISA hardware, so we always want the ++ * addresses to be allocated in the 0x000-0x0ff region ++ * modulo 0x400. ++ * ++ * Why? Because some silly external IO cards only decode ++ * the low 10 bits of the IO address. The 0x00-0xff region ++ * is reserved for motherboard devices that decode all 16 ++ * bits, so it's ok to allocate at, say, 0x2800-0x28ff, ++ * but we want to try to avoid allocating at 0x2900-0x2bff ++ * which might have be mirrored at 0x0100-0x03ff.. ++ */ ++void pcibios_align_resource(void *data, struct resource *res, ++ resource_size_t size, resource_size_t align) ++{ ++ struct pci_dev *dev = data; ++ ++ if (res->flags & IORESOURCE_IO) { ++ resource_size_t start = res->start; ++ ++ if (skip_isa_ioresource_align(dev)) ++ return; ++ if (start & 0x300) { ++ start = (start + 0x3ff) & ~0x3ff; ++ res->start = start; ++ } ++ } ++} ++EXPORT_SYMBOL(pcibios_align_resource); ++ ++/* ++ * Reparent resource children of pr that conflict with res ++ * under res, and make res replace those children. ++ */ ++static int __init reparent_resources(struct resource *parent, ++ struct resource *res) ++{ ++ struct resource *p, **pp; ++ struct resource **firstpp = NULL; ++ ++ for (pp = &parent->child; (p = *pp) != NULL; pp = &p->sibling) { ++ if (p->end < res->start) ++ continue; ++ if (res->end < p->start) ++ break; ++ if (p->start < res->start || p->end > res->end) ++ return -1; /* not completely contained */ ++ if (firstpp == NULL) ++ firstpp = pp; ++ } ++ if (firstpp == NULL) ++ return -1; /* didn't find any conflicting entries? */ ++ res->parent = parent; ++ res->child = *firstpp; ++ res->sibling = *pp; ++ *firstpp = res; ++ *pp = NULL; ++ for (p = res->child; p != NULL; p = p->sibling) { ++ p->parent = res; ++ DBG(KERN_INFO "PCI: reparented %s [%llx..%llx] under %s\n", ++ p->name, ++ (unsigned long long)p->start, ++ (unsigned long long)p->end, res->name); ++ } ++ return 0; ++} ++ ++/* ++ * Handle resources of PCI devices. If the world were perfect, we could ++ * just allocate all the resource regions and do nothing more. It isn't. ++ * On the other hand, we cannot just re-allocate all devices, as it would ++ * require us to know lots of host bridge internals. So we attempt to ++ * keep as much of the original configuration as possible, but tweak it ++ * when it's found to be wrong. ++ * ++ * Known BIOS problems we have to work around: ++ * - I/O or memory regions not configured ++ * - regions configured, but not enabled in the command register ++ * - bogus I/O addresses above 64K used ++ * - expansion ROMs left enabled (this may sound harmless, but given ++ * the fact the PCI specs explicitly allow address decoders to be ++ * shared between expansion ROMs and other resource regions, it's ++ * at least dangerous) ++ * ++ * Our solution: ++ * (1) Allocate resources for all buses behind PCI-to-PCI bridges. ++ * This gives us fixed barriers on where we can allocate. ++ * (2) Allocate resources for all enabled devices. If there is ++ * a collision, just mark the resource as unallocated. Also ++ * disable expansion ROMs during this step. ++ * (3) Try to allocate resources for disabled devices. If the ++ * resources were assigned correctly, everything goes well, ++ * if they weren't, they won't disturb allocation of other ++ * resources. ++ * (4) Assign new addresses to resources which were either ++ * not configured at all or misconfigured. If explicitly ++ * requested by the user, configure expansion ROM address ++ * as well. ++ */ ++ ++static void __init pcibios_allocate_bus_resources(struct list_head *bus_list) ++{ ++ struct pci_bus *bus; ++ int i; ++ struct resource *res, *pr; ++ ++ /* Depth-First Search on bus tree */ ++ list_for_each_entry(bus, bus_list, node) { ++ for (i = 0; i < PCI_BUS_NUM_RESOURCES; ++i) { ++ if ((res = bus->resource[i]) == NULL || !res->flags ++ || res->start > res->end) ++ continue; ++ if (bus->parent == NULL) ++ pr = (res->flags & IORESOURCE_IO) ? ++ &ioport_resource : &iomem_resource; ++ else { ++ /* Don't bother with non-root busses when ++ * re-assigning all resources. We clear the ++ * resource flags as if they were colliding ++ * and as such ensure proper re-allocation ++ * later. ++ */ ++ if (ppc_pci_flags & PPC_PCI_REASSIGN_ALL_RSRC) ++ goto clear_resource; ++ pr = pci_find_parent_resource(bus->self, res); ++ if (pr == res) { ++ /* this happens when the generic PCI ++ * code (wrongly) decides that this ++ * bridge is transparent -- paulus ++ */ ++ continue; ++ } ++ } ++ ++ DBG("PCI: %s (bus %d) bridge rsrc %d: %016llx-%016llx " ++ "[0x%x], parent %p (%s)\n", ++ bus->self ? pci_name(bus->self) : "PHB", ++ bus->number, i, ++ (unsigned long long)res->start, ++ (unsigned long long)res->end, ++ (unsigned int)res->flags, ++ pr, (pr && pr->name) ? pr->name : "nil"); ++ ++ if (pr && !(pr->flags & IORESOURCE_UNSET)) { ++ if (request_resource(pr, res) == 0) ++ continue; ++ /* ++ * Must be a conflict with an existing entry. ++ * Move that entry (or entries) under the ++ * bridge resource and try again. ++ */ ++ if (reparent_resources(pr, res) == 0) ++ continue; ++ } ++ printk(KERN_WARNING ++ "PCI: Cannot allocate resource region " ++ "%d of PCI bridge %d, will remap\n", ++ i, bus->number); ++clear_resource: ++ res->flags = 0; ++ } ++ pcibios_allocate_bus_resources(&bus->children); ++ } ++} ++ ++static inline void __devinit alloc_resource(struct pci_dev *dev, int idx) ++{ ++ struct resource *pr, *r = &dev->resource[idx]; ++ ++ DBG("PCI: Allocating %s: Resource %d: %016llx..%016llx [%x]\n", ++ pci_name(dev), idx, ++ (unsigned long long)r->start, ++ (unsigned long long)r->end, ++ (unsigned int)r->flags); ++ ++ pr = pci_find_parent_resource(dev, r); ++ if (!pr || (pr->flags & IORESOURCE_UNSET) || ++ request_resource(pr, r) < 0) { ++ printk(KERN_WARNING "PCI: Cannot allocate resource region %d" ++ " of device %s, will remap\n", idx, pci_name(dev)); ++ if (pr) ++ DBG("PCI: parent is %p: %016llx-%016llx [%x]\n", pr, ++ (unsigned long long)pr->start, ++ (unsigned long long)pr->end, ++ (unsigned int)pr->flags); ++ /* We'll assign a new address later */ ++ r->flags |= IORESOURCE_UNSET; ++ r->end -= r->start; ++ r->start = 0; ++ } ++} ++ ++static void __init pcibios_allocate_resources(int pass) ++{ ++ struct pci_dev *dev = NULL; ++ int idx, disabled; ++ u16 command; ++ struct resource *r; ++ ++ for_each_pci_dev(dev) { ++ pci_read_config_word(dev, PCI_COMMAND, &command); ++ for (idx = 0; idx < 6; idx++) { ++ r = &dev->resource[idx]; ++ if (r->parent) /* Already allocated */ ++ continue; ++ if (!r->flags || (r->flags & IORESOURCE_UNSET)) ++ continue; /* Not assigned at all */ ++ if (r->flags & IORESOURCE_IO) ++ disabled = !(command & PCI_COMMAND_IO); ++ else ++ disabled = !(command & PCI_COMMAND_MEMORY); ++ if (pass == disabled) ++ alloc_resource(dev, idx); ++ } ++ if (pass) ++ continue; ++ r = &dev->resource[PCI_ROM_RESOURCE]; ++ if (r->flags & IORESOURCE_ROM_ENABLE) { ++ /* Turn the ROM off, leave the resource region, ++ * but keep it unregistered. ++ */ ++ u32 reg; ++ DBG("PCI: Switching off ROM of %s\n", pci_name(dev)); ++ r->flags &= ~IORESOURCE_ROM_ENABLE; ++ pci_read_config_dword(dev, dev->rom_base_reg, ®); ++ pci_write_config_dword(dev, dev->rom_base_reg, ++ reg & ~PCI_ROM_ADDRESS_ENABLE); ++ } ++ } ++} ++ ++void __init pcibios_resource_survey(void) ++{ ++ /* Allocate and assign resources. If we re-assign everything, then ++ * we skip the allocate phase ++ */ ++ pcibios_allocate_bus_resources(&pci_root_buses); ++ ++ if (!(ppc_pci_flags & PPC_PCI_REASSIGN_ALL_RSRC)) { ++ pcibios_allocate_resources(0); ++ pcibios_allocate_resources(1); ++ } ++ ++ if (!(ppc_pci_flags & PPC_PCI_PROBE_ONLY)) { ++ DBG("PCI: Assigning unassigned resouces...\n"); ++ pci_assign_unassigned_resources(); ++ } ++ ++ /* Call machine dependent fixup */ ++ if (ppc_md.pcibios_fixup) ++ ppc_md.pcibios_fixup(); ++} ++ ++#ifdef CONFIG_HOTPLUG ++/* This is used by the pSeries hotplug driver to allocate resource ++ * of newly plugged busses. We can try to consolidate with the ++ * rest of the code later, for now, keep it as-is ++ */ ++void __devinit pcibios_claim_one_bus(struct pci_bus *bus) ++{ ++ struct pci_dev *dev; ++ struct pci_bus *child_bus; ++ ++ list_for_each_entry(dev, &bus->devices, bus_list) { ++ int i; ++ ++ for (i = 0; i < PCI_NUM_RESOURCES; i++) { ++ struct resource *r = &dev->resource[i]; ++ ++ if (r->parent || !r->start || !r->flags) ++ continue; ++ pci_claim_resource(dev, i); ++ } ++ } ++ ++ list_for_each_entry(child_bus, &bus->children, node) ++ pcibios_claim_one_bus(child_bus); ++} ++EXPORT_SYMBOL_GPL(pcibios_claim_one_bus); ++#endif /* CONFIG_HOTPLUG */ ++ ++int pcibios_enable_device(struct pci_dev *dev, int mask) ++{ ++ u16 cmd, old_cmd; ++ int idx; ++ struct resource *r; ++ ++ if (ppc_md.pcibios_enable_device_hook) ++ if (ppc_md.pcibios_enable_device_hook(dev)) ++ return -EINVAL; ++ ++ pci_read_config_word(dev, PCI_COMMAND, &cmd); ++ old_cmd = cmd; ++ for (idx = 0; idx < PCI_NUM_RESOURCES; idx++) { ++ /* Only set up the requested stuff */ ++ if (!(mask & (1 << idx))) ++ continue; ++ r = &dev->resource[idx]; ++ if (!(r->flags & (IORESOURCE_IO | IORESOURCE_MEM))) ++ continue; ++ if ((idx == PCI_ROM_RESOURCE) && ++ (!(r->flags & IORESOURCE_ROM_ENABLE))) ++ continue; ++ if (r->parent == NULL) { ++ printk(KERN_ERR "PCI: Device %s not available because" ++ " of resource collisions\n", pci_name(dev)); ++ return -EINVAL; ++ } ++ if (r->flags & IORESOURCE_IO) ++ cmd |= PCI_COMMAND_IO; ++ if (r->flags & IORESOURCE_MEM) ++ cmd |= PCI_COMMAND_MEMORY; ++ } ++ if (cmd != old_cmd) { ++ printk("PCI: Enabling device %s (%04x -> %04x)\n", ++ pci_name(dev), old_cmd, cmd); ++ pci_write_config_word(dev, PCI_COMMAND, cmd); ++ } ++ return 0; ++} ++ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/pci_32.c powerpc.git/arch/powerpc/kernel/pci_32.c +--- linux-2.6.24/arch/powerpc/kernel/pci_32.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/pci_32.c 2008-01-28 20:25:49.000000000 +0100 +@@ -13,6 +13,7 @@ + #include <linux/bootmem.h> + #include <linux/irq.h> + #include <linux/list.h> ++#include <linux/of.h> + + #include <asm/processor.h> + #include <asm/io.h> +@@ -32,19 +33,12 @@ + #endif + + unsigned long isa_io_base = 0; +-unsigned long isa_mem_base = 0; + unsigned long pci_dram_offset = 0; + int pcibios_assign_bus_offset = 1; + + void pcibios_make_OF_bus_map(void); + +-static int pci_relocate_bridge_resource(struct pci_bus *bus, int i); +-static int probe_resource(struct pci_bus *parent, struct resource *pr, +- struct resource *res, struct resource **conflict); +-static void update_bridge_base(struct pci_bus *bus, int i); +-static void pcibios_fixup_resources(struct pci_dev* dev); + static void fixup_broken_pcnet32(struct pci_dev* dev); +-static int reparent_resources(struct resource *parent, struct resource *res); + static void fixup_cpc710_pci64(struct pci_dev* dev); + #ifdef CONFIG_PPC_OF + static u8* pci_to_OF_bus_map; +@@ -53,7 +47,7 @@ + /* By default, we don't re-assign bus numbers. We do this only on + * some pmacs + */ +-int pci_assign_all_buses; ++static int pci_assign_all_buses; + + LIST_HEAD(hose_list); + +@@ -100,505 +94,6 @@ + } + DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_IBM, PCI_DEVICE_ID_IBM_CPC710_PCI64, fixup_cpc710_pci64); + +-static void +-pcibios_fixup_resources(struct pci_dev *dev) +-{ +- struct pci_controller* hose = (struct pci_controller *)dev->sysdata; +- int i; +- unsigned long offset; +- +- if (!hose) { +- printk(KERN_ERR "No hose for PCI dev %s!\n", pci_name(dev)); +- return; +- } +- for (i = 0; i < DEVICE_COUNT_RESOURCE; i++) { +- struct resource *res = dev->resource + i; +- if (!res->flags) +- continue; +- if (res->end == 0xffffffff) { +- DBG("PCI:%s Resource %d [%016llx-%016llx] is unassigned\n", +- pci_name(dev), i, (u64)res->start, (u64)res->end); +- res->end -= res->start; +- res->start = 0; +- res->flags |= IORESOURCE_UNSET; +- continue; +- } +- offset = 0; +- if (res->flags & IORESOURCE_MEM) { +- offset = hose->pci_mem_offset; +- } else if (res->flags & IORESOURCE_IO) { +- offset = (unsigned long) hose->io_base_virt +- - isa_io_base; +- } +- if (offset != 0) { +- res->start += offset; +- res->end += offset; +- DBG("Fixup res %d (%lx) of dev %s: %llx -> %llx\n", +- i, res->flags, pci_name(dev), +- (u64)res->start - offset, (u64)res->start); +- } +- } +- +- /* Call machine specific resource fixup */ +- if (ppc_md.pcibios_fixup_resources) +- ppc_md.pcibios_fixup_resources(dev); +-} +-DECLARE_PCI_FIXUP_HEADER(PCI_ANY_ID, PCI_ANY_ID, pcibios_fixup_resources); +- +-void pcibios_resource_to_bus(struct pci_dev *dev, struct pci_bus_region *region, +- struct resource *res) +-{ +- unsigned long offset = 0; +- struct pci_controller *hose = dev->sysdata; +- +- if (hose && res->flags & IORESOURCE_IO) +- offset = (unsigned long)hose->io_base_virt - isa_io_base; +- else if (hose && res->flags & IORESOURCE_MEM) +- offset = hose->pci_mem_offset; +- region->start = res->start - offset; +- region->end = res->end - offset; +-} +-EXPORT_SYMBOL(pcibios_resource_to_bus); +- +-void pcibios_bus_to_resource(struct pci_dev *dev, struct resource *res, +- struct pci_bus_region *region) +-{ +- unsigned long offset = 0; +- struct pci_controller *hose = dev->sysdata; +- +- if (hose && res->flags & IORESOURCE_IO) +- offset = (unsigned long)hose->io_base_virt - isa_io_base; +- else if (hose && res->flags & IORESOURCE_MEM) +- offset = hose->pci_mem_offset; +- res->start = region->start + offset; +- res->end = region->end + offset; +-} +-EXPORT_SYMBOL(pcibios_bus_to_resource); +- +-/* +- * We need to avoid collisions with `mirrored' VGA ports +- * and other strange ISA hardware, so we always want the +- * addresses to be allocated in the 0x000-0x0ff region +- * modulo 0x400. +- * +- * Why? Because some silly external IO cards only decode +- * the low 10 bits of the IO address. The 0x00-0xff region +- * is reserved for motherboard devices that decode all 16 +- * bits, so it's ok to allocate at, say, 0x2800-0x28ff, +- * but we want to try to avoid allocating at 0x2900-0x2bff +- * which might have be mirrored at 0x0100-0x03ff.. +- */ +-void pcibios_align_resource(void *data, struct resource *res, +- resource_size_t size, resource_size_t align) +-{ +- struct pci_dev *dev = data; +- +- if (res->flags & IORESOURCE_IO) { +- resource_size_t start = res->start; +- +- if (size > 0x100) { +- printk(KERN_ERR "PCI: I/O Region %s/%d too large" +- " (%lld bytes)\n", pci_name(dev), +- dev->resource - res, (unsigned long long)size); +- } +- +- if (start & 0x300) { +- start = (start + 0x3ff) & ~0x3ff; +- res->start = start; +- } +- } +-} +-EXPORT_SYMBOL(pcibios_align_resource); +- +-/* +- * Handle resources of PCI devices. If the world were perfect, we could +- * just allocate all the resource regions and do nothing more. It isn't. +- * On the other hand, we cannot just re-allocate all devices, as it would +- * require us to know lots of host bridge internals. So we attempt to +- * keep as much of the original configuration as possible, but tweak it +- * when it's found to be wrong. +- * +- * Known BIOS problems we have to work around: +- * - I/O or memory regions not configured +- * - regions configured, but not enabled in the command register +- * - bogus I/O addresses above 64K used +- * - expansion ROMs left enabled (this may sound harmless, but given +- * the fact the PCI specs explicitly allow address decoders to be +- * shared between expansion ROMs and other resource regions, it's +- * at least dangerous) +- * +- * Our solution: +- * (1) Allocate resources for all buses behind PCI-to-PCI bridges. +- * This gives us fixed barriers on where we can allocate. +- * (2) Allocate resources for all enabled devices. If there is +- * a collision, just mark the resource as unallocated. Also +- * disable expansion ROMs during this step. +- * (3) Try to allocate resources for disabled devices. If the +- * resources were assigned correctly, everything goes well, +- * if they weren't, they won't disturb allocation of other +- * resources. +- * (4) Assign new addresses to resources which were either +- * not configured at all or misconfigured. If explicitly +- * requested by the user, configure expansion ROM address +- * as well. +- */ +- +-static void __init +-pcibios_allocate_bus_resources(struct list_head *bus_list) +-{ +- struct pci_bus *bus; +- int i; +- struct resource *res, *pr; +- +- /* Depth-First Search on bus tree */ +- list_for_each_entry(bus, bus_list, node) { +- for (i = 0; i < 4; ++i) { +- if ((res = bus->resource[i]) == NULL || !res->flags +- || res->start > res->end) +- continue; +- if (bus->parent == NULL) +- pr = (res->flags & IORESOURCE_IO)? +- &ioport_resource: &iomem_resource; +- else { +- pr = pci_find_parent_resource(bus->self, res); +- if (pr == res) { +- /* this happens when the generic PCI +- * code (wrongly) decides that this +- * bridge is transparent -- paulus +- */ +- continue; +- } +- } +- +- DBG("PCI: bridge rsrc %llx..%llx (%lx), parent %p\n", +- (u64)res->start, (u64)res->end, res->flags, pr); +- if (pr) { +- if (request_resource(pr, res) == 0) +- continue; +- /* +- * Must be a conflict with an existing entry. +- * Move that entry (or entries) under the +- * bridge resource and try again. +- */ +- if (reparent_resources(pr, res) == 0) +- continue; +- } +- printk(KERN_ERR "PCI: Cannot allocate resource region " +- "%d of PCI bridge %d\n", i, bus->number); +- if (pci_relocate_bridge_resource(bus, i)) +- bus->resource[i] = NULL; +- } +- pcibios_allocate_bus_resources(&bus->children); +- } +-} +- +-/* +- * Reparent resource children of pr that conflict with res +- * under res, and make res replace those children. +- */ +-static int __init +-reparent_resources(struct resource *parent, struct resource *res) +-{ +- struct resource *p, **pp; +- struct resource **firstpp = NULL; +- +- for (pp = &parent->child; (p = *pp) != NULL; pp = &p->sibling) { +- if (p->end < res->start) +- continue; +- if (res->end < p->start) +- break; +- if (p->start < res->start || p->end > res->end) +- return -1; /* not completely contained */ +- if (firstpp == NULL) +- firstpp = pp; +- } +- if (firstpp == NULL) +- return -1; /* didn't find any conflicting entries? */ +- res->parent = parent; +- res->child = *firstpp; +- res->sibling = *pp; +- *firstpp = res; +- *pp = NULL; +- for (p = res->child; p != NULL; p = p->sibling) { +- p->parent = res; +- DBG(KERN_INFO "PCI: reparented %s [%llx..%llx] under %s\n", +- p->name, (u64)p->start, (u64)p->end, res->name); +- } +- return 0; +-} +- +-/* +- * A bridge has been allocated a range which is outside the range +- * of its parent bridge, so it needs to be moved. +- */ +-static int __init +-pci_relocate_bridge_resource(struct pci_bus *bus, int i) +-{ +- struct resource *res, *pr, *conflict; +- unsigned long try, size; +- int j; +- struct pci_bus *parent = bus->parent; +- +- if (parent == NULL) { +- /* shouldn't ever happen */ +- printk(KERN_ERR "PCI: can't move host bridge resource\n"); +- return -1; +- } +- res = bus->resource[i]; +- if (res == NULL) +- return -1; +- pr = NULL; +- for (j = 0; j < 4; j++) { +- struct resource *r = parent->resource[j]; +- if (!r) +- continue; +- if ((res->flags ^ r->flags) & (IORESOURCE_IO | IORESOURCE_MEM)) +- continue; +- if (!((res->flags ^ r->flags) & IORESOURCE_PREFETCH)) { +- pr = r; +- break; +- } +- if (res->flags & IORESOURCE_PREFETCH) +- pr = r; +- } +- if (pr == NULL) +- return -1; +- size = res->end - res->start; +- if (pr->start > pr->end || size > pr->end - pr->start) +- return -1; +- try = pr->end; +- for (;;) { +- res->start = try - size; +- res->end = try; +- if (probe_resource(bus->parent, pr, res, &conflict) == 0) +- break; +- if (conflict->start <= pr->start + size) +- return -1; +- try = conflict->start - 1; +- } +- if (request_resource(pr, res)) { +- DBG(KERN_ERR "PCI: huh? couldn't move to %llx..%llx\n", +- (u64)res->start, (u64)res->end); +- return -1; /* "can't happen" */ +- } +- update_bridge_base(bus, i); +- printk(KERN_INFO "PCI: bridge %d resource %d moved to %llx..%llx\n", +- bus->number, i, (unsigned long long)res->start, +- (unsigned long long)res->end); +- return 0; +-} +- +-static int __init +-probe_resource(struct pci_bus *parent, struct resource *pr, +- struct resource *res, struct resource **conflict) +-{ +- struct pci_bus *bus; +- struct pci_dev *dev; +- struct resource *r; +- int i; +- +- for (r = pr->child; r != NULL; r = r->sibling) { +- if (r->end >= res->start && res->end >= r->start) { +- *conflict = r; +- return 1; +- } +- } +- list_for_each_entry(bus, &parent->children, node) { +- for (i = 0; i < 4; ++i) { +- if ((r = bus->resource[i]) == NULL) +- continue; +- if (!r->flags || r->start > r->end || r == res) +- continue; +- if (pci_find_parent_resource(bus->self, r) != pr) +- continue; +- if (r->end >= res->start && res->end >= r->start) { +- *conflict = r; +- return 1; +- } +- } +- } +- list_for_each_entry(dev, &parent->devices, bus_list) { +- for (i = 0; i < 6; ++i) { +- r = &dev->resource[i]; +- if (!r->flags || (r->flags & IORESOURCE_UNSET)) +- continue; +- if (pci_find_parent_resource(dev, r) != pr) +- continue; +- if (r->end >= res->start && res->end >= r->start) { +- *conflict = r; +- return 1; +- } +- } +- } +- return 0; +-} +- +-void __init +-update_bridge_resource(struct pci_dev *dev, struct resource *res) +-{ +- u8 io_base_lo, io_limit_lo; +- u16 mem_base, mem_limit; +- u16 cmd; +- unsigned long start, end, off; +- struct pci_controller *hose = dev->sysdata; +- +- if (!hose) { +- printk("update_bridge_base: no hose?\n"); +- return; +- } +- pci_read_config_word(dev, PCI_COMMAND, &cmd); +- pci_write_config_word(dev, PCI_COMMAND, +- cmd & ~(PCI_COMMAND_IO | PCI_COMMAND_MEMORY)); +- if (res->flags & IORESOURCE_IO) { +- off = (unsigned long) hose->io_base_virt - isa_io_base; +- start = res->start - off; +- end = res->end - off; +- io_base_lo = (start >> 8) & PCI_IO_RANGE_MASK; +- io_limit_lo = (end >> 8) & PCI_IO_RANGE_MASK; +- if (end > 0xffff) +- io_base_lo |= PCI_IO_RANGE_TYPE_32; +- else +- io_base_lo |= PCI_IO_RANGE_TYPE_16; +- pci_write_config_word(dev, PCI_IO_BASE_UPPER16, +- start >> 16); +- pci_write_config_word(dev, PCI_IO_LIMIT_UPPER16, +- end >> 16); +- pci_write_config_byte(dev, PCI_IO_BASE, io_base_lo); +- pci_write_config_byte(dev, PCI_IO_LIMIT, io_limit_lo); +- +- } else if ((res->flags & (IORESOURCE_MEM | IORESOURCE_PREFETCH)) +- == IORESOURCE_MEM) { +- off = hose->pci_mem_offset; +- mem_base = ((res->start - off) >> 16) & PCI_MEMORY_RANGE_MASK; +- mem_limit = ((res->end - off) >> 16) & PCI_MEMORY_RANGE_MASK; +- pci_write_config_word(dev, PCI_MEMORY_BASE, mem_base); +- pci_write_config_word(dev, PCI_MEMORY_LIMIT, mem_limit); +- +- } else if ((res->flags & (IORESOURCE_MEM | IORESOURCE_PREFETCH)) +- == (IORESOURCE_MEM | IORESOURCE_PREFETCH)) { +- off = hose->pci_mem_offset; +- mem_base = ((res->start - off) >> 16) & PCI_PREF_RANGE_MASK; +- mem_limit = ((res->end - off) >> 16) & PCI_PREF_RANGE_MASK; +- pci_write_config_word(dev, PCI_PREF_MEMORY_BASE, mem_base); +- pci_write_config_word(dev, PCI_PREF_MEMORY_LIMIT, mem_limit); +- +- } else { +- DBG(KERN_ERR "PCI: ugh, bridge %s res has flags=%lx\n", +- pci_name(dev), res->flags); +- } +- pci_write_config_word(dev, PCI_COMMAND, cmd); +-} +- +-static void __init +-update_bridge_base(struct pci_bus *bus, int i) +-{ +- struct resource *res = bus->resource[i]; +- struct pci_dev *dev = bus->self; +- update_bridge_resource(dev, res); +-} +- +-static inline void alloc_resource(struct pci_dev *dev, int idx) +-{ +- struct resource *pr, *r = &dev->resource[idx]; +- +- DBG("PCI:%s: Resource %d: %016llx-%016llx (f=%lx)\n", +- pci_name(dev), idx, (u64)r->start, (u64)r->end, r->flags); +- pr = pci_find_parent_resource(dev, r); +- if (!pr || request_resource(pr, r) < 0) { +- printk(KERN_ERR "PCI: Cannot allocate resource region %d" +- " of device %s\n", idx, pci_name(dev)); +- if (pr) +- DBG("PCI: parent is %p: %016llx-%016llx (f=%lx)\n", +- pr, (u64)pr->start, (u64)pr->end, pr->flags); +- /* We'll assign a new address later */ +- r->flags |= IORESOURCE_UNSET; +- r->end -= r->start; +- r->start = 0; +- } +-} +- +-static void __init +-pcibios_allocate_resources(int pass) +-{ +- struct pci_dev *dev = NULL; +- int idx, disabled; +- u16 command; +- struct resource *r; +- +- for_each_pci_dev(dev) { +- pci_read_config_word(dev, PCI_COMMAND, &command); +- for (idx = 0; idx < 6; idx++) { +- r = &dev->resource[idx]; +- if (r->parent) /* Already allocated */ +- continue; +- if (!r->flags || (r->flags & IORESOURCE_UNSET)) +- continue; /* Not assigned at all */ +- if (r->flags & IORESOURCE_IO) +- disabled = !(command & PCI_COMMAND_IO); +- else +- disabled = !(command & PCI_COMMAND_MEMORY); +- if (pass == disabled) +- alloc_resource(dev, idx); +- } +- if (pass) +- continue; +- r = &dev->resource[PCI_ROM_RESOURCE]; +- if (r->flags & IORESOURCE_ROM_ENABLE) { +- /* Turn the ROM off, leave the resource region, but keep it unregistered. */ +- u32 reg; +- DBG("PCI: Switching off ROM of %s\n", pci_name(dev)); +- r->flags &= ~IORESOURCE_ROM_ENABLE; +- pci_read_config_dword(dev, dev->rom_base_reg, ®); +- pci_write_config_dword(dev, dev->rom_base_reg, +- reg & ~PCI_ROM_ADDRESS_ENABLE); +- } +- } +-} +- +-static void __init +-pcibios_assign_resources(void) +-{ +- struct pci_dev *dev = NULL; +- int idx; +- struct resource *r; +- +- for_each_pci_dev(dev) { +- int class = dev->class >> 8; +- +- /* Don't touch classless devices and host bridges */ +- if (!class || class == PCI_CLASS_BRIDGE_HOST) +- continue; +- +- for (idx = 0; idx < 6; idx++) { +- r = &dev->resource[idx]; +- +- /* +- * We shall assign a new address to this resource, +- * either because the BIOS (sic) forgot to do so +- * or because we have decided the old address was +- * unusable for some reason. +- */ +- if ((r->flags & IORESOURCE_UNSET) && r->end && +- (!ppc_md.pcibios_enable_device_hook || +- !ppc_md.pcibios_enable_device_hook(dev, 1))) { +- int rc; +- +- r->flags &= ~IORESOURCE_UNSET; +- rc = pci_assign_resource(dev, idx); +- BUG_ON(rc); +- } +- } +- +-#if 0 /* don't assign ROMs */ +- r = &dev->resource[PCI_ROM_RESOURCE]; +- r->end -= r->start; +- r->start = 0; +- if (r->end) +- pci_assign_resource(dev, PCI_ROM_RESOURCE); +-#endif +- } +-} +- + #ifdef CONFIG_PPC_OF + /* + * Functions below are used on OpenFirmware machines. +@@ -619,7 +114,7 @@ + } else + pci_to_OF_bus_map[pci_bus] = bus_range[0]; + +- for (node=node->child; node != 0;node = node->sibling) { ++ for_each_child_of_node(node, node) { + struct pci_dev* dev; + const unsigned int *class_code, *reg; + +@@ -662,8 +157,8 @@ + + /* For each hose, we begin searching bridges */ + list_for_each_entry_safe(hose, tmp, &hose_list, list_node) { +- struct device_node* node; +- node = (struct device_node *)hose->arch_data; ++ struct device_node* node = hose->dn; ++ + if (!node) + continue; + make_one_node_map(node, hose->first_busno); +@@ -688,15 +183,18 @@ + typedef int (*pci_OF_scan_iterator)(struct device_node* node, void* data); + + static struct device_node* +-scan_OF_pci_childs(struct device_node* node, pci_OF_scan_iterator filter, void* data) ++scan_OF_pci_childs(struct device_node *parent, pci_OF_scan_iterator filter, void* data) + { ++ struct device_node *node; + struct device_node* sub_node; + +- for (; node != 0;node = node->sibling) { ++ for_each_child_of_node(parent, node) { + const unsigned int *class_code; + +- if (filter(node, data)) ++ if (filter(node, data)) { ++ of_node_put(node); + return node; ++ } + + /* For PCI<->PCI bridges or CardBus bridges, we go down + * Note: some OFs create a parent node "multifunc-device" as +@@ -708,9 +206,11 @@ + (*class_code >> 8) != PCI_CLASS_BRIDGE_CARDBUS)) && + strcmp(node->name, "multifunc-device")) + continue; +- sub_node = scan_OF_pci_childs(node->child, filter, data); +- if (sub_node) ++ sub_node = scan_OF_pci_childs(node, filter, data); ++ if (sub_node) { ++ of_node_put(node); + return sub_node; ++ } + } + return NULL; + } +@@ -718,11 +218,11 @@ + static struct device_node *scan_OF_for_pci_dev(struct device_node *parent, + unsigned int devfn) + { +- struct device_node *np = NULL; ++ struct device_node *np; + const u32 *reg; + unsigned int psize; + +- while ((np = of_get_next_child(parent, np)) != NULL) { ++ for_each_child_of_node(parent, np) { + reg = of_get_property(np, "reg", &psize); + if (reg == NULL || psize < 4) + continue; +@@ -742,7 +242,7 @@ + struct pci_controller *hose = pci_bus_to_host(bus); + if (hose == NULL) + return NULL; +- return of_node_get(hose->arch_data); ++ return of_node_get(hose->dn); + } + + /* not a root bus, we need to get our parent */ +@@ -812,9 +312,9 @@ + return -ENODEV; + /* Make sure it's really a PCI device */ + hose = pci_find_hose_for_OF_device(node); +- if (!hose || !hose->arch_data) ++ if (!hose || !hose->dn) + return -ENODEV; +- if (!scan_OF_pci_childs(((struct device_node*)hose->arch_data)->child, ++ if (!scan_OF_pci_childs(hose->dn, + find_OF_pci_device_filter, (void *)node)) + return -ENODEV; + reg = of_get_property(node, "reg", NULL); +@@ -843,120 +343,6 @@ + } + EXPORT_SYMBOL(pci_device_from_OF_node); + +-void __init +-pci_process_bridge_OF_ranges(struct pci_controller *hose, +- struct device_node *dev, int primary) +-{ +- static unsigned int static_lc_ranges[256] __initdata; +- const unsigned int *dt_ranges; +- unsigned int *lc_ranges, *ranges, *prev, size; +- int rlen = 0, orig_rlen; +- int memno = 0; +- struct resource *res; +- int np, na = of_n_addr_cells(dev); +- np = na + 5; +- +- /* First we try to merge ranges to fix a problem with some pmacs +- * that can have more than 3 ranges, fortunately using contiguous +- * addresses -- BenH +- */ +- dt_ranges = of_get_property(dev, "ranges", &rlen); +- if (!dt_ranges) +- return; +- /* Sanity check, though hopefully that never happens */ +- if (rlen > sizeof(static_lc_ranges)) { +- printk(KERN_WARNING "OF ranges property too large !\n"); +- rlen = sizeof(static_lc_ranges); +- } +- lc_ranges = static_lc_ranges; +- memcpy(lc_ranges, dt_ranges, rlen); +- orig_rlen = rlen; +- +- /* Let's work on a copy of the "ranges" property instead of damaging +- * the device-tree image in memory +- */ +- ranges = lc_ranges; +- prev = NULL; +- while ((rlen -= np * sizeof(unsigned int)) >= 0) { +- if (prev) { +- if (prev[0] == ranges[0] && prev[1] == ranges[1] && +- (prev[2] + prev[na+4]) == ranges[2] && +- (prev[na+2] + prev[na+4]) == ranges[na+2]) { +- prev[na+4] += ranges[na+4]; +- ranges[0] = 0; +- ranges += np; +- continue; +- } +- } +- prev = ranges; +- ranges += np; +- } +- +- /* +- * The ranges property is laid out as an array of elements, +- * each of which comprises: +- * cells 0 - 2: a PCI address +- * cells 3 or 3+4: a CPU physical address +- * (size depending on dev->n_addr_cells) +- * cells 4+5 or 5+6: the size of the range +- */ +- ranges = lc_ranges; +- rlen = orig_rlen; +- while (ranges && (rlen -= np * sizeof(unsigned int)) >= 0) { +- res = NULL; +- size = ranges[na+4]; +- switch ((ranges[0] >> 24) & 0x3) { +- case 1: /* I/O space */ +- if (ranges[2] != 0) +- break; +- hose->io_base_phys = ranges[na+2]; +- /* limit I/O space to 16MB */ +- if (size > 0x01000000) +- size = 0x01000000; +- hose->io_base_virt = ioremap(ranges[na+2], size); +- if (primary) +- isa_io_base = (unsigned long) hose->io_base_virt; +- res = &hose->io_resource; +- res->flags = IORESOURCE_IO; +- res->start = ranges[2]; +- DBG("PCI: IO 0x%llx -> 0x%llx\n", +- (u64)res->start, (u64)res->start + size - 1); +- break; +- case 2: /* memory space */ +- memno = 0; +- if (ranges[1] == 0 && ranges[2] == 0 +- && ranges[na+4] <= (16 << 20)) { +- /* 1st 16MB, i.e. ISA memory area */ +- if (primary) +- isa_mem_base = ranges[na+2]; +- memno = 1; +- } +- while (memno < 3 && hose->mem_resources[memno].flags) +- ++memno; +- if (memno == 0) +- hose->pci_mem_offset = ranges[na+2] - ranges[2]; +- if (memno < 3) { +- res = &hose->mem_resources[memno]; +- res->flags = IORESOURCE_MEM; +- if(ranges[0] & 0x40000000) +- res->flags |= IORESOURCE_PREFETCH; +- res->start = ranges[na+2]; +- DBG("PCI: MEM[%d] 0x%llx -> 0x%llx\n", memno, +- (u64)res->start, (u64)res->start + size - 1); +- } +- break; +- } +- if (res != NULL) { +- res->name = dev->full_name; +- res->end = res->start + size - 1; +- res->parent = NULL; +- res->sibling = NULL; +- res->child = NULL; +- } +- ranges += np; +- } +-} +- + /* We create the "pci-OF-bus-map" property now so it appears in the + * /proc device tree + */ +@@ -986,219 +372,7 @@ + } + #endif /* CONFIG_PPC_OF */ + +-#ifdef CONFIG_PPC_PMAC +-/* +- * This set of routines checks for PCI<->PCI bridges that have closed +- * IO resources and have child devices. It tries to re-open an IO +- * window on them. +- * +- * This is a _temporary_ fix to workaround a problem with Apple's OF +- * closing IO windows on P2P bridges when the OF drivers of cards +- * below this bridge don't claim any IO range (typically ATI or +- * Adaptec). +- * +- * A more complete fix would be to use drivers/pci/setup-bus.c, which +- * involves a working pcibios_fixup_pbus_ranges(), some more care about +- * ordering when creating the host bus resources, and maybe a few more +- * minor tweaks +- */ +- +-/* Initialize bridges with base/limit values we have collected */ +-static void __init +-do_update_p2p_io_resource(struct pci_bus *bus, int enable_vga) +-{ +- struct pci_dev *bridge = bus->self; +- struct pci_controller* hose = (struct pci_controller *)bridge->sysdata; +- u32 l; +- u16 w; +- struct resource res; +- +- if (bus->resource[0] == NULL) +- return; +- res = *(bus->resource[0]); +- +- DBG("Remapping Bus %d, bridge: %s\n", bus->number, pci_name(bridge)); +- res.start -= ((unsigned long) hose->io_base_virt - isa_io_base); +- res.end -= ((unsigned long) hose->io_base_virt - isa_io_base); +- DBG(" IO window: %016llx-%016llx\n", res.start, res.end); +- +- /* Set up the top and bottom of the PCI I/O segment for this bus. */ +- pci_read_config_dword(bridge, PCI_IO_BASE, &l); +- l &= 0xffff000f; +- l |= (res.start >> 8) & 0x00f0; +- l |= res.end & 0xf000; +- pci_write_config_dword(bridge, PCI_IO_BASE, l); +- +- if ((l & PCI_IO_RANGE_TYPE_MASK) == PCI_IO_RANGE_TYPE_32) { +- l = (res.start >> 16) | (res.end & 0xffff0000); +- pci_write_config_dword(bridge, PCI_IO_BASE_UPPER16, l); +- } +- +- pci_read_config_word(bridge, PCI_COMMAND, &w); +- w |= PCI_COMMAND_IO; +- pci_write_config_word(bridge, PCI_COMMAND, w); +- +-#if 0 /* Enabling this causes XFree 4.2.0 to hang during PCI probe */ +- if (enable_vga) { +- pci_read_config_word(bridge, PCI_BRIDGE_CONTROL, &w); +- w |= PCI_BRIDGE_CTL_VGA; +- pci_write_config_word(bridge, PCI_BRIDGE_CONTROL, w); +- } +-#endif +-} +- +-/* This function is pretty basic and actually quite broken for the +- * general case, it's enough for us right now though. It's supposed +- * to tell us if we need to open an IO range at all or not and what +- * size. +- */ +-static int __init +-check_for_io_childs(struct pci_bus *bus, struct resource* res, int *found_vga) +-{ +- struct pci_dev *dev; +- int i; +- int rc = 0; +- +-#define push_end(res, mask) do { \ +- BUG_ON((mask+1) & mask); \ +- res->end = (res->end + mask) | mask; \ +-} while (0) +- +- list_for_each_entry(dev, &bus->devices, bus_list) { +- u16 class = dev->class >> 8; +- +- if (class == PCI_CLASS_DISPLAY_VGA || +- class == PCI_CLASS_NOT_DEFINED_VGA) +- *found_vga = 1; +- if (class >> 8 == PCI_BASE_CLASS_BRIDGE && dev->subordinate) +- rc |= check_for_io_childs(dev->subordinate, res, found_vga); +- if (class == PCI_CLASS_BRIDGE_CARDBUS) +- push_end(res, 0xfff); +- +- for (i=0; i<PCI_NUM_RESOURCES; i++) { +- struct resource *r; +- unsigned long r_size; +- +- if (dev->class >> 8 == PCI_CLASS_BRIDGE_PCI +- && i >= PCI_BRIDGE_RESOURCES) +- continue; +- r = &dev->resource[i]; +- r_size = r->end - r->start; +- if (r_size < 0xfff) +- r_size = 0xfff; +- if (r->flags & IORESOURCE_IO && (r_size) != 0) { +- rc = 1; +- push_end(res, r_size); +- } +- } +- } +- +- return rc; +-} +- +-/* Here we scan all P2P bridges of a given level that have a closed +- * IO window. Note that the test for the presence of a VGA card should +- * be improved to take into account already configured P2P bridges, +- * currently, we don't see them and might end up configuring 2 bridges +- * with VGA pass through enabled +- */ +-static void __init +-do_fixup_p2p_level(struct pci_bus *bus) +-{ +- struct pci_bus *b; +- int i, parent_io; +- int has_vga = 0; +- +- for (parent_io=0; parent_io<4; parent_io++) +- if (bus->resource[parent_io] +- && bus->resource[parent_io]->flags & IORESOURCE_IO) +- break; +- if (parent_io >= 4) +- return; +- +- list_for_each_entry(b, &bus->children, node) { +- struct pci_dev *d = b->self; +- struct pci_controller* hose = (struct pci_controller *)d->sysdata; +- struct resource *res = b->resource[0]; +- struct resource tmp_res; +- unsigned long max; +- int found_vga = 0; +- +- memset(&tmp_res, 0, sizeof(tmp_res)); +- tmp_res.start = bus->resource[parent_io]->start; +- +- /* We don't let low addresses go through that closed P2P bridge, well, +- * that may not be necessary but I feel safer that way +- */ +- if (tmp_res.start == 0) +- tmp_res.start = 0x1000; +- +- if (!list_empty(&b->devices) && res && res->flags == 0 && +- res != bus->resource[parent_io] && +- (d->class >> 8) == PCI_CLASS_BRIDGE_PCI && +- check_for_io_childs(b, &tmp_res, &found_vga)) { +- u8 io_base_lo; +- +- printk(KERN_INFO "Fixing up IO bus %s\n", b->name); +- +- if (found_vga) { +- if (has_vga) { +- printk(KERN_WARNING "Skipping VGA, already active" +- " on bus segment\n"); +- found_vga = 0; +- } else +- has_vga = 1; +- } +- pci_read_config_byte(d, PCI_IO_BASE, &io_base_lo); +- +- if ((io_base_lo & PCI_IO_RANGE_TYPE_MASK) == PCI_IO_RANGE_TYPE_32) +- max = ((unsigned long) hose->io_base_virt +- - isa_io_base) + 0xffffffff; +- else +- max = ((unsigned long) hose->io_base_virt +- - isa_io_base) + 0xffff; +- +- *res = tmp_res; +- res->flags = IORESOURCE_IO; +- res->name = b->name; +- +- /* Find a resource in the parent where we can allocate */ +- for (i = 0 ; i < 4; i++) { +- struct resource *r = bus->resource[i]; +- if (!r) +- continue; +- if ((r->flags & IORESOURCE_IO) == 0) +- continue; +- DBG("Trying to allocate from %016llx, size %016llx from parent" +- " res %d: %016llx -> %016llx\n", +- res->start, res->end, i, r->start, r->end); +- +- if (allocate_resource(r, res, res->end + 1, res->start, max, +- res->end + 1, NULL, NULL) < 0) { +- DBG("Failed !\n"); +- continue; +- } +- do_update_p2p_io_resource(b, found_vga); +- break; +- } +- } +- do_fixup_p2p_level(b); +- } +-} +- +-static void +-pcibios_fixup_p2p_bridges(void) +-{ +- struct pci_bus *b; +- +- list_for_each_entry(b, &pci_root_buses, node) +- do_fixup_p2p_level(b); +-} +- +-#endif /* CONFIG_PPC_PMAC */ +- +-static int __init +-pcibios_init(void) ++static int __init pcibios_init(void) + { + struct pci_controller *hose, *tmp; + struct pci_bus *bus; +@@ -1206,6 +380,9 @@ + + printk(KERN_INFO "PCI: Probing PCI hardware\n"); + ++ if (ppc_pci_flags & PPC_PCI_REASSIGN_ALL_BUS) ++ pci_assign_all_buses = 1; ++ + /* Scan all of the recorded PCI controllers. */ + list_for_each_entry_safe(hose, tmp, &hose_list, list_node) { + if (pci_assign_all_buses) +@@ -1213,9 +390,10 @@ + hose->last_busno = 0xff; + bus = pci_scan_bus_parented(hose->parent, hose->first_busno, + hose->ops, hose); +- if (bus) ++ if (bus) { + pci_bus_add_devices(bus); +- hose->last_busno = bus->subordinate; ++ hose->last_busno = bus->subordinate; ++ } + if (pci_assign_all_buses || next_busno <= hose->last_busno) + next_busno = hose->last_busno + pcibios_assign_bus_offset; + } +@@ -1228,18 +406,8 @@ + if (pci_assign_all_buses && have_of) + pcibios_make_OF_bus_map(); + +- /* Call machine dependent fixup */ +- if (ppc_md.pcibios_fixup) +- ppc_md.pcibios_fixup(); +- +- /* Allocate and assign resources */ +- pcibios_allocate_bus_resources(&pci_root_buses); +- pcibios_allocate_resources(0); +- pcibios_allocate_resources(1); +-#ifdef CONFIG_PPC_PMAC +- pcibios_fixup_p2p_bridges(); +-#endif /* CONFIG_PPC_PMAC */ +- pcibios_assign_resources(); ++ /* Call common code to handle resource allocation */ ++ pcibios_resource_survey(); + + /* Call machine dependent post-init code */ + if (ppc_md.pcibios_after_init) +@@ -1250,14 +418,14 @@ + + subsys_initcall(pcibios_init); + +-void pcibios_fixup_bus(struct pci_bus *bus) ++void __devinit pcibios_do_bus_setup(struct pci_bus *bus) + { + struct pci_controller *hose = (struct pci_controller *) bus->sysdata; + unsigned long io_offset; + struct resource *res; +- struct pci_dev *dev; + int i; + ++ /* Hookup PHB resources */ + io_offset = (unsigned long)hose->io_base_virt - isa_io_base; + if (bus->parent == NULL) { + /* This is a host bridge - fill in its resources */ +@@ -1272,8 +440,8 @@ + res->end = IO_SPACE_LIMIT; + res->flags = IORESOURCE_IO; + } +- res->start += io_offset; +- res->end += io_offset; ++ res->start = (res->start + io_offset) & 0xffffffffu; ++ res->end = (res->end + io_offset) & 0xffffffffu; + + for (i = 0; i < 3; ++i) { + res = &hose->mem_resources[i]; +@@ -1288,35 +456,6 @@ + } + bus->resource[i+1] = res; + } +- } else { +- /* This is a subordinate bridge */ +- pci_read_bridge_bases(bus); +- +- for (i = 0; i < 4; ++i) { +- if ((res = bus->resource[i]) == NULL) +- continue; +- if (!res->flags || bus->self->transparent) +- continue; +- if (io_offset && (res->flags & IORESOURCE_IO)) { +- res->start += io_offset; +- res->end += io_offset; +- } else if (hose->pci_mem_offset +- && (res->flags & IORESOURCE_MEM)) { +- res->start += hose->pci_mem_offset; +- res->end += hose->pci_mem_offset; +- } +- } +- } +- +- /* Platform specific bus fixups */ +- if (ppc_md.pcibios_fixup_bus) +- ppc_md.pcibios_fixup_bus(bus); +- +- /* Read default IRQs and fixup if necessary */ +- list_for_each_entry(dev, &bus->devices, bus_list) { +- pci_read_irq_line(dev); +- if (ppc_md.pci_irq_fixup) +- ppc_md.pci_irq_fixup(dev); + } + } + +@@ -1328,37 +467,6 @@ + /* XXX FIXME - update OF device tree node interrupt property */ + } + +-int pcibios_enable_device(struct pci_dev *dev, int mask) +-{ +- u16 cmd, old_cmd; +- int idx; +- struct resource *r; +- +- if (ppc_md.pcibios_enable_device_hook) +- if (ppc_md.pcibios_enable_device_hook(dev, 0)) +- return -EINVAL; +- +- pci_read_config_word(dev, PCI_COMMAND, &cmd); +- old_cmd = cmd; +- for (idx=0; idx<6; idx++) { +- r = &dev->resource[idx]; +- if (r->flags & IORESOURCE_UNSET) { +- printk(KERN_ERR "PCI: Device %s not available because of resource collisions\n", pci_name(dev)); +- return -EINVAL; +- } +- if (r->flags & IORESOURCE_IO) +- cmd |= PCI_COMMAND_IO; +- if (r->flags & IORESOURCE_MEM) +- cmd |= PCI_COMMAND_MEMORY; +- } +- if (cmd != old_cmd) { +- printk("PCI: Enabling device %s (%04x -> %04x)\n", +- pci_name(dev), old_cmd, cmd); +- pci_write_config_word(dev, PCI_COMMAND, cmd); +- } +- return 0; +-} +- + static struct pci_controller* + pci_bus_to_hose(int bus) + { +@@ -1381,17 +489,6 @@ + struct pci_controller* hose; + long result = -EOPNOTSUPP; + +- /* Argh ! Please forgive me for that hack, but that's the +- * simplest way to get existing XFree to not lockup on some +- * G5 machines... So when something asks for bus 0 io base +- * (bus 0 is HT root), we return the AGP one instead. +- */ +-#ifdef CONFIG_PPC_PMAC +- if (machine_is(powermac) && machine_is_compatible("MacRISC4")) +- if (bus == 0) +- bus = 0xf0; +-#endif /* CONFIG_PPC_PMAC */ +- + hose = pci_bus_to_hose(bus); + if (!hose) + return -ENODEV; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/pci_64.c powerpc.git/arch/powerpc/kernel/pci_64.c +--- linux-2.6.24/arch/powerpc/kernel/pci_64.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/pci_64.c 2008-01-28 20:25:49.000000000 +0100 +@@ -31,7 +31,6 @@ + #include <asm/byteorder.h> + #include <asm/machdep.h> + #include <asm/ppc-pci.h> +-#include <asm/firmware.h> + + #ifdef DEBUG + #include <asm/udbg.h> +@@ -41,10 +40,6 @@ + #endif + + unsigned long pci_probe_only = 1; +-int pci_assign_all_buses = 0; +- +-static void fixup_resource(struct resource *res, struct pci_dev *dev); +-static void do_bus_setup(struct pci_bus *bus); + + /* pci_io_base -- the base address from which io bars are offsets. + * This is the lowest I/O base address (so bar values are always positive), +@@ -70,139 +65,31 @@ + } + EXPORT_SYMBOL(get_pci_dma_ops); + +-static void fixup_broken_pcnet32(struct pci_dev* dev) +-{ +- if ((dev->class>>8 == PCI_CLASS_NETWORK_ETHERNET)) { +- dev->vendor = PCI_VENDOR_ID_AMD; +- pci_write_config_word(dev, PCI_VENDOR_ID, PCI_VENDOR_ID_AMD); +- } +-} +-DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_TRIDENT, PCI_ANY_ID, fixup_broken_pcnet32); +- +-void pcibios_resource_to_bus(struct pci_dev *dev, struct pci_bus_region *region, +- struct resource *res) +-{ +- unsigned long offset = 0; +- struct pci_controller *hose = pci_bus_to_host(dev->bus); +- +- if (!hose) +- return; +- +- if (res->flags & IORESOURCE_IO) +- offset = (unsigned long)hose->io_base_virt - _IO_BASE; +- +- if (res->flags & IORESOURCE_MEM) +- offset = hose->pci_mem_offset; +- +- region->start = res->start - offset; +- region->end = res->end - offset; +-} + +-void pcibios_bus_to_resource(struct pci_dev *dev, struct resource *res, +- struct pci_bus_region *region) ++int pci_set_dma_mask(struct pci_dev *dev, u64 mask) + { +- unsigned long offset = 0; +- struct pci_controller *hose = pci_bus_to_host(dev->bus); +- +- if (!hose) +- return; +- +- if (res->flags & IORESOURCE_IO) +- offset = (unsigned long)hose->io_base_virt - _IO_BASE; +- +- if (res->flags & IORESOURCE_MEM) +- offset = hose->pci_mem_offset; +- +- res->start = region->start + offset; +- res->end = region->end + offset; ++ return dma_set_mask(&dev->dev, mask); + } + +-#ifdef CONFIG_HOTPLUG +-EXPORT_SYMBOL(pcibios_resource_to_bus); +-EXPORT_SYMBOL(pcibios_bus_to_resource); +-#endif +- +-/* +- * We need to avoid collisions with `mirrored' VGA ports +- * and other strange ISA hardware, so we always want the +- * addresses to be allocated in the 0x000-0x0ff region +- * modulo 0x400. +- * +- * Why? Because some silly external IO cards only decode +- * the low 10 bits of the IO address. The 0x00-0xff region +- * is reserved for motherboard devices that decode all 16 +- * bits, so it's ok to allocate at, say, 0x2800-0x28ff, +- * but we want to try to avoid allocating at 0x2900-0x2bff +- * which might have be mirrored at 0x0100-0x03ff.. +- */ +-void pcibios_align_resource(void *data, struct resource *res, +- resource_size_t size, resource_size_t align) ++int pci_set_consistent_dma_mask(struct pci_dev *dev, u64 mask) + { +- struct pci_dev *dev = data; +- struct pci_controller *hose = pci_bus_to_host(dev->bus); +- resource_size_t start = res->start; +- unsigned long alignto; +- +- if (res->flags & IORESOURCE_IO) { +- unsigned long offset = (unsigned long)hose->io_base_virt - +- _IO_BASE; +- /* Make sure we start at our min on all hoses */ +- if (start - offset < PCIBIOS_MIN_IO) +- start = PCIBIOS_MIN_IO + offset; +- +- /* +- * Put everything into 0x00-0xff region modulo 0x400 +- */ +- if (start & 0x300) +- start = (start + 0x3ff) & ~0x3ff; ++ int rc; + +- } else if (res->flags & IORESOURCE_MEM) { +- /* Make sure we start at our min on all hoses */ +- if (start - hose->pci_mem_offset < PCIBIOS_MIN_MEM) +- start = PCIBIOS_MIN_MEM + hose->pci_mem_offset; ++ rc = dma_set_mask(&dev->dev, mask); ++ dev->dev.coherent_dma_mask = dev->dma_mask; + +- /* Align to multiple of size of minimum base. */ +- alignto = max(0x1000UL, align); +- start = ALIGN(start, alignto); +- } +- +- res->start = start; ++ return rc; + } + +-void __devinit pcibios_claim_one_bus(struct pci_bus *b) ++static void fixup_broken_pcnet32(struct pci_dev* dev) + { +- struct pci_dev *dev; +- struct pci_bus *child_bus; +- +- list_for_each_entry(dev, &b->devices, bus_list) { +- int i; +- +- for (i = 0; i < PCI_NUM_RESOURCES; i++) { +- struct resource *r = &dev->resource[i]; +- +- if (r->parent || !r->start || !r->flags) +- continue; +- pci_claim_resource(dev, i); +- } ++ if ((dev->class>>8 == PCI_CLASS_NETWORK_ETHERNET)) { ++ dev->vendor = PCI_VENDOR_ID_AMD; ++ pci_write_config_word(dev, PCI_VENDOR_ID, PCI_VENDOR_ID_AMD); + } +- +- list_for_each_entry(child_bus, &b->children, node) +- pcibios_claim_one_bus(child_bus); + } +-#ifdef CONFIG_HOTPLUG +-EXPORT_SYMBOL_GPL(pcibios_claim_one_bus); +-#endif +- +-static void __init pcibios_claim_of_setup(void) +-{ +- struct pci_bus *b; +- +- if (firmware_has_feature(FW_FEATURE_ISERIES)) +- return; ++DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_TRIDENT, PCI_ANY_ID, fixup_broken_pcnet32); + +- list_for_each_entry(b, &pci_root_buses, node) +- pcibios_claim_one_bus(b); +-} + + static u32 get_int_prop(struct device_node *np, const char *name, u32 def) + { +@@ -270,7 +157,6 @@ + res->end = base + size - 1; + res->flags = flags; + res->name = pci_name(dev); +- fixup_resource(res, dev); + } + } + +@@ -339,16 +225,17 @@ + EXPORT_SYMBOL(of_create_pci_dev); + + void __devinit of_scan_bus(struct device_node *node, +- struct pci_bus *bus) ++ struct pci_bus *bus) + { +- struct device_node *child = NULL; ++ struct device_node *child; + const u32 *reg; + int reglen, devfn; + struct pci_dev *dev; + + DBG("of_scan_bus(%s) bus no %d... \n", node->full_name, bus->number); + +- while ((child = of_get_next_child(node, child)) != NULL) { ++ /* Scan direct children */ ++ for_each_child_of_node(node, child) { + DBG(" * %s\n", child->full_name); + reg = of_get_property(child, "reg", ®len); + if (reg == NULL || reglen < 20) +@@ -359,19 +246,26 @@ + dev = of_create_pci_dev(child, bus, devfn); + if (!dev) + continue; +- DBG("dev header type: %x\n", dev->hdr_type); ++ DBG(" dev header type: %x\n", dev->hdr_type); ++ } + ++ /* Ally all fixups */ ++ pcibios_fixup_of_probed_bus(bus); ++ ++ /* Now scan child busses */ ++ list_for_each_entry(dev, &bus->devices, bus_list) { + if (dev->hdr_type == PCI_HEADER_TYPE_BRIDGE || +- dev->hdr_type == PCI_HEADER_TYPE_CARDBUS) +- of_scan_pci_bridge(child, dev); ++ dev->hdr_type == PCI_HEADER_TYPE_CARDBUS) { ++ struct device_node *child = pci_device_to_OF_node(dev); ++ if (dev) ++ of_scan_pci_bridge(child, dev); ++ } + } +- +- do_bus_setup(bus); + } + EXPORT_SYMBOL(of_scan_bus); + + void __devinit of_scan_pci_bridge(struct device_node *node, +- struct pci_dev *dev) ++ struct pci_dev *dev) + { + struct pci_bus *bus; + const u32 *busrange, *ranges; +@@ -441,7 +335,6 @@ + res->start = of_read_number(&ranges[1], 2); + res->end = res->start + size - 1; + res->flags = flags; +- fixup_resource(res, dev); + } + sprintf(bus->name, "PCI Bus %04x:%02x", pci_domain_nr(bus), + bus->number); +@@ -462,12 +355,12 @@ + void __devinit scan_phb(struct pci_controller *hose) + { + struct pci_bus *bus; +- struct device_node *node = hose->arch_data; ++ struct device_node *node = hose->dn; + int i, mode; +- struct resource *res; + +- DBG("Scanning PHB %s\n", node ? node->full_name : "<NO NAME>"); ++ DBG("PCI: Scanning PHB %s\n", node ? node->full_name : "<NO NAME>"); + ++ /* Create an empty bus for the toplevel */ + bus = pci_create_bus(hose->parent, hose->first_busno, hose->ops, node); + if (bus == NULL) { + printk(KERN_ERR "Failed to create bus for PCI domain %04x\n", +@@ -477,27 +370,27 @@ + bus->secondary = hose->first_busno; + hose->bus = bus; + +- if (!firmware_has_feature(FW_FEATURE_ISERIES)) +- pcibios_map_io_space(bus); +- +- bus->resource[0] = res = &hose->io_resource; +- if (res->flags && request_resource(&ioport_resource, res)) { +- printk(KERN_ERR "Failed to request PCI IO region " +- "on PCI domain %04x\n", hose->global_number); +- DBG("res->start = 0x%016lx, res->end = 0x%016lx\n", +- res->start, res->end); +- } ++ /* Get some IO space for the new PHB */ ++ pcibios_map_io_space(bus); + ++ /* Wire up PHB bus resources */ ++ DBG("PCI: PHB IO resource = %016lx-%016lx [%lx]\n", ++ hose->io_resource.start, hose->io_resource.end, ++ hose->io_resource.flags); ++ bus->resource[0] = &hose->io_resource; + for (i = 0; i < 3; ++i) { +- res = &hose->mem_resources[i]; +- bus->resource[i+1] = res; +- if (res->flags && request_resource(&iomem_resource, res)) +- printk(KERN_ERR "Failed to request PCI memory region " +- "on PCI domain %04x\n", hose->global_number); +- } ++ DBG("PCI: PHB MEM resource %d = %016lx-%016lx [%lx]\n", i, ++ hose->mem_resources[i].start, ++ hose->mem_resources[i].end, ++ hose->mem_resources[i].flags); ++ bus->resource[i+1] = &hose->mem_resources[i]; ++ } ++ DBG("PCI: PHB MEM offset = %016lx\n", hose->pci_mem_offset); ++ DBG("PCI: PHB IO offset = %08lx\n", ++ (unsigned long)hose->io_base_virt - _IO_BASE); + ++ /* Get probe mode and perform scan */ + mode = PCI_PROBE_NORMAL; +- + if (node && ppc_md.pci_probe_mode) + mode = ppc_md.pci_probe_mode(bus); + DBG(" probe mode: %d\n", mode); +@@ -514,15 +407,15 @@ + { + struct pci_controller *hose, *tmp; + ++ printk(KERN_INFO "PCI: Probing PCI hardware\n"); ++ + /* For now, override phys_mem_access_prot. If we need it, + * later, we may move that initialization to each ppc_md + */ + ppc_md.phys_mem_access_prot = pci_phys_mem_access_prot; + +- if (firmware_has_feature(FW_FEATURE_ISERIES)) +- iSeries_pcibios_init(); +- +- printk(KERN_DEBUG "PCI: Probing PCI hardware\n"); ++ if (pci_probe_only) ++ ppc_pci_flags |= PPC_PCI_PROBE_ONLY; + + /* Scan all of the recorded PCI controllers. */ + list_for_each_entry_safe(hose, tmp, &hose_list, list_node) { +@@ -530,19 +423,8 @@ + pci_bus_add_devices(hose->bus); + } + +- if (!firmware_has_feature(FW_FEATURE_ISERIES)) { +- if (pci_probe_only) +- pcibios_claim_of_setup(); +- else +- /* FIXME: `else' will be removed when +- pci_assign_unassigned_resources() is able to work +- correctly with [partially] allocated PCI tree. */ +- pci_assign_unassigned_resources(); +- } +- +- /* Call machine dependent final fixup */ +- if (ppc_md.pcibios_fixup) +- ppc_md.pcibios_fixup(); ++ /* Call common code to handle resource allocation */ ++ pcibios_resource_survey(); + + printk(KERN_DEBUG "PCI: Probing PCI hardware done\n"); + +@@ -551,141 +433,6 @@ + + subsys_initcall(pcibios_init); + +-int pcibios_enable_device(struct pci_dev *dev, int mask) +-{ +- u16 cmd, oldcmd; +- int i; +- +- pci_read_config_word(dev, PCI_COMMAND, &cmd); +- oldcmd = cmd; +- +- for (i = 0; i < PCI_NUM_RESOURCES; i++) { +- struct resource *res = &dev->resource[i]; +- +- /* Only set up the requested stuff */ +- if (!(mask & (1<<i))) +- continue; +- +- if (res->flags & IORESOURCE_IO) +- cmd |= PCI_COMMAND_IO; +- if (res->flags & IORESOURCE_MEM) +- cmd |= PCI_COMMAND_MEMORY; +- } +- +- if (cmd != oldcmd) { +- printk(KERN_DEBUG "PCI: Enabling device: (%s), cmd %x\n", +- pci_name(dev), cmd); +- /* Enable the appropriate bits in the PCI command register. */ +- pci_write_config_word(dev, PCI_COMMAND, cmd); +- } +- return 0; +-} +- +-/* Decide whether to display the domain number in /proc */ +-int pci_proc_domain(struct pci_bus *bus) +-{ +- if (firmware_has_feature(FW_FEATURE_ISERIES)) +- return 0; +- else { +- struct pci_controller *hose = pci_bus_to_host(bus); +- return hose->buid != 0; +- } +-} +- +-void __devinit pci_process_bridge_OF_ranges(struct pci_controller *hose, +- struct device_node *dev, int prim) +-{ +- const unsigned int *ranges; +- unsigned int pci_space; +- unsigned long size; +- int rlen = 0; +- int memno = 0; +- struct resource *res; +- int np, na = of_n_addr_cells(dev); +- unsigned long pci_addr, cpu_phys_addr; +- +- np = na + 5; +- +- /* From "PCI Binding to 1275" +- * The ranges property is laid out as an array of elements, +- * each of which comprises: +- * cells 0 - 2: a PCI address +- * cells 3 or 3+4: a CPU physical address +- * (size depending on dev->n_addr_cells) +- * cells 4+5 or 5+6: the size of the range +- */ +- ranges = of_get_property(dev, "ranges", &rlen); +- if (ranges == NULL) +- return; +- hose->io_base_phys = 0; +- while ((rlen -= np * sizeof(unsigned int)) >= 0) { +- res = NULL; +- pci_space = ranges[0]; +- pci_addr = ((unsigned long)ranges[1] << 32) | ranges[2]; +- cpu_phys_addr = of_translate_address(dev, &ranges[3]); +- size = ((unsigned long)ranges[na+3] << 32) | ranges[na+4]; +- ranges += np; +- if (size == 0) +- continue; +- +- /* Now consume following elements while they are contiguous */ +- while (rlen >= np * sizeof(unsigned int)) { +- unsigned long addr, phys; +- +- if (ranges[0] != pci_space) +- break; +- addr = ((unsigned long)ranges[1] << 32) | ranges[2]; +- phys = ranges[3]; +- if (na >= 2) +- phys = (phys << 32) | ranges[4]; +- if (addr != pci_addr + size || +- phys != cpu_phys_addr + size) +- break; +- +- size += ((unsigned long)ranges[na+3] << 32) +- | ranges[na+4]; +- ranges += np; +- rlen -= np * sizeof(unsigned int); +- } +- +- switch ((pci_space >> 24) & 0x3) { +- case 1: /* I/O space */ +- hose->io_base_phys = cpu_phys_addr - pci_addr; +- /* handle from 0 to top of I/O window */ +- hose->pci_io_size = pci_addr + size; +- +- res = &hose->io_resource; +- res->flags = IORESOURCE_IO; +- res->start = pci_addr; +- DBG("phb%d: IO 0x%lx -> 0x%lx\n", hose->global_number, +- res->start, res->start + size - 1); +- break; +- case 2: /* memory space */ +- memno = 0; +- while (memno < 3 && hose->mem_resources[memno].flags) +- ++memno; +- +- if (memno == 0) +- hose->pci_mem_offset = cpu_phys_addr - pci_addr; +- if (memno < 3) { +- res = &hose->mem_resources[memno]; +- res->flags = IORESOURCE_MEM; +- res->start = cpu_phys_addr; +- DBG("phb%d: MEM 0x%lx -> 0x%lx\n", hose->global_number, +- res->start, res->start + size - 1); +- } +- break; +- } +- if (res != NULL) { +- res->name = dev->full_name; +- res->end = res->start + size - 1; +- res->parent = NULL; +- res->sibling = NULL; +- res->child = NULL; +- } +- } +-} +- + #ifdef CONFIG_HOTPLUG + + int pcibios_unmap_io_space(struct pci_bus *bus) +@@ -719,8 +466,7 @@ + if (hose->io_base_alloc == 0) + return 0; + +- DBG("IO unmapping for PHB %s\n", +- ((struct device_node *)hose->arch_data)->full_name); ++ DBG("IO unmapping for PHB %s\n", hose->dn->full_name); + DBG(" alloc=0x%p\n", hose->io_base_alloc); + + /* This is a PHB, we fully unmap the IO area */ +@@ -779,8 +525,7 @@ + hose->io_base_virt = (void __iomem *)(area->addr + + hose->io_base_phys - phys_page); + +- DBG("IO mapping for PHB %s\n", +- ((struct device_node *)hose->arch_data)->full_name); ++ DBG("IO mapping for PHB %s\n", hose->dn->full_name); + DBG(" phys=0x%016lx, virt=0x%p (alloc=0x%p)\n", + hose->io_base_phys, hose->io_base_virt, hose->io_base_alloc); + DBG(" size=0x%016lx (alloc=0x%016lx)\n", +@@ -803,51 +548,13 @@ + } + EXPORT_SYMBOL_GPL(pcibios_map_io_space); + +-static void __devinit fixup_resource(struct resource *res, struct pci_dev *dev) +-{ +- struct pci_controller *hose = pci_bus_to_host(dev->bus); +- unsigned long offset; +- +- if (res->flags & IORESOURCE_IO) { +- offset = (unsigned long)hose->io_base_virt - _IO_BASE; +- res->start += offset; +- res->end += offset; +- } else if (res->flags & IORESOURCE_MEM) { +- res->start += hose->pci_mem_offset; +- res->end += hose->pci_mem_offset; +- } +-} +- +-void __devinit pcibios_fixup_device_resources(struct pci_dev *dev, +- struct pci_bus *bus) +-{ +- /* Update device resources. */ +- int i; +- +- DBG("%s: Fixup resources:\n", pci_name(dev)); +- for (i = 0; i < PCI_NUM_RESOURCES; i++) { +- struct resource *res = &dev->resource[i]; +- if (!res->flags) +- continue; +- +- DBG(" 0x%02x < %08lx:0x%016lx...0x%016lx\n", +- i, res->flags, res->start, res->end); +- +- fixup_resource(res, dev); +- +- DBG(" > %08lx:0x%016lx...0x%016lx\n", +- res->flags, res->start, res->end); +- } +-} +-EXPORT_SYMBOL(pcibios_fixup_device_resources); +- + void __devinit pcibios_setup_new_device(struct pci_dev *dev) + { + struct dev_archdata *sd = &dev->dev.archdata; + + sd->of_node = pci_device_to_OF_node(dev); + +- DBG("PCI device %s OF node: %s\n", pci_name(dev), ++ DBG("PCI: device %s OF node: %s\n", pci_name(dev), + sd->of_node ? sd->of_node->full_name : "<none>"); + + sd->dma_ops = pci_dma_ops; +@@ -861,7 +568,7 @@ + } + EXPORT_SYMBOL(pcibios_setup_new_device); + +-static void __devinit do_bus_setup(struct pci_bus *bus) ++void __devinit pcibios_do_bus_setup(struct pci_bus *bus) + { + struct pci_dev *dev; + +@@ -870,42 +577,7 @@ + + list_for_each_entry(dev, &bus->devices, bus_list) + pcibios_setup_new_device(dev); +- +- /* Read default IRQs and fixup if necessary */ +- list_for_each_entry(dev, &bus->devices, bus_list) { +- pci_read_irq_line(dev); +- if (ppc_md.pci_irq_fixup) +- ppc_md.pci_irq_fixup(dev); +- } +-} +- +-void __devinit pcibios_fixup_bus(struct pci_bus *bus) +-{ +- struct pci_dev *dev = bus->self; +- struct device_node *np; +- +- np = pci_bus_to_OF_node(bus); +- +- DBG("pcibios_fixup_bus(%s)\n", np ? np->full_name : "<???>"); +- +- if (dev && pci_probe_only && +- (dev->class >> 8) == PCI_CLASS_BRIDGE_PCI) { +- /* This is a subordinate bridge */ +- +- pci_read_bridge_bases(bus); +- pcibios_fixup_device_resources(dev, bus); +- } +- +- do_bus_setup(bus); +- +- if (!pci_probe_only) +- return; +- +- list_for_each_entry(dev, &bus->devices, bus_list) +- if ((dev->class >> 8) != PCI_CLASS_BRIDGE_PCI) +- pcibios_fixup_device_resources(dev, bus); + } +-EXPORT_SYMBOL(pcibios_fixup_bus); + + unsigned long pci_address_to_pio(phys_addr_t address) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/pci_dn.c powerpc.git/arch/powerpc/kernel/pci_dn.c +--- linux-2.6.24/arch/powerpc/kernel/pci_dn.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/pci_dn.c 2008-01-28 20:25:49.000000000 +0100 +@@ -56,11 +56,6 @@ + pdn->busno = (regs[0] >> 16) & 0xff; + pdn->devfn = (regs[0] >> 8) & 0xff; + } +- if (firmware_has_feature(FW_FEATURE_ISERIES)) { +- const u32 *busp = of_get_property(dn, "linux,subbus", NULL); +- if (busp) +- pdn->bussubno = *busp; +- } + + pdn->pci_ext_config_space = (type && *type == 1); + return NULL; +@@ -133,7 +128,7 @@ + */ + void __devinit pci_devs_phb_init_dynamic(struct pci_controller *phb) + { +- struct device_node * dn = (struct device_node *) phb->arch_data; ++ struct device_node *dn = phb->dn; + struct pci_dn *pdn; + + /* PHB nodes themselves must not match */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/ppc_ksyms.c powerpc.git/arch/powerpc/kernel/ppc_ksyms.c +--- linux-2.6.24/arch/powerpc/kernel/ppc_ksyms.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/ppc_ksyms.c 2008-01-28 20:25:49.000000000 +0100 +@@ -59,6 +59,7 @@ + extern int sys_sigreturn(struct pt_regs *regs); + + EXPORT_SYMBOL(clear_pages); ++EXPORT_SYMBOL(copy_page); + EXPORT_SYMBOL(ISA_DMA_THRESHOLD); + EXPORT_SYMBOL(DMA_MODE_READ); + EXPORT_SYMBOL(DMA_MODE_WRITE); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/prom.c powerpc.git/arch/powerpc/kernel/prom.c +--- linux-2.6.24/arch/powerpc/kernel/prom.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/prom.c 2008-01-28 20:25:49.000000000 +0100 +@@ -583,6 +583,20 @@ + ibm_pa_features, ARRAY_SIZE(ibm_pa_features)); + } + ++#ifdef CONFIG_PPC64 ++static void __init check_cpu_slb_size(unsigned long node) ++{ ++ u32 *slb_size_ptr; ++ ++ slb_size_ptr = of_get_flat_dt_prop(node, "ibm,slb-size", NULL); ++ if (slb_size_ptr != NULL) { ++ mmu_slb_size = *slb_size_ptr; ++ } ++} ++#else ++#define check_cpu_slb_size(node) do { } while(0) ++#endif ++ + static struct feature_property { + const char *name; + u32 min_value; +@@ -600,6 +614,29 @@ + #endif /* CONFIG_PPC64 */ + }; + ++#if defined(CONFIG_44x) && defined(CONFIG_PPC_FPU) ++static inline void identical_pvr_fixup(unsigned long node) ++{ ++ unsigned int pvr; ++ char *model = of_get_flat_dt_prop(node, "model", NULL); ++ ++ /* ++ * Since 440GR(x)/440EP(x) processors have the same pvr, ++ * we check the node path and set bit 28 in the cur_cpu_spec ++ * pvr for EP(x) processor version. This bit is always 0 in ++ * the "real" pvr. Then we call identify_cpu again with ++ * the new logical pvr to enable FPU support. ++ */ ++ if (model && strstr(model, "440EP")) { ++ pvr = cur_cpu_spec->pvr_value | 0x8; ++ identify_cpu(0, pvr); ++ DBG("Using logical pvr %x for %s\n", pvr, model); ++ } ++} ++#else ++#define identical_pvr_fixup(node) do { } while(0) ++#endif ++ + static void __init check_cpu_feature_properties(unsigned long node) + { + unsigned long i; +@@ -697,22 +734,13 @@ + prop = of_get_flat_dt_prop(node, "cpu-version", NULL); + if (prop && (*prop & 0xff000000) == 0x0f000000) + identify_cpu(0, *prop); +-#if defined(CONFIG_44x) && defined(CONFIG_PPC_FPU) +- /* +- * Since 440GR(x)/440EP(x) processors have the same pvr, +- * we check the node path and set bit 28 in the cur_cpu_spec +- * pvr for EP(x) processor version. This bit is always 0 in +- * the "real" pvr. Then we call identify_cpu again with +- * the new logical pvr to enable FPU support. +- */ +- if (strstr(uname, "440EP")) { +- identify_cpu(0, cur_cpu_spec->pvr_value | 0x8); +- } +-#endif ++ ++ identical_pvr_fixup(node); + } + + check_cpu_feature_properties(node); + check_cpu_pa_features(node); ++ check_cpu_slb_size(node); + + #ifdef CONFIG_PPC_PSERIES + if (nthreads > 1) +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/prom_parse.c powerpc.git/arch/powerpc/kernel/prom_parse.c +--- linux-2.6.24/arch/powerpc/kernel/prom_parse.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/prom_parse.c 2008-01-28 20:25:49.000000000 +0100 +@@ -273,7 +273,7 @@ + #else + struct pci_controller *host; + host = pci_bus_to_host(pdev->bus); +- ppnode = host ? host->arch_data : NULL; ++ ppnode = host ? host->dn : NULL; + #endif + /* No node for host bridge ? give up */ + if (ppnode == NULL) +@@ -419,7 +419,7 @@ + + static int of_translate_one(struct device_node *parent, struct of_bus *bus, + struct of_bus *pbus, u32 *addr, +- int na, int ns, int pna) ++ int na, int ns, int pna, const char *rprop) + { + const u32 *ranges; + unsigned int rlen; +@@ -438,7 +438,7 @@ + * to translate addresses that aren't supposed to be translated in + * the first place. --BenH. + */ +- ranges = of_get_property(parent, "ranges", &rlen); ++ ranges = of_get_property(parent, rprop, &rlen); + if (ranges == NULL || rlen == 0) { + offset = of_read_number(addr, na); + memset(addr, 0, pna * 4); +@@ -481,7 +481,8 @@ + * that can be mapped to a cpu physical address). This is not really specified + * that way, but this is traditionally the way IBM at least do things + */ +-u64 of_translate_address(struct device_node *dev, const u32 *in_addr) ++u64 __of_translate_address(struct device_node *dev, const u32 *in_addr, ++ const char *rprop) + { + struct device_node *parent = NULL; + struct of_bus *bus, *pbus; +@@ -540,7 +541,7 @@ + pbus->name, pna, pns, parent->full_name); + + /* Apply bus translation */ +- if (of_translate_one(dev, bus, pbus, addr, na, ns, pna)) ++ if (of_translate_one(dev, bus, pbus, addr, na, ns, pna, rprop)) + break; + + /* Complete the move up one level */ +@@ -556,8 +557,19 @@ + + return result; + } ++ ++u64 of_translate_address(struct device_node *dev, const u32 *in_addr) ++{ ++ return __of_translate_address(dev, in_addr, "ranges"); ++} + EXPORT_SYMBOL(of_translate_address); + ++u64 of_translate_dma_address(struct device_node *dev, const u32 *in_addr) ++{ ++ return __of_translate_address(dev, in_addr, "dma-ranges"); ++} ++EXPORT_SYMBOL(of_translate_dma_address); ++ + const u32 *of_get_address(struct device_node *dev, int index, u64 *size, + unsigned int *flags) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/rio.c powerpc.git/arch/powerpc/kernel/rio.c +--- linux-2.6.24/arch/powerpc/kernel/rio.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/rio.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,52 @@ ++/* ++ * RapidIO PPC32 support ++ * ++ * Copyright 2005 MontaVista Software, Inc. ++ * Matt Porter <mporter@kernel.crashing.org> ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++#include <linux/init.h> ++#include <linux/kernel.h> ++#include <linux/rio.h> ++ ++#include <asm/rio.h> ++ ++/** ++ * platform_rio_init - Do platform specific RIO init ++ * ++ * Any platform specific initialization of RapdIO ++ * hardware is done here as well as registration ++ * of any active master ports in the system. ++ */ ++void __attribute__ ((weak)) ++ platform_rio_init(void) ++{ ++ printk(KERN_WARNING "RIO: No platform_rio_init() present\n"); ++} ++ ++/** ++ * ppc_rio_init - Do PPC32 RIO init ++ * ++ * Calls platform-specific RIO init code and then calls ++ * rio_init_mports() to initialize any master ports that ++ * have been registered with the RIO subsystem. ++ */ ++static int __init ppc_rio_init(void) ++{ ++ printk(KERN_INFO "RIO: RapidIO init\n"); ++ ++ /* Platform specific initialization */ ++ platform_rio_init(); ++ ++ /* Enumerate all registered ports */ ++ rio_init_mports(); ++ ++ return 0; ++} ++ ++subsys_initcall(ppc_rio_init); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/rtas_pci.c powerpc.git/arch/powerpc/kernel/rtas_pci.c +--- linux-2.6.24/arch/powerpc/kernel/rtas_pci.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/rtas_pci.c 2008-01-28 20:25:49.000000000 +0100 +@@ -260,7 +260,7 @@ + + int __devinit rtas_setup_phb(struct pci_controller *phb) + { +- struct device_node *dev = phb->arch_data; ++ struct device_node *dev = phb->dn; + + if (is_python(dev)) + python_countermeasures(dev); +@@ -280,10 +280,7 @@ + struct pci_controller *phb; + struct device_node *root = of_find_node_by_path("/"); + +- for (node = of_get_next_child(root, NULL); +- node != NULL; +- node = of_get_next_child(root, node)) { +- ++ for_each_child_of_node(root, node) { + if (node->type == NULL || (strcmp(node->type, "pci") != 0 && + strcmp(node->type, "pciex") != 0)) + continue; +@@ -311,10 +308,12 @@ + if (prop) + pci_probe_only = *prop; + ++#ifdef CONFIG_PPC32 /* Will be made generic soon */ + prop = of_get_property(of_chosen, + "linux,pci-assign-all-buses", NULL); +- if (prop) +- pci_assign_all_buses = *prop; ++ if (prop && *prop) ++ ppc_pci_flags |= PPC_PCI_REASSIGN_ALL_BUS; ++#endif /* CONFIG_PPC32 */ + } + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/setup-common.c powerpc.git/arch/powerpc/kernel/setup-common.c +--- linux-2.6.24/arch/powerpc/kernel/setup-common.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/setup-common.c 2008-01-28 20:25:49.000000000 +0100 +@@ -33,6 +33,7 @@ + #include <linux/serial.h> + #include <linux/serial_8250.h> + #include <linux/debugfs.h> ++#include <linux/percpu.h> + #include <asm/io.h> + #include <asm/prom.h> + #include <asm/processor.h> +@@ -57,6 +58,7 @@ + #include <asm/mmu.h> + #include <asm/lmb.h> + #include <asm/xmon.h> ++#include <asm/cputhreads.h> + + #include "setup.h" + +@@ -327,6 +329,31 @@ + + #ifdef CONFIG_SMP + ++int threads_per_core, threads_shift; ++cpumask_t threads_core_mask; ++ ++static void __init cpu_init_thread_core_maps(int tpc) ++{ ++ int i; ++ ++ threads_per_core = tpc; ++ threads_core_mask = CPU_MASK_NONE; ++ ++ /* This implementation only supports power of 2 number of threads ++ * for simplicity and performance ++ */ ++ threads_shift = ilog2(tpc); ++ BUG_ON(tpc != (1 << threads_shift)); ++ ++ for (i = 0; i < tpc; i++) ++ cpu_set(i, threads_core_mask); ++ ++ printk(KERN_INFO "CPU maps initialized for %d thread%s per core\n", ++ tpc, tpc > 1 ? "s" : ""); ++ printk(KERN_DEBUG " (thread shift is %d)\n", threads_shift); ++} ++ ++ + /** + * setup_cpu_maps - initialize the following cpu maps: + * cpu_possible_map +@@ -350,22 +377,32 @@ + { + struct device_node *dn = NULL; + int cpu = 0; ++ int nthreads = 1; ++ ++ DBG("smp_setup_cpu_maps()\n"); + + while ((dn = of_find_node_by_type(dn, "cpu")) && cpu < NR_CPUS) { + const int *intserv; +- int j, len = sizeof(u32), nthreads = 1; ++ int j, len; ++ ++ DBG(" * %s...\n", dn->full_name); + + intserv = of_get_property(dn, "ibm,ppc-interrupt-server#s", + &len); +- if (intserv) ++ if (intserv) { + nthreads = len / sizeof(int); +- else { ++ DBG(" ibm,ppc-interrupt-server#s -> %d threads\n", ++ nthreads); ++ } else { ++ DBG(" no ibm,ppc-interrupt-server#s -> 1 thread\n"); + intserv = of_get_property(dn, "reg", NULL); + if (!intserv) + intserv = &cpu; /* assume logical == phys */ + } + + for (j = 0; j < nthreads && cpu < NR_CPUS; j++) { ++ DBG(" thread %d -> cpu %d (hard id %d)\n", ++ j, cpu, intserv[j]); + cpu_set(cpu, cpu_present_map); + set_hard_smp_processor_id(cpu, intserv[j]); + cpu_set(cpu, cpu_possible_map); +@@ -373,6 +410,12 @@ + } + } + ++ /* If no SMT supported, nthreads is forced to 1 */ ++ if (!cpu_has_feature(CPU_FTR_SMT)) { ++ DBG(" SMT disabled ! nthreads forced to 1\n"); ++ nthreads = 1; ++ } ++ + #ifdef CONFIG_PPC64 + /* + * On pSeries LPAR, we need to know how many cpus +@@ -395,7 +438,7 @@ + + /* Double maxcpus for processors which have SMT capability */ + if (cpu_has_feature(CPU_FTR_SMT)) +- maxcpus *= 2; ++ maxcpus *= nthreads; + + if (maxcpus > NR_CPUS) { + printk(KERN_WARNING +@@ -412,9 +455,16 @@ + out: + of_node_put(dn); + } +- + vdso_data->processorCount = num_present_cpus(); + #endif /* CONFIG_PPC64 */ ++ ++ /* Initialize CPU <=> thread mapping/ ++ * ++ * WARNING: We assume that the number of threads is the same for ++ * every CPU in the system. If that is not the case, then some code ++ * here will have to be reworked ++ */ ++ cpu_init_thread_core_maps(nthreads); + } + + /* +@@ -424,17 +474,19 @@ + */ + void __init smp_setup_cpu_sibling_map(void) + { +-#if defined(CONFIG_PPC64) +- int cpu; ++#ifdef CONFIG_PPC64 ++ int i, cpu, base; + +- /* +- * Do the sibling map; assume only two threads per processor. +- */ + for_each_possible_cpu(cpu) { +- cpu_set(cpu, per_cpu(cpu_sibling_map, cpu)); +- if (cpu_has_feature(CPU_FTR_SMT)) +- cpu_set(cpu ^ 0x1, per_cpu(cpu_sibling_map, cpu)); ++ DBG("Sibling map for CPU %d:", cpu); ++ base = cpu_first_thread_in_core(cpu); ++ for (i = 0; i < threads_per_core; i++) { ++ cpu_set(base + i, per_cpu(cpu_sibling_map, cpu)); ++ DBG(" %d", base + i); ++ } ++ DBG("\n"); + } ++ + #endif /* CONFIG_PPC64 */ + } + #endif /* CONFIG_SMP */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/signal_32.c powerpc.git/arch/powerpc/kernel/signal_32.c +--- linux-2.6.24/arch/powerpc/kernel/signal_32.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/signal_32.c 2008-01-28 20:25:49.000000000 +0100 +@@ -24,13 +24,12 @@ + #include <linux/signal.h> + #include <linux/errno.h> + #include <linux/elf.h> ++#include <linux/ptrace.h> + #ifdef CONFIG_PPC64 + #include <linux/syscalls.h> + #include <linux/compat.h> +-#include <linux/ptrace.h> + #else + #include <linux/wait.h> +-#include <linux/ptrace.h> + #include <linux/unistd.h> + #include <linux/stddef.h> + #include <linux/tty.h> +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/smp.c powerpc.git/arch/powerpc/kernel/smp.c +--- linux-2.6.24/arch/powerpc/kernel/smp.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/smp.c 2008-01-28 20:25:49.000000000 +0100 +@@ -76,6 +76,8 @@ + + int smt_enabled_at_boot = 1; + ++static int ipi_fail_ok; ++ + static void (*crash_ipi_function_ptr)(struct pt_regs *) = NULL; + + #ifdef CONFIG_PPC64 +@@ -181,12 +183,13 @@ + * <wait> If true, wait (atomically) until function has completed on other CPUs. + * [RETURNS] 0 on success, else a negative status code. Does not return until + * remote CPUs are nearly ready to execute <<func>> or are or have executed. ++ * <map> is a cpu map of the cpus to send IPI to. + * + * You must not call this function with disabled interrupts or from a + * hardware interrupt handler or from a bottom half handler. + */ +-int smp_call_function_map(void (*func) (void *info), void *info, int nonatomic, +- int wait, cpumask_t map) ++static int __smp_call_function_map(void (*func) (void *info), void *info, ++ int nonatomic, int wait, cpumask_t map) + { + struct call_data_struct data; + int ret = -1, num_cpus; +@@ -203,8 +206,6 @@ + if (wait) + atomic_set(&data.finished, 0); + +- spin_lock(&call_lock); +- + /* remove 'self' from the map */ + if (cpu_isset(smp_processor_id(), map)) + cpu_clear(smp_processor_id(), map); +@@ -231,7 +232,8 @@ + printk("smp_call_function on cpu %d: other cpus not " + "responding (%d)\n", smp_processor_id(), + atomic_read(&data.started)); +- debugger(NULL); ++ if (!ipi_fail_ok) ++ debugger(NULL); + goto out; + } + } +@@ -258,14 +260,18 @@ + out: + call_data = NULL; + HMT_medium(); +- spin_unlock(&call_lock); + return ret; + } + + static int __smp_call_function(void (*func)(void *info), void *info, + int nonatomic, int wait) + { +- return smp_call_function_map(func,info,nonatomic,wait,cpu_online_map); ++ int ret; ++ spin_lock(&call_lock); ++ ret =__smp_call_function_map(func, info, nonatomic, wait, ++ cpu_online_map); ++ spin_unlock(&call_lock); ++ return ret; + } + + int smp_call_function(void (*func) (void *info), void *info, int nonatomic, +@@ -278,8 +284,8 @@ + } + EXPORT_SYMBOL(smp_call_function); + +-int smp_call_function_single(int cpu, void (*func) (void *info), void *info, int nonatomic, +- int wait) ++int smp_call_function_single(int cpu, void (*func) (void *info), void *info, ++ int nonatomic, int wait) + { + cpumask_t map = CPU_MASK_NONE; + int ret = 0; +@@ -291,9 +297,11 @@ + return -EINVAL; + + cpu_set(cpu, map); +- if (cpu != get_cpu()) +- ret = smp_call_function_map(func,info,nonatomic,wait,map); +- else { ++ if (cpu != get_cpu()) { ++ spin_lock(&call_lock); ++ ret = __smp_call_function_map(func, info, nonatomic, wait, map); ++ spin_unlock(&call_lock); ++ } else { + local_irq_disable(); + func(info); + local_irq_enable(); +@@ -305,7 +313,22 @@ + + void smp_send_stop(void) + { +- __smp_call_function(stop_this_cpu, NULL, 1, 0); ++ int nolock; ++ ++ /* It's OK to fail sending the IPI, since the alternative is to ++ * be stuck forever waiting on the other CPU to take the interrupt. ++ * ++ * It's better to at least continue and go through reboot, since this ++ * function is usually called at panic or reboot time in the first ++ * place. ++ */ ++ ipi_fail_ok = 1; ++ ++ /* Don't deadlock in case we got called through panic */ ++ nolock = !spin_trylock(&call_lock); ++ __smp_call_function_map(stop_this_cpu, NULL, 1, 0, cpu_online_map); ++ if (!nolock) ++ spin_unlock(&call_lock); + } + + void smp_call_function_interrupt(void) +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/systbl_chk.c powerpc.git/arch/powerpc/kernel/systbl_chk.c +--- linux-2.6.24/arch/powerpc/kernel/systbl_chk.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/systbl_chk.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,58 @@ ++/* ++ * This file, when run through CPP produces a list of syscall numbers ++ * in the order of systbl.h. That way we can check for gaps and syscalls ++ * that are out of order. ++ * ++ * Unfortunately, we cannot check for the correct ordering of entries ++ * using SYSX(). ++ * ++ * Copyright © IBM Corporation ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License ++ * as published by the Free Software Foundation; either version ++ * 2 of the License, or (at your option) any later version. ++ */ ++#include <asm/unistd.h> ++ ++#define SYSCALL(func) __NR_##func ++#define COMPAT_SYS(func) __NR_##func ++#define PPC_SYS(func) __NR_##func ++#ifdef CONFIG_PPC64 ++#define OLDSYS(func) -1 ++#define SYS32ONLY(func) -1 ++#else ++#define OLDSYS(func) __NR_old##func ++#define SYS32ONLY(func) __NR_##func ++#endif ++#define SYSX(f, f3264, f32) -1 ++ ++#define SYSCALL_SPU(func) SYSCALL(func) ++#define COMPAT_SYS_SPU(func) COMPAT_SYS(func) ++#define PPC_SYS_SPU(func) PPC_SYS(func) ++#define SYSX_SPU(f, f3264, f32) SYSX(f, f3264, f32) ++ ++/* Just insert a marker for ni_syscalls */ ++#define __NR_ni_syscall -1 ++ ++/* ++ * These are the known exceptions. ++ * Hopefully, there will be no more. ++ */ ++#define __NR_llseek __NR__llseek ++#undef __NR_umount ++#define __NR_umount __NR_umount2 ++#define __NR_old_getrlimit __NR_getrlimit ++#define __NR_newstat __NR_stat ++#define __NR_newlstat __NR_lstat ++#define __NR_newfstat __NR_fstat ++#define __NR_newuname __NR_uname ++#define __NR_sysctl __NR__sysctl ++#define __NR_olddebug_setcontext __NR_sys_debug_setcontext ++ ++/* We call sys_ugetrlimit for syscall number __NR_getrlimit */ ++#define getrlimit ugetrlimit ++ ++START_TABLE ++#include <asm/systbl.h> ++END_TABLE __NR_syscalls +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/systbl_chk.sh powerpc.git/arch/powerpc/kernel/systbl_chk.sh +--- linux-2.6.24/arch/powerpc/kernel/systbl_chk.sh 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/systbl_chk.sh 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,33 @@ ++#!/bin/sh ++# ++# Just process the CPP output from systbl_chk.c and complain ++# if anything is out of order. ++# ++# Copyright © 2008 IBM Corporation ++# ++# This program is free software; you can redistribute it and/or ++# modify it under the terms of the GNU General Public License ++# as published by the Free Software Foundation; either version ++# 2 of the License, or (at your option) any later version. ++ ++awk 'BEGIN { num = -1; } # Ignore the beginning of the file ++ /^#/ { next; } ++ /^[ \t]*$/ { next; } ++ /^START_TABLE/ { num = 0; next; } ++ /^END_TABLE/ { ++ if (num != $2) { ++ printf "__NR_syscalls (%s) is not one more than the last syscall (%s)\n", ++ $2, num - 1; ++ exit(1); ++ } ++ num = -1; # Ignore the rest of the file ++ } ++ { ++ if (num == -1) next; ++ if (($1 != -1) && ($1 != num)) { ++ printf "Syscall %s out of order (expected %s)\n", ++ $1, num; ++ exit(1); ++ }; ++ num++; ++ }' "$1" +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/time.c powerpc.git/arch/powerpc/kernel/time.c +--- linux-2.6.24/arch/powerpc/kernel/time.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/time.c 2008-01-28 20:25:49.000000000 +0100 +@@ -116,9 +116,12 @@ + .features = CLOCK_EVT_FEAT_ONESHOT, + }; + +-static DEFINE_PER_CPU(struct clock_event_device, decrementers); +-void init_decrementer_clockevent(void); +-static DEFINE_PER_CPU(u64, decrementer_next_tb); ++struct decrementer_clock { ++ struct clock_event_device event; ++ u64 next_tb; ++}; ++ ++static DEFINE_PER_CPU(struct decrementer_clock, decrementers); + + #ifdef CONFIG_PPC_ISERIES + static unsigned long __initdata iSeries_recal_titan; +@@ -216,7 +219,11 @@ + */ + static u64 read_spurr(u64 purr) + { +- if (cpu_has_feature(CPU_FTR_SPURR)) ++ /* ++ * cpus without PURR won't have a SPURR ++ * We already know the former when we use this, so tell gcc ++ */ ++ if (cpu_has_feature(CPU_FTR_PURR) && cpu_has_feature(CPU_FTR_SPURR)) + return mfspr(SPRN_SPURR); + return purr; + } +@@ -227,29 +234,30 @@ + */ + void account_system_vtime(struct task_struct *tsk) + { +- u64 now, nowscaled, delta, deltascaled; ++ u64 now, nowscaled, delta, deltascaled, sys_time; + unsigned long flags; + + local_irq_save(flags); + now = read_purr(); +- delta = now - get_paca()->startpurr; +- get_paca()->startpurr = now; + nowscaled = read_spurr(now); ++ delta = now - get_paca()->startpurr; + deltascaled = nowscaled - get_paca()->startspurr; ++ get_paca()->startpurr = now; + get_paca()->startspurr = nowscaled; + if (!in_interrupt()) { + /* deltascaled includes both user and system time. + * Hence scale it based on the purr ratio to estimate + * the system time */ ++ sys_time = get_paca()->system_time; + if (get_paca()->user_time) +- deltascaled = deltascaled * get_paca()->system_time / +- (get_paca()->system_time + get_paca()->user_time); +- delta += get_paca()->system_time; ++ deltascaled = deltascaled * sys_time / ++ (sys_time + get_paca()->user_time); ++ delta += sys_time; + get_paca()->system_time = 0; + } + account_system_time(tsk, 0, delta); +- get_paca()->purrdelta = delta; + account_system_time_scaled(tsk, deltascaled); ++ get_paca()->purrdelta = delta; + get_paca()->spurrdelta = deltascaled; + local_irq_restore(flags); + } +@@ -326,11 +334,9 @@ + s64 stolen; + struct cpu_purr_data *pme; + +- if (!cpu_has_feature(CPU_FTR_PURR)) +- return; +- pme = &per_cpu(cpu_purr_data, smp_processor_id()); ++ pme = &__get_cpu_var(cpu_purr_data); + if (!pme->initialized) +- return; /* this can happen in early boot */ ++ return; /* !CPU_FTR_PURR or early in early boot */ + tb = mftb(); + purr = mfspr(SPRN_PURR); + stolen = (tb - pme->tb) - (purr - pme->purr); +@@ -353,7 +359,7 @@ + if (!cpu_has_feature(CPU_FTR_PURR)) + return; + local_irq_save(flags); +- pme = &per_cpu(cpu_purr_data, smp_processor_id()); ++ pme = &__get_cpu_var(cpu_purr_data); + pme->tb = mftb(); + pme->purr = mfspr(SPRN_PURR); + pme->initialized = 1; +@@ -556,8 +562,8 @@ + void timer_interrupt(struct pt_regs * regs) + { + struct pt_regs *old_regs; +- int cpu = smp_processor_id(); +- struct clock_event_device *evt = &per_cpu(decrementers, cpu); ++ struct decrementer_clock *decrementer = &__get_cpu_var(decrementers); ++ struct clock_event_device *evt = &decrementer->event; + u64 now; + + /* Ensure a positive value is written to the decrementer, or else +@@ -570,9 +576,9 @@ + #endif + + now = get_tb_or_rtc(); +- if (now < per_cpu(decrementer_next_tb, cpu)) { ++ if (now < decrementer->next_tb) { + /* not time for this event yet */ +- now = per_cpu(decrementer_next_tb, cpu) - now; ++ now = decrementer->next_tb - now; + if (now <= DECREMENTER_MAX) + set_dec((int)now); + return; +@@ -623,6 +629,45 @@ + set_dec(ticks); + } + ++#ifdef CONFIG_SUSPEND ++void generic_suspend_disable_irqs(void) ++{ ++ preempt_disable(); ++ ++ /* Disable the decrementer, so that it doesn't interfere ++ * with suspending. ++ */ ++ ++ set_dec(0x7fffffff); ++ local_irq_disable(); ++ set_dec(0x7fffffff); ++} ++ ++void generic_suspend_enable_irqs(void) ++{ ++ wakeup_decrementer(); ++ ++ local_irq_enable(); ++ preempt_enable(); ++} ++ ++/* Overrides the weak version in kernel/power/main.c */ ++void arch_suspend_disable_irqs(void) ++{ ++ if (ppc_md.suspend_disable_irqs) ++ ppc_md.suspend_disable_irqs(); ++ generic_suspend_disable_irqs(); ++} ++ ++/* Overrides the weak version in kernel/power/main.c */ ++void arch_suspend_enable_irqs(void) ++{ ++ generic_suspend_enable_irqs(); ++ if (ppc_md.suspend_enable_irqs) ++ ppc_md.suspend_enable_irqs(); ++} ++#endif ++ + #ifdef CONFIG_SMP + void __init smp_space_timers(unsigned int max_cpus) + { +@@ -811,7 +856,7 @@ + static int decrementer_set_next_event(unsigned long evt, + struct clock_event_device *dev) + { +- __get_cpu_var(decrementer_next_tb) = get_tb_or_rtc() + evt; ++ __get_cpu_var(decrementers).next_tb = get_tb_or_rtc() + evt; + set_dec(evt); + return 0; + } +@@ -825,7 +870,7 @@ + + static void register_decrementer_clockevent(int cpu) + { +- struct clock_event_device *dec = &per_cpu(decrementers, cpu); ++ struct clock_event_device *dec = &per_cpu(decrementers, cpu).event; + + *dec = decrementer_clockevent; + dec->cpumask = cpumask_of_cpu(cpu); +@@ -836,7 +881,7 @@ + clockevents_register_device(dec); + } + +-void init_decrementer_clockevent(void) ++static void __init init_decrementer_clockevent(void) + { + int cpu = smp_processor_id(); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/traps.c powerpc.git/arch/powerpc/kernel/traps.c +--- linux-2.6.24/arch/powerpc/kernel/traps.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/traps.c 2008-01-28 20:25:49.000000000 +0100 +@@ -334,18 +334,25 @@ + #define clear_single_step(regs) ((regs)->msr &= ~MSR_SE) + #endif + +-static int generic_machine_check_exception(struct pt_regs *regs) ++#if defined(CONFIG_4xx) ++int machine_check_4xx(struct pt_regs *regs) + { + unsigned long reason = get_mc_reason(regs); + +-#if defined(CONFIG_4xx) && !defined(CONFIG_440A) + if (reason & ESR_IMCP) { + printk("Instruction"); + mtspr(SPRN_ESR, reason & ~ESR_IMCP); + } else + printk("Data"); + printk(" machine check in kernel mode.\n"); +-#elif defined(CONFIG_440A) ++ ++ return 0; ++} ++ ++int machine_check_440A(struct pt_regs *regs) ++{ ++ unsigned long reason = get_mc_reason(regs); ++ + printk("Machine check in kernel mode.\n"); + if (reason & ESR_IMCP){ + printk("Instruction Synchronous Machine Check exception\n"); +@@ -375,7 +382,13 @@ + /* Clear MCSR */ + mtspr(SPRN_MCSR, mcsr); + } +-#elif defined (CONFIG_E500) ++ return 0; ++} ++#elif defined(CONFIG_E500) ++int machine_check_e500(struct pt_regs *regs) ++{ ++ unsigned long reason = get_mc_reason(regs); ++ + printk("Machine check in kernel mode.\n"); + printk("Caused by (from MCSR=%lx): ", reason); + +@@ -403,7 +416,14 @@ + printk("Bus - Instruction Parity Error\n"); + if (reason & MCSR_BUS_RPERR) + printk("Bus - Read Parity Error\n"); +-#elif defined (CONFIG_E200) ++ ++ return 0; ++} ++#elif defined(CONFIG_E200) ++int machine_check_e200(struct pt_regs *regs) ++{ ++ unsigned long reason = get_mc_reason(regs); ++ + printk("Machine check in kernel mode.\n"); + printk("Caused by (from MCSR=%lx): ", reason); + +@@ -421,7 +441,14 @@ + printk("Bus - Read Bus Error on data load\n"); + if (reason & MCSR_BUS_WRERR) + printk("Bus - Write Bus Error on buffered store or cache line push\n"); +-#else /* !CONFIG_4xx && !CONFIG_E500 && !CONFIG_E200 */ ++ ++ return 0; ++} ++#else ++int machine_check_generic(struct pt_regs *regs) ++{ ++ unsigned long reason = get_mc_reason(regs); ++ + printk("Machine check in kernel mode.\n"); + printk("Caused by (from SRR1=%lx): ", reason); + switch (reason & 0x601F0000) { +@@ -451,22 +478,26 @@ + default: + printk("Unknown values in msr\n"); + } +-#endif /* CONFIG_4xx */ +- + return 0; + } ++#endif /* everything else */ + + void machine_check_exception(struct pt_regs *regs) + { + int recover = 0; + +- /* See if any machine dependent calls */ ++ /* See if any machine dependent calls. In theory, we would want ++ * to call the CPU first, and call the ppc_md. one if the CPU ++ * one returns a positive number. However there is existing code ++ * that assumes the board gets a first chance, so let's keep it ++ * that way for now and fix things later. --BenH. ++ */ + if (ppc_md.machine_check_exception) + recover = ppc_md.machine_check_exception(regs); +- else +- recover = generic_machine_check_exception(regs); ++ else if (cur_cpu_spec->machine_check) ++ recover = cur_cpu_spec->machine_check(regs); + +- if (recover) ++ if (recover > 0) + return; + + if (user_mode(regs)) { +@@ -476,7 +507,12 @@ + } + + #if defined(CONFIG_8xx) && defined(CONFIG_PCI) +- /* the qspan pci read routines can cause machine checks -- Cort */ ++ /* the qspan pci read routines can cause machine checks -- Cort ++ * ++ * yuck !!! that totally needs to go away ! There are better ways ++ * to deal with that than having a wart in the mcheck handler. ++ * -- BenH ++ */ + bad_page_fault(regs, regs->dar, SIGBUS); + return; + #endif +@@ -622,6 +658,9 @@ + #define INST_POPCNTB 0x7c0000f4 + #define INST_POPCNTB_MASK 0xfc0007fe + ++#define INST_ISEL 0x7c00001e ++#define INST_ISEL_MASK 0xfc00003e ++ + static int emulate_string_inst(struct pt_regs *regs, u32 instword) + { + u8 rT = (instword >> 21) & 0x1f; +@@ -707,6 +746,23 @@ + return 0; + } + ++static int emulate_isel(struct pt_regs *regs, u32 instword) ++{ ++ u8 rT = (instword >> 21) & 0x1f; ++ u8 rA = (instword >> 16) & 0x1f; ++ u8 rB = (instword >> 11) & 0x1f; ++ u8 BC = (instword >> 6) & 0x1f; ++ u8 bit; ++ unsigned long tmp; ++ ++ tmp = (rA == 0) ? 0 : regs->gpr[rA]; ++ bit = (regs->ccr >> (31 - BC)) & 0x1; ++ ++ regs->gpr[rT] = bit ? tmp : regs->gpr[rB]; ++ ++ return 0; ++} ++ + static int emulate_instruction(struct pt_regs *regs) + { + u32 instword; +@@ -749,6 +805,11 @@ + return emulate_popcntb_inst(regs, instword); + } + ++ /* Emulate isel (Integer Select) instruction */ ++ if ((instword & INST_ISEL_MASK) == INST_ISEL) { ++ return emulate_isel(regs, instword); ++ } ++ + return -EINVAL; + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/udbg.c powerpc.git/arch/powerpc/kernel/udbg.c +--- linux-2.6.24/arch/powerpc/kernel/udbg.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/udbg.c 2008-01-28 20:25:49.000000000 +0100 +@@ -54,9 +54,16 @@ + #elif defined(CONFIG_PPC_EARLY_DEBUG_44x) + /* PPC44x debug */ + udbg_init_44x_as1(); ++#elif defined(CONFIG_PPC_EARLY_DEBUG_40x) ++ /* PPC40x debug */ ++ udbg_init_40x_realmode(); + #elif defined(CONFIG_PPC_EARLY_DEBUG_CPM) + udbg_init_cpm(); + #endif ++ ++#ifdef CONFIG_PPC_EARLY_DEBUG ++ console_loglevel = 10; ++#endif + } + + /* udbg library, used by xmon et al */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/kernel/udbg_16550.c powerpc.git/arch/powerpc/kernel/udbg_16550.c +--- linux-2.6.24/arch/powerpc/kernel/udbg_16550.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/kernel/udbg_16550.c 2008-01-28 20:25:49.000000000 +0100 +@@ -46,7 +46,7 @@ + + #define LCR_DLAB 0x80 + +-static volatile struct NS16550 __iomem *udbg_comport; ++static struct NS16550 __iomem *udbg_comport; + + static void udbg_550_putc(char c) + { +@@ -117,7 +117,7 @@ + { + unsigned int dll, dlm, divisor, prescaler, speed; + u8 old_lcr; +- volatile struct NS16550 __iomem *port = comport; ++ struct NS16550 __iomem *port = comport; + + old_lcr = in_8(&port->lcr); + +@@ -162,7 +162,7 @@ + + void __init udbg_init_maple_realmode(void) + { +- udbg_comport = (volatile struct NS16550 __iomem *)0xf40003f8; ++ udbg_comport = (struct NS16550 __iomem *)0xf40003f8; + + udbg_putc = udbg_maple_real_putc; + udbg_getc = NULL; +@@ -184,7 +184,7 @@ + + void udbg_init_pas_realmode(void) + { +- udbg_comport = (volatile struct NS16550 __iomem *)0xfcff03f8UL; ++ udbg_comport = (struct NS16550 __iomem *)0xfcff03f8UL; + + udbg_putc = udbg_pas_real_putc; + udbg_getc = NULL; +@@ -219,9 +219,42 @@ + void __init udbg_init_44x_as1(void) + { + udbg_comport = +- (volatile struct NS16550 __iomem *)PPC44x_EARLY_DEBUG_VIRTADDR; ++ (struct NS16550 __iomem *)PPC44x_EARLY_DEBUG_VIRTADDR; + + udbg_putc = udbg_44x_as1_putc; + udbg_getc = udbg_44x_as1_getc; + } + #endif /* CONFIG_PPC_EARLY_DEBUG_44x */ ++ ++#ifdef CONFIG_PPC_EARLY_DEBUG_40x ++static void udbg_40x_real_putc(char c) ++{ ++ if (udbg_comport) { ++ while ((real_readb(&udbg_comport->lsr) & LSR_THRE) == 0) ++ /* wait for idle */; ++ real_writeb(c, &udbg_comport->thr); eieio(); ++ if (c == '\n') ++ udbg_40x_real_putc('\r'); ++ } ++} ++ ++static int udbg_40x_real_getc(void) ++{ ++ if (udbg_comport) { ++ while ((real_readb(&udbg_comport->lsr) & LSR_DR) == 0) ++ ; /* wait for char */ ++ return real_readb(&udbg_comport->rbr); ++ } ++ return -1; ++} ++ ++void __init udbg_init_40x_realmode(void) ++{ ++ udbg_comport = (struct NS16550 __iomem *) ++ CONFIG_PPC_EARLY_DEBUG_40x_PHYSADDR; ++ ++ udbg_putc = udbg_40x_real_putc; ++ udbg_getc = udbg_40x_real_getc; ++ udbg_getc_poll = NULL; ++} ++#endif /* CONFIG_PPC_EARLY_DEBUG_40x */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/math-emu/op-4.h powerpc.git/arch/powerpc/math-emu/op-4.h +--- linux-2.6.24/arch/powerpc/math-emu/op-4.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/math-emu/op-4.h 2008-01-28 20:25:49.000000000 +0100 +@@ -194,19 +194,39 @@ + (X##_f[3] = I3, X##_f[2] = I2, X##_f[1] = I1, X##_f[0] = I0) + + #ifndef __FP_FRAC_ADD_4 +-#define __FP_FRAC_ADD_4(r3,r2,r1,r0,x3,x2,x1,x0,y3,y2,y1,y0) \ +- (r0 = x0 + y0, \ +- r1 = x1 + y1 + (r0 < x0), \ +- r2 = x2 + y2 + (r1 < x1), \ +- r3 = x3 + y3 + (r2 < x2)) ++#define __FP_FRAC_ADD_4(r3,r2,r1,r0,x3,x2,x1,x0,y3,y2,y1,y0) \ ++ do { \ ++ int _c1, _c2, _c3; \ ++ r0 = x0 + y0; \ ++ _c1 = r0 < x0; \ ++ r1 = x1 + y1; \ ++ _c2 = r1 < x1; \ ++ r1 += _c1; \ ++ _c2 |= r1 < _c1; \ ++ r2 = x2 + y2; \ ++ _c3 = r2 < x2; \ ++ r2 += _c2; \ ++ _c3 |= r2 < _c2; \ ++ r3 = x3 + y3 + _c3; \ ++ } while (0) + #endif + + #ifndef __FP_FRAC_SUB_4 +-#define __FP_FRAC_SUB_4(r3,r2,r1,r0,x3,x2,x1,x0,y3,y2,y1,y0) \ +- (r0 = x0 - y0, \ +- r1 = x1 - y1 - (r0 > x0), \ +- r2 = x2 - y2 - (r1 > x1), \ +- r3 = x3 - y3 - (r2 > x2)) ++#define __FP_FRAC_SUB_4(r3,r2,r1,r0,x3,x2,x1,x0,y3,y2,y1,y0) \ ++ do { \ ++ int _c1, _c2, _c3; \ ++ r0 = x0 - y0; \ ++ _c1 = r0 > x0; \ ++ r1 = x1 - y1; \ ++ _c2 = r1 > x1; \ ++ r1 -= _c1; \ ++ _c2 |= r1 > _c1; \ ++ r2 = x2 - y2; \ ++ _c3 = r2 > x2; \ ++ r2 -= _c2; \ ++ _c3 |= r2 > _c2; \ ++ r3 = x3 - y3 - _c3; \ ++ } while (0) + #endif + + #ifndef __FP_FRAC_ADDI_4 +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/mm/fault.c powerpc.git/arch/powerpc/mm/fault.c +--- linux-2.6.24/arch/powerpc/mm/fault.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/mm/fault.c 2008-01-28 20:25:49.000000000 +0100 +@@ -167,10 +167,8 @@ + if (notify_page_fault(regs)) + return 0; + +- if (trap == 0x300) { +- if (debugger_fault_handler(regs)) +- return 0; +- } ++ if (unlikely(debugger_fault_handler(regs))) ++ return 0; + + /* On a kernel SLB miss we can only check for a valid exception entry */ + if (!user_mode(regs) && (address >= TASK_SIZE)) +@@ -189,7 +187,7 @@ + return SIGSEGV; + /* in_atomic() in user mode is really bad, + as is current->mm == NULL. */ +- printk(KERN_EMERG "Page fault in user mode with" ++ printk(KERN_EMERG "Page fault in user mode with " + "in_atomic() = %d mm = %p\n", in_atomic(), mm); + printk(KERN_EMERG "NIP = %lx MSR = %lx\n", + regs->nip, regs->msr); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/mm/fsl_booke_mmu.c powerpc.git/arch/powerpc/mm/fsl_booke_mmu.c +--- linux-2.6.24/arch/powerpc/mm/fsl_booke_mmu.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/mm/fsl_booke_mmu.c 2008-01-28 20:25:49.000000000 +0100 +@@ -165,15 +165,15 @@ + void __init cam_mapin_ram(unsigned long cam0, unsigned long cam1, + unsigned long cam2) + { +- settlbcam(0, KERNELBASE, PPC_MEMSTART, cam0, _PAGE_KERNEL, 0); ++ settlbcam(0, PAGE_OFFSET, PPC_MEMSTART, cam0, _PAGE_KERNEL, 0); + tlbcam_index++; + if (cam1) { + tlbcam_index++; +- settlbcam(1, KERNELBASE+cam0, PPC_MEMSTART+cam0, cam1, _PAGE_KERNEL, 0); ++ settlbcam(1, PAGE_OFFSET+cam0, PPC_MEMSTART+cam0, cam1, _PAGE_KERNEL, 0); + } + if (cam2) { + tlbcam_index++; +- settlbcam(2, KERNELBASE+cam0+cam1, PPC_MEMSTART+cam0+cam1, cam2, _PAGE_KERNEL, 0); ++ settlbcam(2, PAGE_OFFSET+cam0+cam1, PPC_MEMSTART+cam0+cam1, cam2, _PAGE_KERNEL, 0); + } + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/mm/hash_utils_64.c powerpc.git/arch/powerpc/mm/hash_utils_64.c +--- linux-2.6.24/arch/powerpc/mm/hash_utils_64.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/mm/hash_utils_64.c 2008-01-28 21:37:04.000000000 +0100 +@@ -96,6 +96,7 @@ + int mmu_io_psize = MMU_PAGE_4K; + int mmu_kernel_ssize = MMU_SEGSIZE_256M; + int mmu_highuser_ssize = MMU_SEGSIZE_256M; ++u16 mmu_slb_size = 64; + #ifdef CONFIG_HUGETLB_PAGE + int mmu_huge_psize = MMU_PAGE_16M; + unsigned int HPAGE_SHIFT; +@@ -368,18 +369,11 @@ + * on what is available + */ + if (mmu_psize_defs[MMU_PAGE_16M].shift) +- mmu_huge_psize = MMU_PAGE_16M; ++ set_huge_psize(MMU_PAGE_16M); + /* With 4k/4level pagetables, we can't (for now) cope with a + * huge page size < PMD_SIZE */ + else if (mmu_psize_defs[MMU_PAGE_1M].shift) +- mmu_huge_psize = MMU_PAGE_1M; +- +- /* Calculate HPAGE_SHIFT and sanity check it */ +- if (mmu_psize_defs[mmu_huge_psize].shift > MIN_HUGEPTE_SHIFT && +- mmu_psize_defs[mmu_huge_psize].shift < SID_SHIFT) +- HPAGE_SHIFT = mmu_psize_defs[mmu_huge_psize].shift; +- else +- HPAGE_SHIFT = 0; /* No huge pages dude ! */ ++ set_huge_psize(MMU_PAGE_1M); + #endif /* CONFIG_HUGETLB_PAGE */ + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/mm/hugetlbpage.c powerpc.git/arch/powerpc/mm/hugetlbpage.c +--- linux-2.6.24/arch/powerpc/mm/hugetlbpage.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/mm/hugetlbpage.c 2008-01-28 20:25:49.000000000 +0100 +@@ -24,18 +24,17 @@ + #include <asm/cputable.h> + #include <asm/spu.h> + ++#define HPAGE_SHIFT_64K 16 ++#define HPAGE_SHIFT_16M 24 ++ + #define NUM_LOW_AREAS (0x100000000UL >> SID_SHIFT) + #define NUM_HIGH_AREAS (PGTABLE_RANGE >> HTLB_AREA_SHIFT) + +-#ifdef CONFIG_PPC_64K_PAGES +-#define HUGEPTE_INDEX_SIZE (PMD_SHIFT-HPAGE_SHIFT) +-#else +-#define HUGEPTE_INDEX_SIZE (PUD_SHIFT-HPAGE_SHIFT) +-#endif +-#define PTRS_PER_HUGEPTE (1 << HUGEPTE_INDEX_SIZE) +-#define HUGEPTE_TABLE_SIZE (sizeof(pte_t) << HUGEPTE_INDEX_SIZE) ++unsigned int hugepte_shift; ++#define PTRS_PER_HUGEPTE (1 << hugepte_shift) ++#define HUGEPTE_TABLE_SIZE (sizeof(pte_t) << hugepte_shift) + +-#define HUGEPD_SHIFT (HPAGE_SHIFT + HUGEPTE_INDEX_SIZE) ++#define HUGEPD_SHIFT (HPAGE_SHIFT + hugepte_shift) + #define HUGEPD_SIZE (1UL << HUGEPD_SHIFT) + #define HUGEPD_MASK (~(HUGEPD_SIZE-1)) + +@@ -82,11 +81,35 @@ + return 0; + } + ++/* Base page size affects how we walk hugetlb page tables */ ++#ifdef CONFIG_PPC_64K_PAGES ++#define hpmd_offset(pud, addr) pmd_offset(pud, addr) ++#define hpmd_alloc(mm, pud, addr) pmd_alloc(mm, pud, addr) ++#else ++static inline ++pmd_t *hpmd_offset(pud_t *pud, unsigned long addr) ++{ ++ if (HPAGE_SHIFT == HPAGE_SHIFT_64K) ++ return pmd_offset(pud, addr); ++ else ++ return (pmd_t *) pud; ++} ++static inline ++pmd_t *hpmd_alloc(struct mm_struct *mm, pud_t *pud, unsigned long addr) ++{ ++ if (HPAGE_SHIFT == HPAGE_SHIFT_64K) ++ return pmd_alloc(mm, pud, addr); ++ else ++ return (pmd_t *) pud; ++} ++#endif ++ + /* Modelled after find_linux_pte() */ + pte_t *huge_pte_offset(struct mm_struct *mm, unsigned long addr) + { + pgd_t *pg; + pud_t *pu; ++ pmd_t *pm; + + BUG_ON(get_slice_psize(mm, addr) != mmu_huge_psize); + +@@ -96,14 +119,9 @@ + if (!pgd_none(*pg)) { + pu = pud_offset(pg, addr); + if (!pud_none(*pu)) { +-#ifdef CONFIG_PPC_64K_PAGES +- pmd_t *pm; +- pm = pmd_offset(pu, addr); ++ pm = hpmd_offset(pu, addr); + if (!pmd_none(*pm)) + return hugepte_offset((hugepd_t *)pm, addr); +-#else +- return hugepte_offset((hugepd_t *)pu, addr); +-#endif + } + } + +@@ -114,6 +132,7 @@ + { + pgd_t *pg; + pud_t *pu; ++ pmd_t *pm; + hugepd_t *hpdp = NULL; + + BUG_ON(get_slice_psize(mm, addr) != mmu_huge_psize); +@@ -124,14 +143,9 @@ + pu = pud_alloc(mm, pg, addr); + + if (pu) { +-#ifdef CONFIG_PPC_64K_PAGES +- pmd_t *pm; +- pm = pmd_alloc(mm, pu, addr); ++ pm = hpmd_alloc(mm, pu, addr); + if (pm) + hpdp = (hugepd_t *)pm; +-#else +- hpdp = (hugepd_t *)pu; +-#endif + } + + if (! hpdp) +@@ -158,7 +172,6 @@ + PGF_CACHENUM_MASK)); + } + +-#ifdef CONFIG_PPC_64K_PAGES + static void hugetlb_free_pmd_range(struct mmu_gather *tlb, pud_t *pud, + unsigned long addr, unsigned long end, + unsigned long floor, unsigned long ceiling) +@@ -191,7 +204,6 @@ + pud_clear(pud); + pmd_free_tlb(tlb, pmd); + } +-#endif + + static void hugetlb_free_pud_range(struct mmu_gather *tlb, pgd_t *pgd, + unsigned long addr, unsigned long end, +@@ -210,9 +222,15 @@ + continue; + hugetlb_free_pmd_range(tlb, pud, addr, next, floor, ceiling); + #else +- if (pud_none(*pud)) +- continue; +- free_hugepte_range(tlb, (hugepd_t *)pud); ++ if (HPAGE_SHIFT == HPAGE_SHIFT_64K) { ++ if (pud_none_or_clear_bad(pud)) ++ continue; ++ hugetlb_free_pmd_range(tlb, pud, addr, next, floor, ceiling); ++ } else { ++ if (pud_none(*pud)) ++ continue; ++ free_hugepte_range(tlb, (hugepd_t *)pud); ++ } + #endif + } while (pud++, addr = next, addr != end); + +@@ -526,6 +544,57 @@ + return err; + } + ++void set_huge_psize(int psize) ++{ ++ /* Check that it is a page size supported by the hardware and ++ * that it fits within pagetable limits. */ ++ if (mmu_psize_defs[psize].shift && mmu_psize_defs[psize].shift < SID_SHIFT && ++ (mmu_psize_defs[psize].shift > MIN_HUGEPTE_SHIFT || ++ mmu_psize_defs[psize].shift == HPAGE_SHIFT_64K)) { ++ HPAGE_SHIFT = mmu_psize_defs[psize].shift; ++ mmu_huge_psize = psize; ++#ifdef CONFIG_PPC_64K_PAGES ++ hugepte_shift = (PMD_SHIFT-HPAGE_SHIFT); ++#else ++ if (HPAGE_SHIFT == HPAGE_SHIFT_64K) ++ hugepte_shift = (PMD_SHIFT-HPAGE_SHIFT); ++ else ++ hugepte_shift = (PUD_SHIFT-HPAGE_SHIFT); ++#endif ++ ++ } else ++ HPAGE_SHIFT = 0; ++} ++ ++static int __init hugepage_setup_sz(char *str) ++{ ++ unsigned long long size; ++ int mmu_psize = -1; ++ int shift; ++ ++ size = memparse(str, &str); ++ ++ shift = __ffs(size); ++ switch (shift) { ++#ifndef CONFIG_PPC_64K_PAGES ++ case HPAGE_SHIFT_64K: ++ mmu_psize = MMU_PAGE_64K; ++ break; ++#endif ++ case HPAGE_SHIFT_16M: ++ mmu_psize = MMU_PAGE_16M; ++ break; ++ } ++ ++ if (mmu_psize >=0 && mmu_psize_defs[mmu_psize].shift) ++ set_huge_psize(mmu_psize); ++ else ++ printk(KERN_WARNING "Invalid huge page size specified(%llu)\n", size); ++ ++ return 1; ++} ++__setup("hugepagesz=", hugepage_setup_sz); ++ + static void zero_ctor(struct kmem_cache *cache, void *addr) + { + memset(addr, 0, kmem_cache_size(cache)); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/mm/lmb.c powerpc.git/arch/powerpc/mm/lmb.c +--- linux-2.6.24/arch/powerpc/mm/lmb.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/mm/lmb.c 2008-01-28 20:25:49.000000000 +0100 +@@ -342,3 +342,16 @@ + } + } + } ++ ++int __init lmb_is_reserved(unsigned long addr) ++{ ++ int i; ++ ++ for (i = 0; i < lmb.reserved.cnt; i++) { ++ unsigned long upper = lmb.reserved.region[i].base + ++ lmb.reserved.region[i].size - 1; ++ if ((addr >= lmb.reserved.region[i].base) && (addr <= upper)) ++ return 1; ++ } ++ return 0; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/mm/mem.c powerpc.git/arch/powerpc/mm/mem.c +--- linux-2.6.24/arch/powerpc/mm/mem.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/mm/mem.c 2008-01-28 20:25:49.000000000 +0100 +@@ -213,15 +213,30 @@ + */ + #ifdef CONFIG_HIGHMEM + free_bootmem_with_active_regions(0, total_lowmem >> PAGE_SHIFT); ++ ++ /* reserve the sections we're already using */ ++ for (i = 0; i < lmb.reserved.cnt; i++) { ++ unsigned long addr = lmb.reserved.region[i].base + ++ lmb_size_bytes(&lmb.reserved, i) - 1; ++ if (addr < total_lowmem) ++ reserve_bootmem(lmb.reserved.region[i].base, ++ lmb_size_bytes(&lmb.reserved, i)); ++ else if (lmb.reserved.region[i].base < total_lowmem) { ++ unsigned long adjusted_size = total_lowmem - ++ lmb.reserved.region[i].base; ++ reserve_bootmem(lmb.reserved.region[i].base, ++ adjusted_size); ++ } ++ } + #else + free_bootmem_with_active_regions(0, max_pfn); +-#endif + + /* reserve the sections we're already using */ + for (i = 0; i < lmb.reserved.cnt; i++) + reserve_bootmem(lmb.reserved.region[i].base, + lmb_size_bytes(&lmb.reserved, i)); + ++#endif + /* XXX need to clip this if using highmem? */ + sparse_memory_present_with_active_regions(0); + +@@ -334,11 +349,13 @@ + highmem_mapnr = total_lowmem >> PAGE_SHIFT; + for (pfn = highmem_mapnr; pfn < max_mapnr; ++pfn) { + struct page *page = pfn_to_page(pfn); +- ++ if (lmb_is_reserved(pfn << PAGE_SHIFT)) ++ continue; + ClearPageReserved(page); + init_page_count(page); + __free_page(page); + totalhigh_pages++; ++ reservedpages--; + } + totalram_pages += totalhigh_pages; + printk(KERN_DEBUG "High memory: %luk\n", +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/mm/slb.c powerpc.git/arch/powerpc/mm/slb.c +--- linux-2.6.24/arch/powerpc/mm/slb.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/mm/slb.c 2008-01-28 20:25:49.000000000 +0100 +@@ -256,6 +256,7 @@ + static int slb_encoding_inited; + extern unsigned int *slb_miss_kernel_load_linear; + extern unsigned int *slb_miss_kernel_load_io; ++ extern unsigned int *slb_compare_rr_to_size; + + /* Prepare our SLB miss handler based on our page size */ + linear_llp = mmu_psize_defs[mmu_linear_psize].sllp; +@@ -269,6 +270,8 @@ + SLB_VSID_KERNEL | linear_llp); + patch_slb_encoding(slb_miss_kernel_load_io, + SLB_VSID_KERNEL | io_llp); ++ patch_slb_encoding(slb_compare_rr_to_size, ++ mmu_slb_size); + + DBG("SLB: linear LLP = %04x\n", linear_llp); + DBG("SLB: io LLP = %04x\n", io_llp); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/mm/slb_low.S powerpc.git/arch/powerpc/mm/slb_low.S +--- linux-2.6.24/arch/powerpc/mm/slb_low.S 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/mm/slb_low.S 2008-01-28 20:25:49.000000000 +0100 +@@ -227,8 +227,9 @@ + + 7: ld r10,PACASTABRR(r13) + addi r10,r10,1 +- /* use a cpu feature mask if we ever change our slb size */ +- cmpldi r10,SLB_NUM_ENTRIES ++ /* This gets soft patched on boot. */ ++_GLOBAL(slb_compare_rr_to_size) ++ cmpldi r10,0 + + blt+ 4f + li r10,SLB_NUM_BOLTED +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/oprofile/op_model_cell.c powerpc.git/arch/powerpc/oprofile/op_model_cell.c +--- linux-2.6.24/arch/powerpc/oprofile/op_model_cell.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/oprofile/op_model_cell.c 2008-01-28 20:25:49.000000000 +0100 +@@ -61,7 +61,7 @@ + #define NUM_THREADS 2 /* number of physical threads in + * physical processor + */ +-#define NUM_TRACE_BUS_WORDS 4 ++#define NUM_DEBUG_BUS_WORDS 4 + #define NUM_INPUT_BUS_WORDS 2 + + #define MAX_SPU_COUNT 0xFFFFFF /* maximum 24 bit LFSR value */ +@@ -169,7 +169,6 @@ + + static u32 ctr_enabled; + +-static unsigned char trace_bus[NUM_TRACE_BUS_WORDS]; + static unsigned char input_bus[NUM_INPUT_BUS_WORDS]; + + /* +@@ -298,7 +297,7 @@ + + p->signal_group = event / 100; + p->bus_word = bus_word; +- p->sub_unit = (unit_mask & 0x0000f000) >> 12; ++ p->sub_unit = GET_SUB_UNIT(unit_mask); + + pm_regs.pm07_cntrl[ctr] = 0; + pm_regs.pm07_cntrl[ctr] |= PM07_CTR_COUNT_CYCLES(count_cycles); +@@ -334,16 +333,16 @@ + p->bit = signal_bit; + } + +- for (i = 0; i < NUM_TRACE_BUS_WORDS; i++) { ++ for (i = 0; i < NUM_DEBUG_BUS_WORDS; i++) { + if (bus_word & (1 << i)) { + pm_regs.debug_bus_control |= +- (bus_type << (31 - (2 * i) + 1)); ++ (bus_type << (30 - (2 * i))); + + for (j = 0; j < NUM_INPUT_BUS_WORDS; j++) { + if (input_bus[j] == 0xff) { + input_bus[j] = i; + pm_regs.group_control |= +- (i << (31 - i)); ++ (i << (30 - (2 * j))); + + break; + } +@@ -450,6 +449,12 @@ + hdw_thread = 1 ^ hdw_thread; + next_hdw_thread = hdw_thread; + ++ pm_regs.group_control = 0; ++ pm_regs.debug_bus_control = 0; ++ ++ for (i = 0; i < NUM_INPUT_BUS_WORDS; i++) ++ input_bus[i] = 0xff; ++ + /* + * There are some per thread events. Must do the + * set event, for the thread that is being started +@@ -619,9 +624,6 @@ + pmc_cntrl[1][i].vcntr = i; + } + +- for (i = 0; i < NUM_TRACE_BUS_WORDS; i++) +- trace_bus[i] = 0xff; +- + for (i = 0; i < NUM_INPUT_BUS_WORDS; i++) + input_bus[i] = 0xff; + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/40x/Kconfig powerpc.git/arch/powerpc/platforms/40x/Kconfig +--- linux-2.6.24/arch/powerpc/platforms/40x/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/40x/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -14,28 +14,34 @@ + # help + # This option enables support for the CPCI405 board. + +-#config EP405 +-# bool "EP405/EP405PC" +-# depends on 40x +-# default n +-# select 405GP +-# help +-# This option enables support for the EP405/EP405PC boards. +- +-#config EP405PC +-# bool "EP405PC Support" +-# depends on EP405 +-# default y +-# help +-# This option enables support for the extra features of the EP405PC board. ++config EP405 ++ bool "EP405/EP405PC" ++ depends on 40x ++ default n ++ select 405GP ++ select PCI ++ help ++ This option enables support for the EP405/EP405PC boards. + + config KILAUEA + bool "Kilauea" + depends on 40x + default n ++ select 405EX ++ select PPC4xx_PCI_EXPRESS + help + This option enables support for the AMCC PPC405EX evaluation board. + ++config MAKALU ++ bool "Makalu" ++ depends on 40x ++ default n ++ select 405EX ++ select PCI ++ select PPC4xx_PCI_EXPRESS ++ help ++ This option enables support for the AMCC PPC405EX board. ++ + #config REDWOOD_5 + # bool "Redwood-5" + # depends on 40x +@@ -65,6 +71,7 @@ + depends on 40x + default y + select 405GP ++ select PCI + help + This option enables support for the IBM PPC405GP evaluation board. + +@@ -105,6 +112,11 @@ + config 405EP + bool + ++config 405EX ++ bool ++ select IBM_NEW_EMAC_EMAC4 ++ select IBM_NEW_EMAC_RGMII ++ + config 405GPR + bool + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/40x/Makefile powerpc.git/arch/powerpc/platforms/40x/Makefile +--- linux-2.6.24/arch/powerpc/platforms/40x/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/40x/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -1,3 +1,5 @@ + obj-$(CONFIG_KILAUEA) += kilauea.o ++obj-$(CONFIG_MAKALU) += makalu.o + obj-$(CONFIG_WALNUT) += walnut.o + obj-$(CONFIG_XILINX_VIRTEX_GENERIC_BOARD) += virtex.o ++obj-$(CONFIG_EP405) += ep405.o +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/40x/ep405.c powerpc.git/arch/powerpc/platforms/40x/ep405.c +--- linux-2.6.24/arch/powerpc/platforms/40x/ep405.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/40x/ep405.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,123 @@ ++/* ++ * Architecture- / platform-specific boot-time initialization code for ++ * IBM PowerPC 4xx based boards. Adapted from original ++ * code by Gary Thomas, Cort Dougan <cort@fsmlabs.com>, and Dan Malek ++ * <dan@net4x.com>. ++ * ++ * Copyright(c) 1999-2000 Grant Erickson <grant@lcse.umn.edu> ++ * ++ * Rewritten and ported to the merged powerpc tree: ++ * Copyright 2007 IBM Corporation ++ * Josh Boyer <jwboyer@linux.vnet.ibm.com> ++ * ++ * Adapted to EP405 by Ben. Herrenschmidt <benh@kernel.crashing.org> ++ * ++ * TODO: Wire up the PCI IRQ mux and the southbridge interrupts ++ * ++ * 2002 (c) MontaVista, Software, Inc. This file is licensed under ++ * the terms of the GNU General Public License version 2. This program ++ * is licensed "as is" without any warranty of any kind, whether express ++ * or implied. ++ */ ++ ++#include <linux/init.h> ++#include <linux/of_platform.h> ++ ++#include <asm/machdep.h> ++#include <asm/prom.h> ++#include <asm/udbg.h> ++#include <asm/time.h> ++#include <asm/uic.h> ++#include <asm/pci-bridge.h> ++ ++static struct device_node *bcsr_node; ++static void __iomem *bcsr_regs; ++ ++/* BCSR registers */ ++#define BCSR_ID 0 ++#define BCSR_PCI_CTRL 1 ++#define BCSR_FLASH_NV_POR_CTRL 2 ++#define BCSR_FENET_UART_CTRL 3 ++#define BCSR_PCI_IRQ 4 ++#define BCSR_XIRQ_SELECT 5 ++#define BCSR_XIRQ_ROUTING 6 ++#define BCSR_XIRQ_STATUS 7 ++#define BCSR_XIRQ_STATUS2 8 ++#define BCSR_SW_STAT_LED_CTRL 9 ++#define BCSR_GPIO_IRQ_PAR_CTRL 10 ++/* there's more, can't be bothered typing them tho */ ++ ++ ++static __initdata struct of_device_id ep405_of_bus[] = { ++ { .compatible = "ibm,plb3", }, ++ { .compatible = "ibm,opb", }, ++ { .compatible = "ibm,ebc", }, ++ {}, ++}; ++ ++static int __init ep405_device_probe(void) ++{ ++ of_platform_bus_probe(NULL, ep405_of_bus, NULL); ++ ++ return 0; ++} ++machine_device_initcall(ep405, ep405_device_probe); ++ ++static void __init ep405_init_bcsr(void) ++{ ++ const u8 *irq_routing; ++ int i; ++ ++ /* Find the bloody thing & map it */ ++ bcsr_node = of_find_compatible_node(NULL, NULL, "ep405-bcsr"); ++ if (bcsr_node == NULL) { ++ printk(KERN_ERR "EP405 BCSR not found !\n"); ++ return; ++ } ++ bcsr_regs = of_iomap(bcsr_node, 0); ++ if (bcsr_regs == NULL) { ++ printk(KERN_ERR "EP405 BCSR failed to map !\n"); ++ return; ++ } ++ ++ /* Get the irq-routing property and apply the routing to the CPLD */ ++ irq_routing = of_get_property(bcsr_node, "irq-routing", NULL); ++ if (irq_routing == NULL) ++ return; ++ for (i = 0; i < 16; i++) { ++ u8 irq = irq_routing[i]; ++ out_8(bcsr_regs + BCSR_XIRQ_SELECT, i); ++ out_8(bcsr_regs + BCSR_XIRQ_ROUTING, irq); ++ } ++ in_8(bcsr_regs + BCSR_XIRQ_SELECT); ++ mb(); ++ out_8(bcsr_regs + BCSR_GPIO_IRQ_PAR_CTRL, 0xfe); ++} ++ ++static void __init ep405_setup_arch(void) ++{ ++ /* Find & init the BCSR CPLD */ ++ ep405_init_bcsr(); ++ ++ ppc_pci_flags = PPC_PCI_REASSIGN_ALL_RSRC; ++} ++ ++static int __init ep405_probe(void) ++{ ++ unsigned long root = of_get_flat_dt_root(); ++ ++ if (!of_flat_dt_is_compatible(root, "ep405")) ++ return 0; ++ ++ return 1; ++} ++ ++define_machine(ep405) { ++ .name = "EP405", ++ .probe = ep405_probe, ++ .setup_arch = ep405_setup_arch, ++ .progress = udbg_progress, ++ .init_IRQ = uic_init_tree, ++ .get_irq = uic_get_irq, ++ .calibrate_decr = generic_calibrate_decr, ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/40x/kilauea.c powerpc.git/arch/powerpc/platforms/40x/kilauea.c +--- linux-2.6.24/arch/powerpc/platforms/40x/kilauea.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/40x/kilauea.c 2008-01-28 20:25:49.000000000 +0100 +@@ -19,8 +19,9 @@ + #include <asm/udbg.h> + #include <asm/time.h> + #include <asm/uic.h> ++#include <asm/pci-bridge.h> + +-static struct of_device_id kilauea_of_bus[] = { ++static __initdata struct of_device_id kilauea_of_bus[] = { + { .compatible = "ibm,plb4", }, + { .compatible = "ibm,opb", }, + { .compatible = "ibm,ebc", }, +@@ -29,14 +30,11 @@ + + static int __init kilauea_device_probe(void) + { +- if (!machine_is(kilauea)) +- return 0; +- + of_platform_bus_probe(NULL, kilauea_of_bus, NULL); + + return 0; + } +-device_initcall(kilauea_device_probe); ++machine_device_initcall(kilauea, kilauea_device_probe); + + static int __init kilauea_probe(void) + { +@@ -45,6 +43,8 @@ + if (!of_flat_dt_is_compatible(root, "amcc,kilauea")) + return 0; + ++ ppc_pci_flags = PPC_PCI_REASSIGN_ALL_RSRC; ++ + return 1; + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/40x/makalu.c powerpc.git/arch/powerpc/platforms/40x/makalu.c +--- linux-2.6.24/arch/powerpc/platforms/40x/makalu.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/40x/makalu.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,58 @@ ++/* ++ * Makalu board specific routines ++ * ++ * Copyright 2007 DENX Software Engineering, Stefan Roese <sr@denx.de> ++ * ++ * Based on the Walnut code by ++ * Josh Boyer <jwboyer@linux.vnet.ibm.com> ++ * Copyright 2007 IBM Corporation ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++#include <linux/init.h> ++#include <linux/of_platform.h> ++#include <asm/machdep.h> ++#include <asm/prom.h> ++#include <asm/udbg.h> ++#include <asm/time.h> ++#include <asm/uic.h> ++#include <asm/pci-bridge.h> ++ ++static __initdata struct of_device_id makalu_of_bus[] = { ++ { .compatible = "ibm,plb4", }, ++ { .compatible = "ibm,opb", }, ++ { .compatible = "ibm,ebc", }, ++ {}, ++}; ++ ++static int __init makalu_device_probe(void) ++{ ++ of_platform_bus_probe(NULL, makalu_of_bus, NULL); ++ ++ return 0; ++} ++machine_device_initcall(makalu, makalu_device_probe); ++ ++static int __init makalu_probe(void) ++{ ++ unsigned long root = of_get_flat_dt_root(); ++ ++ if (!of_flat_dt_is_compatible(root, "amcc,makalu")) ++ return 0; ++ ++ ppc_pci_flags = PPC_PCI_REASSIGN_ALL_RSRC; ++ ++ return 1; ++} ++ ++define_machine(makalu) { ++ .name = "Makalu", ++ .probe = makalu_probe, ++ .progress = udbg_progress, ++ .init_IRQ = uic_init_tree, ++ .get_irq = uic_get_irq, ++ .calibrate_decr = generic_calibrate_decr, ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/40x/virtex.c powerpc.git/arch/powerpc/platforms/40x/virtex.c +--- linux-2.6.24/arch/powerpc/platforms/40x/virtex.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/40x/virtex.c 2008-01-28 20:25:49.000000000 +0100 +@@ -15,16 +15,23 @@ + #include <asm/time.h> + #include <asm/xilinx_intc.h> + ++static struct of_device_id xilinx_of_bus_ids[] __initdata = { ++ { .compatible = "xlnx,plb-v46-1.00.a", }, ++ { .compatible = "xlnx,plb-v34-1.01.a", }, ++ { .compatible = "xlnx,plb-v34-1.02.a", }, ++ { .compatible = "xlnx,opb-v20-1.10.c", }, ++ { .compatible = "xlnx,dcr-v29-1.00.a", }, ++ { .compatible = "xlnx,compound", }, ++ {} ++}; ++ + static int __init virtex_device_probe(void) + { +- if (!machine_is(virtex)) +- return 0; +- +- of_platform_bus_probe(NULL, NULL, NULL); ++ of_platform_bus_probe(NULL, xilinx_of_bus_ids, NULL); + + return 0; + } +-device_initcall(virtex_device_probe); ++machine_device_initcall(virtex, virtex_device_probe); + + static int __init virtex_probe(void) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/40x/walnut.c powerpc.git/arch/powerpc/platforms/40x/walnut.c +--- linux-2.6.24/arch/powerpc/platforms/40x/walnut.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/40x/walnut.c 2008-01-28 20:25:49.000000000 +0100 +@@ -24,8 +24,9 @@ + #include <asm/udbg.h> + #include <asm/time.h> + #include <asm/uic.h> ++#include <asm/pci-bridge.h> + +-static struct of_device_id walnut_of_bus[] = { ++static __initdata struct of_device_id walnut_of_bus[] = { + { .compatible = "ibm,plb3", }, + { .compatible = "ibm,opb", }, + { .compatible = "ibm,ebc", }, +@@ -34,15 +35,12 @@ + + static int __init walnut_device_probe(void) + { +- if (!machine_is(walnut)) +- return 0; +- +- /* FIXME: do bus probe here */ + of_platform_bus_probe(NULL, walnut_of_bus, NULL); ++ of_instantiate_rtc(); + + return 0; + } +-device_initcall(walnut_device_probe); ++machine_device_initcall(walnut, walnut_device_probe); + + static int __init walnut_probe(void) + { +@@ -51,6 +49,8 @@ + if (!of_flat_dt_is_compatible(root, "ibm,walnut")) + return 0; + ++ ppc_pci_flags = PPC_PCI_REASSIGN_ALL_RSRC; ++ + return 1; + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/44x/Kconfig powerpc.git/arch/powerpc/platforms/44x/Kconfig +--- linux-2.6.24/arch/powerpc/platforms/44x/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/44x/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -3,6 +3,7 @@ + depends on 44x + default n + select 440EP ++ select PCI + help + This option enables support for the IBM PPC440EP evaluation board. + +@@ -11,6 +12,8 @@ + depends on 44x + default y + select 440GP ++ select PCI ++ select OF_RTC + help + This option enables support for the IBM PPC440GP evaluation board. + +@@ -22,6 +25,48 @@ + help + This option enables support for the AMCC PPC440EPX evaluation board. + ++config TAISHAN ++ bool "Taishan" ++ depends on 44x ++ default n ++ select 440GX ++ select PCI ++ help ++ This option enables support for the AMCC PPC440GX "Taishan" ++ evaluation board. ++ ++config KATMAI ++ bool "Katmai" ++ depends on 44x ++ default n ++ select 440SPe ++ select PCI ++ select PPC4xx_PCI_EXPRESS ++ help ++ This option enables support for the AMCC PPC440SPe evaluation board. ++ ++config RAINIER ++ bool "Rainier" ++ depends on 44x ++ default n ++ select 440GRX ++ select PCI ++ help ++ This option enables support for the AMCC PPC440GRX evaluation board. ++ ++config WARP ++ bool "PIKA Warp" ++ depends on 44x ++ default n ++ select 440EP ++ help ++ This option enables support for the PIKA Warp(tm) Appliance. The Warp ++ is a small computer replacement with up to 9 ports of FXO/FXS plus VOIP ++ stations and trunks. ++ ++ See http://www.pikatechnologies.com/ and follow the "PIKA for Computer ++ Telephony Developers" link for more information. ++ + #config LUAN + # bool "Luan" + # depends on 44x +@@ -44,6 +89,7 @@ + select PPC_FPU + select IBM440EP_ERR42 + select IBM_NEW_EMAC_ZMII ++ select USB_ARCH_HAS_OHCI + + config 440EPX + bool +@@ -52,20 +98,29 @@ + select IBM_NEW_EMAC_RGMII + select IBM_NEW_EMAC_ZMII + ++config 440GRX ++ bool ++ select IBM_NEW_EMAC_EMAC4 ++ select IBM_NEW_EMAC_RGMII ++ select IBM_NEW_EMAC_ZMII ++ + config 440GP + bool + select IBM_NEW_EMAC_ZMII + + config 440GX + bool ++ select IBM_NEW_EMAC_EMAC4 ++ select IBM_NEW_EMAC_RGMII ++ select IBM_NEW_EMAC_ZMII #test only ++ select IBM_NEW_EMAC_TAH #test only + + config 440SP + bool + +-config 440A ++config 440SPe ++ select IBM_NEW_EMAC_EMAC4 + bool +- depends on 440GX || 440EPX +- default y + + # 44x errata/workaround config symbols, selected by the CPU models above + config IBM440EP_ERR42 +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/44x/Makefile powerpc.git/arch/powerpc/platforms/44x/Makefile +--- linux-2.6.24/arch/powerpc/platforms/44x/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/44x/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -1,4 +1,9 @@ + obj-$(CONFIG_44x) := misc_44x.o + obj-$(CONFIG_EBONY) += ebony.o +-obj-$(CONFIG_BAMBOO) += bamboo.o ++obj-$(CONFIG_TAISHAN) += taishan.o ++obj-$(CONFIG_BAMBOO) += bamboo.o + obj-$(CONFIG_SEQUOIA) += sequoia.o ++obj-$(CONFIG_KATMAI) += katmai.o ++obj-$(CONFIG_RAINIER) += rainier.o ++obj-$(CONFIG_WARP) += warp.o ++obj-$(CONFIG_WARP) += warp-nand.o +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/44x/bamboo.c powerpc.git/arch/powerpc/platforms/44x/bamboo.c +--- linux-2.6.24/arch/powerpc/platforms/44x/bamboo.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/44x/bamboo.c 2008-01-28 20:25:49.000000000 +0100 +@@ -21,9 +21,11 @@ + #include <asm/udbg.h> + #include <asm/time.h> + #include <asm/uic.h> ++#include <asm/pci-bridge.h> ++ + #include "44x.h" + +-static struct of_device_id bamboo_of_bus[] = { ++static __initdata struct of_device_id bamboo_of_bus[] = { + { .compatible = "ibm,plb4", }, + { .compatible = "ibm,opb", }, + { .compatible = "ibm,ebc", }, +@@ -32,14 +34,11 @@ + + static int __init bamboo_device_probe(void) + { +- if (!machine_is(bamboo)) +- return 0; +- + of_platform_bus_probe(NULL, bamboo_of_bus, NULL); + + return 0; + } +-device_initcall(bamboo_device_probe); ++machine_device_initcall(bamboo, bamboo_device_probe); + + static int __init bamboo_probe(void) + { +@@ -48,6 +47,8 @@ + if (!of_flat_dt_is_compatible(root, "amcc,bamboo")) + return 0; + ++ ppc_pci_flags = PPC_PCI_REASSIGN_ALL_RSRC; ++ + return 1; + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/44x/ebony.c powerpc.git/arch/powerpc/platforms/44x/ebony.c +--- linux-2.6.24/arch/powerpc/platforms/44x/ebony.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/44x/ebony.c 2008-01-28 20:25:49.000000000 +0100 +@@ -18,16 +18,18 @@ + + #include <linux/init.h> + #include <linux/of_platform.h> ++#include <linux/rtc.h> + + #include <asm/machdep.h> + #include <asm/prom.h> + #include <asm/udbg.h> + #include <asm/time.h> + #include <asm/uic.h> ++#include <asm/pci-bridge.h> + + #include "44x.h" + +-static struct of_device_id ebony_of_bus[] = { ++static __initdata struct of_device_id ebony_of_bus[] = { + { .compatible = "ibm,plb4", }, + { .compatible = "ibm,opb", }, + { .compatible = "ibm,ebc", }, +@@ -36,14 +38,12 @@ + + static int __init ebony_device_probe(void) + { +- if (!machine_is(ebony)) +- return 0; +- + of_platform_bus_probe(NULL, ebony_of_bus, NULL); ++ of_instantiate_rtc(); + + return 0; + } +-device_initcall(ebony_device_probe); ++machine_device_initcall(ebony, ebony_device_probe); + + /* + * Called very early, MMU is off, device-tree isn't unflattened +@@ -55,6 +55,8 @@ + if (!of_flat_dt_is_compatible(root, "ibm,ebony")) + return 0; + ++ ppc_pci_flags = PPC_PCI_REASSIGN_ALL_RSRC; ++ + return 1; + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/44x/katmai.c powerpc.git/arch/powerpc/platforms/44x/katmai.c +--- linux-2.6.24/arch/powerpc/platforms/44x/katmai.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/44x/katmai.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,63 @@ ++/* ++ * Katmai board specific routines ++ * ++ * Benjamin Herrenschmidt <benh@kernel.crashing.org> ++ * Copyright 2007 IBM Corp. ++ * ++ * Based on the Bamboo code by ++ * Josh Boyer <jwboyer@linux.vnet.ibm.com> ++ * Copyright 2007 IBM Corporation ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++#include <linux/init.h> ++#include <linux/of_platform.h> ++ ++#include <asm/machdep.h> ++#include <asm/prom.h> ++#include <asm/udbg.h> ++#include <asm/time.h> ++#include <asm/uic.h> ++#include <asm/pci-bridge.h> ++ ++#include "44x.h" ++ ++static __initdata struct of_device_id katmai_of_bus[] = { ++ { .compatible = "ibm,plb4", }, ++ { .compatible = "ibm,opb", }, ++ { .compatible = "ibm,ebc", }, ++ {}, ++}; ++ ++static int __init katmai_device_probe(void) ++{ ++ of_platform_bus_probe(NULL, katmai_of_bus, NULL); ++ ++ return 0; ++} ++machine_device_initcall(katmai, katmai_device_probe); ++ ++static int __init katmai_probe(void) ++{ ++ unsigned long root = of_get_flat_dt_root(); ++ ++ if (!of_flat_dt_is_compatible(root, "amcc,katmai")) ++ return 0; ++ ++ ppc_pci_flags = PPC_PCI_REASSIGN_ALL_RSRC; ++ ++ return 1; ++} ++ ++define_machine(katmai) { ++ .name = "Katmai", ++ .probe = katmai_probe, ++ .progress = udbg_progress, ++ .init_IRQ = uic_init_tree, ++ .get_irq = uic_get_irq, ++ .restart = ppc44x_reset_system, ++ .calibrate_decr = generic_calibrate_decr, ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/44x/rainier.c powerpc.git/arch/powerpc/platforms/44x/rainier.c +--- linux-2.6.24/arch/powerpc/platforms/44x/rainier.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/44x/rainier.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,62 @@ ++/* ++ * Rainier board specific routines ++ * ++ * Valentine Barshak <vbarshak@ru.mvista.com> ++ * Copyright 2007 MontaVista Software Inc. ++ * ++ * Based on the Bamboo code by ++ * Josh Boyer <jwboyer@linux.vnet.ibm.com> ++ * Copyright 2007 IBM Corporation ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++#include <linux/init.h> ++#include <linux/of_platform.h> ++ ++#include <asm/machdep.h> ++#include <asm/prom.h> ++#include <asm/udbg.h> ++#include <asm/time.h> ++#include <asm/uic.h> ++#include <asm/pci-bridge.h> ++#include "44x.h" ++ ++static __initdata struct of_device_id rainier_of_bus[] = { ++ { .compatible = "ibm,plb4", }, ++ { .compatible = "ibm,opb", }, ++ { .compatible = "ibm,ebc", }, ++ {}, ++}; ++ ++static int __init rainier_device_probe(void) ++{ ++ of_platform_bus_probe(NULL, rainier_of_bus, NULL); ++ ++ return 0; ++} ++machine_device_initcall(rainier, rainier_device_probe); ++ ++static int __init rainier_probe(void) ++{ ++ unsigned long root = of_get_flat_dt_root(); ++ ++ if (!of_flat_dt_is_compatible(root, "amcc,rainier")) ++ return 0; ++ ++ ppc_pci_flags = PPC_PCI_REASSIGN_ALL_RSRC; ++ ++ return 1; ++} ++ ++define_machine(rainier) { ++ .name = "Rainier", ++ .probe = rainier_probe, ++ .progress = udbg_progress, ++ .init_IRQ = uic_init_tree, ++ .get_irq = uic_get_irq, ++ .restart = ppc44x_reset_system, ++ .calibrate_decr = generic_calibrate_decr, ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/44x/sequoia.c powerpc.git/arch/powerpc/platforms/44x/sequoia.c +--- linux-2.6.24/arch/powerpc/platforms/44x/sequoia.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/44x/sequoia.c 2008-01-28 20:25:49.000000000 +0100 +@@ -21,9 +21,11 @@ + #include <asm/udbg.h> + #include <asm/time.h> + #include <asm/uic.h> ++#include <asm/pci-bridge.h> ++ + #include "44x.h" + +-static struct of_device_id sequoia_of_bus[] = { ++static __initdata struct of_device_id sequoia_of_bus[] = { + { .compatible = "ibm,plb4", }, + { .compatible = "ibm,opb", }, + { .compatible = "ibm,ebc", }, +@@ -32,14 +34,11 @@ + + static int __init sequoia_device_probe(void) + { +- if (!machine_is(sequoia)) +- return 0; +- + of_platform_bus_probe(NULL, sequoia_of_bus, NULL); + + return 0; + } +-device_initcall(sequoia_device_probe); ++machine_device_initcall(sequoia, sequoia_device_probe); + + static int __init sequoia_probe(void) + { +@@ -48,6 +47,8 @@ + if (!of_flat_dt_is_compatible(root, "amcc,sequoia")) + return 0; + ++ ppc_pci_flags = PPC_PCI_REASSIGN_ALL_RSRC; ++ + return 1; + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/44x/taishan.c powerpc.git/arch/powerpc/platforms/44x/taishan.c +--- linux-2.6.24/arch/powerpc/platforms/44x/taishan.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/44x/taishan.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,73 @@ ++/* ++ * Taishan board specific routines based off ebony.c code ++ * original copyrights below ++ * ++ * Matt Porter <mporter@kernel.crashing.org> ++ * Copyright 2002-2005 MontaVista Software Inc. ++ * ++ * Eugene Surovegin <eugene.surovegin@zultys.com> or <ebs@ebshome.net> ++ * Copyright (c) 2003-2005 Zultys Technologies ++ * ++ * Rewritten and ported to the merged powerpc tree: ++ * Copyright 2007 David Gibson <dwg@au1.ibm.com>, IBM Corporation. ++ * ++ * Modified from ebony.c for taishan: ++ * Copyright 2007 Hugh Blemings <hugh@au.ibm.com>, IBM Corporation. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++#include <linux/init.h> ++#include <linux/of_platform.h> ++ ++#include <asm/machdep.h> ++#include <asm/prom.h> ++#include <asm/udbg.h> ++#include <asm/time.h> ++#include <asm/uic.h> ++#include <asm/pci-bridge.h> ++ ++#include "44x.h" ++ ++static __initdata struct of_device_id taishan_of_bus[] = { ++ { .compatible = "ibm,plb4", }, ++ { .compatible = "ibm,opb", }, ++ { .compatible = "ibm,ebc", }, ++ {}, ++}; ++ ++static int __init taishan_device_probe(void) ++{ ++ of_platform_bus_probe(NULL, taishan_of_bus, NULL); ++ ++ return 0; ++} ++machine_device_initcall(taishan, taishan_device_probe); ++ ++/* ++ * Called very early, MMU is off, device-tree isn't unflattened ++ */ ++static int __init taishan_probe(void) ++{ ++ unsigned long root = of_get_flat_dt_root(); ++ ++ if (!of_flat_dt_is_compatible(root, "amcc,taishan")) ++ return 0; ++ ++ ppc_pci_flags = PPC_PCI_REASSIGN_ALL_RSRC; ++ ++ return 1; ++} ++ ++define_machine(taishan) { ++ .name = "Taishan", ++ .probe = taishan_probe, ++ .progress = udbg_progress, ++ .init_IRQ = uic_init_tree, ++ .get_irq = uic_get_irq, ++ .restart = ppc44x_reset_system, ++ .calibrate_decr = generic_calibrate_decr, ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/44x/warp-nand.c powerpc.git/arch/powerpc/platforms/44x/warp-nand.c +--- linux-2.6.24/arch/powerpc/platforms/44x/warp-nand.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/44x/warp-nand.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,105 @@ ++/* ++ * PIKA Warp(tm) NAND flash specific routines ++ * ++ * Copyright (c) 2008 PIKA Technologies ++ * Sean MacLennan <smaclennan@pikatech.com> ++ */ ++ ++#include <linux/platform_device.h> ++#include <linux/mtd/mtd.h> ++#include <linux/mtd/map.h> ++#include <linux/mtd/partitions.h> ++#include <linux/mtd/nand.h> ++#include <linux/mtd/ndfc.h> ++ ++#ifdef CONFIG_MTD_NAND_NDFC ++ ++#define CS_NAND_0 1 /* use chip select 1 for NAND device 0 */ ++ ++#define WARP_NAND_FLASH_REG_ADDR 0xD0000000UL ++#define WARP_NAND_FLASH_REG_SIZE 0x2000 ++ ++static struct resource warp_ndfc = { ++ .start = WARP_NAND_FLASH_REG_ADDR, ++ .end = WARP_NAND_FLASH_REG_ADDR + WARP_NAND_FLASH_REG_SIZE, ++ .flags = IORESOURCE_MEM, ++}; ++ ++static struct mtd_partition nand_parts[] = { ++ { ++ .name = "kernel", ++ .offset = 0, ++ .size = 0x0200000 ++ }, ++ { ++ .name = "root", ++ .offset = 0x0200000, ++ .size = 0x3400000 ++ }, ++ { ++ .name = "user", ++ .offset = 0x3600000, ++ .size = 0x0A00000 ++ }, ++}; ++ ++struct ndfc_controller_settings warp_ndfc_settings = { ++ .ccr_settings = (NDFC_CCR_BS(CS_NAND_0) | NDFC_CCR_ARAC1), ++ .ndfc_erpn = 0, ++}; ++ ++static struct ndfc_chip_settings warp_chip0_settings = { ++ .bank_settings = 0x80002222, ++}; ++ ++struct platform_nand_ctrl warp_nand_ctrl = { ++ .priv = &warp_ndfc_settings, ++}; ++ ++static struct platform_device warp_ndfc_device = { ++ .name = "ndfc-nand", ++ .id = 0, ++ .dev = { ++ .platform_data = &warp_nand_ctrl, ++ }, ++ .num_resources = 1, ++ .resource = &warp_ndfc, ++}; ++ ++static struct nand_ecclayout nand_oob_16 = { ++ .eccbytes = 3, ++ .eccpos = { 0, 1, 2, 3, 6, 7 }, ++ .oobfree = { {.offset = 8, .length = 16} } ++}; ++ ++static struct platform_nand_chip warp_nand_chip0 = { ++ .nr_chips = 1, ++ .chip_offset = CS_NAND_0, ++ .nr_partitions = ARRAY_SIZE(nand_parts), ++ .partitions = nand_parts, ++ .chip_delay = 50, ++ .ecclayout = &nand_oob_16, ++ .priv = &warp_chip0_settings, ++}; ++ ++static struct platform_device warp_nand_device = { ++ .name = "ndfc-chip", ++ .id = 0, ++ .num_resources = 1, ++ .resource = &warp_ndfc, ++ .dev = { ++ .platform_data = &warp_nand_chip0, ++ .parent = &warp_ndfc_device.dev, ++ } ++}; ++ ++static int warp_setup_nand_flash(void) ++{ ++ platform_device_register(&warp_ndfc_device); ++ platform_device_register(&warp_nand_device); ++ ++ return 0; ++} ++device_initcall(warp_setup_nand_flash); ++ ++#endif +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/44x/warp.c powerpc.git/arch/powerpc/platforms/44x/warp.c +--- linux-2.6.24/arch/powerpc/platforms/44x/warp.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/44x/warp.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,153 @@ ++/* ++ * PIKA Warp(tm) board specific routines ++ * ++ * Copyright (c) 2008 PIKA Technologies ++ * Sean MacLennan <smaclennan@pikatech.com> ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++#include <linux/init.h> ++#include <linux/of_platform.h> ++#include <linux/kthread.h> ++ ++#include <asm/machdep.h> ++#include <asm/prom.h> ++#include <asm/udbg.h> ++#include <asm/time.h> ++#include <asm/uic.h> ++ ++#include "44x.h" ++ ++ ++static __initdata struct of_device_id warp_of_bus[] = { ++ { .compatible = "ibm,plb4", }, ++ { .compatible = "ibm,opb", }, ++ { .compatible = "ibm,ebc", }, ++ {}, ++}; ++ ++static int __init warp_device_probe(void) ++{ ++ of_platform_bus_probe(NULL, warp_of_bus, NULL); ++ return 0; ++} ++machine_device_initcall(warp, warp_device_probe); ++ ++static int __init warp_probe(void) ++{ ++ unsigned long root = of_get_flat_dt_root(); ++ ++ return of_flat_dt_is_compatible(root, "pika,warp"); ++} ++ ++define_machine(warp) { ++ .name = "Warp", ++ .probe = warp_probe, ++ .progress = udbg_progress, ++ .init_IRQ = uic_init_tree, ++ .get_irq = uic_get_irq, ++ .restart = ppc44x_reset_system, ++ .calibrate_decr = generic_calibrate_decr, ++}; ++ ++ ++#define LED_GREEN (0x80000000 >> 0) ++#define LED_RED (0x80000000 >> 1) ++ ++ ++/* This is for the power LEDs 1 = on, 0 = off, -1 = leave alone */ ++void warp_set_power_leds(int green, int red) ++{ ++ static void __iomem *gpio_base = NULL; ++ unsigned leds; ++ ++ if (gpio_base == NULL) { ++ struct device_node *np; ++ ++ /* Power LEDS are on the second GPIO controller */ ++ np = of_find_compatible_node(NULL, NULL, "ibm,gpio-440EP"); ++ if (np) ++ np = of_find_compatible_node(np, NULL, "ibm,gpio-440EP"); ++ if (np == NULL) { ++ printk(KERN_ERR __FILE__ ": Unable to find gpio\n"); ++ return; ++ } ++ ++ gpio_base = of_iomap(np, 0); ++ of_node_put(np); ++ if (gpio_base == NULL) { ++ printk(KERN_ERR __FILE__ ": Unable to map gpio"); ++ return; ++ } ++ } ++ ++ leds = in_be32(gpio_base); ++ ++ switch (green) { ++ case 0: leds &= ~LED_GREEN; break; ++ case 1: leds |= LED_GREEN; break; ++ } ++ switch (red) { ++ case 0: leds &= ~LED_RED; break; ++ case 1: leds |= LED_RED; break; ++ } ++ ++ out_be32(gpio_base, leds); ++} ++EXPORT_SYMBOL(warp_set_power_leds); ++ ++ ++#ifdef CONFIG_SENSORS_AD7414 ++static int pika_dtm_thread(void __iomem *fpga) ++{ ++ extern int ad7414_get_temp(int index); ++ ++ while (!kthread_should_stop()) { ++ int temp = ad7414_get_temp(0); ++ ++ out_be32(fpga, temp); ++ ++ set_current_state(TASK_INTERRUPTIBLE); ++ schedule_timeout(HZ); ++ } ++ ++ return 0; ++} ++ ++static int __init pika_dtm_start(void) ++{ ++ struct task_struct *dtm_thread; ++ struct device_node *np; ++ struct resource res; ++ void __iomem *fpga; ++ ++ np = of_find_compatible_node(NULL, NULL, "pika,fpga"); ++ if (np == NULL) ++ return -ENOENT; ++ ++ /* We do not call of_iomap here since it would map in the entire ++ * fpga space, which is over 8k. ++ */ ++ if (of_address_to_resource(np, 0, &res)) { ++ of_node_put(np); ++ return -ENOENT; ++ } ++ of_node_put(np); ++ ++ fpga = ioremap(res.start + 0x20, 4); ++ if (fpga == NULL) ++ return -ENOENT; ++ ++ dtm_thread = kthread_run(pika_dtm_thread, fpga + 0x20, "pika-dtm"); ++ if (IS_ERR(dtm_thread)) { ++ iounmap(fpga); ++ return PTR_ERR(dtm_thread); ++ } ++ ++ return 0; ++} ++device_initcall(pika_dtm_start); ++#endif +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/52xx/Kconfig powerpc.git/arch/powerpc/platforms/52xx/Kconfig +--- linux-2.6.24/arch/powerpc/platforms/52xx/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/52xx/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -19,6 +19,28 @@ + + It is safe to say 'Y' here + ++config PPC_MPC5200_SIMPLE ++ bool "Generic support for simple MPC5200 based boards" ++ depends on PPC_MULTIPLATFORM && PPC32 ++ select PPC_MPC5200 ++ select DEFAULT_UIMAGE ++ select WANT_DEVICE_TREE ++ default n ++ help ++ This option enables support for a simple MPC52xx based boards which ++ do not need a custom platform specific setup. Such boards are ++ supported assuming the following: ++ ++ - GPIO pins are configured by the firmware, ++ - CDM configuration (clocking) is setup correctly by firmware, ++ - if the 'fsl,has-wdt' property is present in one of the ++ gpt nodes, then it is safe to use such gpt to reset the board, ++ - PCI is supported if enabled in the kernel configuration ++ and if there is a PCI bus node defined in the device tree. ++ ++ Boards that are compatible with this generic platform support ++ are: 'tqc,tqm5200', 'promess,motionpro', 'schindler,cm5200'. ++ + config PPC_EFIKA + bool "bPlan Efika 5k2. MPC5200B based computer" + depends on PPC_MULTIPLATFORM && PPC32 +@@ -31,8 +53,7 @@ + config PPC_LITE5200 + bool "Freescale Lite5200 Eval Board" + depends on PPC_MULTIPLATFORM && PPC32 +- select WANT_DEVICE_TREE + select PPC_MPC5200 ++ select DEFAULT_UIMAGE ++ select WANT_DEVICE_TREE + default n +- +- +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/52xx/Makefile powerpc.git/arch/powerpc/platforms/52xx/Makefile +--- linux-2.6.24/arch/powerpc/platforms/52xx/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/52xx/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -6,6 +6,7 @@ + obj-$(CONFIG_PCI) += mpc52xx_pci.o + endif + ++obj-$(CONFIG_PPC_MPC5200_SIMPLE) += mpc5200_simple.o + obj-$(CONFIG_PPC_EFIKA) += efika.o + obj-$(CONFIG_PPC_LITE5200) += lite5200.o + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/52xx/lite5200.c powerpc.git/arch/powerpc/platforms/52xx/lite5200.c +--- linux-2.6.24/arch/powerpc/platforms/52xx/lite5200.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/52xx/lite5200.c 2008-01-28 20:25:49.000000000 +0100 +@@ -42,10 +42,13 @@ + static void __init + lite5200_fix_clock_config(void) + { ++ struct device_node *np; + struct mpc52xx_cdm __iomem *cdm; + + /* Map zones */ +- cdm = mpc52xx_find_and_map("mpc5200-cdm"); ++ np = of_find_compatible_node(NULL, NULL, "mpc5200-cdm"); ++ cdm = of_iomap(np, 0); ++ of_node_put(np); + if (!cdm) { + printk(KERN_ERR "%s() failed; expect abnormal behaviour\n", + __FUNCTION__); +@@ -74,10 +77,13 @@ + static void __init + lite5200_fix_port_config(void) + { ++ struct device_node *np; + struct mpc52xx_gpio __iomem *gpio; + u32 port_config; + +- gpio = mpc52xx_find_and_map("mpc5200-gpio"); ++ np = of_find_compatible_node(NULL, NULL, "mpc5200-gpio"); ++ gpio = of_iomap(np, 0); ++ of_node_put(np); + if (!gpio) { + printk(KERN_ERR "%s() failed. expect abnormal behavior\n", + __FUNCTION__); +@@ -131,10 +137,6 @@ + + static void __init lite5200_setup_arch(void) + { +-#ifdef CONFIG_PCI +- struct device_node *np; +-#endif +- + if (ppc_md.progress) + ppc_md.progress("lite5200_setup_arch()", 0); + +@@ -154,13 +156,7 @@ + lite5200_pm_init(); + #endif + +-#ifdef CONFIG_PCI +- np = of_find_node_by_type(NULL, "pci"); +- if (np) { +- mpc52xx_add_bridge(np); +- of_node_put(np); +- } +-#endif ++ mpc52xx_setup_pci(); + } + + /* +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/52xx/lite5200_pm.c powerpc.git/arch/powerpc/platforms/52xx/lite5200_pm.c +--- linux-2.6.24/arch/powerpc/platforms/52xx/lite5200_pm.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/52xx/lite5200_pm.c 2008-01-28 20:25:49.000000000 +0100 +@@ -42,6 +42,8 @@ + + static int lite5200_pm_prepare(void) + { ++ struct device_node *np; ++ + /* deep sleep? let mpc52xx code handle that */ + if (lite5200_pm_target_state == PM_SUSPEND_STANDBY) + return mpc52xx_pm_prepare(); +@@ -50,7 +52,9 @@ + return -EINVAL; + + /* map registers */ +- mbar = mpc52xx_find_and_map("mpc5200"); ++ np = of_find_compatible_node(NULL, NULL, "mpc5200"); ++ mbar = of_iomap(np, 0); ++ of_node_put(np); + if (!mbar) { + printk(KERN_ERR "%s:%i Error mapping registers\n", __func__, __LINE__); + return -ENOSYS; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/52xx/mpc5200_simple.c powerpc.git/arch/powerpc/platforms/52xx/mpc5200_simple.c +--- linux-2.6.24/arch/powerpc/platforms/52xx/mpc5200_simple.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/52xx/mpc5200_simple.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,85 @@ ++/* ++ * Support for 'mpc5200-simple-platform' compatible boards. ++ * ++ * Written by Marian Balakowicz <m8@semihalf.com> ++ * Copyright (C) 2007 Semihalf ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ * ++ * Description: ++ * This code implements support for a simple MPC52xx based boards which ++ * do not need a custom platform specific setup. Such boards are ++ * supported assuming the following: ++ * ++ * - GPIO pins are configured by the firmware, ++ * - CDM configuration (clocking) is setup correctly by firmware, ++ * - if the 'fsl,has-wdt' property is present in one of the ++ * gpt nodes, then it is safe to use such gpt to reset the board, ++ * - PCI is supported if enabled in the kernel configuration ++ * and if there is a PCI bus node defined in the device tree. ++ * ++ * Boards that are compatible with this generic platform support ++ * are listed in a 'board' table. ++ */ ++ ++#undef DEBUG ++#include <asm/time.h> ++#include <asm/prom.h> ++#include <asm/machdep.h> ++#include <asm/mpc52xx.h> ++ ++/* ++ * Setup the architecture ++ */ ++static void __init mpc5200_simple_setup_arch(void) ++{ ++ if (ppc_md.progress) ++ ppc_md.progress("mpc5200_simple_setup_arch()", 0); ++ ++ /* Some mpc5200 & mpc5200b related configuration */ ++ mpc5200_setup_xlb_arbiter(); ++ ++ /* Map wdt for mpc52xx_restart() */ ++ mpc52xx_map_wdt(); ++ ++ mpc52xx_setup_pci(); ++} ++ ++/* list of the supported boards */ ++static char *board[] __initdata = { ++ "promess,motionpro", ++ "schindler,cm5200", ++ "tqc,tqm5200", ++ NULL ++}; ++ ++/* ++ * Called very early, MMU is off, device-tree isn't unflattened ++ */ ++static int __init mpc5200_simple_probe(void) ++{ ++ unsigned long node = of_get_flat_dt_root(); ++ int i = 0; ++ ++ while (board[i]) { ++ if (of_flat_dt_is_compatible(node, board[i])) ++ break; ++ i++; ++ } ++ ++ return (board[i] != NULL); ++} ++ ++define_machine(mpc5200_simple_platform) { ++ .name = "mpc5200-simple-platform", ++ .probe = mpc5200_simple_probe, ++ .setup_arch = mpc5200_simple_setup_arch, ++ .init = mpc52xx_declare_of_platform_devices, ++ .init_IRQ = mpc52xx_init_irq, ++ .get_irq = mpc52xx_get_irq, ++ .restart = mpc52xx_restart, ++ .calibrate_decr = generic_calibrate_decr, ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/52xx/mpc52xx_common.c powerpc.git/arch/powerpc/platforms/52xx/mpc52xx_common.c +--- linux-2.6.24/arch/powerpc/platforms/52xx/mpc52xx_common.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/52xx/mpc52xx_common.c 2008-01-28 20:25:49.000000000 +0100 +@@ -26,45 +26,6 @@ + */ + static volatile struct mpc52xx_gpt *mpc52xx_wdt = NULL; + +-static void __iomem * +-mpc52xx_map_node(struct device_node *ofn) +-{ +- const u32 *regaddr_p; +- u64 regaddr64, size64; +- +- if (!ofn) +- return NULL; +- +- regaddr_p = of_get_address(ofn, 0, &size64, NULL); +- if (!regaddr_p) { +- of_node_put(ofn); +- return NULL; +- } +- +- regaddr64 = of_translate_address(ofn, regaddr_p); +- +- of_node_put(ofn); +- +- return ioremap((u32)regaddr64, (u32)size64); +-} +- +-void __iomem * +-mpc52xx_find_and_map(const char *compatible) +-{ +- return mpc52xx_map_node( +- of_find_compatible_node(NULL, NULL, compatible)); +-} +- +-EXPORT_SYMBOL(mpc52xx_find_and_map); +- +-void __iomem * +-mpc52xx_find_and_map_path(const char *path) +-{ +- return mpc52xx_map_node(of_find_node_by_path(path)); +-} +- +-EXPORT_SYMBOL(mpc52xx_find_and_map_path); +- + /** + * mpc52xx_find_ipb_freq - Find the IPB bus frequency for a device + * @node: device node +@@ -101,9 +62,12 @@ + void __init + mpc5200_setup_xlb_arbiter(void) + { ++ struct device_node *np; + struct mpc52xx_xlb __iomem *xlb; + +- xlb = mpc52xx_find_and_map("mpc5200-xlb"); ++ np = of_find_compatible_node(NULL, NULL, "mpc5200-xlb"); ++ xlb = of_iomap(np, 0); ++ of_node_put(np); + if (!xlb) { + printk(KERN_ERR __FILE__ ": " + "Error mapping XLB in mpc52xx_setup_cpu(). " +@@ -124,11 +88,21 @@ + iounmap(xlb); + } + ++static struct of_device_id mpc52xx_bus_ids[] __initdata= { ++ { .compatible = "fsl,mpc5200-immr", }, ++ { .compatible = "fsl,lpb", }, ++ ++ /* depreciated matches; shouldn't be used in new device trees */ ++ { .type = "builtin", .compatible = "mpc5200", }, /* efika */ ++ { .type = "soc", .compatible = "mpc5200", }, /* lite5200 */ ++ {}, ++}; ++ + void __init + mpc52xx_declare_of_platform_devices(void) + { + /* Find every child of the SOC node and add it to of_platform */ +- if (of_platform_bus_probe(NULL, NULL, NULL)) ++ if (of_platform_bus_probe(NULL, mpc52xx_bus_ids, NULL)) + printk(KERN_ERR __FILE__ ": " + "Error while probing of_platform bus\n"); + } +@@ -146,16 +120,19 @@ + for_each_compatible_node(np, NULL, "fsl,mpc5200-gpt") { + has_wdt = of_get_property(np, "fsl,has-wdt", NULL); + if (has_wdt) { +- mpc52xx_wdt = mpc52xx_map_node(np); ++ mpc52xx_wdt = of_iomap(np, 0); ++ of_node_put(np); + return; + } + } + for_each_compatible_node(np, NULL, "mpc5200-gpt") { + has_wdt = of_get_property(np, "has-wdt", NULL); + if (has_wdt) { +- mpc52xx_wdt = mpc52xx_map_node(np); ++ mpc52xx_wdt = of_iomap(np, 0); ++ of_node_put(np); + return; + } ++ + } + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/52xx/mpc52xx_pci.c powerpc.git/arch/powerpc/platforms/52xx/mpc52xx_pci.c +--- linux-2.6.24/arch/powerpc/platforms/52xx/mpc52xx_pci.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/52xx/mpc52xx_pci.c 2008-01-28 20:25:49.000000000 +0100 +@@ -363,7 +363,7 @@ + + pr_debug("Adding MPC52xx PCI host bridge %s\n", node->full_name); + +- pci_assign_all_buses = 1; ++ ppc_pci_flags |= PPC_PCI_REASSIGN_ALL_BUS; + + if (of_address_to_resource(node, 0, &rsrc) != 0) { + printk(KERN_ERR "Can't get %s resources\n", node->full_name); +@@ -406,3 +406,17 @@ + + return 0; + } ++ ++void __init mpc52xx_setup_pci(void) ++{ ++ struct device_node *pci; ++ ++ pci = of_find_compatible_node(NULL, NULL, "fsl,mpc5200-pci"); ++ if (!pci) ++ pci = of_find_compatible_node(NULL, NULL, "mpc5200-pci"); ++ if (!pci) ++ return; ++ ++ mpc52xx_add_bridge(pci); ++ of_node_put(pci); ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/52xx/mpc52xx_pic.c powerpc.git/arch/powerpc/platforms/52xx/mpc52xx_pic.c +--- linux-2.6.24/arch/powerpc/platforms/52xx/mpc52xx_pic.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/52xx/mpc52xx_pic.c 2008-01-28 20:25:49.000000000 +0100 +@@ -364,16 +364,18 @@ + { + u32 intr_ctrl; + struct device_node *picnode; ++ struct device_node *np; + + /* Remap the necessary zones */ + picnode = of_find_compatible_node(NULL, NULL, "mpc5200-pic"); +- +- intr = mpc52xx_find_and_map("mpc5200-pic"); ++ intr = of_iomap(picnode, 0); + if (!intr) + panic(__FILE__ ": find_and_map failed on 'mpc5200-pic'. " + "Check node !"); + +- sdma = mpc52xx_find_and_map("mpc5200-bestcomm"); ++ np = of_find_compatible_node(NULL, NULL, "mpc5200-bestcomm"); ++ sdma = of_iomap(np, 0); ++ of_node_put(np); + if (!sdma) + panic(__FILE__ ": find_and_map failed on 'mpc5200-bestcomm'. " + "Check node !"); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/52xx/mpc52xx_pm.c powerpc.git/arch/powerpc/platforms/52xx/mpc52xx_pm.c +--- linux-2.6.24/arch/powerpc/platforms/52xx/mpc52xx_pm.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/52xx/mpc52xx_pm.c 2008-01-28 20:25:49.000000000 +0100 +@@ -59,10 +59,14 @@ + + int mpc52xx_pm_prepare(void) + { ++ struct device_node *np; ++ + /* map the whole register space */ +- mbar = mpc52xx_find_and_map("mpc5200"); ++ np = of_find_compatible_node(NULL, NULL, "mpc5200"); ++ mbar = of_iomap(np, 0); ++ of_node_put(np); + if (!mbar) { +- printk(KERN_ERR "%s:%i Error mapping registers\n", __func__, __LINE__); ++ pr_err("mpc52xx_pm_prepare(): could not map registers\n"); + return -ENOSYS; + } + /* these offsets are from mpc5200 users manual */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/82xx/Kconfig powerpc.git/arch/powerpc/platforms/82xx/Kconfig +--- linux-2.6.24/arch/powerpc/platforms/82xx/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/82xx/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -26,6 +26,19 @@ + help + This option enables support for the PQ2FADS board + ++config EP8248E ++ bool "Embedded Planet EP8248E (a.k.a. CWH-PPC-8248N-VE)" ++ select 8272 ++ select 8260 ++ select FSL_SOC ++ select PPC_CPM_NEW_BINDING ++ select MDIO_BITBANG ++ help ++ This enables support for the Embedded Planet EP8248E board. ++ ++ This board is also resold by Freescale as the QUICCStart ++ MPC8248 Evaluation System and/or the CWH-PPC-8248N-VE. ++ + endchoice + + config PQ2ADS +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/82xx/Makefile powerpc.git/arch/powerpc/platforms/82xx/Makefile +--- linux-2.6.24/arch/powerpc/platforms/82xx/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/82xx/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -5,3 +5,4 @@ + obj-$(CONFIG_CPM2) += pq2.o + obj-$(CONFIG_PQ2_ADS_PCI_PIC) += pq2ads-pci-pic.o + obj-$(CONFIG_PQ2FADS) += pq2fads.o ++obj-$(CONFIG_EP8248E) += ep8248e.o +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/82xx/ep8248e.c powerpc.git/arch/powerpc/platforms/82xx/ep8248e.c +--- linux-2.6.24/arch/powerpc/platforms/82xx/ep8248e.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/82xx/ep8248e.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,324 @@ ++/* ++ * Embedded Planet EP8248E support ++ * ++ * Copyright 2007 Freescale Semiconductor, Inc. ++ * Author: Scott Wood <scottwood@freescale.com> ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++#include <linux/init.h> ++#include <linux/interrupt.h> ++#include <linux/fsl_devices.h> ++#include <linux/mdio-bitbang.h> ++#include <linux/of_platform.h> ++ ++#include <asm/io.h> ++#include <asm/cpm2.h> ++#include <asm/udbg.h> ++#include <asm/machdep.h> ++#include <asm/time.h> ++#include <asm/mpc8260.h> ++#include <asm/prom.h> ++ ++#include <sysdev/fsl_soc.h> ++#include <sysdev/cpm2_pic.h> ++ ++#include "pq2.h" ++ ++static u8 __iomem *ep8248e_bcsr; ++static struct device_node *ep8248e_bcsr_node; ++ ++#define BCSR7_SCC2_ENABLE 0x10 ++ ++#define BCSR8_PHY1_ENABLE 0x80 ++#define BCSR8_PHY1_POWER 0x40 ++#define BCSR8_PHY2_ENABLE 0x20 ++#define BCSR8_PHY2_POWER 0x10 ++#define BCSR8_MDIO_READ 0x04 ++#define BCSR8_MDIO_CLOCK 0x02 ++#define BCSR8_MDIO_DATA 0x01 ++ ++#define BCSR9_USB_ENABLE 0x80 ++#define BCSR9_USB_POWER 0x40 ++#define BCSR9_USB_HOST 0x20 ++#define BCSR9_USB_FULL_SPEED_TARGET 0x10 ++ ++static void __init ep8248e_pic_init(void) ++{ ++ struct device_node *np = of_find_compatible_node(NULL, NULL, "fsl,pq2-pic"); ++ if (!np) { ++ printk(KERN_ERR "PIC init: can not find cpm-pic node\n"); ++ return; ++ } ++ ++ cpm2_pic_init(np); ++ of_node_put(np); ++} ++ ++static void ep8248e_set_mdc(struct mdiobb_ctrl *ctrl, int level) ++{ ++ if (level) ++ setbits8(&ep8248e_bcsr[8], BCSR8_MDIO_CLOCK); ++ else ++ clrbits8(&ep8248e_bcsr[8], BCSR8_MDIO_CLOCK); ++ ++ /* Read back to flush the write. */ ++ in_8(&ep8248e_bcsr[8]); ++} ++ ++static void ep8248e_set_mdio_dir(struct mdiobb_ctrl *ctrl, int output) ++{ ++ if (output) ++ clrbits8(&ep8248e_bcsr[8], BCSR8_MDIO_READ); ++ else ++ setbits8(&ep8248e_bcsr[8], BCSR8_MDIO_READ); ++ ++ /* Read back to flush the write. */ ++ in_8(&ep8248e_bcsr[8]); ++} ++ ++static void ep8248e_set_mdio_data(struct mdiobb_ctrl *ctrl, int data) ++{ ++ if (data) ++ setbits8(&ep8248e_bcsr[8], BCSR8_MDIO_DATA); ++ else ++ clrbits8(&ep8248e_bcsr[8], BCSR8_MDIO_DATA); ++ ++ /* Read back to flush the write. */ ++ in_8(&ep8248e_bcsr[8]); ++} ++ ++static int ep8248e_get_mdio_data(struct mdiobb_ctrl *ctrl) ++{ ++ return in_8(&ep8248e_bcsr[8]) & BCSR8_MDIO_DATA; ++} ++ ++static const struct mdiobb_ops ep8248e_mdio_ops = { ++ .set_mdc = ep8248e_set_mdc, ++ .set_mdio_dir = ep8248e_set_mdio_dir, ++ .set_mdio_data = ep8248e_set_mdio_data, ++ .get_mdio_data = ep8248e_get_mdio_data, ++ .owner = THIS_MODULE, ++}; ++ ++static struct mdiobb_ctrl ep8248e_mdio_ctrl = { ++ .ops = &ep8248e_mdio_ops, ++}; ++ ++static int __devinit ep8248e_mdio_probe(struct of_device *ofdev, ++ const struct of_device_id *match) ++{ ++ struct mii_bus *bus; ++ struct resource res; ++ struct device_node *node; ++ int ret, i; ++ ++ node = of_get_parent(ofdev->node); ++ of_node_put(node); ++ if (node != ep8248e_bcsr_node) ++ return -ENODEV; ++ ++ ret = of_address_to_resource(ofdev->node, 0, &res); ++ if (ret) ++ return ret; ++ ++ bus = alloc_mdio_bitbang(&ep8248e_mdio_ctrl); ++ if (!bus) ++ return -ENOMEM; ++ ++ bus->phy_mask = 0; ++ bus->irq = kmalloc(sizeof(int) * PHY_MAX_ADDR, GFP_KERNEL); ++ ++ for (i = 0; i < PHY_MAX_ADDR; i++) ++ bus->irq[i] = -1; ++ ++ bus->name = "ep8248e-mdio-bitbang"; ++ bus->dev = &ofdev->dev; ++ bus->id = res.start; ++ ++ return mdiobus_register(bus); ++} ++ ++static int ep8248e_mdio_remove(struct of_device *ofdev) ++{ ++ BUG(); ++ return 0; ++} ++ ++static const struct of_device_id ep8248e_mdio_match[] = { ++ { ++ .compatible = "fsl,ep8248e-mdio-bitbang", ++ }, ++ {}, ++}; ++ ++static struct of_platform_driver ep8248e_mdio_driver = { ++ .driver = { ++ .name = "ep8248e-mdio-bitbang", ++ }, ++ .match_table = ep8248e_mdio_match, ++ .probe = ep8248e_mdio_probe, ++ .remove = ep8248e_mdio_remove, ++}; ++ ++struct cpm_pin { ++ int port, pin, flags; ++}; ++ ++static __initdata struct cpm_pin ep8248e_pins[] = { ++ /* SMC1 */ ++ {2, 4, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {2, 5, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ ++ /* SCC1 */ ++ {2, 14, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {2, 15, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {3, 29, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ {3, 30, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY}, ++ {3, 31, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ ++ /* FCC1 */ ++ {0, 14, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {0, 15, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {0, 16, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {0, 17, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {0, 18, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ {0, 19, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ {0, 20, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ {0, 21, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ {0, 26, CPM_PIN_INPUT | CPM_PIN_SECONDARY}, ++ {0, 27, CPM_PIN_INPUT | CPM_PIN_SECONDARY}, ++ {0, 28, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY}, ++ {0, 29, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY}, ++ {0, 30, CPM_PIN_INPUT | CPM_PIN_SECONDARY}, ++ {0, 31, CPM_PIN_INPUT | CPM_PIN_SECONDARY}, ++ {2, 21, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {2, 22, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ ++ /* FCC2 */ ++ {1, 18, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {1, 19, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {1, 20, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {1, 21, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {1, 22, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ {1, 23, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ {1, 24, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ {1, 25, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ {1, 26, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {1, 27, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {1, 28, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {1, 29, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY}, ++ {1, 30, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {1, 31, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ {2, 18, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {2, 19, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ ++ /* I2C */ ++ {4, 14, CPM_PIN_INPUT | CPM_PIN_SECONDARY}, ++ {4, 15, CPM_PIN_INPUT | CPM_PIN_SECONDARY}, ++ ++ /* USB */ ++ {2, 10, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {2, 11, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {2, 20, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ {2, 24, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++ {3, 23, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ {3, 24, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, ++ {3, 25, CPM_PIN_INPUT | CPM_PIN_PRIMARY}, ++}; ++ ++static void __init init_ioports(void) ++{ ++ int i; ++ ++ for (i = 0; i < ARRAY_SIZE(ep8248e_pins); i++) { ++ const struct cpm_pin *pin = &ep8248e_pins[i]; ++ cpm2_set_pin(pin->port, pin->pin, pin->flags); ++ } ++ ++ cpm2_smc_clk_setup(CPM_CLK_SMC1, CPM_BRG7); ++ cpm2_clk_setup(CPM_CLK_SCC1, CPM_BRG1, CPM_CLK_RX); ++ cpm2_clk_setup(CPM_CLK_SCC1, CPM_BRG1, CPM_CLK_TX); ++ cpm2_clk_setup(CPM_CLK_SCC3, CPM_CLK8, CPM_CLK_TX); /* USB */ ++ cpm2_clk_setup(CPM_CLK_FCC1, CPM_CLK11, CPM_CLK_RX); ++ cpm2_clk_setup(CPM_CLK_FCC1, CPM_CLK10, CPM_CLK_TX); ++ cpm2_clk_setup(CPM_CLK_FCC2, CPM_CLK13, CPM_CLK_RX); ++ cpm2_clk_setup(CPM_CLK_FCC2, CPM_CLK14, CPM_CLK_TX); ++} ++ ++static void __init ep8248e_setup_arch(void) ++{ ++ if (ppc_md.progress) ++ ppc_md.progress("ep8248e_setup_arch()", 0); ++ ++ cpm2_reset(); ++ ++ /* When this is set, snooping CPM DMA from RAM causes ++ * machine checks. See erratum SIU18. ++ */ ++ clrbits32(&cpm2_immr->im_siu_conf.siu_82xx.sc_bcr, MPC82XX_BCR_PLDP); ++ ++ ep8248e_bcsr_node = ++ of_find_compatible_node(NULL, NULL, "fsl,ep8248e-bcsr"); ++ if (!ep8248e_bcsr_node) { ++ printk(KERN_ERR "No bcsr in device tree\n"); ++ return; ++ } ++ ++ ep8248e_bcsr = of_iomap(ep8248e_bcsr_node, 0); ++ if (!ep8248e_bcsr) { ++ printk(KERN_ERR "Cannot map BCSR registers\n"); ++ of_node_put(ep8248e_bcsr_node); ++ ep8248e_bcsr_node = NULL; ++ return; ++ } ++ ++ setbits8(&ep8248e_bcsr[7], BCSR7_SCC2_ENABLE); ++ setbits8(&ep8248e_bcsr[8], BCSR8_PHY1_ENABLE | BCSR8_PHY1_POWER | ++ BCSR8_PHY2_ENABLE | BCSR8_PHY2_POWER); ++ ++ init_ioports(); ++ ++ if (ppc_md.progress) ++ ppc_md.progress("ep8248e_setup_arch(), finish", 0); ++} ++ ++static __initdata struct of_device_id of_bus_ids[] = { ++ { .compatible = "simple-bus", }, ++ { .compatible = "fsl,ep8248e-bcsr", }, ++ {}, ++}; ++ ++static int __init declare_of_platform_devices(void) ++{ ++ of_platform_bus_probe(NULL, of_bus_ids, NULL); ++ of_register_platform_driver(&ep8248e_mdio_driver); ++ ++ return 0; ++} ++machine_device_initcall(ep8248e, declare_of_platform_devices); ++ ++/* ++ * Called very early, device-tree isn't unflattened ++ */ ++static int __init ep8248e_probe(void) ++{ ++ unsigned long root = of_get_flat_dt_root(); ++ return of_flat_dt_is_compatible(root, "fsl,ep8248e"); ++} ++ ++define_machine(ep8248e) ++{ ++ .name = "Embedded Planet EP8248E", ++ .probe = ep8248e_probe, ++ .setup_arch = ep8248e_setup_arch, ++ .init_IRQ = ep8248e_pic_init, ++ .get_irq = cpm2_get_irq, ++ .calibrate_decr = generic_calibrate_decr, ++ .restart = pq2_restart, ++ .progress = udbg_progress, ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/82xx/pq2.c powerpc.git/arch/powerpc/platforms/82xx/pq2.c +--- linux-2.6.24/arch/powerpc/platforms/82xx/pq2.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/82xx/pq2.c 2008-01-28 20:25:49.000000000 +0100 +@@ -53,13 +53,13 @@ + if (of_address_to_resource(np, 0, &r) || r.end - r.start < 0x10b) + goto err; + +- pci_assign_all_buses = 1; ++ ppc_pci_flags |= PPC_PCI_REASSIGN_ALL_BUS; + + hose = pcibios_alloc_controller(np); + if (!hose) + return; + +- hose->arch_data = np; ++ hose->dn = np; + + setup_indirect_pci(hose, r.start + 0x100, r.start + 0x104, 0); + pci_process_bridge_OF_ranges(hose, np, 1); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/82xx/pq2fads.c powerpc.git/arch/powerpc/platforms/82xx/pq2fads.c +--- linux-2.6.24/arch/powerpc/platforms/82xx/pq2fads.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/82xx/pq2fads.c 2008-01-28 20:25:49.000000000 +0100 +@@ -15,12 +15,12 @@ + #include <linux/init.h> + #include <linux/interrupt.h> + #include <linux/fsl_devices.h> ++#include <linux/of_platform.h> + + #include <asm/io.h> + #include <asm/cpm2.h> + #include <asm/udbg.h> + #include <asm/machdep.h> +-#include <asm/of_platform.h> + #include <asm/time.h> + + #include <sysdev/fsl_soc.h> +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/83xx/Kconfig powerpc.git/arch/powerpc/platforms/83xx/Kconfig +--- linux-2.6.24/arch/powerpc/platforms/83xx/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/83xx/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -50,6 +50,11 @@ + help + This option enables support for the MPC836x MDS Processor Board. + ++config MPC837x_MDS ++ bool "Freescale MPC837x MDS" ++ select DEFAULT_UIMAGE ++ help ++ This option enables support for the MPC837x MDS Processor Board. + endchoice + + config PPC_MPC831x +@@ -75,3 +80,9 @@ + select PPC_UDBG_16550 + select PPC_INDIRECT_PCI + default y if MPC836x_MDS ++ ++config PPC_MPC837x ++ bool ++ select PPC_UDBG_16550 ++ select PPC_INDIRECT_PCI ++ default y if MPC837x_MDS +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/83xx/Makefile powerpc.git/arch/powerpc/platforms/83xx/Makefile +--- linux-2.6.24/arch/powerpc/platforms/83xx/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/83xx/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -9,3 +9,4 @@ + obj-$(CONFIG_MPC834x_ITX) += mpc834x_itx.o + obj-$(CONFIG_MPC836x_MDS) += mpc836x_mds.o + obj-$(CONFIG_MPC832x_MDS) += mpc832x_mds.o ++obj-$(CONFIG_MPC837x_MDS) += mpc837x_mds.o +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/83xx/mpc8313_rdb.c powerpc.git/arch/powerpc/platforms/83xx/mpc8313_rdb.c +--- linux-2.6.24/arch/powerpc/platforms/83xx/mpc8313_rdb.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/83xx/mpc8313_rdb.c 2008-01-28 20:25:49.000000000 +0100 +@@ -14,6 +14,7 @@ + */ + + #include <linux/pci.h> ++#include <linux/of_platform.h> + + #include <asm/time.h> + #include <asm/ipic.h> +@@ -70,11 +71,23 @@ + */ + static int __init mpc8313_rdb_probe(void) + { +- unsigned long root = of_get_flat_dt_root(); ++ unsigned long root = of_get_flat_dt_root(); + +- return of_flat_dt_is_compatible(root, "MPC8313ERDB"); ++ return of_flat_dt_is_compatible(root, "MPC8313ERDB"); + } + ++static struct of_device_id __initdata of_bus_ids[] = { ++ { .compatible = "simple-bus" }, ++ {}, ++}; ++ ++static int __init declare_of_platform_devices(void) ++{ ++ of_platform_bus_probe(NULL, of_bus_ids, NULL); ++ return 0; ++} ++machine_device_initcall(mpc8313_rdb, declare_of_platform_devices); ++ + define_machine(mpc8313_rdb) { + .name = "MPC8313 RDB", + .probe = mpc8313_rdb_probe, +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/83xx/mpc832x_mds.c powerpc.git/arch/powerpc/platforms/83xx/mpc832x_mds.c +--- linux-2.6.24/arch/powerpc/platforms/83xx/mpc832x_mds.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/83xx/mpc832x_mds.c 2008-01-28 20:25:49.000000000 +0100 +@@ -23,9 +23,9 @@ + #include <linux/seq_file.h> + #include <linux/root_dev.h> + #include <linux/initrd.h> ++#include <linux/of_platform.h> ++#include <linux/of_device.h> + +-#include <asm/of_device.h> +-#include <asm/of_platform.h> + #include <asm/system.h> + #include <asm/atomic.h> + #include <asm/time.h> +@@ -110,15 +110,12 @@ + + static int __init mpc832x_declare_of_platform_devices(void) + { +- if (!machine_is(mpc832x_mds)) +- return 0; +- + /* Publish the QE devices */ + of_platform_bus_probe(NULL, mpc832x_ids, NULL); + + return 0; + } +-device_initcall(mpc832x_declare_of_platform_devices); ++machine_device_initcall(mpc832x_mds, mpc832x_declare_of_platform_devices); + + static void __init mpc832x_sys_init_IRQ(void) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/83xx/mpc832x_rdb.c powerpc.git/arch/powerpc/platforms/83xx/mpc832x_rdb.c +--- linux-2.6.24/arch/powerpc/platforms/83xx/mpc832x_rdb.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/83xx/mpc832x_rdb.c 2008-01-28 20:25:49.000000000 +0100 +@@ -19,8 +19,8 @@ + #include <linux/spi/spi.h> + #include <linux/spi/mmc_spi.h> + #include <linux/mmc/host.h> ++#include <linux/of_platform.h> + +-#include <asm/of_platform.h> + #include <asm/time.h> + #include <asm/ipic.h> + #include <asm/udbg.h> +@@ -63,9 +63,6 @@ + + static int __init mpc832x_spi_init(void) + { +- if (!machine_is(mpc832x_rdb)) +- return 0; +- + par_io_config_pin(3, 0, 3, 0, 1, 0); /* SPI1 MOSI, I/O */ + par_io_config_pin(3, 1, 3, 0, 1, 0); /* SPI1 MISO, I/O */ + par_io_config_pin(3, 2, 3, 0, 1, 0); /* SPI1 CLK, I/O */ +@@ -80,7 +77,7 @@ + mpc83xx_spi_deactivate_cs); + } + +-device_initcall(mpc832x_spi_init); ++machine_device_initcall(mpc832x_rdb, mpc832x_spi_init); + + /* ************************************************************************ + * +@@ -123,15 +120,12 @@ + + static int __init mpc832x_declare_of_platform_devices(void) + { +- if (!machine_is(mpc832x_rdb)) +- return 0; +- + /* Publish the QE devices */ + of_platform_bus_probe(NULL, mpc832x_ids, NULL); + + return 0; + } +-device_initcall(mpc832x_declare_of_platform_devices); ++machine_device_initcall(mpc832x_rdb, mpc832x_declare_of_platform_devices); + + void __init mpc832x_rdb_init_IRQ(void) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/83xx/mpc834x_itx.c powerpc.git/arch/powerpc/platforms/83xx/mpc834x_itx.c +--- linux-2.6.24/arch/powerpc/platforms/83xx/mpc834x_itx.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/83xx/mpc834x_itx.c 2008-01-28 20:25:49.000000000 +0100 +@@ -23,6 +23,7 @@ + #include <linux/delay.h> + #include <linux/seq_file.h> + #include <linux/root_dev.h> ++#include <linux/of_platform.h> + + #include <asm/system.h> + #include <asm/atomic.h> +@@ -37,6 +38,17 @@ + + #include "mpc83xx.h" + ++static struct of_device_id __initdata mpc834x_itx_ids[] = { ++ { .compatible = "fsl,pq2pro-localbus", }, ++ {}, ++}; ++ ++static int __init mpc834x_itx_declare_of_platform_devices(void) ++{ ++ return of_platform_bus_probe(NULL, mpc834x_itx_ids, NULL); ++} ++machine_device_initcall(mpc834x_itx, mpc834x_itx_declare_of_platform_devices); ++ + /* ************************************************************************ + * + * Setup the architecture +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/83xx/mpc834x_mds.c powerpc.git/arch/powerpc/platforms/83xx/mpc834x_mds.c +--- linux-2.6.24/arch/powerpc/platforms/83xx/mpc834x_mds.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/83xx/mpc834x_mds.c 2008-01-28 20:25:49.000000000 +0100 +@@ -23,6 +23,7 @@ + #include <linux/delay.h> + #include <linux/seq_file.h> + #include <linux/root_dev.h> ++#include <linux/of_platform.h> + + #include <asm/system.h> + #include <asm/atomic.h> +@@ -106,14 +107,27 @@ + ipic_set_default_priority(); + } + ++static struct of_device_id mpc834x_ids[] = { ++ { .type = "soc", }, ++ { .compatible = "soc", }, ++ {}, ++}; ++ ++static int __init mpc834x_declare_of_platform_devices(void) ++{ ++ of_platform_bus_probe(NULL, mpc834x_ids, NULL); ++ return 0; ++} ++machine_device_initcall(mpc834x_mds, mpc834x_declare_of_platform_devices); ++ + /* + * Called very early, MMU is off, device-tree isn't unflattened + */ + static int __init mpc834x_mds_probe(void) + { +- unsigned long root = of_get_flat_dt_root(); ++ unsigned long root = of_get_flat_dt_root(); + +- return of_flat_dt_is_compatible(root, "MPC834xMDS"); ++ return of_flat_dt_is_compatible(root, "MPC834xMDS"); + } + + define_machine(mpc834x_mds) { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/83xx/mpc836x_mds.c powerpc.git/arch/powerpc/platforms/83xx/mpc836x_mds.c +--- linux-2.6.24/arch/powerpc/platforms/83xx/mpc836x_mds.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/83xx/mpc836x_mds.c 2008-01-28 20:25:49.000000000 +0100 +@@ -29,9 +29,9 @@ + #include <linux/seq_file.h> + #include <linux/root_dev.h> + #include <linux/initrd.h> ++#include <linux/of_platform.h> ++#include <linux/of_device.h> + +-#include <asm/of_device.h> +-#include <asm/of_platform.h> + #include <asm/system.h> + #include <asm/atomic.h> + #include <asm/time.h> +@@ -141,15 +141,12 @@ + + static int __init mpc836x_declare_of_platform_devices(void) + { +- if (!machine_is(mpc836x_mds)) +- return 0; +- + /* Publish the QE devices */ + of_platform_bus_probe(NULL, mpc836x_ids, NULL); + + return 0; + } +-device_initcall(mpc836x_declare_of_platform_devices); ++machine_device_initcall(mpc836x_mds, mpc836x_declare_of_platform_devices); + + static void __init mpc836x_mds_init_IRQ(void) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/83xx/mpc837x_mds.c powerpc.git/arch/powerpc/platforms/83xx/mpc837x_mds.c +--- linux-2.6.24/arch/powerpc/platforms/83xx/mpc837x_mds.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/83xx/mpc837x_mds.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,147 @@ ++/* ++ * arch/powerpc/platforms/83xx/mpc837x_mds.c ++ * ++ * Copyright (C) 2007 Freescale Semiconductor, Inc. All rights reserved. ++ * ++ * MPC837x MDS board specific routines ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++#include <linux/pci.h> ++#include <linux/of.h> ++#include <linux/of_platform.h> ++ ++#include <asm/time.h> ++#include <asm/ipic.h> ++#include <asm/udbg.h> ++#include <asm/prom.h> ++ ++#include "mpc83xx.h" ++ ++#define BCSR12_USB_SER_MASK 0x8a ++#define BCSR12_USB_SER_PIN 0x80 ++#define BCSR12_USB_SER_DEVICE 0x02 ++extern int mpc837x_usb_cfg(void); ++ ++static int mpc837xmds_usb_cfg(void) ++{ ++ struct device_node *np; ++ const void *phy_type, *mode; ++ void __iomem *bcsr_regs = NULL; ++ u8 bcsr12; ++ int ret; ++ ++ ret = mpc837x_usb_cfg(); ++ if (ret) ++ return ret; ++ /* Map BCSR area */ ++ np = of_find_node_by_name(NULL, "bcsr"); ++ if (np) { ++ struct resource res; ++ ++ of_address_to_resource(np, 0, &res); ++ bcsr_regs = ioremap(res.start, res.end - res.start + 1); ++ of_node_put(np); ++ } ++ if (!bcsr_regs) ++ return -1; ++ ++ np = of_find_node_by_name(NULL, "usb"); ++ if (!np) ++ return -ENODEV; ++ phy_type = of_get_property(np, "phy_type", NULL); ++ if (phy_type && !strcmp(phy_type, "ulpi")) { ++ clrbits8(bcsr_regs + 12, BCSR12_USB_SER_PIN); ++ } else if (phy_type && !strcmp(phy_type, "serial")) { ++ mode = of_get_property(np, "dr_mode", NULL); ++ bcsr12 = in_8(bcsr_regs + 12) & ~BCSR12_USB_SER_MASK; ++ bcsr12 |= BCSR12_USB_SER_PIN; ++ if (mode && !strcmp(mode, "peripheral")) ++ bcsr12 |= BCSR12_USB_SER_DEVICE; ++ out_8(bcsr_regs + 12, bcsr12); ++ } else { ++ printk(KERN_ERR "USB DR: unsupported PHY\n"); ++ } ++ ++ of_node_put(np); ++ iounmap(bcsr_regs); ++ return 0; ++} ++ ++/* ************************************************************************ ++ * ++ * Setup the architecture ++ * ++ */ ++static void __init mpc837x_mds_setup_arch(void) ++{ ++#ifdef CONFIG_PCI ++ struct device_node *np; ++#endif ++ ++ if (ppc_md.progress) ++ ppc_md.progress("mpc837x_mds_setup_arch()", 0); ++ ++#ifdef CONFIG_PCI ++ for_each_compatible_node(np, "pci", "fsl,mpc8349-pci") ++ mpc83xx_add_bridge(np); ++#endif ++ mpc837xmds_usb_cfg(); ++} ++ ++static struct of_device_id mpc837x_ids[] = { ++ { .type = "soc", }, ++ { .compatible = "soc", }, ++ {}, ++}; ++ ++static int __init mpc837x_declare_of_platform_devices(void) ++{ ++ /* Publish of_device */ ++ of_platform_bus_probe(NULL, mpc837x_ids, NULL); ++ ++ return 0; ++} ++machine_device_initcall(mpc837x_mds, mpc837x_declare_of_platform_devices); ++ ++static void __init mpc837x_mds_init_IRQ(void) ++{ ++ struct device_node *np; ++ ++ np = of_find_compatible_node(NULL, NULL, "fsl,ipic"); ++ if (!np) ++ return; ++ ++ ipic_init(np, 0); ++ ++ /* Initialize the default interrupt mapping priorities, ++ * in case the boot rom changed something on us. ++ */ ++ ipic_set_default_priority(); ++} ++ ++/* ++ * Called very early, MMU is off, device-tree isn't unflattened ++ */ ++static int __init mpc837x_mds_probe(void) ++{ ++ unsigned long root = of_get_flat_dt_root(); ++ ++ return of_flat_dt_is_compatible(root, "fsl,mpc837xmds"); ++} ++ ++define_machine(mpc837x_mds) { ++ .name = "MPC837x MDS", ++ .probe = mpc837x_mds_probe, ++ .setup_arch = mpc837x_mds_setup_arch, ++ .init_IRQ = mpc837x_mds_init_IRQ, ++ .get_irq = ipic_get_irq, ++ .restart = mpc83xx_restart, ++ .time_init = mpc83xx_time_init, ++ .calibrate_decr = generic_calibrate_decr, ++ .progress = udbg_progress, ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/83xx/mpc83xx.h powerpc.git/arch/powerpc/platforms/83xx/mpc83xx.h +--- linux-2.6.24/arch/powerpc/platforms/83xx/mpc83xx.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/83xx/mpc83xx.h 2008-01-28 20:25:49.000000000 +0100 +@@ -14,6 +14,7 @@ + #define MPC83XX_SCCR_USB_DRCM_11 0x00300000 + #define MPC83XX_SCCR_USB_DRCM_01 0x00100000 + #define MPC83XX_SCCR_USB_DRCM_10 0x00200000 ++#define MPC837X_SCCR_USB_DRCM_11 0x00c00000 + + /* system i/o configuration register low */ + #define MPC83XX_SICRL_OFFS 0x114 +@@ -22,6 +23,8 @@ + #define MPC834X_SICRL_USB1 0x20000000 + #define MPC831X_SICRL_USB_MASK 0x00000c00 + #define MPC831X_SICRL_USB_ULPI 0x00000800 ++#define MPC837X_SICRL_USB_MASK 0xf0000000 ++#define MPC837X_SICRL_USB_ULPI 0x50000000 + + /* system i/o configuration register high */ + #define MPC83XX_SICRH_OFFS 0x118 +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/83xx/pci.c powerpc.git/arch/powerpc/platforms/83xx/pci.c +--- linux-2.6.24/arch/powerpc/platforms/83xx/pci.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/83xx/pci.c 2008-01-28 20:25:49.000000000 +0100 +@@ -54,7 +54,7 @@ + " bus 0\n", dev->full_name); + } + +- pci_assign_all_buses = 1; ++ ppc_pci_flags |= PPC_PCI_REASSIGN_ALL_BUS; + hose = pcibios_alloc_controller(dev); + if (!hose) + return -ENOMEM; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/83xx/usb.c powerpc.git/arch/powerpc/platforms/83xx/usb.c +--- linux-2.6.24/arch/powerpc/platforms/83xx/usb.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/83xx/usb.c 2008-01-28 20:25:49.000000000 +0100 +@@ -41,7 +41,7 @@ + sicrl = in_be32(immap + MPC83XX_SICRL_OFFS) & ~MPC834X_SICRL_USB_MASK; + sicrh = in_be32(immap + MPC83XX_SICRH_OFFS) & ~MPC834X_SICRH_USB_UTMI; + +- np = of_find_compatible_node(NULL, "usb", "fsl-usb2-dr"); ++ np = of_find_compatible_node(NULL, NULL, "fsl-usb2-dr"); + if (np) { + sccr |= MPC83XX_SCCR_USB_DRCM_11; /* 1:3 */ + +@@ -67,7 +67,7 @@ + port0_is_dr = 1; + of_node_put(np); + } +- np = of_find_compatible_node(NULL, "usb", "fsl-usb2-mph"); ++ np = of_find_compatible_node(NULL, NULL, "fsl-usb2-mph"); + if (np) { + sccr |= MPC83XX_SCCR_USB_MPHCM_11; /* 1:3 */ + +@@ -111,7 +111,7 @@ + const void *dr_mode; + #endif + +- np = of_find_compatible_node(NULL, "usb", "fsl-usb2-dr"); ++ np = of_find_compatible_node(NULL, NULL, "fsl-usb2-dr"); + if (!np) + return -ENODEV; + prop = of_get_property(np, "phy_type", NULL); +@@ -179,3 +179,43 @@ + return ret; + } + #endif /* CONFIG_PPC_MPC831x */ ++ ++#ifdef CONFIG_PPC_MPC837x ++int mpc837x_usb_cfg(void) ++{ ++ void __iomem *immap; ++ struct device_node *np = NULL; ++ const void *prop; ++ int ret = 0; ++ ++ np = of_find_compatible_node(NULL, NULL, "fsl-usb2-dr"); ++ if (!np) ++ return -ENODEV; ++ prop = of_get_property(np, "phy_type", NULL); ++ ++ if (!prop || (strcmp(prop, "ulpi") && strcmp(prop, "serial"))) { ++ printk(KERN_WARNING "837x USB PHY type not supported\n"); ++ of_node_put(np); ++ return -EINVAL; ++ } ++ ++ /* Map IMMR space for pin and clock settings */ ++ immap = ioremap(get_immrbase(), 0x1000); ++ if (!immap) { ++ of_node_put(np); ++ return -ENOMEM; ++ } ++ ++ /* Configure clock */ ++ clrsetbits_be32(immap + MPC83XX_SCCR_OFFS, MPC837X_SCCR_USB_DRCM_11, ++ MPC837X_SCCR_USB_DRCM_11); ++ ++ /* Configure pin mux for ULPI/serial */ ++ clrsetbits_be32(immap + MPC83XX_SICRL_OFFS, MPC837X_SICRL_USB_MASK, ++ MPC837X_SICRL_USB_ULPI); ++ ++ iounmap(immap); ++ of_node_put(np); ++ return ret; ++} ++#endif /* CONFIG_PPC_MPC837x */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/85xx/mpc85xx_ads.c powerpc.git/arch/powerpc/platforms/85xx/mpc85xx_ads.c +--- linux-2.6.24/arch/powerpc/platforms/85xx/mpc85xx_ads.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/85xx/mpc85xx_ads.c 2008-01-28 20:25:49.000000000 +0100 +@@ -52,9 +52,9 @@ + { + int cascade_irq; + +- while ((cascade_irq = cpm2_get_irq()) >= 0) { ++ while ((cascade_irq = cpm2_get_irq()) >= 0) + generic_handle_irq(cascade_irq); +- } ++ + desc->chip->eoi(irq); + } + +@@ -70,13 +70,12 @@ + #endif + + np = of_find_node_by_type(np, "open-pic"); +- +- if (np == NULL) { ++ if (!np) { + printk(KERN_ERR "Could not find open-pic node\n"); + return; + } + +- if(of_address_to_resource(np, 0, &r)) { ++ if (of_address_to_resource(np, 0, &r)) { + printk(KERN_ERR "Could not map mpic register space\n"); + of_node_put(np); + return; +@@ -100,6 +99,7 @@ + irq = irq_of_parse_and_map(np, 0); + + cpm2_pic_init(np); ++ of_node_put(np); + set_irq_chained_handler(irq, cpm2_cascade); + #endif + } +@@ -112,7 +112,7 @@ + int port, pin, flags; + }; + +-static struct cpm_pin mpc8560_ads_pins[] = { ++static const struct cpm_pin mpc8560_ads_pins[] = { + /* SCC1 */ + {3, 29, CPM_PIN_OUTPUT | CPM_PIN_PRIMARY}, + {3, 30, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY}, +@@ -233,13 +233,11 @@ + + static int __init declare_of_platform_devices(void) + { +- if (!machine_is(mpc85xx_ads)) +- return 0; +- + of_platform_bus_probe(NULL, of_bus_ids, NULL); ++ + return 0; + } +-device_initcall(declare_of_platform_devices); ++machine_device_initcall(mpc85xx_ads, declare_of_platform_devices); + + /* + * Called very early, device-tree isn't unflattened +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/85xx/mpc85xx_cds.c powerpc.git/arch/powerpc/platforms/85xx/mpc85xx_cds.c +--- linux-2.6.24/arch/powerpc/platforms/85xx/mpc85xx_cds.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/85xx/mpc85xx_cds.c 2008-01-28 20:25:49.000000000 +0100 +@@ -222,9 +222,6 @@ + struct device_node *cascade_node = NULL; + int cascade_irq; + +- if (!machine_is(mpc85xx_cds)) +- return 0; +- + /* Initialize the i8259 controller */ + for_each_node_by_type(np, "interrupt-controller") + if (of_device_is_compatible(np, "chrp,iic")) { +@@ -262,8 +259,7 @@ + + return 0; + } +- +-device_initcall(mpc85xx_cds_8259_attach); ++machine_device_initcall(mpc85xx_cds, mpc85xx_cds_8259_attach); + + #endif /* CONFIG_PPC_I8259 */ + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/85xx/mpc85xx_ds.c powerpc.git/arch/powerpc/platforms/85xx/mpc85xx_ds.c +--- linux-2.6.24/arch/powerpc/platforms/85xx/mpc85xx_ds.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/85xx/mpc85xx_ds.c 2008-01-28 20:25:49.000000000 +0100 +@@ -123,7 +123,7 @@ + struct device_node* node; + struct resource rsrc; + +- node = (struct device_node *)hose->arch_data; ++ node = hose->dn; + of_address_to_resource(node, 0, &rsrc); + + if ((rsrc.start & 0xfffff) == primary_phb_addr) { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/85xx/mpc85xx_mds.c powerpc.git/arch/powerpc/platforms/85xx/mpc85xx_mds.c +--- linux-2.6.24/arch/powerpc/platforms/85xx/mpc85xx_mds.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/85xx/mpc85xx_mds.c 2008-01-28 20:25:49.000000000 +0100 +@@ -30,9 +30,9 @@ + #include <linux/initrd.h> + #include <linux/module.h> + #include <linux/fsl_devices.h> ++#include <linux/of_platform.h> ++#include <linux/of_device.h> + +-#include <asm/of_device.h> +-#include <asm/of_platform.h> + #include <asm/system.h> + #include <asm/atomic.h> + #include <asm/time.h> +@@ -144,15 +144,12 @@ + + static int __init mpc85xx_publish_devices(void) + { +- if (!machine_is(mpc85xx_mds)) +- return 0; +- + /* Publish the QE devices */ +- of_platform_bus_probe(NULL,mpc85xx_ids,NULL); ++ of_platform_bus_probe(NULL, mpc85xx_ids, NULL); + + return 0; + } +-device_initcall(mpc85xx_publish_devices); ++machine_device_initcall(mpc85xx_mds, mpc85xx_publish_devices); + + static void __init mpc85xx_mds_pic_init(void) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/86xx/mpc8610_hpcd.c powerpc.git/arch/powerpc/platforms/86xx/mpc8610_hpcd.c +--- linux-2.6.24/arch/powerpc/platforms/86xx/mpc8610_hpcd.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/86xx/mpc8610_hpcd.c 2008-01-28 20:25:49.000000000 +0100 +@@ -34,9 +34,24 @@ + + #include <asm/mpic.h> + ++#include <linux/of_platform.h> + #include <sysdev/fsl_pci.h> + #include <sysdev/fsl_soc.h> + ++static struct of_device_id __initdata mpc8610_ids[] = { ++ { .compatible = "fsl,mpc8610-immr", }, ++ {} ++}; ++ ++static int __init mpc8610_declare_of_platform_devices(void) ++{ ++ /* Without this call, the SSI device driver won't get probed. */ ++ of_platform_bus_probe(NULL, mpc8610_ids, NULL); ++ ++ return 0; ++} ++machine_device_initcall(mpc86xx_hpcd, mpc8610_declare_of_platform_devices); ++ + void __init + mpc86xx_hpcd_init_irq(void) + { +@@ -124,7 +139,7 @@ + static void __devinit final_uli5288(struct pci_dev *dev) + { + struct pci_controller *hose = pci_bus_to_host(dev->bus); +- struct device_node *hosenode = hose ? hose->arch_data : NULL; ++ struct device_node *hosenode = hose ? hose->dn : NULL; + struct of_irq oirq; + int virq, pin = 2; + u32 laddr[3]; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/86xx/mpc86xx_hpcn.c powerpc.git/arch/powerpc/platforms/86xx/mpc86xx_hpcn.c +--- linux-2.6.24/arch/powerpc/platforms/86xx/mpc86xx_hpcn.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/86xx/mpc86xx_hpcn.c 2008-01-28 20:25:49.000000000 +0100 +@@ -18,6 +18,7 @@ + #include <linux/kdev_t.h> + #include <linux/delay.h> + #include <linux/seq_file.h> ++#include <linux/of_platform.h> + + #include <asm/system.h> + #include <asm/time.h> +@@ -116,7 +117,7 @@ + struct device_node* node; + struct resource rsrc; + +- node = (struct device_node *)hose->arch_data; ++ node = hose->dn; + of_address_to_resource(node, 0, &rsrc); + + if ((rsrc.start & 0xfffff) == 0x8000) { +@@ -212,6 +213,19 @@ + return 0; + } + ++static __initdata struct of_device_id of_bus_ids[] = { ++ { .compatible = "simple-bus", }, ++ {}, ++}; ++ ++static int __init declare_of_platform_devices(void) ++{ ++ of_platform_bus_probe(NULL, of_bus_ids, NULL); ++ ++ return 0; ++} ++machine_device_initcall(mpc86xx_hpcn, declare_of_platform_devices); ++ + define_machine(mpc86xx_hpcn) { + .name = "MPC86xx HPCN", + .probe = mpc86xx_hpcn_probe, +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/8xx/Kconfig powerpc.git/arch/powerpc/platforms/8xx/Kconfig +--- linux-2.6.24/arch/powerpc/platforms/8xx/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/8xx/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -18,6 +18,7 @@ + config MPC86XADS + bool "MPC86XADS" + select CPM1 ++ select PPC_CPM_NEW_BINDING + help + MPC86x Application Development System by Freescale Semiconductor. + The MPC86xADS is meant to serve as a platform for s/w and h/w +@@ -43,6 +44,15 @@ + This board is also resold by Freescale as the QUICCStart + MPC885 Evaluation System and/or the CWH-PPC-885XN-VE. + ++config PPC_ADDER875 ++ bool "Analogue & Micro Adder 875" ++ select CPM1 ++ select PPC_CPM_NEW_BINDING ++ select REDBOOT ++ help ++ This enables support for the Analogue & Micro Adder 875 ++ board. ++ + endchoice + + menu "Freescale Ethernet driver platform-specific options" +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/8xx/Makefile powerpc.git/arch/powerpc/platforms/8xx/Makefile +--- linux-2.6.24/arch/powerpc/platforms/8xx/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/8xx/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -5,3 +5,4 @@ + obj-$(CONFIG_MPC885ADS) += mpc885ads_setup.o + obj-$(CONFIG_MPC86XADS) += mpc86xads_setup.o + obj-$(CONFIG_PPC_EP88XC) += ep88xc.o ++obj-$(CONFIG_PPC_ADDER875) += adder875.o +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/8xx/adder875.c powerpc.git/arch/powerpc/platforms/8xx/adder875.c +--- linux-2.6.24/arch/powerpc/platforms/8xx/adder875.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/8xx/adder875.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,118 @@ ++/* Analogue & Micro Adder MPC875 board support ++ * ++ * Author: Scott Wood <scottwood@freescale.com> ++ * ++ * Copyright (c) 2007 Freescale Semiconductor, Inc. ++ * ++ * This program is free software; you can redistribute it and/or modify ++ * it under the terms of the GNU General Public License, version 2, as ++ * published by the Free Software Foundation. ++ */ ++ ++#include <linux/init.h> ++#include <linux/fs_enet_pd.h> ++#include <linux/of_platform.h> ++ ++#include <asm/time.h> ++#include <asm/machdep.h> ++#include <asm/commproc.h> ++#include <asm/fs_pd.h> ++#include <asm/udbg.h> ++#include <asm/prom.h> ++ ++#include <sysdev/commproc.h> ++ ++struct cpm_pin { ++ int port, pin, flags; ++}; ++ ++static __initdata struct cpm_pin adder875_pins[] = { ++ /* SMC1 */ ++ {CPM_PORTB, 24, CPM_PIN_INPUT}, /* RX */ ++ {CPM_PORTB, 25, CPM_PIN_INPUT | CPM_PIN_SECONDARY}, /* TX */ ++ ++ /* MII1 */ ++ {CPM_PORTA, 0, CPM_PIN_INPUT}, ++ {CPM_PORTA, 1, CPM_PIN_INPUT}, ++ {CPM_PORTA, 2, CPM_PIN_INPUT}, ++ {CPM_PORTA, 3, CPM_PIN_INPUT}, ++ {CPM_PORTA, 4, CPM_PIN_OUTPUT}, ++ {CPM_PORTA, 10, CPM_PIN_OUTPUT}, ++ {CPM_PORTA, 11, CPM_PIN_OUTPUT}, ++ {CPM_PORTB, 19, CPM_PIN_INPUT}, ++ {CPM_PORTB, 31, CPM_PIN_INPUT}, ++ {CPM_PORTC, 12, CPM_PIN_INPUT}, ++ {CPM_PORTC, 13, CPM_PIN_INPUT}, ++ {CPM_PORTE, 30, CPM_PIN_OUTPUT}, ++ {CPM_PORTE, 31, CPM_PIN_OUTPUT}, ++ ++ /* MII2 */ ++ {CPM_PORTE, 14, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY}, ++ {CPM_PORTE, 15, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY}, ++ {CPM_PORTE, 16, CPM_PIN_OUTPUT}, ++ {CPM_PORTE, 17, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY}, ++ {CPM_PORTE, 18, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY}, ++ {CPM_PORTE, 19, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY}, ++ {CPM_PORTE, 20, CPM_PIN_OUTPUT | CPM_PIN_SECONDARY}, ++ {CPM_PORTE, 21, CPM_PIN_OUTPUT}, ++ {CPM_PORTE, 22, CPM_PIN_OUTPUT}, ++ {CPM_PORTE, 23, CPM_PIN_OUTPUT}, ++ {CPM_PORTE, 24, CPM_PIN_OUTPUT}, ++ {CPM_PORTE, 25, CPM_PIN_OUTPUT}, ++ {CPM_PORTE, 26, CPM_PIN_OUTPUT}, ++ {CPM_PORTE, 27, CPM_PIN_OUTPUT}, ++ {CPM_PORTE, 28, CPM_PIN_OUTPUT}, ++ {CPM_PORTE, 29, CPM_PIN_OUTPUT}, ++}; ++ ++static void __init init_ioports(void) ++{ ++ int i; ++ ++ for (i = 0; i < ARRAY_SIZE(adder875_pins); i++) { ++ const struct cpm_pin *pin = &adder875_pins[i]; ++ cpm1_set_pin(pin->port, pin->pin, pin->flags); ++ } ++ ++ cpm1_clk_setup(CPM_CLK_SMC1, CPM_BRG1, CPM_CLK_RTX); ++ ++ /* Set FEC1 and FEC2 to MII mode */ ++ clrbits32(&mpc8xx_immr->im_cpm.cp_cptr, 0x00000180); ++} ++ ++static void __init adder875_setup(void) ++{ ++ cpm_reset(); ++ init_ioports(); ++} ++ ++static int __init adder875_probe(void) ++{ ++ unsigned long root = of_get_flat_dt_root(); ++ return of_flat_dt_is_compatible(root, "analogue-and-micro,adder875"); ++} ++ ++static __initdata struct of_device_id of_bus_ids[] = { ++ { .compatible = "simple-bus", }, ++ {}, ++}; ++ ++static int __init declare_of_platform_devices(void) ++{ ++ of_platform_bus_probe(NULL, of_bus_ids, NULL); ++ return 0; ++} ++machine_device_initcall(adder875, declare_of_platform_devices); ++ ++define_machine(adder875) { ++ .name = "Adder MPC875", ++ .probe = adder875_probe, ++ .setup_arch = adder875_setup, ++ .init_IRQ = m8xx_pic_init, ++ .get_irq = mpc8xx_get_irq, ++ .restart = mpc8xx_restart, ++ .calibrate_decr = generic_calibrate_decr, ++ .set_rtc_time = mpc8xx_set_rtc_time, ++ .get_rtc_time = mpc8xx_get_rtc_time, ++ .progress = udbg_progress, ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/8xx/ep88xc.c powerpc.git/arch/powerpc/platforms/8xx/ep88xc.c +--- linux-2.6.24/arch/powerpc/platforms/8xx/ep88xc.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/8xx/ep88xc.c 2008-01-28 20:25:49.000000000 +0100 +@@ -155,12 +155,11 @@ + static int __init declare_of_platform_devices(void) + { + /* Publish the QE devices */ +- if (machine_is(ep88xc)) +- of_platform_bus_probe(NULL, of_bus_ids, NULL); ++ of_platform_bus_probe(NULL, of_bus_ids, NULL); + + return 0; + } +-device_initcall(declare_of_platform_devices); ++machine_device_initcall(ep88xc, declare_of_platform_devices); + + define_machine(ep88xc) { + .name = "Embedded Planet EP88xC", +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/8xx/m8xx_setup.c powerpc.git/arch/powerpc/platforms/8xx/m8xx_setup.c +--- linux-2.6.24/arch/powerpc/platforms/8xx/m8xx_setup.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/8xx/m8xx_setup.c 2008-01-28 20:25:49.000000000 +0100 +@@ -120,7 +120,7 @@ + ppc_tb_freq /= 16; + ppc_proc_freq = 50000000; + if (!get_freq("clock-frequency", &ppc_proc_freq)) +- printk(KERN_ERR "WARNING: Estimating processor frequency" ++ printk(KERN_ERR "WARNING: Estimating processor frequency " + "(not found)\n"); + + printk("Decrementer Frequency = 0x%lx\n", ppc_tb_freq); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/8xx/mpc86xads.h powerpc.git/arch/powerpc/platforms/8xx/mpc86xads.h +--- linux-2.6.24/arch/powerpc/platforms/8xx/mpc86xads.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/8xx/mpc86xads.h 2008-01-28 20:25:49.000000000 +0100 +@@ -15,27 +15,6 @@ + #ifndef __ASM_MPC86XADS_H__ + #define __ASM_MPC86XADS_H__ + +-#include <sysdev/fsl_soc.h> +- +-/* U-Boot maps BCSR to 0xff080000 */ +-#define BCSR_ADDR ((uint)0xff080000) +-#define BCSR_SIZE ((uint)32) +-#define BCSR0 ((uint)(BCSR_ADDR + 0x00)) +-#define BCSR1 ((uint)(BCSR_ADDR + 0x04)) +-#define BCSR2 ((uint)(BCSR_ADDR + 0x08)) +-#define BCSR3 ((uint)(BCSR_ADDR + 0x0c)) +-#define BCSR4 ((uint)(BCSR_ADDR + 0x10)) +- +-#define CFG_PHYDEV_ADDR ((uint)0xff0a0000) +-#define BCSR5 ((uint)(CFG_PHYDEV_ADDR + 0x300)) +- +-#define MPC8xx_CPM_OFFSET (0x9c0) +-#define CPM_MAP_ADDR (get_immrbase() + MPC8xx_CPM_OFFSET) +-#define CPM_IRQ_OFFSET 16 // for compability with cpm_uart driver +- +-#define PCMCIA_MEM_ADDR ((uint)0xff020000) +-#define PCMCIA_MEM_SIZE ((uint)(64 * 1024)) +- + /* Bits of interest in the BCSRs. + */ + #define BCSR1_ETHEN ((uint)0x20000000) +@@ -64,28 +43,5 @@ + #define BCSR5_MII1_EN 0x02 + #define BCSR5_MII1_RST 0x01 + +-/* Interrupt level assignments */ +-#define PHY_INTERRUPT SIU_IRQ7 /* PHY link change interrupt */ +-#define SIU_INT_FEC1 SIU_LEVEL1 /* FEC1 interrupt */ +-#define FEC_INTERRUPT SIU_INT_FEC1 /* FEC interrupt */ +- +-/* We don't use the 8259 */ +-#define NR_8259_INTS 0 +- +-/* CPM Ethernet through SCC1 */ +-#define PA_ENET_RXD ((ushort)0x0001) +-#define PA_ENET_TXD ((ushort)0x0002) +-#define PA_ENET_TCLK ((ushort)0x0100) +-#define PA_ENET_RCLK ((ushort)0x0200) +-#define PB_ENET_TENA ((uint)0x00001000) +-#define PC_ENET_CLSN ((ushort)0x0010) +-#define PC_ENET_RENA ((ushort)0x0020) +- +-/* Control bits in the SICR to route TCLK (CLK1) and RCLK (CLK2) to +- * SCC1. Also, make sure GR1 (bit 24) and SC1 (bit 25) are zero. +- */ +-#define SICR_ENET_MASK ((uint)0x000000ff) +-#define SICR_ENET_CLKRT ((uint)0x0000002c) +- + #endif /* __ASM_MPC86XADS_H__ */ + #endif /* __KERNEL__ */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/8xx/mpc86xads_setup.c powerpc.git/arch/powerpc/platforms/8xx/mpc86xads_setup.c +--- linux-2.6.24/arch/powerpc/platforms/8xx/mpc86xads_setup.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/8xx/mpc86xads_setup.c 2008-01-28 20:25:49.000000000 +0100 +@@ -6,264 +6,133 @@ + * + * Copyright 2005 MontaVista Software Inc. + * ++ * Heavily modified by Scott Wood <scottwood@freescale.com> ++ * Copyright 2007 Freescale Semiconductor, Inc. ++ * + * This file is licensed under the terms of the GNU General Public License + * version 2. This program is licensed "as is" without any warranty of any + * kind, whether express or implied. + */ + + #include <linux/init.h> +-#include <linux/module.h> +-#include <linux/param.h> +-#include <linux/string.h> +-#include <linux/ioport.h> +-#include <linux/device.h> +-#include <linux/delay.h> +-#include <linux/root_dev.h> +- +-#include <linux/fs_enet_pd.h> +-#include <linux/fs_uart_pd.h> +-#include <linux/mii.h> ++#include <linux/of_platform.h> + +-#include <asm/delay.h> + #include <asm/io.h> + #include <asm/machdep.h> +-#include <asm/page.h> +-#include <asm/processor.h> + #include <asm/system.h> + #include <asm/time.h> + #include <asm/mpc8xx.h> + #include <asm/8xx_immap.h> + #include <asm/commproc.h> + #include <asm/fs_pd.h> +-#include <asm/prom.h> ++#include <asm/udbg.h> + + #include <sysdev/commproc.h> + +-static void init_smc1_uart_ioports(struct fs_uart_platform_info* fpi); +-static void init_smc2_uart_ioports(struct fs_uart_platform_info* fpi); +-static void init_scc1_ioports(struct fs_platform_info* ptr); +- +-void __init mpc86xads_board_setup(void) +-{ +- cpm8xx_t *cp; +- unsigned int *bcsr_io; +- u8 tmpval8; +- +- bcsr_io = ioremap(BCSR1, sizeof(unsigned long)); +- cp = (cpm8xx_t *)immr_map(im_cpm); ++#include "mpc86xads.h" + +- if (bcsr_io == NULL) { +- printk(KERN_CRIT "Could not remap BCSR\n"); +- return; +- } +-#ifdef CONFIG_SERIAL_CPM_SMC1 +- clrbits32(bcsr_io, BCSR1_RS232EN_1); +- clrbits32(&cp->cp_simode, 0xe0000000 >> 17); /* brg1 */ +- tmpval8 = in_8(&(cp->cp_smc[0].smc_smcm)) | (SMCM_RX | SMCM_TX); +- out_8(&(cp->cp_smc[0].smc_smcm), tmpval8); +- clrbits16(&cp->cp_smc[0].smc_smcmr, SMCMR_REN | SMCMR_TEN); +-#else +- setbits32(bcsr_io,BCSR1_RS232EN_1); +- out_be16(&cp->cp_smc[0].smc_smcmr, 0); +- out_8(&cp->cp_smc[0].smc_smce, 0); +-#endif +- +-#ifdef CONFIG_SERIAL_CPM_SMC2 +- clrbits32(bcsr_io,BCSR1_RS232EN_2); +- clrbits32(&cp->cp_simode, 0xe0000000 >> 1); +- setbits32(&cp->cp_simode, 0x20000000 >> 1); /* brg2 */ +- tmpval8 = in_8(&(cp->cp_smc[1].smc_smcm)) | (SMCM_RX | SMCM_TX); +- out_8(&(cp->cp_smc[1].smc_smcm), tmpval8); +- clrbits16(&cp->cp_smc[1].smc_smcmr, SMCMR_REN | SMCMR_TEN); +- +- init_smc2_uart_ioports(0); +-#else +- setbits32(bcsr_io,BCSR1_RS232EN_2); +- out_be16(&cp->cp_smc[1].smc_smcmr, 0); +- out_8(&cp->cp_smc[1].smc_smce, 0); +-#endif +- immr_unmap(cp); +- iounmap(bcsr_io); +-} ++struct cpm_pin { ++ int port, pin, flags; ++}; + ++static struct cpm_pin mpc866ads_pins[] = { ++ /* SMC1 */ ++ {CPM_PORTB, 24, CPM_PIN_INPUT}, /* RX */ ++ {CPM_PORTB, 25, CPM_PIN_INPUT | CPM_PIN_SECONDARY}, /* TX */ ++ ++ /* SMC2 */ ++ {CPM_PORTB, 21, CPM_PIN_INPUT}, /* RX */ ++ {CPM_PORTB, 20, CPM_PIN_INPUT | CPM_PIN_SECONDARY}, /* TX */ ++ ++ /* SCC1 */ ++ {CPM_PORTA, 6, CPM_PIN_INPUT}, /* CLK1 */ ++ {CPM_PORTA, 7, CPM_PIN_INPUT}, /* CLK2 */ ++ {CPM_PORTA, 14, CPM_PIN_INPUT}, /* TX */ ++ {CPM_PORTA, 15, CPM_PIN_INPUT}, /* RX */ ++ {CPM_PORTB, 19, CPM_PIN_INPUT | CPM_PIN_SECONDARY}, /* TENA */ ++ {CPM_PORTC, 10, CPM_PIN_INPUT | CPM_PIN_SECONDARY | CPM_PIN_GPIO}, /* RENA */ ++ {CPM_PORTC, 11, CPM_PIN_INPUT | CPM_PIN_SECONDARY | CPM_PIN_GPIO}, /* CLSN */ ++ ++ /* MII */ ++ {CPM_PORTD, 3, CPM_PIN_OUTPUT}, ++ {CPM_PORTD, 4, CPM_PIN_OUTPUT}, ++ {CPM_PORTD, 5, CPM_PIN_OUTPUT}, ++ {CPM_PORTD, 6, CPM_PIN_OUTPUT}, ++ {CPM_PORTD, 7, CPM_PIN_OUTPUT}, ++ {CPM_PORTD, 8, CPM_PIN_OUTPUT}, ++ {CPM_PORTD, 9, CPM_PIN_OUTPUT}, ++ {CPM_PORTD, 10, CPM_PIN_OUTPUT}, ++ {CPM_PORTD, 11, CPM_PIN_OUTPUT}, ++ {CPM_PORTD, 12, CPM_PIN_OUTPUT}, ++ {CPM_PORTD, 13, CPM_PIN_OUTPUT}, ++ {CPM_PORTD, 14, CPM_PIN_OUTPUT}, ++ {CPM_PORTD, 15, CPM_PIN_OUTPUT}, ++}; + +-static void init_fec1_ioports(struct fs_platform_info* ptr) ++static void __init init_ioports(void) + { +- iop8xx_t *io_port = (iop8xx_t *)immr_map(im_ioport); ++ int i; + +- /* configure FEC1 pins */ ++ for (i = 0; i < ARRAY_SIZE(mpc866ads_pins); i++) { ++ struct cpm_pin *pin = &mpc866ads_pins[i]; ++ cpm1_set_pin(pin->port, pin->pin, pin->flags); ++ } + +- setbits16(&io_port->iop_pdpar, 0x1fff); +- setbits16(&io_port->iop_pddir, 0x1fff); ++ cpm1_clk_setup(CPM_CLK_SMC1, CPM_BRG1, CPM_CLK_RTX); ++ cpm1_clk_setup(CPM_CLK_SMC2, CPM_BRG2, CPM_CLK_RTX); ++ cpm1_clk_setup(CPM_CLK_SCC1, CPM_CLK1, CPM_CLK_TX); ++ cpm1_clk_setup(CPM_CLK_SCC1, CPM_CLK2, CPM_CLK_RX); + +- immr_unmap(io_port); ++ /* Set FEC1 and FEC2 to MII mode */ ++ clrbits32(&mpc8xx_immr->im_cpm.cp_cptr, 0x00000180); + } + +-void init_fec_ioports(struct fs_platform_info *fpi) ++static void __init mpc86xads_setup_arch(void) + { +- int fec_no = fs_get_fec_index(fpi->fs_no); ++ struct device_node *np; ++ u32 __iomem *bcsr_io; ++ ++ cpm_reset(); ++ init_ioports(); + +- switch (fec_no) { +- case 0: +- init_fec1_ioports(fpi); +- break; +- default: +- printk(KERN_ERR "init_fec_ioports: invalid FEC number\n"); ++ np = of_find_compatible_node(NULL, NULL, "fsl,mpc866ads-bcsr"); ++ if (!np) { ++ printk(KERN_CRIT "Could not find fsl,mpc866ads-bcsr node\n"); + return; + } +-} + +-static void init_scc1_ioports(struct fs_platform_info* fpi) +-{ +- unsigned *bcsr_io; +- iop8xx_t *io_port; +- cpm8xx_t *cp; +- +- bcsr_io = ioremap(BCSR_ADDR, BCSR_SIZE); +- io_port = (iop8xx_t *)immr_map(im_ioport); +- cp = (cpm8xx_t *)immr_map(im_cpm); ++ bcsr_io = of_iomap(np, 0); ++ of_node_put(np); + + if (bcsr_io == NULL) { + printk(KERN_CRIT "Could not remap BCSR\n"); + return; + } + +- /* Configure port A pins for Txd and Rxd. +- */ +- setbits16(&io_port->iop_papar, PA_ENET_RXD | PA_ENET_TXD); +- clrbits16(&io_port->iop_padir, PA_ENET_RXD | PA_ENET_TXD); +- clrbits16(&io_port->iop_paodr, PA_ENET_TXD); +- +- /* Configure port C pins to enable CLSN and RENA. +- */ +- clrbits16(&io_port->iop_pcpar, PC_ENET_CLSN | PC_ENET_RENA); +- clrbits16(&io_port->iop_pcdir, PC_ENET_CLSN | PC_ENET_RENA); +- setbits16(&io_port->iop_pcso, PC_ENET_CLSN | PC_ENET_RENA); +- +- /* Configure port A for TCLK and RCLK. +- */ +- setbits16(&io_port->iop_papar, PA_ENET_TCLK | PA_ENET_RCLK); +- clrbits16(&io_port->iop_padir, PA_ENET_TCLK | PA_ENET_RCLK); +- clrbits32(&cp->cp_pbpar, PB_ENET_TENA); +- clrbits32(&cp->cp_pbdir, PB_ENET_TENA); +- +- /* Configure Serial Interface clock routing. +- * First, clear all SCC bits to zero, then set the ones we want. +- */ +- clrbits32(&cp->cp_sicr, SICR_ENET_MASK); +- setbits32(&cp->cp_sicr, SICR_ENET_CLKRT); +- +- /* In the original SCC enet driver the following code is placed at +- the end of the initialization */ +- setbits32(&cp->cp_pbpar, PB_ENET_TENA); +- setbits32(&cp->cp_pbdir, PB_ENET_TENA); +- +- clrbits32(bcsr_io+1, BCSR1_ETHEN); ++ clrbits32(bcsr_io, BCSR1_RS232EN_1 | BCSR1_RS232EN_2 | BCSR1_ETHEN); + iounmap(bcsr_io); +- immr_unmap(cp); +- immr_unmap(io_port); +-} +- +-void init_scc_ioports(struct fs_platform_info *fpi) +-{ +- int scc_no = fs_get_scc_index(fpi->fs_no); +- +- switch (scc_no) { +- case 0: +- init_scc1_ioports(fpi); +- break; +- default: +- printk(KERN_ERR "init_scc_ioports: invalid SCC number\n"); +- return; +- } + } + +- +- +-static void init_smc1_uart_ioports(struct fs_uart_platform_info* ptr) ++static int __init mpc86xads_probe(void) + { +- unsigned *bcsr_io; +- cpm8xx_t *cp = (cpm8xx_t *)immr_map(im_cpm); +- +- setbits32(&cp->cp_pbpar, 0x000000c0); +- clrbits32(&cp->cp_pbdir, 0x000000c0); +- clrbits16(&cp->cp_pbodr, 0x00c0); +- immr_unmap(cp); +- +- bcsr_io = ioremap(BCSR1, sizeof(unsigned long)); +- +- if (bcsr_io == NULL) { +- printk(KERN_CRIT "Could not remap BCSR1\n"); +- return; +- } +- clrbits32(bcsr_io,BCSR1_RS232EN_1); +- iounmap(bcsr_io); ++ unsigned long root = of_get_flat_dt_root(); ++ return of_flat_dt_is_compatible(root, "fsl,mpc866ads"); + } + +-static void init_smc2_uart_ioports(struct fs_uart_platform_info* fpi) +-{ +- unsigned *bcsr_io; +- cpm8xx_t *cp = (cpm8xx_t *)immr_map(im_cpm); +- +- setbits32(&cp->cp_pbpar, 0x00000c00); +- clrbits32(&cp->cp_pbdir, 0x00000c00); +- clrbits16(&cp->cp_pbodr, 0x0c00); +- immr_unmap(cp); +- +- bcsr_io = ioremap(BCSR1, sizeof(unsigned long)); +- +- if (bcsr_io == NULL) { +- printk(KERN_CRIT "Could not remap BCSR1\n"); +- return; +- } +- clrbits32(bcsr_io,BCSR1_RS232EN_2); +- iounmap(bcsr_io); +-} ++static struct of_device_id __initdata of_bus_ids[] = { ++ { .name = "soc", }, ++ { .name = "cpm", }, ++ { .name = "localbus", }, ++ {}, ++}; + +-void init_smc_ioports(struct fs_uart_platform_info *data) ++static int __init declare_of_platform_devices(void) + { +- int smc_no = fs_uart_id_fsid2smc(data->fs_no); +- +- switch (smc_no) { +- case 0: +- init_smc1_uart_ioports(data); +- data->brg = data->clk_rx; +- break; +- case 1: +- init_smc2_uart_ioports(data); +- data->brg = data->clk_rx; +- break; +- default: +- printk(KERN_ERR "init_scc_ioports: invalid SCC number\n"); +- return; +- } +-} ++ of_platform_bus_probe(NULL, of_bus_ids, NULL); + +-int platform_device_skip(const char *model, int id) +-{ + return 0; + } +- +-static void __init mpc86xads_setup_arch(void) +-{ +- cpm_reset(); +- +- mpc86xads_board_setup(); +- +- ROOT_DEV = Root_NFS; +-} +- +-static int __init mpc86xads_probe(void) +-{ +- char *model = of_get_flat_dt_prop(of_get_flat_dt_root(), +- "model", NULL); +- if (model == NULL) +- return 0; +- if (strcmp(model, "MPC866ADS")) +- return 0; +- +- return 1; +-} ++machine_device_initcall(mpc86x_ads, declare_of_platform_devices); + + define_machine(mpc86x_ads) { + .name = "MPC86x ADS", +@@ -275,4 +144,5 @@ + .calibrate_decr = mpc8xx_calibrate_decr, + .set_rtc_time = mpc8xx_set_rtc_time, + .get_rtc_time = mpc8xx_get_rtc_time, ++ .progress = udbg_progress, + }; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/8xx/mpc885ads_setup.c powerpc.git/arch/powerpc/platforms/8xx/mpc885ads_setup.c +--- linux-2.6.24/arch/powerpc/platforms/8xx/mpc885ads_setup.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/8xx/mpc885ads_setup.c 2008-01-28 20:25:49.000000000 +0100 +@@ -264,12 +264,11 @@ + static int __init declare_of_platform_devices(void) + { + /* Publish the QE devices */ +- if (machine_is(mpc885_ads)) +- of_platform_bus_probe(NULL, of_bus_ids, NULL); ++ of_platform_bus_probe(NULL, of_bus_ids, NULL); + + return 0; + } +-device_initcall(declare_of_platform_devices); ++machine_device_initcall(mpc885_ads, declare_of_platform_devices); + + define_machine(mpc885_ads) { + .name = "Freescale MPC885 ADS", +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/Kconfig powerpc.git/arch/powerpc/platforms/Kconfig +--- linux-2.6.24/arch/powerpc/platforms/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -22,6 +22,7 @@ + depends on 6xx + select FSL_SOC + select 83xx ++ select IPIC + select WANT_DEVICE_TREE + + config PPC_86xx +@@ -80,6 +81,10 @@ + bool + default y + ++config IPIC ++ bool ++ default n ++ + config MPIC + bool + default n +@@ -265,6 +270,7 @@ + config QUICC_ENGINE + bool + select PPC_LIB_RHEAP ++ select CRC32 + help + The QUICC Engine (QE) is a new generation of communications + coprocessors on Freescale embedded CPUs (akin to CPM in older chips). +@@ -315,6 +321,12 @@ + config CPM + bool + ++config OF_RTC ++ bool ++ help ++ Uses information from the OF or flattened device tree to instatiate ++ platform devices for direct mapped RTC chips like the DS1742 or DS1743. ++ + source "arch/powerpc/sysdev/bestcomm/Kconfig" + + endmenu +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/Kconfig.cputype powerpc.git/arch/powerpc/platforms/Kconfig.cputype +--- linux-2.6.24/arch/powerpc/platforms/Kconfig.cputype 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/Kconfig.cputype 2008-01-28 20:25:49.000000000 +0100 +@@ -43,6 +43,7 @@ + bool "AMCC 40x" + select PPC_DCR_NATIVE + select WANT_DEVICE_TREE ++ select PPC_UDBG_16550 + + config 44x + bool "AMCC 44x" +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/Makefile powerpc.git/arch/powerpc/platforms/cell/Makefile +--- linux-2.6.24/arch/powerpc/platforms/cell/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -20,7 +20,7 @@ + + obj-$(CONFIG_SPU_BASE) += spu_callbacks.o spu_base.o \ + spu_notify.o \ +- spu_syscalls.o \ ++ spu_syscalls.o spu_fault.o \ + $(spu-priv1-y) \ + $(spu-manage-y) \ + spufs/ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/cbe_cpufreq.c powerpc.git/arch/powerpc/platforms/cell/cbe_cpufreq.c +--- linux-2.6.24/arch/powerpc/platforms/cell/cbe_cpufreq.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/cbe_cpufreq.c 2008-01-28 20:25:49.000000000 +0100 +@@ -21,8 +21,9 @@ + */ + + #include <linux/cpufreq.h> ++#include <linux/of_platform.h> ++ + #include <asm/machdep.h> +-#include <asm/of_platform.h> + #include <asm/prom.h> + #include <asm/cell-regs.h> + #include "cbe_cpufreq.h" +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/cbe_cpufreq_pmi.c powerpc.git/arch/powerpc/platforms/cell/cbe_cpufreq_pmi.c +--- linux-2.6.24/arch/powerpc/platforms/cell/cbe_cpufreq_pmi.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/cbe_cpufreq_pmi.c 2008-01-28 20:25:49.000000000 +0100 +@@ -23,7 +23,8 @@ + #include <linux/kernel.h> + #include <linux/types.h> + #include <linux/timer.h> +-#include <asm/of_platform.h> ++#include <linux/of_platform.h> ++ + #include <asm/processor.h> + #include <asm/prom.h> + #include <asm/pmi.h> +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/cbe_regs.c powerpc.git/arch/powerpc/platforms/cell/cbe_regs.c +--- linux-2.6.24/arch/powerpc/platforms/cell/cbe_regs.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/cbe_regs.c 2008-01-28 20:25:49.000000000 +0100 +@@ -9,13 +9,13 @@ + #include <linux/percpu.h> + #include <linux/types.h> + #include <linux/module.h> ++#include <linux/of_device.h> ++#include <linux/of_platform.h> + + #include <asm/io.h> + #include <asm/pgtable.h> + #include <asm/prom.h> + #include <asm/ptrace.h> +-#include <asm/of_device.h> +-#include <asm/of_platform.h> + #include <asm/cell-regs.h> + + /* +@@ -256,6 +256,7 @@ + printk(KERN_ERR "cbe_regs: More BE chips than supported" + "!\n"); + cbe_regs_map_count--; ++ of_node_put(cpu); + return; + } + map->cpu_node = cpu; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/io-workarounds.c powerpc.git/arch/powerpc/platforms/cell/io-workarounds.c +--- linux-2.6.24/arch/powerpc/platforms/cell/io-workarounds.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/io-workarounds.c 2008-01-28 20:25:49.000000000 +0100 +@@ -238,7 +238,7 @@ + static void __init spider_pci_add_one(struct pci_controller *phb) + { + struct spider_pci_bus *bus = &spider_pci_busses[spider_pci_count]; +- struct device_node *np = phb->arch_data; ++ struct device_node *np = phb->dn; + struct resource rsrc; + void __iomem *regs; + +@@ -309,15 +309,12 @@ + { + struct pci_controller *phb; + +- if (!machine_is(cell)) +- return 0; +- + /* Find spider bridges. We assume they have been all probed + * in setup_arch(). If that was to change, we would need to + * update this code to cope with dynamically added busses + */ + list_for_each_entry(phb, &hose_list, list_node) { +- struct device_node *np = phb->arch_data; ++ struct device_node *np = phb->dn; + const char *model = of_get_property(np, "model", NULL); + + /* If no model property or name isn't exactly "pci", skip */ +@@ -343,4 +340,4 @@ + + return 0; + } +-arch_initcall(spider_pci_workaround_init); ++machine_arch_initcall(cell, spider_pci_workaround_init); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/iommu.c powerpc.git/arch/powerpc/platforms/cell/iommu.c +--- linux-2.6.24/arch/powerpc/platforms/cell/iommu.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/iommu.c 2008-01-28 20:25:49.000000000 +0100 +@@ -26,14 +26,15 @@ + #include <linux/init.h> + #include <linux/interrupt.h> + #include <linux/notifier.h> ++#include <linux/of_platform.h> + + #include <asm/prom.h> + #include <asm/iommu.h> + #include <asm/machdep.h> + #include <asm/pci-bridge.h> + #include <asm/udbg.h> +-#include <asm/of_platform.h> + #include <asm/lmb.h> ++#include <asm/firmware.h> + #include <asm/cell-regs.h> + + #include "interrupt.h" +@@ -309,8 +310,8 @@ + { + struct page *page; + int ret, i; +- unsigned long reg, segments, pages_per_segment, ptab_size, n_pte_pages; +- unsigned long xlate_base; ++ unsigned long reg, segments, pages_per_segment, ptab_size, stab_size, ++ n_pte_pages, xlate_base; + unsigned int virq; + + if (cell_iommu_find_ioc(iommu->nid, &xlate_base)) +@@ -327,7 +328,8 @@ + __FUNCTION__, iommu->nid, segments, pages_per_segment); + + /* set up the segment table */ +- page = alloc_pages_node(iommu->nid, GFP_KERNEL, 0); ++ stab_size = segments * sizeof(unsigned long); ++ page = alloc_pages_node(iommu->nid, GFP_KERNEL, get_order(stab_size)); + BUG_ON(!page); + iommu->stab = page_address(page); + clear_page(iommu->stab); +@@ -489,15 +491,18 @@ + return NULL; + } + ++static unsigned long cell_dma_direct_offset; ++ + static void cell_dma_dev_setup(struct device *dev) + { + struct iommu_window *window; + struct cbe_iommu *iommu; + struct dev_archdata *archdata = &dev->archdata; + +- /* If we run without iommu, no need to do anything */ +- if (get_pci_dma_ops() == &dma_direct_ops) ++ if (get_pci_dma_ops() == &dma_direct_ops) { ++ archdata->dma_data = (void *)cell_dma_direct_offset; + return; ++ } + + /* Current implementation uses the first window available in that + * node's iommu. We -might- do something smarter later though it may +@@ -653,7 +658,7 @@ + + /* If we have no Axon, we set up the spider DMA magic offset */ + if (of_find_node_by_name(NULL, "axon") == NULL) +- dma_direct_offset = SPIDER_DMA_OFFSET; ++ cell_dma_direct_offset = SPIDER_DMA_OFFSET; + + /* Now we need to check to see where the memory is mapped + * in PCI space. We assume that all busses use the same dma +@@ -687,10 +692,13 @@ + return -ENODEV; + } + +- dma_direct_offset += base; ++ cell_dma_direct_offset += base; ++ ++ if (cell_dma_direct_offset != 0) ++ ppc_md.pci_dma_dev_setup = cell_pci_dma_dev_setup; + + printk("iommu: disabled, direct DMA offset is 0x%lx\n", +- dma_direct_offset); ++ cell_dma_direct_offset); + + return 0; + } +@@ -699,9 +707,6 @@ + { + struct device_node *np; + +- if (!machine_is(cell)) +- return -ENODEV; +- + /* If IOMMU is disabled or we have little enough RAM to not need + * to enable it, we setup a direct mapping. + * +@@ -744,5 +749,6 @@ + + return 0; + } +-arch_initcall(cell_iommu_init); ++machine_arch_initcall(cell, cell_iommu_init); ++machine_arch_initcall(celleb_native, cell_iommu_init); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/pmu.c powerpc.git/arch/powerpc/platforms/cell/pmu.c +--- linux-2.6.24/arch/powerpc/platforms/cell/pmu.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/pmu.c 2008-01-28 20:25:49.000000000 +0100 +@@ -213,7 +213,7 @@ + break; + + case pm_interval: +- READ_SHADOW_REG(val, pm_interval); ++ READ_MMIO_UPPER32(val, pm_interval); + break; + + case pm_start_stop: +@@ -381,9 +381,6 @@ + unsigned int irq; + int rc, node; + +- if (!machine_is(cell)) +- return 0; +- + for_each_node(node) { + irq = irq_create_mapping(NULL, IIC_IRQ_IOEX_PMI | + (node << IIC_IRQ_NODE_SHIFT)); +@@ -404,7 +401,7 @@ + + return 0; + } +-arch_initcall(cbe_init_pm_irq); ++machine_arch_initcall(cell, cbe_init_pm_irq); + + void cbe_sync_irq(int node) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/setup.c powerpc.git/arch/powerpc/platforms/cell/setup.c +--- linux-2.6.24/arch/powerpc/platforms/cell/setup.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/setup.c 2008-01-28 20:25:49.000000000 +0100 +@@ -30,6 +30,7 @@ + #include <linux/console.h> + #include <linux/mutex.h> + #include <linux/memory_hotplug.h> ++#include <linux/of_platform.h> + + #include <asm/mmu.h> + #include <asm/processor.h> +@@ -51,7 +52,6 @@ + #include <asm/spu_priv1.h> + #include <asm/udbg.h> + #include <asm/mpic.h> +-#include <asm/of_platform.h> + #include <asm/cell-regs.h> + + #include "interrupt.h" +@@ -85,9 +85,6 @@ + { + int node; + +- if (!machine_is(cell)) +- return 0; +- + /* Publish OF platform devices for southbridge IOs */ + of_platform_bus_probe(NULL, NULL, NULL); + +@@ -101,7 +98,7 @@ + } + return 0; + } +-device_initcall(cell_publish_devices); ++machine_device_initcall(cell, cell_publish_devices); + + static void cell_mpic_cascade(unsigned int irq, struct irq_desc *desc) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/smp.c powerpc.git/arch/powerpc/platforms/cell/smp.c +--- linux-2.6.24/arch/powerpc/platforms/cell/smp.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/smp.c 2008-01-28 20:25:49.000000000 +0100 +@@ -42,6 +42,7 @@ + #include <asm/firmware.h> + #include <asm/system.h> + #include <asm/rtas.h> ++#include <asm/cputhreads.h> + + #include "interrupt.h" + #include <asm/udbg.h> +@@ -182,7 +183,7 @@ + */ + if (system_state < SYSTEM_RUNNING && + cpu_has_feature(CPU_FTR_SMT) && +- !smt_enabled_at_boot && nr % 2 != 0) ++ !smt_enabled_at_boot && cpu_thread_in_core(nr) != 0) + return 0; + + return 1; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spu_base.c powerpc.git/arch/powerpc/platforms/cell/spu_base.c +--- linux-2.6.24/arch/powerpc/platforms/cell/spu_base.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spu_base.c 2008-01-28 20:25:49.000000000 +0100 +@@ -34,6 +34,7 @@ + #include <linux/linux_logo.h> + #include <asm/spu.h> + #include <asm/spu_priv1.h> ++#include <asm/spu_csa.h> + #include <asm/xmon.h> + #include <asm/prom.h> + +@@ -47,6 +48,13 @@ + EXPORT_SYMBOL_GPL(cbe_spu_info); + + /* ++ * The spufs fault-handling code needs to call force_sig_info to raise signals ++ * on DMA errors. Export it here to avoid general kernel-wide access to this ++ * function ++ */ ++EXPORT_SYMBOL_GPL(force_sig_info); ++ ++/* + * Protects cbe_spu_info and spu->number. + */ + static DEFINE_SPINLOCK(spu_lock); +@@ -66,6 +74,10 @@ + static DEFINE_SPINLOCK(spu_full_list_lock); + static DEFINE_MUTEX(spu_full_list_mutex); + ++struct spu_slb { ++ u64 esid, vsid; ++}; ++ + void spu_invalidate_slbs(struct spu *spu) + { + struct spu_priv2 __iomem *priv2 = spu->priv2; +@@ -114,40 +126,36 @@ + } + EXPORT_SYMBOL_GPL(spu_associate_mm); + +-static int __spu_trap_invalid_dma(struct spu *spu) ++int spu_64k_pages_available(void) + { +- pr_debug("%s\n", __FUNCTION__); +- spu->dma_callback(spu, SPE_EVENT_INVALID_DMA); +- return 0; ++ return mmu_psize_defs[MMU_PAGE_64K].shift != 0; + } ++EXPORT_SYMBOL_GPL(spu_64k_pages_available); + +-static int __spu_trap_dma_align(struct spu *spu) ++static void spu_restart_dma(struct spu *spu) + { +- pr_debug("%s\n", __FUNCTION__); +- spu->dma_callback(spu, SPE_EVENT_DMA_ALIGNMENT); +- return 0; +-} ++ struct spu_priv2 __iomem *priv2 = spu->priv2; + +-static int __spu_trap_error(struct spu *spu) +-{ +- pr_debug("%s\n", __FUNCTION__); +- spu->dma_callback(spu, SPE_EVENT_SPE_ERROR); +- return 0; ++ if (!test_bit(SPU_CONTEXT_SWITCH_PENDING, &spu->flags)) ++ out_be64(&priv2->mfc_control_RW, MFC_CNTL_RESTART_DMA_COMMAND); + } + +-static void spu_restart_dma(struct spu *spu) ++static inline void spu_load_slb(struct spu *spu, int slbe, struct spu_slb *slb) + { + struct spu_priv2 __iomem *priv2 = spu->priv2; + +- if (!test_bit(SPU_CONTEXT_SWITCH_PENDING, &spu->flags)) +- out_be64(&priv2->mfc_control_RW, MFC_CNTL_RESTART_DMA_COMMAND); ++ pr_debug("%s: adding SLB[%d] 0x%016lx 0x%016lx\n", ++ __func__, slbe, slb->vsid, slb->esid); ++ ++ out_be64(&priv2->slb_index_W, slbe); ++ out_be64(&priv2->slb_vsid_RW, slb->vsid); ++ out_be64(&priv2->slb_esid_RW, slb->esid); + } + + static int __spu_trap_data_seg(struct spu *spu, unsigned long ea) + { +- struct spu_priv2 __iomem *priv2 = spu->priv2; + struct mm_struct *mm = spu->mm; +- u64 esid, vsid, llp; ++ struct spu_slb slb; + int psize; + + pr_debug("%s\n", __FUNCTION__); +@@ -159,7 +167,7 @@ + printk("%s: invalid access during switch!\n", __func__); + return 1; + } +- esid = (ea & ESID_MASK) | SLB_ESID_V; ++ slb.esid = (ea & ESID_MASK) | SLB_ESID_V; + + switch(REGION_ID(ea)) { + case USER_REGION_ID: +@@ -168,21 +176,21 @@ + #else + psize = mm->context.user_psize; + #endif +- vsid = (get_vsid(mm->context.id, ea, MMU_SEGSIZE_256M) << SLB_VSID_SHIFT) | +- SLB_VSID_USER; ++ slb.vsid = (get_vsid(mm->context.id, ea, MMU_SEGSIZE_256M) ++ << SLB_VSID_SHIFT) | SLB_VSID_USER; + break; + case VMALLOC_REGION_ID: + if (ea < VMALLOC_END) + psize = mmu_vmalloc_psize; + else + psize = mmu_io_psize; +- vsid = (get_kernel_vsid(ea, MMU_SEGSIZE_256M) << SLB_VSID_SHIFT) | +- SLB_VSID_KERNEL; ++ slb.vsid = (get_kernel_vsid(ea, MMU_SEGSIZE_256M) ++ << SLB_VSID_SHIFT) | SLB_VSID_KERNEL; + break; + case KERNEL_REGION_ID: + psize = mmu_linear_psize; +- vsid = (get_kernel_vsid(ea, MMU_SEGSIZE_256M) << SLB_VSID_SHIFT) | +- SLB_VSID_KERNEL; ++ slb.vsid = (get_kernel_vsid(ea, MMU_SEGSIZE_256M) ++ << SLB_VSID_SHIFT) | SLB_VSID_KERNEL; + break; + default: + /* Future: support kernel segments so that drivers +@@ -191,11 +199,9 @@ + pr_debug("invalid region access at %016lx\n", ea); + return 1; + } +- llp = mmu_psize_defs[psize].sllp; ++ slb.vsid |= mmu_psize_defs[psize].sllp; + +- out_be64(&priv2->slb_index_W, spu->slb_replace); +- out_be64(&priv2->slb_vsid_RW, vsid | llp); +- out_be64(&priv2->slb_esid_RW, esid); ++ spu_load_slb(spu, spu->slb_replace, &slb); + + spu->slb_replace++; + if (spu->slb_replace >= 8) +@@ -225,13 +231,83 @@ + return 1; + } + ++ spu->class_0_pending = 0; + spu->dar = ea; + spu->dsisr = dsisr; +- mb(); ++ + spu->stop_callback(spu); ++ + return 0; + } + ++static void __spu_kernel_slb(void *addr, struct spu_slb *slb) ++{ ++ unsigned long ea = (unsigned long)addr; ++ u64 llp; ++ ++ if (REGION_ID(ea) == KERNEL_REGION_ID) ++ llp = mmu_psize_defs[mmu_linear_psize].sllp; ++ else ++ llp = mmu_psize_defs[mmu_virtual_psize].sllp; ++ ++ slb->vsid = (get_kernel_vsid(ea, MMU_SEGSIZE_256M) << SLB_VSID_SHIFT) | ++ SLB_VSID_KERNEL | llp; ++ slb->esid = (ea & ESID_MASK) | SLB_ESID_V; ++} ++ ++/** ++ * Given an array of @nr_slbs SLB entries, @slbs, return non-zero if the ++ * address @new_addr is present. ++ */ ++static inline int __slb_present(struct spu_slb *slbs, int nr_slbs, ++ void *new_addr) ++{ ++ unsigned long ea = (unsigned long)new_addr; ++ int i; ++ ++ for (i = 0; i < nr_slbs; i++) ++ if (!((slbs[i].esid ^ ea) & ESID_MASK)) ++ return 1; ++ ++ return 0; ++} ++ ++/** ++ * Setup the SPU kernel SLBs, in preparation for a context save/restore. We ++ * need to map both the context save area, and the save/restore code. ++ * ++ * Because the lscsa and code may cross segment boundaires, we check to see ++ * if mappings are required for the start and end of each range. We currently ++ * assume that the mappings are smaller that one segment - if not, something ++ * is seriously wrong. ++ */ ++void spu_setup_kernel_slbs(struct spu *spu, struct spu_lscsa *lscsa, ++ void *code, int code_size) ++{ ++ struct spu_slb slbs[4]; ++ int i, nr_slbs = 0; ++ /* start and end addresses of both mappings */ ++ void *addrs[] = { ++ lscsa, (void *)lscsa + sizeof(*lscsa) - 1, ++ code, code + code_size - 1 ++ }; ++ ++ /* check the set of addresses, and create a new entry in the slbs array ++ * if there isn't already a SLB for that address */ ++ for (i = 0; i < ARRAY_SIZE(addrs); i++) { ++ if (__slb_present(slbs, nr_slbs, addrs[i])) ++ continue; ++ ++ __spu_kernel_slb(addrs[i], &slbs[nr_slbs]); ++ nr_slbs++; ++ } ++ ++ /* Add the set of SLBs */ ++ for (i = 0; i < nr_slbs; i++) ++ spu_load_slb(spu, i, &slbs[i]); ++} ++EXPORT_SYMBOL_GPL(spu_setup_kernel_slbs); ++ + static irqreturn_t + spu_irq_class_0(int irq, void *data) + { +@@ -240,12 +316,13 @@ + + spu = data; + ++ spin_lock(&spu->register_lock); + mask = spu_int_mask_get(spu, 0); +- stat = spu_int_stat_get(spu, 0); +- stat &= mask; ++ stat = spu_int_stat_get(spu, 0) & mask; + +- spin_lock(&spu->register_lock); + spu->class_0_pending |= stat; ++ spu->dsisr = spu_mfc_dsisr_get(spu); ++ spu->dar = spu_mfc_dar_get(spu); + spin_unlock(&spu->register_lock); + + spu->stop_callback(spu); +@@ -255,31 +332,6 @@ + return IRQ_HANDLED; + } + +-int +-spu_irq_class_0_bottom(struct spu *spu) +-{ +- unsigned long flags; +- unsigned long stat; +- +- spin_lock_irqsave(&spu->register_lock, flags); +- stat = spu->class_0_pending; +- spu->class_0_pending = 0; +- +- if (stat & 1) /* invalid DMA alignment */ +- __spu_trap_dma_align(spu); +- +- if (stat & 2) /* invalid MFC DMA */ +- __spu_trap_invalid_dma(spu); +- +- if (stat & 4) /* error on SPU */ +- __spu_trap_error(spu); +- +- spin_unlock_irqrestore(&spu->register_lock, flags); +- +- return (stat & 0x7) ? -EIO : 0; +-} +-EXPORT_SYMBOL_GPL(spu_irq_class_0_bottom); +- + static irqreturn_t + spu_irq_class_1(int irq, void *data) + { +@@ -294,24 +346,23 @@ + stat = spu_int_stat_get(spu, 1) & mask; + dar = spu_mfc_dar_get(spu); + dsisr = spu_mfc_dsisr_get(spu); +- if (stat & 2) /* mapping fault */ ++ if (stat & CLASS1_STORAGE_FAULT_INTR) + spu_mfc_dsisr_set(spu, 0ul); + spu_int_stat_clear(spu, 1, stat); + spin_unlock(&spu->register_lock); + pr_debug("%s: %lx %lx %lx %lx\n", __FUNCTION__, mask, stat, + dar, dsisr); + +- if (stat & 1) /* segment fault */ ++ if (stat & CLASS1_SEGMENT_FAULT_INTR) + __spu_trap_data_seg(spu, dar); + +- if (stat & 2) { /* mapping fault */ ++ if (stat & CLASS1_STORAGE_FAULT_INTR) + __spu_trap_data_map(spu, dar, dsisr); +- } + +- if (stat & 4) /* ls compare & suspend on get */ ++ if (stat & CLASS1_LS_COMPARE_SUSPEND_ON_GET_INTR) + ; + +- if (stat & 8) /* ls compare & suspend on put */ ++ if (stat & CLASS1_LS_COMPARE_SUSPEND_ON_PUT_INTR) + ; + + return stat ? IRQ_HANDLED : IRQ_NONE; +@@ -323,6 +374,8 @@ + struct spu *spu; + unsigned long stat; + unsigned long mask; ++ const int mailbox_intrs = ++ CLASS2_MAILBOX_THRESHOLD_INTR | CLASS2_MAILBOX_INTR; + + spu = data; + spin_lock(&spu->register_lock); +@@ -330,31 +383,30 @@ + mask = spu_int_mask_get(spu, 2); + /* ignore interrupts we're not waiting for */ + stat &= mask; +- /* +- * mailbox interrupts (0x1 and 0x10) are level triggered. +- * mask them now before acknowledging. +- */ +- if (stat & 0x11) +- spu_int_mask_and(spu, 2, ~(stat & 0x11)); ++ ++ /* mailbox interrupts are level triggered. mask them now before ++ * acknowledging */ ++ if (stat & mailbox_intrs) ++ spu_int_mask_and(spu, 2, ~(stat & mailbox_intrs)); + /* acknowledge all interrupts before the callbacks */ + spu_int_stat_clear(spu, 2, stat); + spin_unlock(&spu->register_lock); + + pr_debug("class 2 interrupt %d, %lx, %lx\n", irq, stat, mask); + +- if (stat & 1) /* PPC core mailbox */ ++ if (stat & CLASS2_MAILBOX_INTR) + spu->ibox_callback(spu); + +- if (stat & 2) /* SPU stop-and-signal */ ++ if (stat & CLASS2_SPU_STOP_INTR) + spu->stop_callback(spu); + +- if (stat & 4) /* SPU halted */ ++ if (stat & CLASS2_SPU_HALT_INTR) + spu->stop_callback(spu); + +- if (stat & 8) /* DMA tag group complete */ ++ if (stat & CLASS2_SPU_DMA_TAG_GROUP_COMPLETE_INTR) + spu->mfc_callback(spu); + +- if (stat & 0x10) /* SPU mailbox threshold */ ++ if (stat & CLASS2_MAILBOX_THRESHOLD_INTR) + spu->wbox_callback(spu); + + spu->stats.class2_intr++; +@@ -479,13 +531,27 @@ + int spu_add_sysdev_attr_group(struct attribute_group *attrs) + { + struct spu *spu; ++ int rc = 0; + + mutex_lock(&spu_full_list_mutex); +- list_for_each_entry(spu, &spu_full_list, full_list) +- sysfs_create_group(&spu->sysdev.kobj, attrs); ++ list_for_each_entry(spu, &spu_full_list, full_list) { ++ rc = sysfs_create_group(&spu->sysdev.kobj, attrs); ++ ++ /* we're in trouble here, but try unwinding anyway */ ++ if (rc) { ++ printk(KERN_ERR "%s: can't create sysfs group '%s'\n", ++ __func__, attrs->name); ++ ++ list_for_each_entry_continue_reverse(spu, ++ &spu_full_list, full_list) ++ sysfs_remove_group(&spu->sysdev.kobj, attrs); ++ break; ++ } ++ } ++ + mutex_unlock(&spu_full_list_mutex); + +- return 0; ++ return rc; + } + EXPORT_SYMBOL_GPL(spu_add_sysdev_attr_group); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spu_fault.c powerpc.git/arch/powerpc/platforms/cell/spu_fault.c +--- linux-2.6.24/arch/powerpc/platforms/cell/spu_fault.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spu_fault.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,98 @@ ++/* ++ * SPU mm fault handler ++ * ++ * (C) Copyright IBM Deutschland Entwicklung GmbH 2007 ++ * ++ * Author: Arnd Bergmann <arndb@de.ibm.com> ++ * Author: Jeremy Kerr <jk@ozlabs.org> ++ * ++ * This program is free software; you can redistribute it and/or modify ++ * it under the terms of the GNU General Public License as published by ++ * the Free Software Foundation; either version 2, or (at your option) ++ * any later version. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ++ */ ++#include <linux/sched.h> ++#include <linux/mm.h> ++#include <linux/module.h> ++ ++#include <asm/spu.h> ++#include <asm/spu_csa.h> ++ ++/* ++ * This ought to be kept in sync with the powerpc specific do_page_fault ++ * function. Currently, there are a few corner cases that we haven't had ++ * to handle fortunately. ++ */ ++int spu_handle_mm_fault(struct mm_struct *mm, unsigned long ea, ++ unsigned long dsisr, unsigned *flt) ++{ ++ struct vm_area_struct *vma; ++ unsigned long is_write; ++ int ret; ++ ++#if 0 ++ if (!IS_VALID_EA(ea)) { ++ return -EFAULT; ++ } ++#endif /* XXX */ ++ if (mm == NULL) { ++ return -EFAULT; ++ } ++ if (mm->pgd == NULL) { ++ return -EFAULT; ++ } ++ ++ down_read(&mm->mmap_sem); ++ vma = find_vma(mm, ea); ++ if (!vma) ++ goto bad_area; ++ if (vma->vm_start <= ea) ++ goto good_area; ++ if (!(vma->vm_flags & VM_GROWSDOWN)) ++ goto bad_area; ++ if (expand_stack(vma, ea)) ++ goto bad_area; ++good_area: ++ is_write = dsisr & MFC_DSISR_ACCESS_PUT; ++ if (is_write) { ++ if (!(vma->vm_flags & VM_WRITE)) ++ goto bad_area; ++ } else { ++ if (dsisr & MFC_DSISR_ACCESS_DENIED) ++ goto bad_area; ++ if (!(vma->vm_flags & (VM_READ | VM_EXEC))) ++ goto bad_area; ++ } ++ ret = 0; ++ *flt = handle_mm_fault(mm, vma, ea, is_write); ++ if (unlikely(*flt & VM_FAULT_ERROR)) { ++ if (*flt & VM_FAULT_OOM) { ++ ret = -ENOMEM; ++ goto bad_area; ++ } else if (*flt & VM_FAULT_SIGBUS) { ++ ret = -EFAULT; ++ goto bad_area; ++ } ++ BUG(); ++ } ++ if (*flt & VM_FAULT_MAJOR) ++ current->maj_flt++; ++ else ++ current->min_flt++; ++ up_read(&mm->mmap_sem); ++ return ret; ++ ++bad_area: ++ up_read(&mm->mmap_sem); ++ return -EFAULT; ++} ++EXPORT_SYMBOL_GPL(spu_handle_mm_fault); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spu_manage.c powerpc.git/arch/powerpc/platforms/cell/spu_manage.c +--- linux-2.6.24/arch/powerpc/platforms/cell/spu_manage.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spu_manage.c 2008-01-28 20:25:49.000000000 +0100 +@@ -35,6 +35,7 @@ + #include <asm/firmware.h> + #include <asm/prom.h> + ++#include "spufs/spufs.h" + #include "interrupt.h" + + struct device_node *spu_devnode(struct spu *spu) +@@ -345,7 +346,7 @@ + } + ret = spu_map_interrupts_old(spu, spe); + if (ret) { +- printk(KERN_ERR "%s: could not map interrupts", ++ printk(KERN_ERR "%s: could not map interrupts\n", + spu->name); + goto out_unmap; + } +@@ -369,6 +370,16 @@ + return 0; + } + ++static void enable_spu_by_master_run(struct spu_context *ctx) ++{ ++ ctx->ops->master_start(ctx); ++} ++ ++static void disable_spu_by_master_run(struct spu_context *ctx) ++{ ++ ctx->ops->master_stop(ctx); ++} ++ + /* Hardcoded affinity idxs for qs20 */ + #define QS20_SPES_PER_BE 8 + static int qs20_reg_idxs[QS20_SPES_PER_BE] = { 0, 2, 4, 6, 7, 5, 3, 1 }; +@@ -411,10 +422,15 @@ + + static int of_has_vicinity(void) + { +- struct spu* spu; ++ struct device_node *dn; + +- spu = list_first_entry(&cbe_spu_info[0].spus, struct spu, cbe_list); +- return of_find_property(spu_devnode(spu), "vicinity", NULL) != NULL; ++ for_each_node_by_type(dn, "spe") { ++ if (of_find_property(dn, "vicinity", NULL)) { ++ of_node_put(dn); ++ return 1; ++ } ++ } ++ return 0; + } + + static struct spu *devnode_spu(int cbe, struct device_node *dn) +@@ -525,7 +541,7 @@ + if (of_flat_dt_is_compatible(root, "IBM,CPBW-1.0")) + init_affinity_qs20_harcoded(); + else +- printk("No affinity configuration found"); ++ printk("No affinity configuration found\n"); + } + + return 0; +@@ -535,5 +551,7 @@ + .enumerate_spus = of_enumerate_spus, + .create_spu = of_create_spu, + .destroy_spu = of_destroy_spu, ++ .enable_spu = enable_spu_by_master_run, ++ .disable_spu = disable_spu_by_master_run, + .init_affinity = init_affinity, + }; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spufs/Makefile powerpc.git/arch/powerpc/platforms/cell/spufs/Makefile +--- linux-2.6.24/arch/powerpc/platforms/cell/spufs/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spufs/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -1,8 +1,8 @@ +-obj-y += switch.o fault.o lscsa_alloc.o + + obj-$(CONFIG_SPU_FS) += spufs.o + spufs-y += inode.o file.o context.o syscalls.o coredump.o + spufs-y += sched.o backing_ops.o hw_ops.o run.o gang.o ++spufs-y += switch.o fault.o lscsa_alloc.o + + # Rules to build switch.o with the help of SPU tool chain + SPU_CROSS := spu- +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spufs/backing_ops.c powerpc.git/arch/powerpc/platforms/cell/spufs/backing_ops.c +--- linux-2.6.24/arch/powerpc/platforms/cell/spufs/backing_ops.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spufs/backing_ops.c 2008-01-28 20:25:49.000000000 +0100 +@@ -106,16 +106,20 @@ + if (stat & 0xff0000) + ret |= POLLIN | POLLRDNORM; + else { +- ctx->csa.priv1.int_stat_class0_RW &= ~0x1; +- ctx->csa.priv1.int_mask_class2_RW |= 0x1; ++ ctx->csa.priv1.int_stat_class2_RW &= ++ ~CLASS2_MAILBOX_INTR; ++ ctx->csa.priv1.int_mask_class2_RW |= ++ CLASS2_ENABLE_MAILBOX_INTR; + } + } + if (events & (POLLOUT | POLLWRNORM)) { + if (stat & 0x00ff00) + ret = POLLOUT | POLLWRNORM; + else { +- ctx->csa.priv1.int_stat_class0_RW &= ~0x10; +- ctx->csa.priv1.int_mask_class2_RW |= 0x10; ++ ctx->csa.priv1.int_stat_class2_RW &= ++ ~CLASS2_MAILBOX_THRESHOLD_INTR; ++ ctx->csa.priv1.int_mask_class2_RW |= ++ CLASS2_ENABLE_MAILBOX_THRESHOLD_INTR; + } + } + spin_unlock_irq(&ctx->csa.register_lock); +@@ -139,7 +143,7 @@ + ret = 4; + } else { + /* make sure we get woken up by the interrupt */ +- ctx->csa.priv1.int_mask_class2_RW |= 0x1UL; ++ ctx->csa.priv1.int_mask_class2_RW |= CLASS2_ENABLE_MAILBOX_INTR; + ret = 0; + } + spin_unlock(&ctx->csa.register_lock); +@@ -169,7 +173,8 @@ + } else { + /* make sure we get woken up by the interrupt when space + becomes available */ +- ctx->csa.priv1.int_mask_class2_RW |= 0x10; ++ ctx->csa.priv1.int_mask_class2_RW |= ++ CLASS2_ENABLE_MAILBOX_THRESHOLD_INTR; + ret = 0; + } + spin_unlock(&ctx->csa.register_lock); +@@ -268,6 +273,11 @@ + return ctx->csa.lscsa->ls; + } + ++static void spu_backing_privcntl_write(struct spu_context *ctx, u64 val) ++{ ++ ctx->csa.priv2.spu_privcntl_RW = val; ++} ++ + static u32 spu_backing_runcntl_read(struct spu_context *ctx) + { + return ctx->csa.prob.spu_runcntl_RW; +@@ -285,6 +295,11 @@ + spin_unlock(&ctx->csa.register_lock); + } + ++static void spu_backing_runcntl_stop(struct spu_context *ctx) ++{ ++ spu_backing_runcntl_write(ctx, SPU_RUNCNTL_STOP); ++} ++ + static void spu_backing_master_start(struct spu_context *ctx) + { + struct spu_state *csa = &ctx->csa; +@@ -358,7 +373,7 @@ + + static void spu_backing_restart_dma(struct spu_context *ctx) + { +- /* nothing to do here */ ++ ctx->csa.priv2.mfc_control_RW |= MFC_CNTL_RESTART_DMA_COMMAND; + } + + struct spu_context_ops spu_backing_ops = { +@@ -379,8 +394,10 @@ + .npc_write = spu_backing_npc_write, + .status_read = spu_backing_status_read, + .get_ls = spu_backing_get_ls, ++ .privcntl_write = spu_backing_privcntl_write, + .runcntl_read = spu_backing_runcntl_read, + .runcntl_write = spu_backing_runcntl_write, ++ .runcntl_stop = spu_backing_runcntl_stop, + .master_start = spu_backing_master_start, + .master_stop = spu_backing_master_stop, + .set_mfc_query = spu_backing_set_mfc_query, +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spufs/context.c powerpc.git/arch/powerpc/platforms/cell/spufs/context.c +--- linux-2.6.24/arch/powerpc/platforms/cell/spufs/context.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spufs/context.c 2008-01-28 20:25:49.000000000 +0100 +@@ -52,6 +52,7 @@ + init_waitqueue_head(&ctx->wbox_wq); + init_waitqueue_head(&ctx->stop_wq); + init_waitqueue_head(&ctx->mfc_wq); ++ init_waitqueue_head(&ctx->run_wq); + ctx->state = SPU_STATE_SAVED; + ctx->ops = &spu_backing_ops; + ctx->owner = get_task_mm(current); +@@ -105,7 +106,17 @@ + void spu_forget(struct spu_context *ctx) + { + struct mm_struct *mm; +- spu_acquire_saved(ctx); ++ ++ /* ++ * This is basically an open-coded spu_acquire_saved, except that ++ * we don't acquire the state mutex interruptible. ++ */ ++ mutex_lock(&ctx->state_mutex); ++ if (ctx->state != SPU_STATE_SAVED) { ++ set_bit(SPU_SCHED_WAS_ACTIVE, &ctx->sched_flags); ++ spu_deactivate(ctx); ++ } ++ + mm = ctx->owner; + ctx->owner = NULL; + mmput(mm); +@@ -133,47 +144,23 @@ + } + + /** +- * spu_acquire_runnable - lock spu contex and make sure it is in runnable state ++ * spu_acquire_saved - lock spu contex and make sure it is in saved state + * @ctx: spu contex to lock +- * +- * Note: +- * Returns 0 and with the context locked on success +- * Returns negative error and with the context _unlocked_ on failure. + */ +-int spu_acquire_runnable(struct spu_context *ctx, unsigned long flags) ++int spu_acquire_saved(struct spu_context *ctx) + { +- int ret = -EINVAL; ++ int ret; + +- spu_acquire(ctx); +- if (ctx->state == SPU_STATE_SAVED) { +- /* +- * Context is about to be freed, so we can't acquire it anymore. +- */ +- if (!ctx->owner) +- goto out_unlock; +- ret = spu_activate(ctx, flags); +- if (ret) +- goto out_unlock; +- } +- +- return 0; ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; + +- out_unlock: +- spu_release(ctx); +- return ret; +-} +- +-/** +- * spu_acquire_saved - lock spu contex and make sure it is in saved state +- * @ctx: spu contex to lock +- */ +-void spu_acquire_saved(struct spu_context *ctx) +-{ +- spu_acquire(ctx); + if (ctx->state != SPU_STATE_SAVED) { + set_bit(SPU_SCHED_WAS_ACTIVE, &ctx->sched_flags); + spu_deactivate(ctx); + } ++ ++ return 0; + } + + /** +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spufs/coredump.c powerpc.git/arch/powerpc/platforms/cell/spufs/coredump.c +--- linux-2.6.24/arch/powerpc/platforms/cell/spufs/coredump.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spufs/coredump.c 2008-01-28 20:25:49.000000000 +0100 +@@ -148,7 +148,9 @@ + + fd = 0; + while ((ctx = coredump_next_context(&fd)) != NULL) { +- spu_acquire_saved(ctx); ++ rc = spu_acquire_saved(ctx); ++ if (rc) ++ break; + rc = spufs_ctx_note_size(ctx, fd); + spu_release_saved(ctx); + if (rc < 0) +@@ -224,7 +226,9 @@ + + fd = 0; + while ((ctx = coredump_next_context(&fd)) != NULL) { +- spu_acquire_saved(ctx); ++ rc = spu_acquire_saved(ctx); ++ if (rc) ++ return rc; + + for (j = 0; spufs_coredump_read[j].name != NULL; j++) { + rc = spufs_arch_write_note(ctx, j, file, fd, foffset); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spufs/fault.c powerpc.git/arch/powerpc/platforms/cell/spufs/fault.c +--- linux-2.6.24/arch/powerpc/platforms/cell/spufs/fault.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spufs/fault.c 2008-01-28 20:25:49.000000000 +0100 +@@ -28,117 +28,71 @@ + + #include "spufs.h" + +-/* +- * This ought to be kept in sync with the powerpc specific do_page_fault +- * function. Currently, there are a few corner cases that we haven't had +- * to handle fortunately. ++/** ++ * Handle an SPE event, depending on context SPU_CREATE_EVENTS_ENABLED flag. ++ * ++ * If the context was created with events, we just set the return event. ++ * Otherwise, send an appropriate signal to the process. + */ +-static int spu_handle_mm_fault(struct mm_struct *mm, unsigned long ea, +- unsigned long dsisr, unsigned *flt) +-{ +- struct vm_area_struct *vma; +- unsigned long is_write; +- int ret; +- +-#if 0 +- if (!IS_VALID_EA(ea)) { +- return -EFAULT; +- } +-#endif /* XXX */ +- if (mm == NULL) { +- return -EFAULT; +- } +- if (mm->pgd == NULL) { +- return -EFAULT; +- } +- +- down_read(&mm->mmap_sem); +- vma = find_vma(mm, ea); +- if (!vma) +- goto bad_area; +- if (vma->vm_start <= ea) +- goto good_area; +- if (!(vma->vm_flags & VM_GROWSDOWN)) +- goto bad_area; +- if (expand_stack(vma, ea)) +- goto bad_area; +-good_area: +- is_write = dsisr & MFC_DSISR_ACCESS_PUT; +- if (is_write) { +- if (!(vma->vm_flags & VM_WRITE)) +- goto bad_area; +- } else { +- if (dsisr & MFC_DSISR_ACCESS_DENIED) +- goto bad_area; +- if (!(vma->vm_flags & (VM_READ | VM_EXEC))) +- goto bad_area; +- } +- ret = 0; +- *flt = handle_mm_fault(mm, vma, ea, is_write); +- if (unlikely(*flt & VM_FAULT_ERROR)) { +- if (*flt & VM_FAULT_OOM) { +- ret = -ENOMEM; +- goto bad_area; +- } else if (*flt & VM_FAULT_SIGBUS) { +- ret = -EFAULT; +- goto bad_area; +- } +- BUG(); +- } +- if (*flt & VM_FAULT_MAJOR) +- current->maj_flt++; +- else +- current->min_flt++; +- up_read(&mm->mmap_sem); +- return ret; +- +-bad_area: +- up_read(&mm->mmap_sem); +- return -EFAULT; +-} +- +-static void spufs_handle_dma_error(struct spu_context *ctx, ++static void spufs_handle_event(struct spu_context *ctx, + unsigned long ea, int type) + { ++ siginfo_t info; ++ + if (ctx->flags & SPU_CREATE_EVENTS_ENABLED) { + ctx->event_return |= type; + wake_up_all(&ctx->stop_wq); +- } else { +- siginfo_t info; +- memset(&info, 0, sizeof(info)); +- +- switch (type) { +- case SPE_EVENT_INVALID_DMA: +- info.si_signo = SIGBUS; +- info.si_code = BUS_OBJERR; +- break; +- case SPE_EVENT_SPE_DATA_STORAGE: +- info.si_signo = SIGBUS; +- info.si_addr = (void __user *)ea; +- info.si_code = BUS_ADRERR; +- break; +- case SPE_EVENT_DMA_ALIGNMENT: +- info.si_signo = SIGBUS; +- /* DAR isn't set for an alignment fault :( */ +- info.si_code = BUS_ADRALN; +- break; +- case SPE_EVENT_SPE_ERROR: +- info.si_signo = SIGILL; +- info.si_addr = (void __user *)(unsigned long) +- ctx->ops->npc_read(ctx) - 4; +- info.si_code = ILL_ILLOPC; +- break; +- } +- if (info.si_signo) +- force_sig_info(info.si_signo, &info, current); ++ return; + } ++ ++ memset(&info, 0, sizeof(info)); ++ ++ switch (type) { ++ case SPE_EVENT_INVALID_DMA: ++ info.si_signo = SIGBUS; ++ info.si_code = BUS_OBJERR; ++ break; ++ case SPE_EVENT_SPE_DATA_STORAGE: ++ info.si_signo = SIGSEGV; ++ info.si_addr = (void __user *)ea; ++ info.si_code = SEGV_ACCERR; ++ ctx->ops->restart_dma(ctx); ++ break; ++ case SPE_EVENT_DMA_ALIGNMENT: ++ info.si_signo = SIGBUS; ++ /* DAR isn't set for an alignment fault :( */ ++ info.si_code = BUS_ADRALN; ++ break; ++ case SPE_EVENT_SPE_ERROR: ++ info.si_signo = SIGILL; ++ info.si_addr = (void __user *)(unsigned long) ++ ctx->ops->npc_read(ctx) - 4; ++ info.si_code = ILL_ILLOPC; ++ break; ++ } ++ ++ if (info.si_signo) ++ force_sig_info(info.si_signo, &info, current); + } + +-void spufs_dma_callback(struct spu *spu, int type) ++int spufs_handle_class0(struct spu_context *ctx) + { +- spufs_handle_dma_error(spu->ctx, spu->dar, type); ++ unsigned long stat = ctx->csa.class_0_pending & CLASS0_INTR_MASK; ++ ++ if (likely(!stat)) ++ return 0; ++ ++ if (stat & CLASS0_DMA_ALIGNMENT_INTR) ++ spufs_handle_event(ctx, ctx->csa.dar, SPE_EVENT_DMA_ALIGNMENT); ++ ++ if (stat & CLASS0_INVALID_DMA_COMMAND_INTR) ++ spufs_handle_event(ctx, ctx->csa.dar, SPE_EVENT_INVALID_DMA); ++ ++ if (stat & CLASS0_SPU_ERROR_INTR) ++ spufs_handle_event(ctx, ctx->csa.dar, SPE_EVENT_SPE_ERROR); ++ ++ return -EIO; + } +-EXPORT_SYMBOL_GPL(spufs_dma_callback); + + /* + * bottom half handler for page faults, we can't do this from +@@ -154,7 +108,7 @@ + u64 ea, dsisr, access; + unsigned long flags; + unsigned flt = 0; +- int ret; ++ int ret, ret2; + + /* + * dar and dsisr get passed from the registers +@@ -165,16 +119,8 @@ + * in time, we can still expect to get the same fault + * the immediately after the context restore. + */ +- if (ctx->state == SPU_STATE_RUNNABLE) { +- ea = ctx->spu->dar; +- dsisr = ctx->spu->dsisr; +- ctx->spu->dar= ctx->spu->dsisr = 0; +- } else { +- ea = ctx->csa.priv1.mfc_dar_RW; +- dsisr = ctx->csa.priv1.mfc_dsisr_RW; +- ctx->csa.priv1.mfc_dar_RW = 0; +- ctx->csa.priv1.mfc_dsisr_RW = 0; +- } ++ ea = ctx->csa.dar; ++ dsisr = ctx->csa.dsisr; + + if (!(dsisr & (MFC_DSISR_PTE_NOT_FOUND | MFC_DSISR_ACCESS_DENIED))) + return 0; +@@ -201,7 +147,22 @@ + if (ret) + ret = spu_handle_mm_fault(current->mm, ea, dsisr, &flt); + +- spu_acquire(ctx); ++ /* ++ * If spu_acquire fails due to a pending signal we just want to return ++ * EINTR to userspace even if that means missing the dma restart or ++ * updating the page fault statistics. ++ */ ++ ret2 = spu_acquire(ctx); ++ if (ret2) ++ goto out; ++ ++ /* ++ * Clear dsisr under ctxt lock after handling the fault, so that ++ * time slicing will not preempt the context while the page fault ++ * handler is running. Context switch code removes mappings. ++ */ ++ ctx->csa.dar = ctx->csa.dsisr = 0; ++ + /* + * If we handled the fault successfully and are in runnable + * state, restart the DMA. +@@ -222,9 +183,9 @@ + if (ctx->spu) + ctx->ops->restart_dma(ctx); + } else +- spufs_handle_dma_error(ctx, ea, SPE_EVENT_SPE_DATA_STORAGE); ++ spufs_handle_event(ctx, ea, SPE_EVENT_SPE_DATA_STORAGE); + ++ out: + spuctx_switch_state(ctx, SPU_UTIL_SYSTEM); + return ret; + } +-EXPORT_SYMBOL_GPL(spufs_handle_class1); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spufs/file.c powerpc.git/arch/powerpc/platforms/cell/spufs/file.c +--- linux-2.6.24/arch/powerpc/platforms/cell/spufs/file.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spufs/file.c 2008-01-28 20:25:49.000000000 +0100 +@@ -40,6 +40,120 @@ + + #define SPUFS_MMAP_4K (PAGE_SIZE == 0x1000) + ++/* Simple attribute files */ ++struct spufs_attr { ++ int (*get)(void *, u64 *); ++ int (*set)(void *, u64); ++ char get_buf[24]; /* enough to store a u64 and "\n\0" */ ++ char set_buf[24]; ++ void *data; ++ const char *fmt; /* format for read operation */ ++ struct mutex mutex; /* protects access to these buffers */ ++}; ++ ++static int spufs_attr_open(struct inode *inode, struct file *file, ++ int (*get)(void *, u64 *), int (*set)(void *, u64), ++ const char *fmt) ++{ ++ struct spufs_attr *attr; ++ ++ attr = kmalloc(sizeof(*attr), GFP_KERNEL); ++ if (!attr) ++ return -ENOMEM; ++ ++ attr->get = get; ++ attr->set = set; ++ attr->data = inode->i_private; ++ attr->fmt = fmt; ++ mutex_init(&attr->mutex); ++ file->private_data = attr; ++ ++ return nonseekable_open(inode, file); ++} ++ ++static int spufs_attr_release(struct inode *inode, struct file *file) ++{ ++ kfree(file->private_data); ++ return 0; ++} ++ ++static ssize_t spufs_attr_read(struct file *file, char __user *buf, ++ size_t len, loff_t *ppos) ++{ ++ struct spufs_attr *attr; ++ size_t size; ++ ssize_t ret; ++ ++ attr = file->private_data; ++ if (!attr->get) ++ return -EACCES; ++ ++ ret = mutex_lock_interruptible(&attr->mutex); ++ if (ret) ++ return ret; ++ ++ if (*ppos) { /* continued read */ ++ size = strlen(attr->get_buf); ++ } else { /* first read */ ++ u64 val; ++ ret = attr->get(attr->data, &val); ++ if (ret) ++ goto out; ++ ++ size = scnprintf(attr->get_buf, sizeof(attr->get_buf), ++ attr->fmt, (unsigned long long)val); ++ } ++ ++ ret = simple_read_from_buffer(buf, len, ppos, attr->get_buf, size); ++out: ++ mutex_unlock(&attr->mutex); ++ return ret; ++} ++ ++static ssize_t spufs_attr_write(struct file *file, const char __user *buf, ++ size_t len, loff_t *ppos) ++{ ++ struct spufs_attr *attr; ++ u64 val; ++ size_t size; ++ ssize_t ret; ++ ++ attr = file->private_data; ++ if (!attr->set) ++ return -EACCES; ++ ++ ret = mutex_lock_interruptible(&attr->mutex); ++ if (ret) ++ return ret; ++ ++ ret = -EFAULT; ++ size = min(sizeof(attr->set_buf) - 1, len); ++ if (copy_from_user(attr->set_buf, buf, size)) ++ goto out; ++ ++ ret = len; /* claim we got the whole input */ ++ attr->set_buf[size] = '\0'; ++ val = simple_strtol(attr->set_buf, NULL, 0); ++ attr->set(attr->data, val); ++out: ++ mutex_unlock(&attr->mutex); ++ return ret; ++} ++ ++#define DEFINE_SPUFS_SIMPLE_ATTRIBUTE(__fops, __get, __set, __fmt) \ ++static int __fops ## _open(struct inode *inode, struct file *file) \ ++{ \ ++ __simple_attr_check_format(__fmt, 0ull); \ ++ return spufs_attr_open(inode, file, __get, __set, __fmt); \ ++} \ ++static struct file_operations __fops = { \ ++ .owner = THIS_MODULE, \ ++ .open = __fops ## _open, \ ++ .release = spufs_attr_release, \ ++ .read = spufs_attr_read, \ ++ .write = spufs_attr_write, \ ++}; ++ + + static int + spufs_mem_open(struct inode *inode, struct file *file) +@@ -84,9 +198,12 @@ + struct spu_context *ctx = file->private_data; + ssize_t ret; + +- spu_acquire(ctx); ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; + ret = __spufs_mem_read(ctx, buffer, size, pos); + spu_release(ctx); ++ + return ret; + } + +@@ -106,7 +223,10 @@ + if (size > LS_SIZE - pos) + size = LS_SIZE - pos; + +- spu_acquire(ctx); ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; ++ + local_store = ctx->ops->get_ls(ctx); + ret = copy_from_user(local_store + pos, buffer, size); + spu_release(ctx); +@@ -146,7 +266,8 @@ + pr_debug("spufs_mem_mmap_nopfn address=0x%lx -> 0x%lx, offset=0x%lx\n", + addr0, address, offset); + +- spu_acquire(ctx); ++ if (spu_acquire(ctx)) ++ return NOPFN_REFAULT; + + if (ctx->state == SPU_STATE_SAVED) { + vma->vm_page_prot = __pgprot(pgprot_val(vma->vm_page_prot) +@@ -236,23 +357,32 @@ + { + struct spu_context *ctx = vma->vm_file->private_data; + unsigned long area, offset = address - vma->vm_start; +- int ret; + + offset += vma->vm_pgoff << PAGE_SHIFT; + if (offset >= ps_size) + return NOPFN_SIGBUS; + +- /* error here usually means a signal.. we might want to test +- * the error code more precisely though ++ /* ++ * We have to wait for context to be loaded before we have ++ * pages to hand out to the user, but we don't want to wait ++ * with the mmap_sem held. ++ * It is possible to drop the mmap_sem here, but then we need ++ * to return NOPFN_REFAULT because the mappings may have ++ * hanged. + */ +- ret = spu_acquire_runnable(ctx, 0); +- if (ret) ++ if (spu_acquire(ctx)) + return NOPFN_REFAULT; + +- area = ctx->spu->problem_phys + ps_offs; +- vm_insert_pfn(vma, address, (area + offset) >> PAGE_SHIFT); +- spu_release(ctx); ++ if (ctx->state == SPU_STATE_SAVED) { ++ up_read(¤t->mm->mmap_sem); ++ spufs_wait(ctx->run_wq, ctx->state == SPU_STATE_RUNNABLE); ++ down_read(¤t->mm->mmap_sem); ++ } else { ++ area = ctx->spu->problem_phys + ps_offs; ++ vm_insert_pfn(vma, address, (area + offset) >> PAGE_SHIFT); ++ } + ++ spu_release(ctx); + return NOPFN_REFAULT; + } + +@@ -286,25 +416,32 @@ + #define spufs_cntl_mmap NULL + #endif /* !SPUFS_MMAP_4K */ + +-static u64 spufs_cntl_get(void *data) ++static int spufs_cntl_get(void *data, u64 *val) + { + struct spu_context *ctx = data; +- u64 val; ++ int ret; + +- spu_acquire(ctx); +- val = ctx->ops->status_read(ctx); ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; ++ *val = ctx->ops->status_read(ctx); + spu_release(ctx); + +- return val; ++ return 0; + } + +-static void spufs_cntl_set(void *data, u64 val) ++static int spufs_cntl_set(void *data, u64 val) + { + struct spu_context *ctx = data; ++ int ret; + +- spu_acquire(ctx); ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; + ctx->ops->runcntl_write(ctx, val); + spu_release(ctx); ++ ++ return 0; + } + + static int spufs_cntl_open(struct inode *inode, struct file *file) +@@ -317,7 +454,7 @@ + if (!i->i_openers++) + ctx->cntl = inode->i_mapping; + mutex_unlock(&ctx->mapping_lock); +- return simple_attr_open(inode, file, spufs_cntl_get, ++ return spufs_attr_open(inode, file, spufs_cntl_get, + spufs_cntl_set, "0x%08lx"); + } + +@@ -327,7 +464,7 @@ + struct spufs_inode_info *i = SPUFS_I(inode); + struct spu_context *ctx = i->i_ctx; + +- simple_attr_close(inode, file); ++ spufs_attr_release(inode, file); + + mutex_lock(&ctx->mapping_lock); + if (!--i->i_openers) +@@ -339,8 +476,8 @@ + static const struct file_operations spufs_cntl_fops = { + .open = spufs_cntl_open, + .release = spufs_cntl_release, +- .read = simple_attr_read, +- .write = simple_attr_write, ++ .read = spufs_attr_read, ++ .write = spufs_attr_write, + .mmap = spufs_cntl_mmap, + }; + +@@ -368,7 +505,9 @@ + int ret; + struct spu_context *ctx = file->private_data; + +- spu_acquire_saved(ctx); ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + ret = __spufs_regs_read(ctx, buffer, size, pos); + spu_release_saved(ctx); + return ret; +@@ -387,7 +526,9 @@ + return -EFBIG; + *pos += size; + +- spu_acquire_saved(ctx); ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + + ret = copy_from_user(lscsa->gprs + *pos - size, + buffer, size) ? -EFAULT : size; +@@ -419,7 +560,9 @@ + int ret; + struct spu_context *ctx = file->private_data; + +- spu_acquire_saved(ctx); ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + ret = __spufs_fpcr_read(ctx, buffer, size, pos); + spu_release_saved(ctx); + return ret; +@@ -436,10 +579,12 @@ + size = min_t(ssize_t, sizeof(lscsa->fpcr) - *pos, size); + if (size <= 0) + return -EFBIG; +- *pos += size; + +- spu_acquire_saved(ctx); ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + ++ *pos += size; + ret = copy_from_user((char *)&lscsa->fpcr + *pos - size, + buffer, size) ? -EFAULT : size; + +@@ -486,7 +631,10 @@ + + udata = (void __user *)buf; + +- spu_acquire(ctx); ++ count = spu_acquire(ctx); ++ if (count) ++ return count; ++ + for (count = 0; (count + 4) <= len; count += 4, udata++) { + int ret; + ret = ctx->ops->mbox_read(ctx, &mbox_data); +@@ -522,12 +670,15 @@ + size_t len, loff_t *pos) + { + struct spu_context *ctx = file->private_data; ++ ssize_t ret; + u32 mbox_stat; + + if (len < 4) + return -EINVAL; + +- spu_acquire(ctx); ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; + + mbox_stat = ctx->ops->mbox_stat_read(ctx) & 0xff; + +@@ -562,6 +713,9 @@ + { + struct spu_context *ctx = spu->ctx; + ++ if (!ctx) ++ return; ++ + wake_up_all(&ctx->ibox_wq); + kill_fasync(&ctx->ibox_fasync, SIGIO, POLLIN); + } +@@ -593,7 +747,9 @@ + + udata = (void __user *)buf; + +- spu_acquire(ctx); ++ count = spu_acquire(ctx); ++ if (count) ++ return count; + + /* wait only for the first element */ + count = 0; +@@ -639,7 +795,11 @@ + + poll_wait(file, &ctx->ibox_wq, wait); + +- spu_acquire(ctx); ++ /* ++ * For now keep this uninterruptible and also ignore the rule ++ * that poll should not sleep. Will be fixed later. ++ */ ++ mutex_lock(&ctx->state_mutex); + mask = ctx->ops->mbox_stat_poll(ctx, POLLIN | POLLRDNORM); + spu_release(ctx); + +@@ -657,12 +817,15 @@ + size_t len, loff_t *pos) + { + struct spu_context *ctx = file->private_data; ++ ssize_t ret; + u32 ibox_stat; + + if (len < 4) + return -EINVAL; + +- spu_acquire(ctx); ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; + ibox_stat = (ctx->ops->mbox_stat_read(ctx) >> 16) & 0xff; + spu_release(ctx); + +@@ -698,6 +861,9 @@ + { + struct spu_context *ctx = spu->ctx; + ++ if (!ctx) ++ return; ++ + wake_up_all(&ctx->wbox_wq); + kill_fasync(&ctx->wbox_fasync, SIGIO, POLLOUT); + } +@@ -731,7 +897,9 @@ + if (__get_user(wbox_data, udata)) + return -EFAULT; + +- spu_acquire(ctx); ++ count = spu_acquire(ctx); ++ if (count) ++ return count; + + /* + * make sure we can at least write one element, by waiting +@@ -772,7 +940,11 @@ + + poll_wait(file, &ctx->wbox_wq, wait); + +- spu_acquire(ctx); ++ /* ++ * For now keep this uninterruptible and also ignore the rule ++ * that poll should not sleep. Will be fixed later. ++ */ ++ mutex_lock(&ctx->state_mutex); + mask = ctx->ops->mbox_stat_poll(ctx, POLLOUT | POLLWRNORM); + spu_release(ctx); + +@@ -790,12 +962,15 @@ + size_t len, loff_t *pos) + { + struct spu_context *ctx = file->private_data; ++ ssize_t ret; + u32 wbox_stat; + + if (len < 4) + return -EINVAL; + +- spu_acquire(ctx); ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; + wbox_stat = (ctx->ops->mbox_stat_read(ctx) >> 8) & 0xff; + spu_release(ctx); + +@@ -866,7 +1041,9 @@ + int ret; + struct spu_context *ctx = file->private_data; + +- spu_acquire_saved(ctx); ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + ret = __spufs_signal1_read(ctx, buf, len, pos); + spu_release_saved(ctx); + +@@ -877,6 +1054,7 @@ + size_t len, loff_t *pos) + { + struct spu_context *ctx; ++ ssize_t ret; + u32 data; + + ctx = file->private_data; +@@ -887,7 +1065,9 @@ + if (copy_from_user(&data, buf, 4)) + return -EFAULT; + +- spu_acquire(ctx); ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; + ctx->ops->signal1_write(ctx, data); + spu_release(ctx); + +@@ -997,7 +1177,9 @@ + struct spu_context *ctx = file->private_data; + int ret; + +- spu_acquire_saved(ctx); ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + ret = __spufs_signal2_read(ctx, buf, len, pos); + spu_release_saved(ctx); + +@@ -1008,6 +1190,7 @@ + size_t len, loff_t *pos) + { + struct spu_context *ctx; ++ ssize_t ret; + u32 data; + + ctx = file->private_data; +@@ -1018,7 +1201,9 @@ + if (copy_from_user(&data, buf, 4)) + return -EFAULT; + +- spu_acquire(ctx); ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; + ctx->ops->signal2_write(ctx, data); + spu_release(ctx); + +@@ -1086,33 +1271,42 @@ + #define SPU_ATTR_ACQUIRE_SAVED 2 + + #define DEFINE_SPUFS_ATTRIBUTE(__name, __get, __set, __fmt, __acquire) \ +-static u64 __##__get(void *data) \ ++static int __##__get(void *data, u64 *val) \ + { \ + struct spu_context *ctx = data; \ +- u64 ret; \ ++ int ret = 0; \ + \ + if (__acquire == SPU_ATTR_ACQUIRE) { \ +- spu_acquire(ctx); \ +- ret = __get(ctx); \ ++ ret = spu_acquire(ctx); \ ++ if (ret) \ ++ return ret; \ ++ *val = __get(ctx); \ + spu_release(ctx); \ + } else if (__acquire == SPU_ATTR_ACQUIRE_SAVED) { \ +- spu_acquire_saved(ctx); \ +- ret = __get(ctx); \ ++ ret = spu_acquire_saved(ctx); \ ++ if (ret) \ ++ return ret; \ ++ *val = __get(ctx); \ + spu_release_saved(ctx); \ + } else \ +- ret = __get(ctx); \ ++ *val = __get(ctx); \ + \ +- return ret; \ ++ return 0; \ + } \ +-DEFINE_SIMPLE_ATTRIBUTE(__name, __##__get, __set, __fmt); ++DEFINE_SPUFS_SIMPLE_ATTRIBUTE(__name, __##__get, __set, __fmt); + +-static void spufs_signal1_type_set(void *data, u64 val) ++static int spufs_signal1_type_set(void *data, u64 val) + { + struct spu_context *ctx = data; ++ int ret; + +- spu_acquire(ctx); ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; + ctx->ops->signal1_type_set(ctx, val); + spu_release(ctx); ++ ++ return 0; + } + + static u64 spufs_signal1_type_get(struct spu_context *ctx) +@@ -1123,13 +1317,18 @@ + spufs_signal1_type_set, "%llu", SPU_ATTR_ACQUIRE); + + +-static void spufs_signal2_type_set(void *data, u64 val) ++static int spufs_signal2_type_set(void *data, u64 val) + { + struct spu_context *ctx = data; ++ int ret; + +- spu_acquire(ctx); ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; + ctx->ops->signal2_type_set(ctx, val); + spu_release(ctx); ++ ++ return 0; + } + + static u64 spufs_signal2_type_get(struct spu_context *ctx) +@@ -1329,6 +1528,9 @@ + { + struct spu_context *ctx = spu->ctx; + ++ if (!ctx) ++ return; ++ + wake_up_all(&ctx->mfc_wq); + + pr_debug("%s %s\n", __FUNCTION__, spu->name); +@@ -1375,12 +1577,17 @@ + if (size != 4) + goto out; + +- spu_acquire(ctx); ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; ++ ++ ret = -EINVAL; + if (file->f_flags & O_NONBLOCK) { + status = ctx->ops->read_mfc_tagstatus(ctx); + if (!(status & ctx->tagwait)) + ret = -EAGAIN; + else ++ /* XXX(hch): shouldn't we clear ret here? */ + ctx->tagwait &= ~status; + } else { + ret = spufs_wait(ctx->mfc_wq, +@@ -1505,7 +1712,11 @@ + if (ret) + goto out; + +- ret = spu_acquire_runnable(ctx, 0); ++ ret = spu_acquire(ctx); ++ if (ret) ++ goto out; ++ ++ ret = spufs_wait(ctx->run_wq, ctx->state == SPU_STATE_RUNNABLE); + if (ret) + goto out; + +@@ -1539,7 +1750,11 @@ + + poll_wait(file, &ctx->mfc_wq, wait); + +- spu_acquire(ctx); ++ /* ++ * For now keep this uninterruptible and also ignore the rule ++ * that poll should not sleep. Will be fixed later. ++ */ ++ mutex_lock(&ctx->state_mutex); + ctx->ops->set_mfc_query(ctx, ctx->tagwait, 2); + free_elements = ctx->ops->get_mfc_free_elements(ctx); + tagstatus = ctx->ops->read_mfc_tagstatus(ctx); +@@ -1562,7 +1777,9 @@ + struct spu_context *ctx = file->private_data; + int ret; + +- spu_acquire(ctx); ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; + #if 0 + /* this currently hangs */ + ret = spufs_wait(ctx->mfc_wq, +@@ -1605,12 +1822,18 @@ + .mmap = spufs_mfc_mmap, + }; + +-static void spufs_npc_set(void *data, u64 val) ++static int spufs_npc_set(void *data, u64 val) + { + struct spu_context *ctx = data; +- spu_acquire(ctx); ++ int ret; ++ ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; + ctx->ops->npc_write(ctx, val); + spu_release(ctx); ++ ++ return 0; + } + + static u64 spufs_npc_get(struct spu_context *ctx) +@@ -1620,13 +1843,19 @@ + DEFINE_SPUFS_ATTRIBUTE(spufs_npc_ops, spufs_npc_get, spufs_npc_set, + "0x%llx\n", SPU_ATTR_ACQUIRE); + +-static void spufs_decr_set(void *data, u64 val) ++static int spufs_decr_set(void *data, u64 val) + { + struct spu_context *ctx = data; + struct spu_lscsa *lscsa = ctx->csa.lscsa; +- spu_acquire_saved(ctx); ++ int ret; ++ ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + lscsa->decr.slot[0] = (u32) val; + spu_release_saved(ctx); ++ ++ return 0; + } + + static u64 spufs_decr_get(struct spu_context *ctx) +@@ -1637,15 +1866,21 @@ + DEFINE_SPUFS_ATTRIBUTE(spufs_decr_ops, spufs_decr_get, spufs_decr_set, + "0x%llx\n", SPU_ATTR_ACQUIRE_SAVED); + +-static void spufs_decr_status_set(void *data, u64 val) ++static int spufs_decr_status_set(void *data, u64 val) + { + struct spu_context *ctx = data; +- spu_acquire_saved(ctx); ++ int ret; ++ ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + if (val) + ctx->csa.priv2.mfc_control_RW |= MFC_CNTL_DECREMENTER_RUNNING; + else + ctx->csa.priv2.mfc_control_RW &= ~MFC_CNTL_DECREMENTER_RUNNING; + spu_release_saved(ctx); ++ ++ return 0; + } + + static u64 spufs_decr_status_get(struct spu_context *ctx) +@@ -1659,13 +1894,19 @@ + spufs_decr_status_set, "0x%llx\n", + SPU_ATTR_ACQUIRE_SAVED); + +-static void spufs_event_mask_set(void *data, u64 val) ++static int spufs_event_mask_set(void *data, u64 val) + { + struct spu_context *ctx = data; + struct spu_lscsa *lscsa = ctx->csa.lscsa; +- spu_acquire_saved(ctx); ++ int ret; ++ ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + lscsa->event_mask.slot[0] = (u32) val; + spu_release_saved(ctx); ++ ++ return 0; + } + + static u64 spufs_event_mask_get(struct spu_context *ctx) +@@ -1690,13 +1931,19 @@ + DEFINE_SPUFS_ATTRIBUTE(spufs_event_status_ops, spufs_event_status_get, + NULL, "0x%llx\n", SPU_ATTR_ACQUIRE_SAVED) + +-static void spufs_srr0_set(void *data, u64 val) ++static int spufs_srr0_set(void *data, u64 val) + { + struct spu_context *ctx = data; + struct spu_lscsa *lscsa = ctx->csa.lscsa; +- spu_acquire_saved(ctx); ++ int ret; ++ ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + lscsa->srr0.slot[0] = (u32) val; + spu_release_saved(ctx); ++ ++ return 0; + } + + static u64 spufs_srr0_get(struct spu_context *ctx) +@@ -1727,10 +1974,12 @@ + return ctx->object_id; + } + +-static void spufs_object_id_set(void *data, u64 id) ++static int spufs_object_id_set(void *data, u64 id) + { + struct spu_context *ctx = data; + ctx->object_id = id; ++ ++ return 0; + } + + DEFINE_SPUFS_ATTRIBUTE(spufs_object_id_ops, spufs_object_id_get, +@@ -1777,13 +2026,13 @@ + static ssize_t __spufs_mbox_info_read(struct spu_context *ctx, + char __user *buf, size_t len, loff_t *pos) + { +- u32 mbox_stat; + u32 data; + +- mbox_stat = ctx->csa.prob.mb_stat_R; +- if (mbox_stat & 0x0000ff) { +- data = ctx->csa.prob.pu_mb_R; +- } ++ /* EOF if there's no entry in the mbox */ ++ if (!(ctx->csa.prob.mb_stat_R & 0x0000ff)) ++ return 0; ++ ++ data = ctx->csa.prob.pu_mb_R; + + return simple_read_from_buffer(buf, len, pos, &data, sizeof data); + } +@@ -1797,7 +2046,9 @@ + if (!access_ok(VERIFY_WRITE, buf, len)) + return -EFAULT; + +- spu_acquire_saved(ctx); ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + spin_lock(&ctx->csa.register_lock); + ret = __spufs_mbox_info_read(ctx, buf, len, pos); + spin_unlock(&ctx->csa.register_lock); +@@ -1815,13 +2066,13 @@ + static ssize_t __spufs_ibox_info_read(struct spu_context *ctx, + char __user *buf, size_t len, loff_t *pos) + { +- u32 ibox_stat; + u32 data; + +- ibox_stat = ctx->csa.prob.mb_stat_R; +- if (ibox_stat & 0xff0000) { +- data = ctx->csa.priv2.puint_mb_R; +- } ++ /* EOF if there's no entry in the ibox */ ++ if (!(ctx->csa.prob.mb_stat_R & 0xff0000)) ++ return 0; ++ ++ data = ctx->csa.priv2.puint_mb_R; + + return simple_read_from_buffer(buf, len, pos, &data, sizeof data); + } +@@ -1835,7 +2086,9 @@ + if (!access_ok(VERIFY_WRITE, buf, len)) + return -EFAULT; + +- spu_acquire_saved(ctx); ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + spin_lock(&ctx->csa.register_lock); + ret = __spufs_ibox_info_read(ctx, buf, len, pos); + spin_unlock(&ctx->csa.register_lock); +@@ -1876,7 +2129,9 @@ + if (!access_ok(VERIFY_WRITE, buf, len)) + return -EFAULT; + +- spu_acquire_saved(ctx); ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + spin_lock(&ctx->csa.register_lock); + ret = __spufs_wbox_info_read(ctx, buf, len, pos); + spin_unlock(&ctx->csa.register_lock); +@@ -1926,7 +2181,9 @@ + if (!access_ok(VERIFY_WRITE, buf, len)) + return -EFAULT; + +- spu_acquire_saved(ctx); ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + spin_lock(&ctx->csa.register_lock); + ret = __spufs_dma_info_read(ctx, buf, len, pos); + spin_unlock(&ctx->csa.register_lock); +@@ -1977,7 +2234,9 @@ + struct spu_context *ctx = file->private_data; + int ret; + +- spu_acquire_saved(ctx); ++ ret = spu_acquire_saved(ctx); ++ if (ret) ++ return ret; + spin_lock(&ctx->csa.register_lock); + ret = __spufs_proxydma_info_read(ctx, buf, len, pos); + spin_unlock(&ctx->csa.register_lock); +@@ -2066,8 +2325,12 @@ + static int spufs_show_stat(struct seq_file *s, void *private) + { + struct spu_context *ctx = s->private; ++ int ret; ++ ++ ret = spu_acquire(ctx); ++ if (ret) ++ return ret; + +- spu_acquire(ctx); + seq_printf(s, "%s %llu %llu %llu %llu " + "%llu %llu %llu %llu %llu %llu %llu %llu\n", + ctx_state_names[ctx->stats.util_state], +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spufs/hw_ops.c powerpc.git/arch/powerpc/platforms/cell/spufs/hw_ops.c +--- linux-2.6.24/arch/powerpc/platforms/cell/spufs/hw_ops.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spufs/hw_ops.c 2008-01-28 20:25:49.000000000 +0100 +@@ -76,16 +76,18 @@ + if (stat & 0xff0000) + ret |= POLLIN | POLLRDNORM; + else { +- spu_int_stat_clear(spu, 2, 0x1); +- spu_int_mask_or(spu, 2, 0x1); ++ spu_int_stat_clear(spu, 2, CLASS2_MAILBOX_INTR); ++ spu_int_mask_or(spu, 2, CLASS2_ENABLE_MAILBOX_INTR); + } + } + if (events & (POLLOUT | POLLWRNORM)) { + if (stat & 0x00ff00) + ret = POLLOUT | POLLWRNORM; + else { +- spu_int_stat_clear(spu, 2, 0x10); +- spu_int_mask_or(spu, 2, 0x10); ++ spu_int_stat_clear(spu, 2, ++ CLASS2_MAILBOX_THRESHOLD_INTR); ++ spu_int_mask_or(spu, 2, ++ CLASS2_ENABLE_MAILBOX_THRESHOLD_INTR); + } + } + spin_unlock_irq(&spu->register_lock); +@@ -106,7 +108,7 @@ + ret = 4; + } else { + /* make sure we get woken up by the interrupt */ +- spu_int_mask_or(spu, 2, 0x1); ++ spu_int_mask_or(spu, 2, CLASS2_ENABLE_MAILBOX_INTR); + ret = 0; + } + spin_unlock_irq(&spu->register_lock); +@@ -127,7 +129,7 @@ + } else { + /* make sure we get woken up by the interrupt when space + becomes available */ +- spu_int_mask_or(spu, 2, 0x10); ++ spu_int_mask_or(spu, 2, CLASS2_ENABLE_MAILBOX_THRESHOLD_INTR); + ret = 0; + } + spin_unlock_irq(&spu->register_lock); +@@ -206,6 +208,11 @@ + return ctx->spu->local_store; + } + ++static void spu_hw_privcntl_write(struct spu_context *ctx, u64 val) ++{ ++ out_be64(&ctx->spu->priv2->spu_privcntl_RW, val); ++} ++ + static u32 spu_hw_runcntl_read(struct spu_context *ctx) + { + return in_be32(&ctx->spu->problem->spu_runcntl_RW); +@@ -215,11 +222,21 @@ + { + spin_lock_irq(&ctx->spu->register_lock); + if (val & SPU_RUNCNTL_ISOLATE) +- out_be64(&ctx->spu->priv2->spu_privcntl_RW, 4LL); ++ spu_hw_privcntl_write(ctx, ++ SPU_PRIVCNT_LOAD_REQUEST_ENABLE_MASK); + out_be32(&ctx->spu->problem->spu_runcntl_RW, val); + spin_unlock_irq(&ctx->spu->register_lock); + } + ++static void spu_hw_runcntl_stop(struct spu_context *ctx) ++{ ++ spin_lock_irq(&ctx->spu->register_lock); ++ out_be32(&ctx->spu->problem->spu_runcntl_RW, SPU_RUNCNTL_STOP); ++ while (in_be32(&ctx->spu->problem->spu_status_R) & SPU_STATUS_RUNNING) ++ cpu_relax(); ++ spin_unlock_irq(&ctx->spu->register_lock); ++} ++ + static void spu_hw_master_start(struct spu_context *ctx) + { + struct spu *spu = ctx->spu; +@@ -319,8 +336,10 @@ + .npc_write = spu_hw_npc_write, + .status_read = spu_hw_status_read, + .get_ls = spu_hw_get_ls, ++ .privcntl_write = spu_hw_privcntl_write, + .runcntl_read = spu_hw_runcntl_read, + .runcntl_write = spu_hw_runcntl_write, ++ .runcntl_stop = spu_hw_runcntl_stop, + .master_start = spu_hw_master_start, + .master_stop = spu_hw_master_stop, + .set_mfc_query = spu_hw_set_mfc_query, +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spufs/lscsa_alloc.c powerpc.git/arch/powerpc/platforms/cell/spufs/lscsa_alloc.c +--- linux-2.6.24/arch/powerpc/platforms/cell/spufs/lscsa_alloc.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spufs/lscsa_alloc.c 2008-01-28 20:25:49.000000000 +0100 +@@ -28,6 +28,8 @@ + #include <asm/spu_csa.h> + #include <asm/mmu.h> + ++#include "spufs.h" ++ + static int spu_alloc_lscsa_std(struct spu_state *csa) + { + struct spu_lscsa *lscsa; +@@ -73,7 +75,7 @@ + int i, j, n_4k; + + /* Check availability of 64K pages */ +- if (mmu_psize_defs[MMU_PAGE_64K].shift == 0) ++ if (!spu_64k_pages_available()) + goto fail; + + csa->use_big_pages = 1; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spufs/run.c powerpc.git/arch/powerpc/platforms/cell/spufs/run.c +--- linux-2.6.24/arch/powerpc/platforms/cell/spufs/run.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spufs/run.c 2008-01-28 20:25:49.000000000 +0100 +@@ -15,24 +15,55 @@ + { + struct spu_context *ctx = spu->ctx; + +- wake_up_all(&ctx->stop_wq); ++ /* ++ * It should be impossible to preempt a context while an exception ++ * is being processed, since the context switch code is specially ++ * coded to deal with interrupts ... But, just in case, sanity check ++ * the context pointer. It is OK to return doing nothing since ++ * the exception will be regenerated when the context is resumed. ++ */ ++ if (ctx) { ++ /* Copy exception arguments into module specific structure */ ++ ctx->csa.class_0_pending = spu->class_0_pending; ++ ctx->csa.dsisr = spu->dsisr; ++ ctx->csa.dar = spu->dar; ++ ++ /* ensure that the exception status has hit memory before a ++ * thread waiting on the context's stop queue is woken */ ++ smp_wmb(); ++ ++ wake_up_all(&ctx->stop_wq); ++ } ++ ++ /* Clear callback arguments from spu structure */ ++ spu->class_0_pending = 0; ++ spu->dsisr = 0; ++ spu->dar = 0; + } + +-static inline int spu_stopped(struct spu_context *ctx, u32 *stat) ++int spu_stopped(struct spu_context *ctx, u32 *stat) + { +- struct spu *spu; +- u64 pte_fault; ++ u64 dsisr; ++ u32 stopped; + + *stat = ctx->ops->status_read(ctx); + +- spu = ctx->spu; +- if (ctx->state != SPU_STATE_RUNNABLE || +- test_bit(SPU_SCHED_NOTIFY_ACTIVE, &ctx->sched_flags)) ++ if (test_bit(SPU_SCHED_NOTIFY_ACTIVE, &ctx->sched_flags)) ++ return 1; ++ ++ stopped = SPU_STATUS_INVALID_INSTR | SPU_STATUS_SINGLE_STEP | ++ SPU_STATUS_STOPPED_BY_HALT | SPU_STATUS_STOPPED_BY_STOP; ++ if (*stat & stopped) ++ return 1; ++ ++ dsisr = ctx->csa.dsisr; ++ if (dsisr & (MFC_DSISR_PTE_NOT_FOUND | MFC_DSISR_ACCESS_DENIED)) + return 1; +- pte_fault = spu->dsisr & +- (MFC_DSISR_PTE_NOT_FOUND | MFC_DSISR_ACCESS_DENIED); +- return (!(*stat & SPU_STATUS_RUNNING) || pte_fault || spu->class_0_pending) ? +- 1 : 0; ++ ++ if (ctx->csa.class_0_pending) ++ return 1; ++ ++ return 0; + } + + static int spu_setup_isolated(struct spu_context *ctx) +@@ -128,34 +159,66 @@ + + static int spu_run_init(struct spu_context *ctx, u32 *npc) + { ++ unsigned long runcntl = SPU_RUNCNTL_RUNNABLE; ++ int ret; ++ + spuctx_switch_state(ctx, SPU_UTIL_SYSTEM); + +- if (ctx->flags & SPU_CREATE_ISOLATE) { +- unsigned long runcntl; ++ /* ++ * NOSCHED is synchronous scheduling with respect to the caller. ++ * The caller waits for the context to be loaded. ++ */ ++ if (ctx->flags & SPU_CREATE_NOSCHED) { ++ if (ctx->state == SPU_STATE_SAVED) { ++ ret = spu_activate(ctx, 0); ++ if (ret) ++ return ret; ++ } ++ } + ++ /* ++ * Apply special setup as required. ++ */ ++ if (ctx->flags & SPU_CREATE_ISOLATE) { + if (!(ctx->ops->status_read(ctx) & SPU_STATUS_ISOLATED_STATE)) { +- int ret = spu_setup_isolated(ctx); ++ ret = spu_setup_isolated(ctx); + if (ret) + return ret; + } + +- /* if userspace has set the runcntrl register (eg, to issue an +- * isolated exit), we need to re-set it here */ ++ /* ++ * If userspace has set the runcntrl register (eg, to ++ * issue an isolated exit), we need to re-set it here ++ */ + runcntl = ctx->ops->runcntl_read(ctx) & + (SPU_RUNCNTL_RUNNABLE | SPU_RUNCNTL_ISOLATE); + if (runcntl == 0) + runcntl = SPU_RUNCNTL_RUNNABLE; ++ } ++ ++ if (ctx->flags & SPU_CREATE_NOSCHED) { ++ spuctx_switch_state(ctx, SPU_UTIL_USER); + ctx->ops->runcntl_write(ctx, runcntl); + } else { +- unsigned long mode = SPU_PRIVCNTL_MODE_NORMAL; +- ctx->ops->npc_write(ctx, *npc); ++ unsigned long privcntl; ++ + if (test_thread_flag(TIF_SINGLESTEP)) +- mode = SPU_PRIVCNTL_MODE_SINGLE_STEP; +- out_be64(&ctx->spu->priv2->spu_privcntl_RW, mode); +- ctx->ops->runcntl_write(ctx, SPU_RUNCNTL_RUNNABLE); +- } ++ privcntl = SPU_PRIVCNTL_MODE_SINGLE_STEP; ++ else ++ privcntl = SPU_PRIVCNTL_MODE_NORMAL; + +- spuctx_switch_state(ctx, SPU_UTIL_USER); ++ ctx->ops->npc_write(ctx, *npc); ++ ctx->ops->privcntl_write(ctx, privcntl); ++ ctx->ops->runcntl_write(ctx, runcntl); ++ ++ if (ctx->state == SPU_STATE_SAVED) { ++ ret = spu_activate(ctx, 0); ++ if (ret) ++ return ret; ++ } else { ++ spuctx_switch_state(ctx, SPU_UTIL_USER); ++ } ++ } + + return 0; + } +@@ -165,6 +228,8 @@ + { + int ret = 0; + ++ spu_del_from_rq(ctx); ++ + *status = ctx->ops->status_read(ctx); + *npc = ctx->ops->npc_read(ctx); + +@@ -177,26 +242,6 @@ + return ret; + } + +-static int spu_reacquire_runnable(struct spu_context *ctx, u32 *npc, +- u32 *status) +-{ +- int ret; +- +- ret = spu_run_fini(ctx, npc, status); +- if (ret) +- return ret; +- +- if (*status & (SPU_STATUS_STOPPED_BY_STOP | SPU_STATUS_STOPPED_BY_HALT)) +- return *status; +- +- ret = spu_acquire_runnable(ctx, 0); +- if (ret) +- return ret; +- +- spuctx_switch_state(ctx, SPU_UTIL_USER); +- return 0; +-} +- + /* + * SPU syscall restarting is tricky because we violate the basic + * assumption that the signal handler is running on the interrupted +@@ -247,7 +292,7 @@ + u32 ls_pointer, npc; + void __iomem *ls; + long spu_ret; +- int ret; ++ int ret, ret2; + + /* get syscall block from local store */ + npc = ctx->ops->npc_read(ctx) & ~3; +@@ -269,9 +314,11 @@ + if (spu_ret <= -ERESTARTSYS) { + ret = spu_handle_restartsys(ctx, &spu_ret, &npc); + } +- spu_acquire(ctx); ++ ret2 = spu_acquire(ctx); + if (ret == -ERESTARTSYS) + return ret; ++ if (ret2) ++ return -EINTR; + } + + /* write result, jump over indirect pointer */ +@@ -281,18 +328,6 @@ + return ret; + } + +-static inline int spu_process_events(struct spu_context *ctx) +-{ +- struct spu *spu = ctx->spu; +- int ret = 0; +- +- if (spu->class_0_pending) +- ret = spu_irq_class_0_bottom(spu); +- if (!ret && signal_pending(current)) +- ret = -ERESTARTSYS; +- return ret; +-} +- + long spufs_run_spu(struct spu_context *ctx, u32 *npc, u32 *event) + { + int ret; +@@ -302,29 +337,14 @@ + if (mutex_lock_interruptible(&ctx->run_mutex)) + return -ERESTARTSYS; + +- ctx->ops->master_start(ctx); ++ spu_enable_spu(ctx); + ctx->event_return = 0; + +- spu_acquire(ctx); +- if (ctx->state == SPU_STATE_SAVED) { +- __spu_update_sched_info(ctx); +- spu_set_timeslice(ctx); +- +- ret = spu_activate(ctx, 0); +- if (ret) { +- spu_release(ctx); +- goto out; +- } +- } else { +- /* +- * We have to update the scheduling priority under active_mutex +- * to protect against find_victim(). +- * +- * No need to update the timeslice ASAP, it will get updated +- * once the current one has expired. +- */ +- spu_update_sched_info(ctx); +- } ++ ret = spu_acquire(ctx); ++ if (ret) ++ goto out_unlock; ++ ++ spu_update_sched_info(ctx); + + ret = spu_run_init(ctx, npc); + if (ret) { +@@ -358,14 +378,12 @@ + if (ret) + break; + +- if (unlikely(ctx->state != SPU_STATE_RUNNABLE)) { +- ret = spu_reacquire_runnable(ctx, npc, &status); +- if (ret) +- goto out2; +- continue; +- } +- ret = spu_process_events(ctx); ++ ret = spufs_handle_class0(ctx); ++ if (ret) ++ break; + ++ if (signal_pending(current)) ++ ret = -ERESTARTSYS; + } while (!ret && !(status & (SPU_STATUS_STOPPED_BY_STOP | + SPU_STATUS_STOPPED_BY_HALT | + SPU_STATUS_SINGLE_STEP))); +@@ -376,11 +394,10 @@ + ctx->stats.libassist++; + + +- ctx->ops->master_stop(ctx); ++ spu_disable_spu(ctx); + ret = spu_run_fini(ctx, npc, &status); + spu_yield(ctx); + +-out2: + if ((ret == 0) || + ((ret == -ERESTARTSYS) && + ((status & SPU_STATUS_STOPPED_BY_HALT) || +@@ -401,6 +418,7 @@ + + out: + *event = ctx->event_return; ++out_unlock: + mutex_unlock(&ctx->run_mutex); + return ret; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spufs/sched.c powerpc.git/arch/powerpc/platforms/cell/spufs/sched.c +--- linux-2.6.24/arch/powerpc/platforms/cell/spufs/sched.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spufs/sched.c 2008-01-28 20:25:49.000000000 +0100 +@@ -58,6 +58,7 @@ + static struct spu_prio_array *spu_prio; + static struct task_struct *spusched_task; + static struct timer_list spusched_timer; ++static struct timer_list spuloadavg_timer; + + /* + * Priority of a normal, non-rt, non-niced'd process (aka nice level 0). +@@ -105,15 +106,21 @@ + void __spu_update_sched_info(struct spu_context *ctx) + { + /* +- * 32-Bit assignment are atomic on powerpc, and we don't care about +- * memory ordering here because retriving the controlling thread is +- * per defintion racy. ++ * assert that the context is not on the runqueue, so it is safe ++ * to change its scheduling parameters. ++ */ ++ BUG_ON(!list_empty(&ctx->rq)); ++ ++ /* ++ * 32-Bit assignments are atomic on powerpc, and we don't care about ++ * memory ordering here because retrieving the controlling thread is ++ * per definition racy. + */ + ctx->tid = current->pid; + + /* + * We do our own priority calculations, so we normally want +- * ->static_prio to start with. Unfortunately thies field ++ * ->static_prio to start with. Unfortunately this field + * contains junk for threads with a realtime scheduling + * policy so we have to look at ->prio in this case. + */ +@@ -124,23 +131,32 @@ + ctx->policy = current->policy; + + /* +- * A lot of places that don't hold list_mutex poke into +- * cpus_allowed, including grab_runnable_context which +- * already holds the runq_lock. So abuse runq_lock +- * to protect this field aswell. ++ * TO DO: the context may be loaded, so we may need to activate ++ * it again on a different node. But it shouldn't hurt anything ++ * to update its parameters, because we know that the scheduler ++ * is not actively looking at this field, since it is not on the ++ * runqueue. The context will be rescheduled on the proper node ++ * if it is timesliced or preempted. + */ +- spin_lock(&spu_prio->runq_lock); + ctx->cpus_allowed = current->cpus_allowed; +- spin_unlock(&spu_prio->runq_lock); + } + + void spu_update_sched_info(struct spu_context *ctx) + { +- int node = ctx->spu->node; ++ int node; + +- mutex_lock(&cbe_spu_info[node].list_mutex); +- __spu_update_sched_info(ctx); +- mutex_unlock(&cbe_spu_info[node].list_mutex); ++ if (ctx->state == SPU_STATE_RUNNABLE) { ++ node = ctx->spu->node; ++ ++ /* ++ * Take list_mutex to sync with find_victim(). ++ */ ++ mutex_lock(&cbe_spu_info[node].list_mutex); ++ __spu_update_sched_info(ctx); ++ mutex_unlock(&cbe_spu_info[node].list_mutex); ++ } else { ++ __spu_update_sched_info(ctx); ++ } + } + + static int __node_allowed(struct spu_context *ctx, int node) +@@ -174,7 +190,7 @@ + * Wake up the active spu_contexts. + * + * When the awakened processes see their "notify_active" flag is set, +- * they will call spu_switch_notify(); ++ * they will call spu_switch_notify(). + */ + for_each_online_node(node) { + struct spu *spu; +@@ -221,7 +237,6 @@ + spu->wbox_callback = spufs_wbox_callback; + spu->stop_callback = spufs_stop_callback; + spu->mfc_callback = spufs_mfc_callback; +- spu->dma_callback = spufs_dma_callback; + mb(); + spu_unmap_mappings(ctx); + spu_restore(&ctx->csa, spu); +@@ -409,7 +424,6 @@ + spu->wbox_callback = NULL; + spu->stop_callback = NULL; + spu->mfc_callback = NULL; +- spu->dma_callback = NULL; + spu_associate_mm(spu, NULL); + spu->pid = 0; + spu->tgid = 0; +@@ -454,6 +468,13 @@ + } + } + ++static void spu_add_to_rq(struct spu_context *ctx) ++{ ++ spin_lock(&spu_prio->runq_lock); ++ __spu_add_to_rq(ctx); ++ spin_unlock(&spu_prio->runq_lock); ++} ++ + static void __spu_del_from_rq(struct spu_context *ctx) + { + int prio = ctx->prio; +@@ -468,10 +489,24 @@ + } + } + ++void spu_del_from_rq(struct spu_context *ctx) ++{ ++ spin_lock(&spu_prio->runq_lock); ++ __spu_del_from_rq(ctx); ++ spin_unlock(&spu_prio->runq_lock); ++} ++ + static void spu_prio_wait(struct spu_context *ctx) + { + DEFINE_WAIT(wait); + ++ /* ++ * The caller must explicitly wait for a context to be loaded ++ * if the nosched flag is set. If NOSCHED is not set, the caller ++ * queues the context and waits for an spu event or error. ++ */ ++ BUG_ON(!(ctx->flags & SPU_CREATE_NOSCHED)); ++ + spin_lock(&spu_prio->runq_lock); + prepare_to_wait_exclusive(&ctx->stop_wq, &wait, TASK_INTERRUPTIBLE); + if (!signal_pending(current)) { +@@ -555,7 +590,7 @@ + /* + * Look for a possible preemption candidate on the local node first. + * If there is no candidate look at the other nodes. This isn't +- * exactly fair, but so far the whole spu schedule tries to keep ++ * exactly fair, but so far the whole spu scheduler tries to keep + * a strong node affinity. We might want to fine-tune this in + * the future. + */ +@@ -571,6 +606,7 @@ + struct spu_context *tmp = spu->ctx; + + if (tmp && tmp->prio > ctx->prio && ++ !(tmp->flags & SPU_CREATE_NOSCHED) && + (!victim || tmp->prio > victim->prio)) + victim = spu->ctx; + } +@@ -582,6 +618,10 @@ + * higher priority contexts before lower priority + * ones, so this is safe until we introduce + * priority inheritance schemes. ++ * ++ * XXX if the highest priority context is locked, ++ * this can loop a long time. Might be better to ++ * look at another context or give up after X retries. + */ + if (!mutex_trylock(&victim->state_mutex)) { + victim = NULL; +@@ -589,10 +629,10 @@ + } + + spu = victim->spu; +- if (!spu) { ++ if (!spu || victim->prio <= ctx->prio) { + /* + * This race can happen because we've dropped +- * the active list mutex. No a problem, just ++ * the active list mutex. Not a problem, just + * restart the search. + */ + mutex_unlock(&victim->state_mutex); +@@ -607,13 +647,10 @@ + + victim->stats.invol_ctx_switch++; + spu->stats.invol_ctx_switch++; ++ spu_add_to_rq(victim); ++ + mutex_unlock(&victim->state_mutex); +- /* +- * We need to break out of the wait loop in spu_run +- * manually to ensure this context gets put on the +- * runqueue again ASAP. +- */ +- wake_up(&victim->stop_wq); ++ + return spu; + } + } +@@ -621,6 +658,50 @@ + return NULL; + } + ++static void __spu_schedule(struct spu *spu, struct spu_context *ctx) ++{ ++ int node = spu->node; ++ int success = 0; ++ ++ spu_set_timeslice(ctx); ++ ++ mutex_lock(&cbe_spu_info[node].list_mutex); ++ if (spu->ctx == NULL) { ++ spu_bind_context(spu, ctx); ++ cbe_spu_info[node].nr_active++; ++ spu->alloc_state = SPU_USED; ++ success = 1; ++ } ++ mutex_unlock(&cbe_spu_info[node].list_mutex); ++ ++ if (success) ++ wake_up_all(&ctx->run_wq); ++ else ++ spu_add_to_rq(ctx); ++} ++ ++static void spu_schedule(struct spu *spu, struct spu_context *ctx) ++{ ++ /* not a candidate for interruptible because it's called either ++ from the scheduler thread or from spu_deactivate */ ++ mutex_lock(&ctx->state_mutex); ++ __spu_schedule(spu, ctx); ++ spu_release(ctx); ++} ++ ++static void spu_unschedule(struct spu *spu, struct spu_context *ctx) ++{ ++ int node = spu->node; ++ ++ mutex_lock(&cbe_spu_info[node].list_mutex); ++ cbe_spu_info[node].nr_active--; ++ spu->alloc_state = SPU_FREE; ++ spu_unbind_context(spu, ctx); ++ ctx->stats.invol_ctx_switch++; ++ spu->stats.invol_ctx_switch++; ++ mutex_unlock(&cbe_spu_info[node].list_mutex); ++} ++ + /** + * spu_activate - find a free spu for a context and execute it + * @ctx: spu context to schedule +@@ -632,39 +713,47 @@ + */ + int spu_activate(struct spu_context *ctx, unsigned long flags) + { +- do { +- struct spu *spu; ++ struct spu *spu; + +- /* +- * If there are multiple threads waiting for a single context +- * only one actually binds the context while the others will +- * only be able to acquire the state_mutex once the context +- * already is in runnable state. +- */ +- if (ctx->spu) +- return 0; ++ /* ++ * If there are multiple threads waiting for a single context ++ * only one actually binds the context while the others will ++ * only be able to acquire the state_mutex once the context ++ * already is in runnable state. ++ */ ++ if (ctx->spu) ++ return 0; + +- spu = spu_get_idle(ctx); +- /* +- * If this is a realtime thread we try to get it running by +- * preempting a lower priority thread. +- */ +- if (!spu && rt_prio(ctx->prio)) +- spu = find_victim(ctx); +- if (spu) { +- int node = spu->node; ++spu_activate_top: ++ if (signal_pending(current)) ++ return -ERESTARTSYS; + +- mutex_lock(&cbe_spu_info[node].list_mutex); +- spu_bind_context(spu, ctx); +- cbe_spu_info[node].nr_active++; +- mutex_unlock(&cbe_spu_info[node].list_mutex); +- return 0; +- } ++ spu = spu_get_idle(ctx); ++ /* ++ * If this is a realtime thread we try to get it running by ++ * preempting a lower priority thread. ++ */ ++ if (!spu && rt_prio(ctx->prio)) ++ spu = find_victim(ctx); ++ if (spu) { ++ unsigned long runcntl; + ++ runcntl = ctx->ops->runcntl_read(ctx); ++ __spu_schedule(spu, ctx); ++ if (runcntl & SPU_RUNCNTL_RUNNABLE) ++ spuctx_switch_state(ctx, SPU_UTIL_USER); ++ ++ return 0; ++ } ++ ++ if (ctx->flags & SPU_CREATE_NOSCHED) { + spu_prio_wait(ctx); +- } while (!signal_pending(current)); ++ goto spu_activate_top; ++ } ++ ++ spu_add_to_rq(ctx); + +- return -ERESTARTSYS; ++ return 0; + } + + /** +@@ -706,21 +795,19 @@ + if (spu) { + new = grab_runnable_context(max_prio, spu->node); + if (new || force) { +- int node = spu->node; +- +- mutex_lock(&cbe_spu_info[node].list_mutex); +- spu_unbind_context(spu, ctx); +- spu->alloc_state = SPU_FREE; +- cbe_spu_info[node].nr_active--; +- mutex_unlock(&cbe_spu_info[node].list_mutex); +- +- ctx->stats.vol_ctx_switch++; +- spu->stats.vol_ctx_switch++; +- +- if (new) +- wake_up(&new->stop_wq); ++ spu_unschedule(spu, ctx); ++ if (new) { ++ if (new->flags & SPU_CREATE_NOSCHED) ++ wake_up(&new->stop_wq); ++ else { ++ spu_release(ctx); ++ spu_schedule(spu, new); ++ /* this one can't easily be made ++ interruptible */ ++ mutex_lock(&ctx->state_mutex); ++ } ++ } + } +- + } + + return new != NULL; +@@ -757,43 +844,38 @@ + + static noinline void spusched_tick(struct spu_context *ctx) + { ++ struct spu_context *new = NULL; ++ struct spu *spu = NULL; ++ u32 status; ++ ++ if (spu_acquire(ctx)) ++ BUG(); /* a kernel thread never has signals pending */ ++ ++ if (ctx->state != SPU_STATE_RUNNABLE) ++ goto out; ++ if (spu_stopped(ctx, &status)) ++ goto out; + if (ctx->flags & SPU_CREATE_NOSCHED) +- return; ++ goto out; + if (ctx->policy == SCHED_FIFO) +- return; ++ goto out; + + if (--ctx->time_slice) +- return; +- +- /* +- * Unfortunately list_mutex ranks outside of state_mutex, so +- * we have to trylock here. If we fail give the context another +- * tick and try again. +- */ +- if (mutex_trylock(&ctx->state_mutex)) { +- struct spu *spu = ctx->spu; +- struct spu_context *new; ++ goto out; + +- new = grab_runnable_context(ctx->prio + 1, spu->node); +- if (new) { +- spu_unbind_context(spu, ctx); +- ctx->stats.invol_ctx_switch++; +- spu->stats.invol_ctx_switch++; +- spu->alloc_state = SPU_FREE; +- cbe_spu_info[spu->node].nr_active--; +- wake_up(&new->stop_wq); +- /* +- * We need to break out of the wait loop in +- * spu_run manually to ensure this context +- * gets put on the runqueue again ASAP. +- */ +- wake_up(&ctx->stop_wq); +- } +- spu_set_timeslice(ctx); +- mutex_unlock(&ctx->state_mutex); ++ spu = ctx->spu; ++ new = grab_runnable_context(ctx->prio + 1, spu->node); ++ if (new) { ++ spu_unschedule(spu, ctx); ++ spu_add_to_rq(ctx); + } else { + ctx->time_slice++; + } ++out: ++ spu_release(ctx); ++ ++ if (new) ++ spu_schedule(spu, new); + } + + /** +@@ -817,35 +899,31 @@ + } + + /** +- * spu_calc_load - given tick count, update the avenrun load estimates. +- * @tick: tick count ++ * spu_calc_load - update the avenrun load estimates. + * + * No locking against reading these values from userspace, as for + * the CPU loadavg code. + */ +-static void spu_calc_load(unsigned long ticks) ++static void spu_calc_load(void) + { + unsigned long active_tasks; /* fixed-point */ +- static int count = LOAD_FREQ; + +- count -= ticks; +- +- if (unlikely(count < 0)) { +- active_tasks = count_active_contexts() * FIXED_1; +- do { +- CALC_LOAD(spu_avenrun[0], EXP_1, active_tasks); +- CALC_LOAD(spu_avenrun[1], EXP_5, active_tasks); +- CALC_LOAD(spu_avenrun[2], EXP_15, active_tasks); +- count += LOAD_FREQ; +- } while (count < 0); +- } ++ active_tasks = count_active_contexts() * FIXED_1; ++ CALC_LOAD(spu_avenrun[0], EXP_1, active_tasks); ++ CALC_LOAD(spu_avenrun[1], EXP_5, active_tasks); ++ CALC_LOAD(spu_avenrun[2], EXP_15, active_tasks); + } + + static void spusched_wake(unsigned long data) + { + mod_timer(&spusched_timer, jiffies + SPUSCHED_TICK); + wake_up_process(spusched_task); +- spu_calc_load(SPUSCHED_TICK); ++} ++ ++static void spuloadavg_wake(unsigned long data) ++{ ++ mod_timer(&spuloadavg_timer, jiffies + LOAD_FREQ); ++ spu_calc_load(); + } + + static int spusched_thread(void *unused) +@@ -857,17 +935,58 @@ + set_current_state(TASK_INTERRUPTIBLE); + schedule(); + for (node = 0; node < MAX_NUMNODES; node++) { +- mutex_lock(&cbe_spu_info[node].list_mutex); +- list_for_each_entry(spu, &cbe_spu_info[node].spus, cbe_list) +- if (spu->ctx) +- spusched_tick(spu->ctx); +- mutex_unlock(&cbe_spu_info[node].list_mutex); ++ struct mutex *mtx = &cbe_spu_info[node].list_mutex; ++ ++ mutex_lock(mtx); ++ list_for_each_entry(spu, &cbe_spu_info[node].spus, ++ cbe_list) { ++ struct spu_context *ctx = spu->ctx; ++ ++ if (ctx) { ++ mutex_unlock(mtx); ++ spusched_tick(ctx); ++ mutex_lock(mtx); ++ } ++ } ++ mutex_unlock(mtx); + } + } + + return 0; + } + ++void spuctx_switch_state(struct spu_context *ctx, ++ enum spu_utilization_state new_state) ++{ ++ unsigned long long curtime; ++ signed long long delta; ++ struct timespec ts; ++ struct spu *spu; ++ enum spu_utilization_state old_state; ++ ++ ktime_get_ts(&ts); ++ curtime = timespec_to_ns(&ts); ++ delta = curtime - ctx->stats.tstamp; ++ ++ WARN_ON(!mutex_is_locked(&ctx->state_mutex)); ++ WARN_ON(delta < 0); ++ ++ spu = ctx->spu; ++ old_state = ctx->stats.util_state; ++ ctx->stats.util_state = new_state; ++ ctx->stats.tstamp = curtime; ++ ++ /* ++ * Update the physical SPU utilization statistics. ++ */ ++ if (spu) { ++ ctx->stats.times[old_state] += delta; ++ spu->stats.times[old_state] += delta; ++ spu->stats.util_state = new_state; ++ spu->stats.tstamp = curtime; ++ } ++} ++ + #define LOAD_INT(x) ((x) >> FSHIFT) + #define LOAD_FRAC(x) LOAD_INT(((x) & (FIXED_1-1)) * 100) + +@@ -881,7 +1000,7 @@ + + /* + * Note that last_pid doesn't really make much sense for the +- * SPU loadavg (it even seems very odd on the CPU side..), ++ * SPU loadavg (it even seems very odd on the CPU side...), + * but we include it here to have a 100% compatible interface. + */ + seq_printf(s, "%d.%02d %d.%02d %d.%02d %ld/%d %d\n", +@@ -922,6 +1041,7 @@ + spin_lock_init(&spu_prio->runq_lock); + + setup_timer(&spusched_timer, spusched_wake, 0); ++ setup_timer(&spuloadavg_timer, spuloadavg_wake, 0); + + spusched_task = kthread_run(spusched_thread, NULL, "spusched"); + if (IS_ERR(spusched_task)) { +@@ -929,6 +1049,8 @@ + goto out_free_spu_prio; + } + ++ mod_timer(&spuloadavg_timer, 0); ++ + entry = create_proc_entry("spu_loadavg", 0, NULL); + if (!entry) + goto out_stop_kthread; +@@ -954,6 +1076,7 @@ + remove_proc_entry("spu_loadavg", NULL); + + del_timer_sync(&spusched_timer); ++ del_timer_sync(&spuloadavg_timer); + kthread_stop(spusched_task); + + for (node = 0; node < MAX_NUMNODES; node++) { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spufs/spufs.h powerpc.git/arch/powerpc/platforms/cell/spufs/spufs.h +--- linux-2.6.24/arch/powerpc/platforms/cell/spufs/spufs.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spufs/spufs.h 2008-01-28 20:25:49.000000000 +0100 +@@ -71,6 +71,7 @@ + wait_queue_head_t wbox_wq; + wait_queue_head_t stop_wq; + wait_queue_head_t mfc_wq; ++ wait_queue_head_t run_wq; + struct fasync_struct *ibox_fasync; + struct fasync_struct *wbox_fasync; + struct fasync_struct *mfc_fasync; +@@ -168,8 +169,10 @@ + void (*npc_write) (struct spu_context * ctx, u32 data); + u32(*status_read) (struct spu_context * ctx); + char*(*get_ls) (struct spu_context * ctx); ++ void (*privcntl_write) (struct spu_context *ctx, u64 data); + u32 (*runcntl_read) (struct spu_context * ctx); + void (*runcntl_write) (struct spu_context * ctx, u32 data); ++ void (*runcntl_stop) (struct spu_context * ctx); + void (*master_start) (struct spu_context * ctx); + void (*master_stop) (struct spu_context * ctx); + int (*set_mfc_query)(struct spu_context * ctx, u32 mask, u32 mode); +@@ -219,15 +222,16 @@ + + /* fault handling */ + int spufs_handle_class1(struct spu_context *ctx); ++int spufs_handle_class0(struct spu_context *ctx); + + /* affinity */ + struct spu *affinity_check(struct spu_context *ctx); + + /* context management */ + extern atomic_t nr_spu_contexts; +-static inline void spu_acquire(struct spu_context *ctx) ++static inline int __must_check spu_acquire(struct spu_context *ctx) + { +- mutex_lock(&ctx->state_mutex); ++ return mutex_lock_interruptible(&ctx->state_mutex); + } + + static inline void spu_release(struct spu_context *ctx) +@@ -242,10 +246,11 @@ + void spu_unmap_mappings(struct spu_context *ctx); + + void spu_forget(struct spu_context *ctx); +-int spu_acquire_runnable(struct spu_context *ctx, unsigned long flags); +-void spu_acquire_saved(struct spu_context *ctx); ++int __must_check spu_acquire_saved(struct spu_context *ctx); + void spu_release_saved(struct spu_context *ctx); + ++int spu_stopped(struct spu_context *ctx, u32 * stat); ++void spu_del_from_rq(struct spu_context *ctx); + int spu_activate(struct spu_context *ctx, unsigned long flags); + void spu_deactivate(struct spu_context *ctx); + void spu_yield(struct spu_context *ctx); +@@ -279,7 +284,9 @@ + } \ + spu_release(ctx); \ + schedule(); \ +- spu_acquire(ctx); \ ++ __ret = spu_acquire(ctx); \ ++ if (__ret) \ ++ break; \ + } \ + finish_wait(&(wq), &__wait); \ + __ret; \ +@@ -306,41 +313,16 @@ + extern struct spufs_coredump_reader spufs_coredump_read[]; + extern int spufs_coredump_num_notes; + +-/* +- * This function is a little bit too large for an inline, but +- * as fault.c is built into the kernel we can't move it out of +- * line. +- */ +-static inline void spuctx_switch_state(struct spu_context *ctx, +- enum spu_utilization_state new_state) +-{ +- unsigned long long curtime; +- signed long long delta; +- struct timespec ts; +- struct spu *spu; +- enum spu_utilization_state old_state; +- +- ktime_get_ts(&ts); +- curtime = timespec_to_ns(&ts); +- delta = curtime - ctx->stats.tstamp; +- +- WARN_ON(!mutex_is_locked(&ctx->state_mutex)); +- WARN_ON(delta < 0); +- +- spu = ctx->spu; +- old_state = ctx->stats.util_state; +- ctx->stats.util_state = new_state; +- ctx->stats.tstamp = curtime; +- +- /* +- * Update the physical SPU utilization statistics. +- */ +- if (spu) { +- ctx->stats.times[old_state] += delta; +- spu->stats.times[old_state] += delta; +- spu->stats.util_state = new_state; +- spu->stats.tstamp = curtime; +- } +-} ++extern int spu_init_csa(struct spu_state *csa); ++extern void spu_fini_csa(struct spu_state *csa); ++extern int spu_save(struct spu_state *prev, struct spu *spu); ++extern int spu_restore(struct spu_state *new, struct spu *spu); ++extern int spu_switch(struct spu_state *prev, struct spu_state *new, ++ struct spu *spu); ++extern int spu_alloc_lscsa(struct spu_state *csa); ++extern void spu_free_lscsa(struct spu_state *csa); ++ ++extern void spuctx_switch_state(struct spu_context *ctx, ++ enum spu_utilization_state new_state); + + #endif +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/cell/spufs/switch.c powerpc.git/arch/powerpc/platforms/cell/spufs/switch.c +--- linux-2.6.24/arch/powerpc/platforms/cell/spufs/switch.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/cell/spufs/switch.c 2008-01-28 20:25:49.000000000 +0100 +@@ -48,6 +48,8 @@ + #include <asm/spu_csa.h> + #include <asm/mmu_context.h> + ++#include "spufs.h" ++ + #include "spu_save_dump.h" + #include "spu_restore_dump.h" + +@@ -691,35 +693,9 @@ + out_be64(&priv2->mfc_control_RW, MFC_CNTL_RESUME_DMA_QUEUE); + } + +-static inline void get_kernel_slb(u64 ea, u64 slb[2]) ++static inline void setup_mfc_slbs(struct spu_state *csa, struct spu *spu, ++ unsigned int *code, int code_size) + { +- u64 llp; +- +- if (REGION_ID(ea) == KERNEL_REGION_ID) +- llp = mmu_psize_defs[mmu_linear_psize].sllp; +- else +- llp = mmu_psize_defs[mmu_virtual_psize].sllp; +- slb[0] = (get_kernel_vsid(ea, MMU_SEGSIZE_256M) << SLB_VSID_SHIFT) | +- SLB_VSID_KERNEL | llp; +- slb[1] = (ea & ESID_MASK) | SLB_ESID_V; +-} +- +-static inline void load_mfc_slb(struct spu *spu, u64 slb[2], int slbe) +-{ +- struct spu_priv2 __iomem *priv2 = spu->priv2; +- +- out_be64(&priv2->slb_index_W, slbe); +- eieio(); +- out_be64(&priv2->slb_vsid_RW, slb[0]); +- out_be64(&priv2->slb_esid_RW, slb[1]); +- eieio(); +-} +- +-static inline void setup_mfc_slbs(struct spu_state *csa, struct spu *spu) +-{ +- u64 code_slb[2]; +- u64 lscsa_slb[2]; +- + /* Save, Step 47: + * Restore, Step 30. + * If MFC_SR1[R]=1, write 0 to SLB_Invalidate_All +@@ -735,11 +711,7 @@ + * translation is desired by OS environment). + */ + spu_invalidate_slbs(spu); +- get_kernel_slb((unsigned long)&spu_save_code[0], code_slb); +- get_kernel_slb((unsigned long)csa->lscsa, lscsa_slb); +- load_mfc_slb(spu, code_slb, 0); +- if ((lscsa_slb[0] != code_slb[0]) || (lscsa_slb[1] != code_slb[1])) +- load_mfc_slb(spu, lscsa_slb, 1); ++ spu_setup_kernel_slbs(spu, csa->lscsa, code, code_size); + } + + static inline void set_switch_active(struct spu_state *csa, struct spu *spu) +@@ -768,9 +740,9 @@ + * (translation) interrupts. + */ + spin_lock_irq(&spu->register_lock); +- spu_int_stat_clear(spu, 0, ~0ul); +- spu_int_stat_clear(spu, 1, ~0ul); +- spu_int_stat_clear(spu, 2, ~0ul); ++ spu_int_stat_clear(spu, 0, CLASS0_INTR_MASK); ++ spu_int_stat_clear(spu, 1, CLASS1_INTR_MASK); ++ spu_int_stat_clear(spu, 2, CLASS2_INTR_MASK); + spu_int_mask_set(spu, 0, 0ul); + spu_int_mask_set(spu, 1, class1_mask); + spu_int_mask_set(spu, 2, 0ul); +@@ -927,8 +899,8 @@ + POLL_WHILE_FALSE(in_be32(&prob->dma_tagstatus_R) & mask); + + local_irq_save(flags); +- spu_int_stat_clear(spu, 0, ~(0ul)); +- spu_int_stat_clear(spu, 2, ~(0ul)); ++ spu_int_stat_clear(spu, 0, CLASS0_INTR_MASK); ++ spu_int_stat_clear(spu, 2, CLASS2_INTR_MASK); + local_irq_restore(flags); + } + +@@ -946,8 +918,8 @@ + POLL_WHILE_TRUE(in_be32(&prob->spu_status_R) & SPU_STATUS_RUNNING); + + local_irq_save(flags); +- spu_int_stat_clear(spu, 0, ~(0ul)); +- spu_int_stat_clear(spu, 2, ~(0ul)); ++ spu_int_stat_clear(spu, 0, CLASS0_INTR_MASK); ++ spu_int_stat_clear(spu, 2, CLASS2_INTR_MASK); + local_irq_restore(flags); + } + +@@ -1423,9 +1395,9 @@ + spu_int_mask_set(spu, 0, 0ul); + spu_int_mask_set(spu, 1, 0ul); + spu_int_mask_set(spu, 2, 0ul); +- spu_int_stat_clear(spu, 0, ~0ul); +- spu_int_stat_clear(spu, 1, ~0ul); +- spu_int_stat_clear(spu, 2, ~0ul); ++ spu_int_stat_clear(spu, 0, CLASS0_INTR_MASK); ++ spu_int_stat_clear(spu, 1, CLASS1_INTR_MASK); ++ spu_int_stat_clear(spu, 2, CLASS2_INTR_MASK); + spin_unlock_irq(&spu->register_lock); + } + +@@ -1866,7 +1838,8 @@ + */ + + resume_mfc_queue(prev, spu); /* Step 46. */ +- setup_mfc_slbs(prev, spu); /* Step 47. */ ++ /* Step 47. */ ++ setup_mfc_slbs(prev, spu, spu_save_code, sizeof(spu_save_code)); + set_switch_active(prev, spu); /* Step 48. */ + enable_interrupts(prev, spu); /* Step 49. */ + save_ls_16kb(prev, spu); /* Step 50. */ +@@ -1971,7 +1944,8 @@ + setup_spu_status_part1(next, spu); /* Step 27. */ + setup_spu_status_part2(next, spu); /* Step 28. */ + restore_mfc_rag(next, spu); /* Step 29. */ +- setup_mfc_slbs(next, spu); /* Step 30. */ ++ /* Step 30. */ ++ setup_mfc_slbs(next, spu, spu_restore_code, sizeof(spu_restore_code)); + set_spu_npc(next, spu); /* Step 31. */ + set_signot1(next, spu); /* Step 32. */ + set_signot2(next, spu); /* Step 33. */ +@@ -2103,10 +2077,6 @@ + int rc; + + acquire_spu_lock(spu); /* Step 1. */ +- prev->dar = spu->dar; +- prev->dsisr = spu->dsisr; +- spu->dar = 0; +- spu->dsisr = 0; + rc = __do_spu_save(prev, spu); /* Steps 2-53. */ + release_spu_lock(spu); + if (rc != 0 && rc != 2 && rc != 6) { +@@ -2133,9 +2103,6 @@ + acquire_spu_lock(spu); + harvest(NULL, spu); + spu->slb_replace = 0; +- new->dar = 0; +- new->dsisr = 0; +- spu->class_0_pending = 0; + rc = __do_spu_restore(new, spu); + release_spu_lock(spu); + if (rc) { +@@ -2215,10 +2182,8 @@ + + return 0; + } +-EXPORT_SYMBOL_GPL(spu_init_csa); + + void spu_fini_csa(struct spu_state *csa) + { + spu_free_lscsa(csa); + } +-EXPORT_SYMBOL_GPL(spu_fini_csa); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/celleb/Kconfig powerpc.git/arch/powerpc/platforms/celleb/Kconfig +--- linux-2.6.24/arch/powerpc/platforms/celleb/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/celleb/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -2,6 +2,8 @@ + bool "Toshiba's Cell Reference Set 'Celleb' Architecture" + depends on PPC_MULTIPLATFORM && PPC64 + select PPC_CELL ++ select PPC_CELL_NATIVE ++ select PPC_RTAS + select PPC_INDIRECT_IO + select PPC_OF_PLATFORM_PCI + select HAS_TXX9_SERIAL +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/celleb/io-workarounds.c powerpc.git/arch/powerpc/platforms/celleb/io-workarounds.c +--- linux-2.6.24/arch/powerpc/platforms/celleb/io-workarounds.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/celleb/io-workarounds.c 2008-01-28 20:25:49.000000000 +0100 +@@ -22,6 +22,7 @@ + + #undef DEBUG + ++#include <linux/of.h> + #include <linux/of_device.h> + #include <linux/irq.h> + +@@ -222,7 +223,7 @@ + void (*dummy_read)(struct pci_controller *)) + { + struct celleb_pci_bus *bus = &celleb_pci_busses[celleb_pci_count]; +- struct device_node *np = phb->arch_data; ++ struct device_node *np = phb->dn; + + if (celleb_pci_count >= MAX_CELLEB_PCI_BUS) { + printk(KERN_ERR "Too many pci bridges, workarounds" +@@ -256,13 +257,13 @@ + + celleb_dummy_page_va = kmalloc(PAGE_SIZE, GFP_KERNEL); + if (!celleb_dummy_page_va) { +- printk(KERN_ERR "Celleb: dummy read disabled." ++ printk(KERN_ERR "Celleb: dummy read disabled. " + "Alloc celleb_dummy_page_va failed\n"); + return 1; + } + + list_for_each_entry(phb, &hose_list, list_node) { +- node = phb->arch_data; ++ node = phb->dn; + match = of_match_node(celleb_pci_workaround_match, node); + + if (match) { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/celleb/iommu.c powerpc.git/arch/powerpc/platforms/celleb/iommu.c +--- linux-2.6.24/arch/powerpc/platforms/celleb/iommu.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/celleb/iommu.c 2008-01-28 20:25:49.000000000 +0100 +@@ -22,8 +22,9 @@ + #include <linux/init.h> + #include <linux/dma-mapping.h> + #include <linux/pci.h> ++#include <linux/of_platform.h> + +-#include <asm/of_platform.h> ++#include <asm/machdep.h> + + #include "beat_wrapper.h" + +@@ -51,6 +52,8 @@ + return 0; + } + ++static unsigned long celleb_dma_direct_offset; ++ + static void __init celleb_init_direct_mapping(void) + { + u64 lpar_addr, io_addr; +@@ -68,7 +71,18 @@ + ioid, DMA_FLAGS); + } + +- dma_direct_offset = dma_base; ++ celleb_dma_direct_offset = dma_base; ++} ++ ++static void celleb_dma_dev_setup(struct device *dev) ++{ ++ dev->archdata.dma_ops = get_pci_dma_ops(); ++ dev->archdata.dma_data = (void *)celleb_dma_direct_offset; ++} ++ ++static void celleb_pci_dma_dev_setup(struct pci_dev *pdev) ++{ ++ celleb_dma_dev_setup(&pdev->dev); + } + + static int celleb_of_bus_notify(struct notifier_block *nb, +@@ -80,7 +94,7 @@ + if (action != BUS_NOTIFY_ADD_DEVICE) + return 0; + +- dev->archdata.dma_ops = get_pci_dma_ops(); ++ celleb_dma_dev_setup(dev); + + return 0; + } +@@ -91,14 +105,12 @@ + + static int __init celleb_init_iommu(void) + { +- if (!machine_is(celleb)) +- return -ENODEV; +- + celleb_init_direct_mapping(); + set_pci_dma_ops(&dma_direct_ops); ++ ppc_md.pci_dma_dev_setup = celleb_pci_dma_dev_setup; + bus_register_notifier(&of_platform_bus_type, &celleb_of_bus_notifier); + + return 0; + } + +-arch_initcall(celleb_init_iommu); ++machine_arch_initcall(celleb_beat, celleb_init_iommu); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/celleb/pci.c powerpc.git/arch/powerpc/platforms/celleb/pci.c +--- linux-2.6.24/arch/powerpc/platforms/celleb/pci.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/celleb/pci.c 2008-01-28 20:25:49.000000000 +0100 +@@ -31,6 +31,7 @@ + #include <linux/init.h> + #include <linux/bootmem.h> + #include <linux/pci_regs.h> ++#include <linux/of.h> + #include <linux/of_device.h> + + #include <asm/io.h> +@@ -138,8 +139,6 @@ + *val = celleb_fake_config_readl(p); + break; + } +- +- return; + } + + static void celleb_config_write_fake(unsigned char *config, int where, +@@ -158,7 +157,6 @@ + celleb_fake_config_writel(val, p); + break; + } +- return; + } + + static int celleb_fake_pci_read_config(struct pci_bus *bus, +@@ -351,6 +349,10 @@ + wi1 = of_get_property(node, "vendor-id", NULL); + wi2 = of_get_property(node, "class-code", NULL); + wi3 = of_get_property(node, "revision-id", NULL); ++ if (!wi0 || !wi1 || !wi2 || !wi3) { ++ printk(KERN_ERR "PCI: Missing device tree properties.\n"); ++ goto error; ++ } + + celleb_config_write_fake(*config, PCI_DEVICE_ID, 2, wi0[0] & 0xffff); + celleb_config_write_fake(*config, PCI_VENDOR_ID, 2, wi1[0] & 0xffff); +@@ -372,6 +374,10 @@ + celleb_setup_pci_base_addrs(hose, devno, fn, num_base_addr); + + li = of_get_property(node, "interrupts", &rlen); ++ if (!li) { ++ printk(KERN_ERR "PCI: interrupts not found.\n"); ++ goto error; ++ } + val = li[0]; + celleb_config_write_fake(*config, PCI_INTERRUPT_PIN, 1, 1); + celleb_config_write_fake(*config, PCI_INTERRUPT_LINE, 1, val); +@@ -475,7 +481,7 @@ + + int __init celleb_setup_phb(struct pci_controller *phb) + { +- struct device_node *dev = phb->arch_data; ++ struct device_node *dev = phb->dn; + const struct of_device_id *match; + int (*setup_func)(struct device_node *, struct pci_controller *); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/celleb/scc_epci.c powerpc.git/arch/powerpc/platforms/celleb/scc_epci.c +--- linux-2.6.24/arch/powerpc/platforms/celleb/scc_epci.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/celleb/scc_epci.c 2008-01-28 20:25:49.000000000 +0100 +@@ -95,7 +95,7 @@ + private->dummy_page_da = dma_map_single(hose->parent, + celleb_dummy_page_va, PAGE_SIZE, DMA_FROM_DEVICE); + if (private->dummy_page_da == DMA_ERROR_CODE) { +- printk(KERN_ERR "EPCI: dummy read disabled." ++ printk(KERN_ERR "EPCI: dummy read disabled. " + "Map dummy page failed.\n"); + return; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/celleb/scc_uhc.c powerpc.git/arch/powerpc/platforms/celleb/scc_uhc.c +--- linux-2.6.24/arch/powerpc/platforms/celleb/scc_uhc.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/celleb/scc_uhc.c 2008-01-28 20:25:49.000000000 +0100 +@@ -47,7 +47,8 @@ + u32 val = 0; + int i; + +- if (!machine_is(celleb)) ++ if (!machine_is(celleb_beat) && ++ !machine_is(celleb_native)) + return; + + uhc_base = ioremap(pci_resource_start(dev, 0), +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/celleb/setup.c powerpc.git/arch/powerpc/platforms/celleb/setup.c +--- linux-2.6.24/arch/powerpc/platforms/celleb/setup.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/celleb/setup.c 2008-01-28 20:25:49.000000000 +0100 +@@ -40,6 +40,7 @@ + #include <linux/seq_file.h> + #include <linux/root_dev.h> + #include <linux/console.h> ++#include <linux/of_platform.h> + + #include <asm/mmu.h> + #include <asm/processor.h> +@@ -52,12 +53,16 @@ + #include <asm/time.h> + #include <asm/spu_priv1.h> + #include <asm/firmware.h> +-#include <asm/of_platform.h> ++#include <asm/rtas.h> ++#include <asm/cell-regs.h> + + #include "interrupt.h" + #include "beat_wrapper.h" + #include "beat.h" + #include "pci.h" ++#include "../cell/interrupt.h" ++#include "../cell/pervasive.h" ++#include "../cell/ras.h" + + static char celleb_machine_type[128] = "Celleb"; + +@@ -88,61 +93,122 @@ + printk("*** %04x : %s\n", hex, s ? s : ""); + } + +-static void __init celleb_setup_arch(void) ++static void __init celleb_setup_arch_common(void) ++{ ++ /* init to some ~sane value until calibrate_delay() runs */ ++ loops_per_jiffy = 50000000; ++ ++#ifdef CONFIG_DUMMY_CONSOLE ++ conswitchp = &dummy_con; ++#endif ++} ++ ++static struct of_device_id celleb_bus_ids[] __initdata = { ++ { .type = "scc", }, ++ { .type = "ioif", }, /* old style */ ++ {}, ++}; ++ ++static int __init celleb_publish_devices(void) ++{ ++ /* Publish OF platform devices for southbridge IOs */ ++ of_platform_bus_probe(NULL, celleb_bus_ids, NULL); ++ ++ celleb_pci_workaround_init(); ++ ++ return 0; ++} ++machine_device_initcall(celleb_beat, celleb_publish_devices); ++machine_device_initcall(celleb_native, celleb_publish_devices); ++ ++ ++/* ++ * functions for Celleb-Beat ++ */ ++static void __init celleb_setup_arch_beat(void) + { + #ifdef CONFIG_SPU_BASE +- spu_priv1_ops = &spu_priv1_beat_ops; +- spu_management_ops = &spu_management_of_ops; ++ spu_priv1_ops = &spu_priv1_beat_ops; ++ spu_management_ops = &spu_management_of_ops; + #endif + + #ifdef CONFIG_SMP + smp_init_celleb(); + #endif + +- /* init to some ~sane value until calibrate_delay() runs */ +- loops_per_jiffy = 50000000; +- +-#ifdef CONFIG_DUMMY_CONSOLE +- conswitchp = &dummy_con; +-#endif ++ celleb_setup_arch_common(); + } + +-static int __init celleb_probe(void) ++static int __init celleb_probe_beat(void) + { + unsigned long root = of_get_flat_dt_root(); + + if (!of_flat_dt_is_compatible(root, "Beat")) + return 0; + +- powerpc_firmware_features |= FW_FEATURE_CELLEB_POSSIBLE; ++ powerpc_firmware_features |= FW_FEATURE_CELLEB_ALWAYS ++ | FW_FEATURE_BEAT | FW_FEATURE_LPAR; + hpte_init_beat_v3(); ++ + return 1; + } + +-static struct of_device_id celleb_bus_ids[] __initdata = { +- { .type = "scc", }, +- { .type = "ioif", }, /* old style */ +- {}, +-}; + +-static int __init celleb_publish_devices(void) ++/* ++ * functions for Celleb-native ++ */ ++static void __init celleb_init_IRQ_native(void) + { +- if (!machine_is(celleb)) +- return 0; ++ iic_init_IRQ(); ++ spider_init_IRQ(); ++} + +- /* Publish OF platform devices for southbridge IOs */ +- of_platform_bus_probe(NULL, celleb_bus_ids, NULL); ++static void __init celleb_setup_arch_native(void) ++{ ++#ifdef CONFIG_SPU_BASE ++ spu_priv1_ops = &spu_priv1_mmio_ops; ++ spu_management_ops = &spu_management_of_ops; ++#endif + +- celleb_pci_workaround_init(); ++ cbe_regs_init(); + +- return 0; ++#ifdef CONFIG_CBE_RAS ++ cbe_ras_init(); ++#endif ++ ++#ifdef CONFIG_SMP ++ smp_init_cell(); ++#endif ++ ++ cbe_pervasive_init(); ++ ++ /* XXX: nvram initialization should be added */ ++ ++ celleb_setup_arch_common(); ++} ++ ++static int __init celleb_probe_native(void) ++{ ++ unsigned long root = of_get_flat_dt_root(); ++ ++ if (of_flat_dt_is_compatible(root, "Beat") || ++ !of_flat_dt_is_compatible(root, "TOSHIBA,Celleb")) ++ return 0; ++ ++ powerpc_firmware_features |= FW_FEATURE_CELLEB_ALWAYS; ++ hpte_init_native(); ++ ++ return 1; + } +-device_initcall(celleb_publish_devices); + +-define_machine(celleb) { +- .name = "Cell Reference Set", +- .probe = celleb_probe, +- .setup_arch = celleb_setup_arch, ++ ++/* ++ * machine definitions ++ */ ++define_machine(celleb_beat) { ++ .name = "Cell Reference Set (Beat)", ++ .probe = celleb_probe_beat, ++ .setup_arch = celleb_setup_arch_beat, + .show_cpuinfo = celleb_show_cpuinfo, + .restart = beat_restart, + .power_off = beat_power_off, +@@ -167,3 +233,26 @@ + .machine_crash_shutdown = default_machine_crash_shutdown, + #endif + }; ++ ++define_machine(celleb_native) { ++ .name = "Cell Reference Set (native)", ++ .probe = celleb_probe_native, ++ .setup_arch = celleb_setup_arch_native, ++ .show_cpuinfo = celleb_show_cpuinfo, ++ .restart = rtas_restart, ++ .power_off = rtas_power_off, ++ .halt = rtas_halt, ++ .get_boot_time = rtas_get_boot_time, ++ .get_rtc_time = rtas_get_rtc_time, ++ .set_rtc_time = rtas_set_rtc_time, ++ .calibrate_decr = generic_calibrate_decr, ++ .progress = celleb_progress, ++ .pci_probe_mode = celleb_pci_probe_mode, ++ .pci_setup_phb = celleb_setup_phb, ++ .init_IRQ = celleb_init_IRQ_native, ++#ifdef CONFIG_KEXEC ++ .machine_kexec = default_machine_kexec, ++ .machine_kexec_prepare = default_machine_kexec_prepare, ++ .machine_crash_shutdown = default_machine_crash_shutdown, ++#endif ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/chrp/pci.c powerpc.git/arch/powerpc/platforms/chrp/pci.c +--- linux-2.6.24/arch/powerpc/platforms/chrp/pci.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/chrp/pci.c 2008-01-28 20:25:49.000000000 +0100 +@@ -198,7 +198,7 @@ + printk ("RTAS supporting Pegasos OF not found, please upgrade" + " your firmware\n"); + } +- pci_assign_all_buses = 1; ++ ppc_pci_flags |= PPC_PCI_REASSIGN_ALL_BUS; + /* keep the reference to the root node */ + } + +@@ -354,7 +354,7 @@ + * mode as well. The same fixup must be done to the class-code property in + * the IDE node /pci@80000000/ide@C,1 + */ +-static void __devinit chrp_pci_fixup_vt8231_ata(struct pci_dev *viaide) ++static void chrp_pci_fixup_vt8231_ata(struct pci_dev *viaide) + { + u8 progif; + struct pci_dev *viaisa; +@@ -375,4 +375,4 @@ + + pci_dev_put(viaisa); + } +-DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C586_1, chrp_pci_fixup_vt8231_ata); ++DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_VIA, PCI_DEVICE_ID_VIA_82C586_1, chrp_pci_fixup_vt8231_ata); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/chrp/setup.c powerpc.git/arch/powerpc/platforms/chrp/setup.c +--- linux-2.6.24/arch/powerpc/platforms/chrp/setup.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/chrp/setup.c 2008-01-28 20:25:49.000000000 +0100 +@@ -115,7 +115,7 @@ + seq_printf(m, "machine\t\t: CHRP %s\n", model); + + /* longtrail (goldengate) stuff */ +- if (!strncmp(model, "IBM,LongTrail", 13)) { ++ if (model && !strncmp(model, "IBM,LongTrail", 13)) { + /* VLSI VAS96011/12 `Golden Gate 2' */ + /* Memory banks */ + sdramen = (in_le32(gg2_pci_config_base + GG2_PCI_DRAM_CTRL) +@@ -203,15 +203,20 @@ + static void __init sio_init(void) + { + struct device_node *root; ++ const char *model; + +- if ((root = of_find_node_by_path("/")) && +- !strncmp(of_get_property(root, "model", NULL), +- "IBM,LongTrail", 13)) { ++ root = of_find_node_by_path("/"); ++ if (!root) ++ return; ++ ++ model = of_get_property(root, "model", NULL); ++ if (model && !strncmp(model, "IBM,LongTrail", 13)) { + /* logical device 0 (KBC/Keyboard) */ + sio_fixup_irq("keyboard", 0, 1, 2); + /* select logical device 1 (KBC/Mouse) */ + sio_fixup_irq("mouse", 1, 12, 2); + } ++ + of_node_put(root); + } + +@@ -251,6 +256,57 @@ + for(;;); + } + ++/* ++ * Per default, input/output-device points to the keyboard/screen ++ * If no card is installed, the built-in serial port is used as a fallback. ++ * But unfortunately, the firmware does not connect /chosen/{stdin,stdout} ++ * the the built-in serial node. Instead, a /failsafe node is created. ++ */ ++static void chrp_init_early(void) ++{ ++ struct device_node *node; ++ const char *property; ++ ++ if (strstr(cmd_line, "console=")) ++ return; ++ /* find the boot console from /chosen/stdout */ ++ if (!of_chosen) ++ return; ++ node = of_find_node_by_path("/"); ++ if (!node) ++ return; ++ property = of_get_property(node, "model", NULL); ++ if (!property) ++ goto out_put; ++ if (strcmp(property, "Pegasos2")) ++ goto out_put; ++ /* this is a Pegasos2 */ ++ property = of_get_property(of_chosen, "linux,stdout-path", NULL); ++ if (!property) ++ goto out_put; ++ of_node_put(node); ++ node = of_find_node_by_path(property); ++ if (!node) ++ return; ++ property = of_get_property(node, "device_type", NULL); ++ if (!property) ++ goto out_put; ++ if (strcmp(property, "serial")) ++ goto out_put; ++ /* ++ * The 9pin connector is either /failsafe ++ * or /pci@80000000/isa@C/serial@i2F8 ++ * The optional graphics card has also type 'serial' in VGA mode. ++ */ ++ property = of_get_property(node, "name", NULL); ++ if (!property) ++ goto out_put; ++ if (!strcmp(property, "failsafe") || !strcmp(property, "serial")) ++ add_preferred_console("ttyS", 0, NULL); ++out_put: ++ of_node_put(node); ++} ++ + void __init chrp_setup_arch(void) + { + struct device_node *root = of_find_node_by_path("/"); +@@ -594,6 +650,7 @@ + .probe = chrp_probe, + .setup_arch = chrp_setup_arch, + .init = chrp_init2, ++ .init_early = chrp_init_early, + .show_cpuinfo = chrp_show_cpuinfo, + .init_IRQ = chrp_init_IRQ, + .restart = rtas_restart, +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/embedded6xx/Kconfig powerpc.git/arch/powerpc/platforms/embedded6xx/Kconfig +--- linux-2.6.24/arch/powerpc/platforms/embedded6xx/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/embedded6xx/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -9,6 +9,8 @@ + select FSL_SOC + select PPC_UDBG_16550 if SERIAL_8250 + select DEFAULT_UIMAGE ++ select MPC10X_OPENPIC ++ select MPC10X_BRIDGE + help + Select LINKSTATION if configuring for one of PPC- (MPC8241) + based NAS systems from Buffalo Technology. So far only +@@ -16,6 +18,19 @@ + Linkstation-I HD-HLAN and HD-HGLAN versions, and PPC-based + Terastation systems should be supported too. + ++config STORCENTER ++ bool "IOMEGA StorCenter" ++ depends on EMBEDDED6xx ++ select MPIC ++ select FSL_SOC ++ select PPC_UDBG_16550 if SERIAL_8250 ++ select WANT_DEVICE_TREE ++ select MPC10X_OPENPIC ++ select MPC10X_BRIDGE ++ help ++ Select STORCENTER if configuring for the iomega StorCenter ++ with an 8241 CPU in it. ++ + config MPC7448HPC2 + bool "Freescale MPC7448HPC2(Taiga)" + depends on EMBEDDED6xx +@@ -23,6 +38,7 @@ + select DEFAULT_UIMAGE + select PPC_UDBG_16550 + select WANT_DEVICE_TREE ++ select TSI108_BRIDGE + help + Select MPC7448HPC2 if configuring for Freescale MPC7448HPC2 (Taiga) + platform +@@ -33,6 +49,7 @@ + select TSI108_BRIDGE + select PPC_UDBG_16550 + select WANT_DEVICE_TREE ++ select TSI108_BRIDGE + help + Select PPC_HOLLY if configuring for an IBM 750GX/CL Eval + Board with TSI108/9 bridge (Hickory/Holly) +@@ -48,17 +65,13 @@ + + config TSI108_BRIDGE + bool +- depends on MPC7448HPC2 || PPC_HOLLY + select PCI + select MPIC + select MPIC_WEIRD +- default y + + config MPC10X_BRIDGE + bool +- depends on LINKSTATION + select PPC_INDIRECT_PCI +- default y + + config MV64X60 + bool +@@ -67,8 +80,6 @@ + + config MPC10X_OPENPIC + bool +- depends on LINKSTATION +- default y + + config MPC10X_STORE_GATHERING + bool "Enable MPC10x store gathering" +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/embedded6xx/Makefile powerpc.git/arch/powerpc/platforms/embedded6xx/Makefile +--- linux-2.6.24/arch/powerpc/platforms/embedded6xx/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/embedded6xx/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -3,5 +3,6 @@ + # + obj-$(CONFIG_MPC7448HPC2) += mpc7448_hpc2.o + obj-$(CONFIG_LINKSTATION) += linkstation.o ls_uart.o ++obj-$(CONFIG_STORCENTER) += storcenter.o + obj-$(CONFIG_PPC_HOLLY) += holly.o + obj-$(CONFIG_PPC_PRPMC2800) += prpmc2800.o +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/embedded6xx/holly.c powerpc.git/arch/powerpc/platforms/embedded6xx/holly.c +--- linux-2.6.24/arch/powerpc/platforms/embedded6xx/holly.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/embedded6xx/holly.c 2008-01-28 20:25:49.000000000 +0100 +@@ -20,12 +20,12 @@ + #include <linux/console.h> + #include <linux/delay.h> + #include <linux/irq.h> +-#include <linux/ide.h> + #include <linux/seq_file.h> + #include <linux/root_dev.h> + #include <linux/serial.h> + #include <linux/tty.h> + #include <linux/serial_core.h> ++#include <linux/of_platform.h> + + #include <asm/system.h> + #include <asm/time.h> +@@ -39,7 +39,6 @@ + #include <asm/tsi108_irq.h> + #include <asm/tsi108_pci.h> + #include <asm/mpic.h> +-#include <asm/of_platform.h> + + #undef DEBUG + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/embedded6xx/mpc7448_hpc2.c powerpc.git/arch/powerpc/platforms/embedded6xx/mpc7448_hpc2.c +--- linux-2.6.24/arch/powerpc/platforms/embedded6xx/mpc7448_hpc2.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/embedded6xx/mpc7448_hpc2.c 2008-01-28 20:25:49.000000000 +0100 +@@ -53,8 +53,6 @@ + + #define MPC7448HPC2_PCI_CFG_PHYS 0xfb000000 + +-extern void _nmask_and_or_msr(unsigned long nmask, unsigned long or_val); +- + int mpc7448_hpc2_exclude_device(struct pci_controller *hose, + u_char bus, u_char devfn) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/embedded6xx/storcenter.c powerpc.git/arch/powerpc/platforms/embedded6xx/storcenter.c +--- linux-2.6.24/arch/powerpc/platforms/embedded6xx/storcenter.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/embedded6xx/storcenter.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,192 @@ ++/* ++ * Board setup routines for the storcenter ++ * ++ * Copyright 2007 (C) Oyvind Repvik (nail@nslu2-linux.org) ++ * Copyright 2007 Andy Wilcox, Jon Loeliger ++ * ++ * Based on linkstation.c by G. Liakhovetski ++ * ++ * This file is licensed under the terms of the GNU General Public License ++ * version 2. This program is licensed "as is" without any warranty of ++ * any kind, whether express or implied. ++ */ ++ ++#include <linux/kernel.h> ++#include <linux/pci.h> ++#include <linux/initrd.h> ++#include <linux/mtd/physmap.h> ++#include <linux/of_platform.h> ++ ++#include <asm/system.h> ++#include <asm/time.h> ++#include <asm/prom.h> ++#include <asm/mpic.h> ++#include <asm/pci-bridge.h> ++ ++#include "mpc10x.h" ++ ++ ++#ifdef CONFIG_MTD_PHYSMAP ++static struct mtd_partition storcenter_physmap_partitions[] = { ++ { ++ .name = "kernel", ++ .offset = 0x000000, ++ .size = 0x170000, ++ }, ++ { ++ .name = "rootfs", ++ .offset = 0x170000, ++ .size = 0x590000, ++ }, ++ { ++ .name = "uboot", ++ .offset = 0x700000, ++ .size = 0x040000, ++ }, ++ { ++ .name = "config", ++ .offset = 0x740000, ++ .size = 0x0c0000, ++ }, ++}; ++#endif ++ ++ ++static __initdata struct of_device_id storcenter_of_bus[] = { ++ { .name = "soc", }, ++ {}, ++}; ++ ++static int __init storcenter_device_probe(void) ++{ ++ of_platform_bus_probe(NULL, storcenter_of_bus, NULL); ++ return 0; ++} ++machine_device_initcall(storcenter, storcenter_device_probe); ++ ++ ++static int __init storcenter_add_bridge(struct device_node *dev) ++{ ++#ifdef CONFIG_PCI ++ int len; ++ struct pci_controller *hose; ++ const int *bus_range; ++ ++ printk("Adding PCI host bridge %s\n", dev->full_name); ++ ++ hose = pcibios_alloc_controller(dev); ++ if (hose == NULL) ++ return -ENOMEM; ++ ++ bus_range = of_get_property(dev, "bus-range", &len); ++ hose->first_busno = bus_range ? bus_range[0] : 0; ++ hose->last_busno = bus_range ? bus_range[1] : 0xff; ++ ++ setup_indirect_pci(hose, MPC10X_MAPB_CNFG_ADDR, MPC10X_MAPB_CNFG_DATA, 0); ++ ++ /* Interpret the "ranges" property */ ++ /* This also maps the I/O region and sets isa_io/mem_base */ ++ pci_process_bridge_OF_ranges(hose, dev, 1); ++#endif ++ ++ return 0; ++} ++ ++static void __init storcenter_setup_arch(void) ++{ ++ struct device_node *np; ++ ++#ifdef CONFIG_MTD_PHYSMAP ++ physmap_set_partitions(storcenter_physmap_partitions, ++ ARRAY_SIZE(storcenter_physmap_partitions)); ++#endif ++ ++ /* Lookup PCI host bridges */ ++ for_each_compatible_node(np, "pci", "mpc10x-pci") ++ storcenter_add_bridge(np); ++ ++ printk(KERN_INFO "IOMEGA StorCenter\n"); ++} ++ ++/* ++ * Interrupt setup and service. Interrrupts on the turbostation come ++ * from the four PCI slots plus onboard 8241 devices: I2C, DUART. ++ */ ++static void __init storcenter_init_IRQ(void) ++{ ++ struct mpic *mpic; ++ struct device_node *dnp; ++ const void *prop; ++ int size; ++ phys_addr_t paddr; ++ ++ dnp = of_find_node_by_type(NULL, "open-pic"); ++ if (dnp == NULL) ++ return; ++ ++ prop = of_get_property(dnp, "reg", &size); ++ if (prop == NULL) { ++ of_node_put(dnp); ++ return; ++ } ++ ++ paddr = (phys_addr_t)of_translate_address(dnp, prop); ++ mpic = mpic_alloc(dnp, paddr, MPIC_PRIMARY | MPIC_WANTS_RESET, ++ 4, 32, " EPIC "); ++ ++ of_node_put(dnp); ++ ++ BUG_ON(mpic == NULL); ++ ++ /* PCI IRQs */ ++ /* ++ * 2.6.12 patch: ++ * openpic_set_sources(0, 5, OpenPIC_Addr + 0x10200); ++ * openpic_set_sources(5, 2, OpenPIC_Addr + 0x11120); ++ * first_irq, num_irqs, __iomem first_ISR ++ * o_ss: i, src: 0, fdf50200 ++ * o_ss: i, src: 1, fdf50220 ++ * o_ss: i, src: 2, fdf50240 ++ * o_ss: i, src: 3, fdf50260 ++ * o_ss: i, src: 4, fdf50280 ++ * o_ss: i, src: 5, fdf51120 ++ * o_ss: i, src: 6, fdf51140 ++ */ ++ mpic_assign_isu(mpic, 0, paddr + 0x10200); ++ mpic_assign_isu(mpic, 1, paddr + 0x10220); ++ mpic_assign_isu(mpic, 2, paddr + 0x10240); ++ mpic_assign_isu(mpic, 3, paddr + 0x10260); ++ mpic_assign_isu(mpic, 4, paddr + 0x10280); ++ mpic_assign_isu(mpic, 5, paddr + 0x11120); ++ mpic_assign_isu(mpic, 6, paddr + 0x11140); ++ ++ mpic_init(mpic); ++} ++ ++static void storcenter_restart(char *cmd) ++{ ++ local_irq_disable(); ++ ++ /* Set exception prefix high - to the firmware */ ++ _nmask_and_or_msr(0, MSR_IP); ++ ++ /* Wait for reset to happen */ ++ for (;;) ; ++} ++ ++static int __init storcenter_probe(void) ++{ ++ unsigned long root = of_get_flat_dt_root(); ++ ++ return of_flat_dt_is_compatible(root, "storcenter"); ++} ++ ++define_machine(storcenter){ ++ .name = "IOMEGA StorCenter", ++ .probe = storcenter_probe, ++ .setup_arch = storcenter_setup_arch, ++ .init_IRQ = storcenter_init_IRQ, ++ .get_irq = mpic_get_irq, ++ .restart = storcenter_restart, ++ .calibrate_decr = generic_calibrate_decr, ++}; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/iseries/Makefile powerpc.git/arch/powerpc/platforms/iseries/Makefile +--- linux-2.6.24/arch/powerpc/platforms/iseries/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/iseries/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -5,7 +5,7 @@ + obj-y += exception.o + obj-y += hvlog.o hvlpconfig.o lpardata.o setup.o dt_mod.o mf.o lpevents.o \ + hvcall.o proc.o htab.o iommu.o misc.o irq.o +-obj-$(CONFIG_PCI) += pci.o vpdinfo.o ++obj-$(CONFIG_PCI) += pci.o + obj-$(CONFIG_SMP) += smp.o + obj-$(CONFIG_VIOPATH) += viopath.o vio.o + obj-$(CONFIG_MODULES) += ksyms.o +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/iseries/iommu.c powerpc.git/arch/powerpc/platforms/iseries/iommu.c +--- linux-2.6.24/arch/powerpc/platforms/iseries/iommu.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/iseries/iommu.c 2008-01-28 20:25:49.000000000 +0100 +@@ -163,8 +163,10 @@ + (it->it_type == TCE_PCI) && + (it->it_offset == tbl->it_offset) && + (it->it_index == tbl->it_index) && +- (it->it_size == tbl->it_size)) ++ (it->it_size == tbl->it_size)) { ++ of_node_put(node); + return it; ++ } + } + return NULL; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/iseries/lpevents.c powerpc.git/arch/powerpc/platforms/iseries/lpevents.c +--- linux-2.6.24/arch/powerpc/platforms/iseries/lpevents.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/iseries/lpevents.c 2008-01-28 20:25:49.000000000 +0100 +@@ -239,7 +239,7 @@ + * other CPUs, and that the deleted handler isn't + * still running on another CPU when we return. + */ +- synchronize_rcu(); ++ synchronize_sched(); + return 0; + } + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/iseries/pci.c powerpc.git/arch/powerpc/platforms/iseries/pci.c +--- linux-2.6.24/arch/powerpc/platforms/iseries/pci.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/iseries/pci.c 2008-01-28 20:25:49.000000000 +0100 +@@ -1,5 +1,6 @@ + /* + * Copyright (C) 2001 Allan Trautman, IBM Corporation ++ * Copyright (C) 2005,2007 Stephen Rothwell, IBM Corp + * + * iSeries specific routines for PCI. + * +@@ -19,13 +20,18 @@ + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + */ ++ ++#undef DEBUG ++ + #include <linux/kernel.h> + #include <linux/list.h> + #include <linux/string.h> + #include <linux/init.h> + #include <linux/module.h> + #include <linux/pci.h> ++#include <linux/of.h> + ++#include <asm/types.h> + #include <asm/io.h> + #include <asm/irq.h> + #include <asm/prom.h> +@@ -35,6 +41,7 @@ + #include <asm/abs_addr.h> + #include <asm/firmware.h> + ++#include <asm/iseries/hv_types.h> + #include <asm/iseries/hv_call_xm.h> + #include <asm/iseries/mf.h> + #include <asm/iseries/iommu.h> +@@ -45,15 +52,8 @@ + #include "pci.h" + #include "call_pci.h" + +-/* +- * Forward declares of prototypes. +- */ +-static struct device_node *find_Device_Node(int bus, int devfn); +- +-static int Pci_Retry_Max = 3; /* Only retry 3 times */ +-static int Pci_Error_Flag = 1; /* Set Retry Error on. */ +- +-static struct pci_ops iSeries_pci_ops; ++#define PCI_RETRY_MAX 3 ++static int limit_pci_retries = 1; /* Set Retry Error on. */ + + /* + * Table defines +@@ -62,6 +62,7 @@ + #define IOMM_TABLE_MAX_ENTRIES 1024 + #define IOMM_TABLE_ENTRY_SIZE 0x0000000000400000UL + #define BASE_IO_MEMORY 0xE000000000000000UL ++#define END_IO_MEMORY 0xEFFFFFFFFFFFFFFFUL + + static unsigned long max_io_memory = BASE_IO_MEMORY; + static long current_iomm_table_entry; +@@ -70,12 +71,237 @@ + * Lookup Tables. + */ + static struct device_node *iomm_table[IOMM_TABLE_MAX_ENTRIES]; +-static u8 iobar_table[IOMM_TABLE_MAX_ENTRIES]; ++static u64 ds_addr_table[IOMM_TABLE_MAX_ENTRIES]; + +-static const char pci_io_text[] = "iSeries PCI I/O"; + static DEFINE_SPINLOCK(iomm_table_lock); + + /* ++ * Generate a Direct Select Address for the Hypervisor ++ */ ++static inline u64 iseries_ds_addr(struct device_node *node) ++{ ++ struct pci_dn *pdn = PCI_DN(node); ++ const u32 *sbp = of_get_property(node, "linux,subbus", NULL); ++ ++ return ((u64)pdn->busno << 48) + ((u64)(sbp ? *sbp : 0) << 40) ++ + ((u64)0x10 << 32); ++} ++ ++/* ++ * Size of Bus VPD data ++ */ ++#define BUS_VPDSIZE 1024 ++ ++/* ++ * Bus Vpd Tags ++ */ ++#define VPD_END_OF_AREA 0x79 ++#define VPD_ID_STRING 0x82 ++#define VPD_VENDOR_AREA 0x84 ++ ++/* ++ * Mfg Area Tags ++ */ ++#define VPD_FRU_FRAME_ID 0x4649 /* "FI" */ ++#define VPD_SLOT_MAP_FORMAT 0x4D46 /* "MF" */ ++#define VPD_SLOT_MAP 0x534D /* "SM" */ ++ ++/* ++ * Structures of the areas ++ */ ++struct mfg_vpd_area { ++ u16 tag; ++ u8 length; ++ u8 data1; ++ u8 data2; ++}; ++#define MFG_ENTRY_SIZE 3 ++ ++struct slot_map { ++ u8 agent; ++ u8 secondary_agent; ++ u8 phb; ++ char card_location[3]; ++ char parms[8]; ++ char reserved[2]; ++}; ++#define SLOT_ENTRY_SIZE 16 ++ ++/* ++ * Parse the Slot Area ++ */ ++static void __init iseries_parse_slot_area(struct slot_map *map, int len, ++ HvAgentId agent, u8 *phb, char card[4]) ++{ ++ /* ++ * Parse Slot label until we find the one requested ++ */ ++ while (len > 0) { ++ if (map->agent == agent) { ++ /* ++ * If Phb wasn't found, grab the entry first one found. ++ */ ++ if (*phb == 0xff) ++ *phb = map->phb; ++ /* Found it, extract the data. */ ++ if (map->phb == *phb) { ++ memcpy(card, &map->card_location, 3); ++ card[3] = 0; ++ break; ++ } ++ } ++ /* Point to the next Slot */ ++ map = (struct slot_map *)((char *)map + SLOT_ENTRY_SIZE); ++ len -= SLOT_ENTRY_SIZE; ++ } ++} ++ ++/* ++ * Parse the Mfg Area ++ */ ++static void __init iseries_parse_mfg_area(struct mfg_vpd_area *area, int len, ++ HvAgentId agent, u8 *phb, u8 *frame, char card[4]) ++{ ++ u16 slot_map_fmt = 0; ++ ++ /* Parse Mfg Data */ ++ while (len > 0) { ++ int mfg_tag_len = area->length; ++ /* Frame ID (FI 4649020310 ) */ ++ if (area->tag == VPD_FRU_FRAME_ID) ++ *frame = area->data1; ++ /* Slot Map Format (MF 4D46020004 ) */ ++ else if (area->tag == VPD_SLOT_MAP_FORMAT) ++ slot_map_fmt = (area->data1 * 256) ++ + area->data2; ++ /* Slot Map (SM 534D90 */ ++ else if (area->tag == VPD_SLOT_MAP) { ++ struct slot_map *slot_map; ++ ++ if (slot_map_fmt == 0x1004) ++ slot_map = (struct slot_map *)((char *)area ++ + MFG_ENTRY_SIZE + 1); ++ else ++ slot_map = (struct slot_map *)((char *)area ++ + MFG_ENTRY_SIZE); ++ iseries_parse_slot_area(slot_map, mfg_tag_len, ++ agent, phb, card); ++ } ++ /* ++ * Point to the next Mfg Area ++ * Use defined size, sizeof give wrong answer ++ */ ++ area = (struct mfg_vpd_area *)((char *)area + mfg_tag_len ++ + MFG_ENTRY_SIZE); ++ len -= (mfg_tag_len + MFG_ENTRY_SIZE); ++ } ++} ++ ++/* ++ * Look for "BUS".. Data is not Null terminated. ++ * PHBID of 0xFF indicates PHB was not found in VPD Data. ++ */ ++static u8 __init iseries_parse_phbid(u8 *area, int len) ++{ ++ while (len > 0) { ++ if ((*area == 'B') && (*(area + 1) == 'U') ++ && (*(area + 2) == 'S')) { ++ area += 3; ++ while (*area == ' ') ++ area++; ++ return *area & 0x0F; ++ } ++ area++; ++ len--; ++ } ++ return 0xff; ++} ++ ++/* ++ * Parse out the VPD Areas ++ */ ++static void __init iseries_parse_vpd(u8 *data, int data_len, ++ HvAgentId agent, u8 *frame, char card[4]) ++{ ++ u8 phb = 0xff; ++ ++ while (data_len > 0) { ++ int len; ++ u8 tag = *data; ++ ++ if (tag == VPD_END_OF_AREA) ++ break; ++ len = *(data + 1) + (*(data + 2) * 256); ++ data += 3; ++ data_len -= 3; ++ if (tag == VPD_ID_STRING) ++ phb = iseries_parse_phbid(data, len); ++ else if (tag == VPD_VENDOR_AREA) ++ iseries_parse_mfg_area((struct mfg_vpd_area *)data, len, ++ agent, &phb, frame, card); ++ /* Point to next Area. */ ++ data += len; ++ data_len -= len; ++ } ++} ++ ++static int __init iseries_get_location_code(u16 bus, HvAgentId agent, ++ u8 *frame, char card[4]) ++{ ++ int status = 0; ++ int bus_vpd_len = 0; ++ u8 *bus_vpd = kmalloc(BUS_VPDSIZE, GFP_KERNEL); ++ ++ if (bus_vpd == NULL) { ++ printk("PCI: Bus VPD Buffer allocation failure.\n"); ++ return 0; ++ } ++ bus_vpd_len = HvCallPci_getBusVpd(bus, iseries_hv_addr(bus_vpd), ++ BUS_VPDSIZE); ++ if (bus_vpd_len == 0) { ++ printk("PCI: Bus VPD Buffer zero length.\n"); ++ goto out_free; ++ } ++ /* printk("PCI: bus_vpd: %p, %d\n",bus_vpd, bus_vpd_len); */ ++ /* Make sure this is what I think it is */ ++ if (*bus_vpd != VPD_ID_STRING) { ++ printk("PCI: Bus VPD Buffer missing starting tag.\n"); ++ goto out_free; ++ } ++ iseries_parse_vpd(bus_vpd, bus_vpd_len, agent, frame, card); ++ status = 1; ++out_free: ++ kfree(bus_vpd); ++ return status; ++} ++ ++/* ++ * Prints the device information. ++ * - Pass in pci_dev* pointer to the device. ++ * - Pass in the device count ++ * ++ * Format: ++ * PCI: Bus 0, Device 26, Vendor 0x12AE Frame 1, Card C10 Ethernet ++ * controller ++ */ ++static void __init iseries_device_information(struct pci_dev *pdev, ++ u16 bus, HvSubBusNumber subbus) ++{ ++ u8 frame = 0; ++ char card[4]; ++ HvAgentId agent; ++ ++ agent = ISERIES_PCI_AGENTID(ISERIES_GET_DEVICE_FROM_SUBBUS(subbus), ++ ISERIES_GET_FUNCTION_FROM_SUBBUS(subbus)); ++ ++ if (iseries_get_location_code(bus, agent, &frame, card)) { ++ printk(KERN_INFO "PCI: %s, Vendor %04X Frame%3d, " ++ "Card %4s 0x%04X\n", pci_name(pdev), pdev->vendor, ++ frame, card, (int)(pdev->class >> 8)); ++ } ++} ++ ++/* + * iomm_table_allocate_entry + * + * Adds pci_dev entry in address translation table +@@ -87,7 +313,7 @@ + * - CurrentIndex is incremented to keep track of the last entry. + * - Builds the resource entry for allocated BARs. + */ +-static void iomm_table_allocate_entry(struct pci_dev *dev, int bar_num) ++static void __init iomm_table_allocate_entry(struct pci_dev *dev, int bar_num) + { + struct resource *bar_res = &dev->resource[bar_num]; + long bar_size = pci_resource_len(dev, bar_num); +@@ -101,7 +327,6 @@ + * Set Resource values. + */ + spin_lock(&iomm_table_lock); +- bar_res->name = pci_io_text; + bar_res->start = BASE_IO_MEMORY + + IOMM_TABLE_ENTRY_SIZE * current_iomm_table_entry; + bar_res->end = bar_res->start + bar_size - 1; +@@ -110,7 +335,8 @@ + */ + while (bar_size > 0 ) { + iomm_table[current_iomm_table_entry] = dev->sysdata; +- iobar_table[current_iomm_table_entry] = bar_num; ++ ds_addr_table[current_iomm_table_entry] = ++ iseries_ds_addr(dev->sysdata) | (bar_num << 24); + bar_size -= IOMM_TABLE_ENTRY_SIZE; + ++current_iomm_table_entry; + } +@@ -130,7 +356,7 @@ + * - Loops through The Bar resources(0 - 5) including the ROM + * is resource(6). + */ +-static void allocate_device_bars(struct pci_dev *dev) ++static void __init allocate_device_bars(struct pci_dev *dev) + { + int bar_num; + +@@ -145,79 +371,19 @@ + * PCI: Read Vendor Failed 0x18.58.10 Rc: 0x00xx + * PCI: Connect Bus Unit Failed 0x18.58.10 Rc: 0x00xx + */ +-static void pci_Log_Error(char *Error_Text, int Bus, int SubBus, +- int AgentId, int HvRc) ++static void pci_log_error(char *error, int bus, int subbus, ++ int agent, int hv_res) + { +- if (HvRc == 0x0302) ++ if (hv_res == 0x0302) + return; + printk(KERN_ERR "PCI: %s Failed: 0x%02X.%02X.%02X Rc: 0x%04X", +- Error_Text, Bus, SubBus, AgentId, HvRc); +-} +- +-/* +- * iSeries_pci_final_fixup(void) +- */ +-void __init iSeries_pci_final_fixup(void) +-{ +- struct pci_dev *pdev = NULL; +- struct device_node *node; +- int DeviceCount = 0; +- +- /* Fix up at the device node and pci_dev relationship */ +- mf_display_src(0xC9000100); +- +- printk("pcibios_final_fixup\n"); +- for_each_pci_dev(pdev) { +- node = find_Device_Node(pdev->bus->number, pdev->devfn); +- printk("pci dev %p (%x.%x), node %p\n", pdev, +- pdev->bus->number, pdev->devfn, node); +- +- if (node != NULL) { +- struct pci_dn *pdn = PCI_DN(node); +- const u32 *agent; +- +- agent = of_get_property(node, "linux,agent-id", NULL); +- if ((pdn != NULL) && (agent != NULL)) { +- u8 irq = iSeries_allocate_IRQ(pdn->busno, 0, +- pdn->bussubno); +- int err; +- +- err = HvCallXm_connectBusUnit(pdn->busno, pdn->bussubno, +- *agent, irq); +- if (err) +- pci_Log_Error("Connect Bus Unit", +- pdn->busno, pdn->bussubno, *agent, err); +- else { +- err = HvCallPci_configStore8(pdn->busno, pdn->bussubno, +- *agent, +- PCI_INTERRUPT_LINE, +- irq); +- if (err) +- pci_Log_Error("PciCfgStore Irq Failed!", +- pdn->busno, pdn->bussubno, *agent, err); +- } +- if (!err) +- pdev->irq = irq; +- } +- +- ++DeviceCount; +- pdev->sysdata = (void *)node; +- PCI_DN(node)->pcidev = pdev; +- allocate_device_bars(pdev); +- iSeries_Device_Information(pdev, DeviceCount); +- iommu_devnode_init_iSeries(pdev, node); +- } else +- printk("PCI: Device Tree not found for 0x%016lX\n", +- (unsigned long)pdev); +- } +- iSeries_activate_IRQs(); +- mf_display_src(0xC9000200); ++ error, bus, subbus, agent, hv_res); + } + + /* + * Look down the chain to find the matching Device Device + */ +-static struct device_node *find_Device_Node(int bus, int devfn) ++static struct device_node *find_device_node(int bus, int devfn) + { + struct device_node *node; + +@@ -230,22 +396,66 @@ + return NULL; + } + +-#if 0 + /* +- * Returns the device node for the passed pci_dev +- * Sanity Check Node PciDev to passed pci_dev +- * If none is found, returns a NULL which the client must handle. ++ * iSeries_pcibios_fixup_resources ++ * ++ * Fixes up all resources for devices + */ +-static struct device_node *get_Device_Node(struct pci_dev *pdev) ++void __init iSeries_pcibios_fixup_resources(struct pci_dev *pdev) + { ++ const u32 *agent; ++ const u32 *sub_bus; ++ unsigned char bus = pdev->bus->number; + struct device_node *node; ++ int i; ++ ++ node = find_device_node(bus, pdev->devfn); ++ pr_debug("PCI: iSeries %s, pdev %p, node %p\n", ++ pci_name(pdev), pdev, node); ++ if (!node) { ++ printk("PCI: %s disabled, device tree entry not found !\n", ++ pci_name(pdev)); ++ for (i = 0; i <= PCI_ROM_RESOURCE; i++) ++ pdev->resource[i].flags = 0; ++ return; ++ } ++ sub_bus = of_get_property(node, "linux,subbus", NULL); ++ agent = of_get_property(node, "linux,agent-id", NULL); ++ if (agent && sub_bus) { ++ u8 irq = iSeries_allocate_IRQ(bus, 0, *sub_bus); ++ int err; ++ ++ err = HvCallXm_connectBusUnit(bus, *sub_bus, *agent, irq); ++ if (err) ++ pci_log_error("Connect Bus Unit", ++ bus, *sub_bus, *agent, err); ++ else { ++ err = HvCallPci_configStore8(bus, *sub_bus, ++ *agent, PCI_INTERRUPT_LINE, irq); ++ if (err) ++ pci_log_error("PciCfgStore Irq Failed!", ++ bus, *sub_bus, *agent, err); ++ else ++ pdev->irq = irq; ++ } ++ } + +- node = pdev->sysdata; +- if (node == NULL || PCI_DN(node)->pcidev != pdev) +- node = find_Device_Node(pdev->bus->number, pdev->devfn); +- return node; ++ pdev->sysdata = node; ++ allocate_device_bars(pdev); ++ iseries_device_information(pdev, bus, *sub_bus); ++ iommu_devnode_init_iSeries(pdev, node); ++} ++ ++/* ++ * iSeries_pci_final_fixup(void) ++ */ ++void __init iSeries_pci_final_fixup(void) ++{ ++ /* Fix up at the device node and pci_dev relationship */ ++ mf_display_src(0xC9000100); ++ iSeries_activate_IRQs(); ++ mf_display_src(0xC9000200); + } +-#endif + + /* + * Config space read and write functions. +@@ -269,7 +479,7 @@ + static int iSeries_pci_read_config(struct pci_bus *bus, unsigned int devfn, + int offset, int size, u32 *val) + { +- struct device_node *node = find_Device_Node(bus->number, devfn); ++ struct device_node *node = find_device_node(bus->number, devfn); + u64 fn; + struct HvCallPci_LoadReturn ret; + +@@ -299,7 +509,7 @@ + static int iSeries_pci_write_config(struct pci_bus *bus, unsigned int devfn, + int offset, int size, u32 val) + { +- struct device_node *node = find_Device_Node(bus->number, devfn); ++ struct device_node *node = find_device_node(bus->number, devfn); + u64 fn; + u64 ret; + +@@ -331,22 +541,22 @@ + * PCI: Device 23.90 ReadL Retry( 1) + * PCI: Device 23.90 ReadL Retry Successful(1) + */ +-static int CheckReturnCode(char *TextHdr, struct device_node *DevNode, ++static int check_return_code(char *type, struct device_node *dn, + int *retry, u64 ret) + { + if (ret != 0) { +- struct pci_dn *pdn = PCI_DN(DevNode); ++ struct pci_dn *pdn = PCI_DN(dn); + + (*retry)++; + printk("PCI: %s: Device 0x%04X:%02X I/O Error(%2d): 0x%04X\n", +- TextHdr, pdn->busno, pdn->devfn, ++ type, pdn->busno, pdn->devfn, + *retry, (int)ret); + /* + * Bump the retry and check for retry count exceeded. + * If, Exceeded, panic the system. + */ +- if (((*retry) > Pci_Retry_Max) && +- (Pci_Error_Flag > 0)) { ++ if (((*retry) > PCI_RETRY_MAX) && ++ (limit_pci_retries > 0)) { + mf_display_src(0xB6000103); + panic_timeout = 0; + panic("PCI: Hardware I/O Error, SRC B6000103, " +@@ -363,28 +573,39 @@ + * the exposure of being device global. + */ + static inline struct device_node *xlate_iomm_address( +- const volatile void __iomem *IoAddress, +- u64 *dsaptr, u64 *BarOffsetPtr) ++ const volatile void __iomem *addr, ++ u64 *dsaptr, u64 *bar_offset, const char *func) + { +- unsigned long OrigIoAddr; +- unsigned long BaseIoAddr; +- unsigned long TableIndex; +- struct device_node *DevNode; ++ unsigned long orig_addr; ++ unsigned long base_addr; ++ unsigned long ind; ++ struct device_node *dn; + +- OrigIoAddr = (unsigned long __force)IoAddress; +- if ((OrigIoAddr < BASE_IO_MEMORY) || (OrigIoAddr >= max_io_memory)) ++ orig_addr = (unsigned long __force)addr; ++ if ((orig_addr < BASE_IO_MEMORY) || (orig_addr >= max_io_memory)) { ++ static unsigned long last_jiffies; ++ static int num_printed; ++ ++ if ((jiffies - last_jiffies) > 60 * HZ) { ++ last_jiffies = jiffies; ++ num_printed = 0; ++ } ++ if (num_printed++ < 10) ++ printk(KERN_ERR ++ "iSeries_%s: invalid access at IO address %p\n", ++ func, addr); + return NULL; +- BaseIoAddr = OrigIoAddr - BASE_IO_MEMORY; +- TableIndex = BaseIoAddr / IOMM_TABLE_ENTRY_SIZE; +- DevNode = iomm_table[TableIndex]; +- +- if (DevNode != NULL) { +- int barnum = iobar_table[TableIndex]; +- *dsaptr = iseries_ds_addr(DevNode) | (barnum << 24); +- *BarOffsetPtr = BaseIoAddr % IOMM_TABLE_ENTRY_SIZE; ++ } ++ base_addr = orig_addr - BASE_IO_MEMORY; ++ ind = base_addr / IOMM_TABLE_ENTRY_SIZE; ++ dn = iomm_table[ind]; ++ ++ if (dn != NULL) { ++ *dsaptr = ds_addr_table[ind]; ++ *bar_offset = base_addr % IOMM_TABLE_ENTRY_SIZE; + } else +- panic("PCI: Invalid PCI IoAddress detected!\n"); +- return DevNode; ++ panic("PCI: Invalid PCI IO address detected!\n"); ++ return dn; + } + + /* +@@ -392,91 +613,58 @@ + * On MM I/O error, all ones are returned and iSeries_pci_IoError is cal + * else, data is returned in Big Endian format. + */ +-static u8 iSeries_Read_Byte(const volatile void __iomem *IoAddress) ++static u8 iseries_readb(const volatile void __iomem *addr) + { +- u64 BarOffset; ++ u64 bar_offset; + u64 dsa; + int retry = 0; + struct HvCallPci_LoadReturn ret; +- struct device_node *DevNode = +- xlate_iomm_address(IoAddress, &dsa, &BarOffset); +- +- if (DevNode == NULL) { +- static unsigned long last_jiffies; +- static int num_printed; ++ struct device_node *dn = ++ xlate_iomm_address(addr, &dsa, &bar_offset, "read_byte"); + +- if ((jiffies - last_jiffies) > 60 * HZ) { +- last_jiffies = jiffies; +- num_printed = 0; +- } +- if (num_printed++ < 10) +- printk(KERN_ERR "iSeries_Read_Byte: invalid access at IO address %p\n", +- IoAddress); ++ if (dn == NULL) + return 0xff; +- } + do { +- HvCall3Ret16(HvCallPciBarLoad8, &ret, dsa, BarOffset, 0); +- } while (CheckReturnCode("RDB", DevNode, &retry, ret.rc) != 0); ++ HvCall3Ret16(HvCallPciBarLoad8, &ret, dsa, bar_offset, 0); ++ } while (check_return_code("RDB", dn, &retry, ret.rc) != 0); + + return ret.value; + } + +-static u16 iSeries_Read_Word(const volatile void __iomem *IoAddress) ++static u16 iseries_readw_be(const volatile void __iomem *addr) + { +- u64 BarOffset; ++ u64 bar_offset; + u64 dsa; + int retry = 0; + struct HvCallPci_LoadReturn ret; +- struct device_node *DevNode = +- xlate_iomm_address(IoAddress, &dsa, &BarOffset); +- +- if (DevNode == NULL) { +- static unsigned long last_jiffies; +- static int num_printed; ++ struct device_node *dn = ++ xlate_iomm_address(addr, &dsa, &bar_offset, "read_word"); + +- if ((jiffies - last_jiffies) > 60 * HZ) { +- last_jiffies = jiffies; +- num_printed = 0; +- } +- if (num_printed++ < 10) +- printk(KERN_ERR "iSeries_Read_Word: invalid access at IO address %p\n", +- IoAddress); ++ if (dn == NULL) + return 0xffff; +- } + do { + HvCall3Ret16(HvCallPciBarLoad16, &ret, dsa, +- BarOffset, 0); +- } while (CheckReturnCode("RDW", DevNode, &retry, ret.rc) != 0); ++ bar_offset, 0); ++ } while (check_return_code("RDW", dn, &retry, ret.rc) != 0); + + return ret.value; + } + +-static u32 iSeries_Read_Long(const volatile void __iomem *IoAddress) ++static u32 iseries_readl_be(const volatile void __iomem *addr) + { +- u64 BarOffset; ++ u64 bar_offset; + u64 dsa; + int retry = 0; + struct HvCallPci_LoadReturn ret; +- struct device_node *DevNode = +- xlate_iomm_address(IoAddress, &dsa, &BarOffset); ++ struct device_node *dn = ++ xlate_iomm_address(addr, &dsa, &bar_offset, "read_long"); + +- if (DevNode == NULL) { +- static unsigned long last_jiffies; +- static int num_printed; +- +- if ((jiffies - last_jiffies) > 60 * HZ) { +- last_jiffies = jiffies; +- num_printed = 0; +- } +- if (num_printed++ < 10) +- printk(KERN_ERR "iSeries_Read_Long: invalid access at IO address %p\n", +- IoAddress); ++ if (dn == NULL) + return 0xffffffff; +- } + do { + HvCall3Ret16(HvCallPciBarLoad32, &ret, dsa, +- BarOffset, 0); +- } while (CheckReturnCode("RDL", DevNode, &retry, ret.rc) != 0); ++ bar_offset, 0); ++ } while (check_return_code("RDL", dn, &retry, ret.rc) != 0); + + return ret.value; + } +@@ -485,134 +673,72 @@ + * Write MM I/O Instructions for the iSeries + * + */ +-static void iSeries_Write_Byte(u8 data, volatile void __iomem *IoAddress) ++static void iseries_writeb(u8 data, volatile void __iomem *addr) + { +- u64 BarOffset; ++ u64 bar_offset; + u64 dsa; + int retry = 0; + u64 rc; +- struct device_node *DevNode = +- xlate_iomm_address(IoAddress, &dsa, &BarOffset); +- +- if (DevNode == NULL) { +- static unsigned long last_jiffies; +- static int num_printed; ++ struct device_node *dn = ++ xlate_iomm_address(addr, &dsa, &bar_offset, "write_byte"); + +- if ((jiffies - last_jiffies) > 60 * HZ) { +- last_jiffies = jiffies; +- num_printed = 0; +- } +- if (num_printed++ < 10) +- printk(KERN_ERR "iSeries_Write_Byte: invalid access at IO address %p\n", IoAddress); ++ if (dn == NULL) + return; +- } + do { +- rc = HvCall4(HvCallPciBarStore8, dsa, BarOffset, data, 0); +- } while (CheckReturnCode("WWB", DevNode, &retry, rc) != 0); ++ rc = HvCall4(HvCallPciBarStore8, dsa, bar_offset, data, 0); ++ } while (check_return_code("WWB", dn, &retry, rc) != 0); + } + +-static void iSeries_Write_Word(u16 data, volatile void __iomem *IoAddress) ++static void iseries_writew_be(u16 data, volatile void __iomem *addr) + { +- u64 BarOffset; ++ u64 bar_offset; + u64 dsa; + int retry = 0; + u64 rc; +- struct device_node *DevNode = +- xlate_iomm_address(IoAddress, &dsa, &BarOffset); ++ struct device_node *dn = ++ xlate_iomm_address(addr, &dsa, &bar_offset, "write_word"); + +- if (DevNode == NULL) { +- static unsigned long last_jiffies; +- static int num_printed; +- +- if ((jiffies - last_jiffies) > 60 * HZ) { +- last_jiffies = jiffies; +- num_printed = 0; +- } +- if (num_printed++ < 10) +- printk(KERN_ERR "iSeries_Write_Word: invalid access at IO address %p\n", +- IoAddress); ++ if (dn == NULL) + return; +- } + do { +- rc = HvCall4(HvCallPciBarStore16, dsa, BarOffset, data, 0); +- } while (CheckReturnCode("WWW", DevNode, &retry, rc) != 0); ++ rc = HvCall4(HvCallPciBarStore16, dsa, bar_offset, data, 0); ++ } while (check_return_code("WWW", dn, &retry, rc) != 0); + } + +-static void iSeries_Write_Long(u32 data, volatile void __iomem *IoAddress) ++static void iseries_writel_be(u32 data, volatile void __iomem *addr) + { +- u64 BarOffset; ++ u64 bar_offset; + u64 dsa; + int retry = 0; + u64 rc; +- struct device_node *DevNode = +- xlate_iomm_address(IoAddress, &dsa, &BarOffset); +- +- if (DevNode == NULL) { +- static unsigned long last_jiffies; +- static int num_printed; ++ struct device_node *dn = ++ xlate_iomm_address(addr, &dsa, &bar_offset, "write_long"); + +- if ((jiffies - last_jiffies) > 60 * HZ) { +- last_jiffies = jiffies; +- num_printed = 0; +- } +- if (num_printed++ < 10) +- printk(KERN_ERR "iSeries_Write_Long: invalid access at IO address %p\n", +- IoAddress); ++ if (dn == NULL) + return; +- } + do { +- rc = HvCall4(HvCallPciBarStore32, dsa, BarOffset, data, 0); +- } while (CheckReturnCode("WWL", DevNode, &retry, rc) != 0); +-} +- +-static u8 iseries_readb(const volatile void __iomem *addr) +-{ +- return iSeries_Read_Byte(addr); ++ rc = HvCall4(HvCallPciBarStore32, dsa, bar_offset, data, 0); ++ } while (check_return_code("WWL", dn, &retry, rc) != 0); + } + + static u16 iseries_readw(const volatile void __iomem *addr) + { +- return le16_to_cpu(iSeries_Read_Word(addr)); ++ return le16_to_cpu(iseries_readw_be(addr)); + } + + static u32 iseries_readl(const volatile void __iomem *addr) + { +- return le32_to_cpu(iSeries_Read_Long(addr)); +-} +- +-static u16 iseries_readw_be(const volatile void __iomem *addr) +-{ +- return iSeries_Read_Word(addr); +-} +- +-static u32 iseries_readl_be(const volatile void __iomem *addr) +-{ +- return iSeries_Read_Long(addr); +-} +- +-static void iseries_writeb(u8 data, volatile void __iomem *addr) +-{ +- iSeries_Write_Byte(data, addr); ++ return le32_to_cpu(iseries_readl_be(addr)); + } + + static void iseries_writew(u16 data, volatile void __iomem *addr) + { +- iSeries_Write_Word(cpu_to_le16(data), addr); ++ iseries_writew_be(cpu_to_le16(data), addr); + } + + static void iseries_writel(u32 data, volatile void __iomem *addr) + { +- iSeries_Write_Long(cpu_to_le32(data), addr); +-} +- +-static void iseries_writew_be(u16 data, volatile void __iomem *addr) +-{ +- iSeries_Write_Word(data, addr); +-} +- +-static void iseries_writel_be(u32 data, volatile void __iomem *addr) +-{ +- iSeries_Write_Long(data, addr); ++ iseries_writel(cpu_to_le32(data), addr); + } + + static void iseries_readsb(const volatile void __iomem *addr, void *buf, +@@ -620,7 +746,7 @@ + { + u8 *dst = buf; + while(count-- > 0) +- *(dst++) = iSeries_Read_Byte(addr); ++ *(dst++) = iseries_readb(addr); + } + + static void iseries_readsw(const volatile void __iomem *addr, void *buf, +@@ -628,7 +754,7 @@ + { + u16 *dst = buf; + while(count-- > 0) +- *(dst++) = iSeries_Read_Word(addr); ++ *(dst++) = iseries_readw_be(addr); + } + + static void iseries_readsl(const volatile void __iomem *addr, void *buf, +@@ -636,7 +762,7 @@ + { + u32 *dst = buf; + while(count-- > 0) +- *(dst++) = iSeries_Read_Long(addr); ++ *(dst++) = iseries_readl_be(addr); + } + + static void iseries_writesb(volatile void __iomem *addr, const void *buf, +@@ -644,7 +770,7 @@ + { + const u8 *src = buf; + while(count-- > 0) +- iSeries_Write_Byte(*(src++), addr); ++ iseries_writeb(*(src++), addr); + } + + static void iseries_writesw(volatile void __iomem *addr, const void *buf, +@@ -652,7 +778,7 @@ + { + const u16 *src = buf; + while(count-- > 0) +- iSeries_Write_Word(*(src++), addr); ++ iseries_writew_be(*(src++), addr); + } + + static void iseries_writesl(volatile void __iomem *addr, const void *buf, +@@ -660,7 +786,7 @@ + { + const u32 *src = buf; + while(count-- > 0) +- iSeries_Write_Long(*(src++), addr); ++ iseries_writel_be(*(src++), addr); + } + + static void iseries_memset_io(volatile void __iomem *addr, int c, +@@ -669,7 +795,7 @@ + volatile char __iomem *d = addr; + + while (n-- > 0) +- iSeries_Write_Byte(c, d++); ++ iseries_writeb(c, d++); + } + + static void iseries_memcpy_fromio(void *dest, const volatile void __iomem *src, +@@ -679,7 +805,7 @@ + const volatile char __iomem *s = src; + + while (n-- > 0) +- *d++ = iSeries_Read_Byte(s++); ++ *d++ = iseries_readb(s++); + } + + static void iseries_memcpy_toio(volatile void __iomem *dest, const void *src, +@@ -689,7 +815,7 @@ + volatile char __iomem *d = dest; + + while (n-- > 0) +- iSeries_Write_Byte(*s++, d++); ++ iseries_writeb(*s++, d++); + } + + /* We only set MMIO ops. The default PIO ops will be default +@@ -742,6 +868,8 @@ + /* Install IO hooks */ + ppc_pci_io = iseries_pci_io; + ++ pci_probe_only = 1; ++ + /* iSeries has no IO space in the common sense, it needs to set + * the IO base to 0 + */ +@@ -767,11 +895,21 @@ + phb = pcibios_alloc_controller(node); + if (phb == NULL) + continue; ++ /* All legacy iSeries PHBs are in domain zero */ ++ phb->global_number = 0; + +- phb->pci_mem_offset = bus; + phb->first_busno = bus; + phb->last_busno = bus; + phb->ops = &iSeries_pci_ops; ++ phb->io_base_virt = (void __iomem *)_IO_BASE; ++ phb->io_resource.flags = IORESOURCE_IO; ++ phb->io_resource.start = BASE_IO_MEMORY; ++ phb->io_resource.end = END_IO_MEMORY; ++ phb->io_resource.name = "iSeries PCI IO"; ++ phb->mem_resources[0].flags = IORESOURCE_MEM; ++ phb->mem_resources[0].start = BASE_IO_MEMORY; ++ phb->mem_resources[0].end = END_IO_MEMORY; ++ phb->mem_resources[0].name = "Series PCI MEM"; + } + + of_node_put(root); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/iseries/pci.h powerpc.git/arch/powerpc/platforms/iseries/pci.h +--- linux-2.6.24/arch/powerpc/platforms/iseries/pci.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/iseries/pci.h 2008-01-28 20:25:49.000000000 +0100 +@@ -30,10 +30,6 @@ + * End Change Activity + */ + +-#include <asm/pci-bridge.h> +- +-struct pci_dev; /* For Forward Reference */ +- + /* + * Decodes Linux DevFn to iSeries DevFn, bridge device, or function. + * For Linux, see PCI_SLOT and PCI_FUNC in include/linux/pci.h +@@ -47,17 +43,16 @@ + #define ISERIES_GET_DEVICE_FROM_SUBBUS(subbus) ((subbus >> 5) & 0x7) + #define ISERIES_GET_FUNCTION_FROM_SUBBUS(subbus) ((subbus >> 2) & 0x7) + +-/* +- * Generate a Direct Select Address for the Hypervisor +- */ +-static inline u64 iseries_ds_addr(struct device_node *node) +-{ +- struct pci_dn *pdn = PCI_DN(node); +- +- return ((u64)pdn->busno << 48) + ((u64)pdn->bussubno << 40) +- + ((u64)0x10 << 32); +-} ++struct pci_dev; + +-extern void iSeries_Device_Information(struct pci_dev*, int); ++#ifdef CONFIG_PCI ++extern void iSeries_pcibios_init(void); ++extern void iSeries_pci_final_fixup(void); ++extern void iSeries_pcibios_fixup_resources(struct pci_dev *dev); ++#else ++static inline void iSeries_pcibios_init(void) { } ++static inline void iSeries_pci_final_fixup(void) { } ++static inline void iSeries_pcibios_fixup_resources(struct pci_dev *dev) {} ++#endif + + #endif /* _PLATFORMS_ISERIES_PCI_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/iseries/setup.c powerpc.git/arch/powerpc/platforms/iseries/setup.c +--- linux-2.6.24/arch/powerpc/platforms/iseries/setup.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/iseries/setup.c 2008-01-28 20:25:49.000000000 +0100 +@@ -63,6 +63,7 @@ + #include "main_store.h" + #include "call_sm.h" + #include "call_hpt.h" ++#include "pci.h" + + #ifdef DEBUG + #define DBG(fmt...) udbg_printf(fmt) +@@ -74,11 +75,6 @@ + static unsigned long build_iSeries_Memory_Map(void); + static void iseries_shared_idle(void); + static void iseries_dedicated_idle(void); +-#ifdef CONFIG_PCI +-extern void iSeries_pci_final_fixup(void); +-#else +-static void iSeries_pci_final_fixup(void) { } +-#endif + + + struct MemoryBlock { +@@ -112,13 +108,13 @@ + * correctly. + */ + mb_array[0].logicalStart = 0; +- mb_array[0].logicalEnd = 0x100000000; ++ mb_array[0].logicalEnd = 0x100000000UL; + mb_array[0].absStart = 0; +- mb_array[0].absEnd = 0x100000000; ++ mb_array[0].absEnd = 0x100000000UL; + + if (holeSize) { + numMemoryBlocks = 2; +- holeStart = holeStart & 0x000fffffffffffff; ++ holeStart = holeStart & 0x000fffffffffffffUL; + holeStart = addr_to_chunk(holeStart); + holeFirstChunk = holeStart; + holeSize = addr_to_chunk(holeSize); +@@ -128,9 +124,9 @@ + mb_array[0].logicalEnd = holeFirstChunk; + mb_array[0].absEnd = holeFirstChunk; + mb_array[1].logicalStart = holeFirstChunk; +- mb_array[1].logicalEnd = 0x100000000 - holeSizeChunks; ++ mb_array[1].logicalEnd = 0x100000000UL - holeSizeChunks; + mb_array[1].absStart = holeFirstChunk + holeSizeChunks; +- mb_array[1].absEnd = 0x100000000; ++ mb_array[1].absEnd = 0x100000000UL; + } + return numMemoryBlocks; + } +@@ -234,9 +230,9 @@ + mb_array[i].logicalEnd, + mb_array[i].absStart, mb_array[i].absEnd); + mb_array[i].absStart = addr_to_chunk(mb_array[i].absStart & +- 0x000fffffffffffff); ++ 0x000fffffffffffffUL); + mb_array[i].absEnd = addr_to_chunk(mb_array[i].absEnd & +- 0x000fffffffffffff); ++ 0x000fffffffffffffUL); + mb_array[i].logicalStart = + addr_to_chunk(mb_array[i].logicalStart); + mb_array[i].logicalEnd = addr_to_chunk(mb_array[i].logicalEnd); +@@ -320,7 +316,7 @@ + }; + EXPORT_SYMBOL(mschunks_map); + +-void mschunks_alloc(unsigned long num_chunks) ++static void mschunks_alloc(unsigned long num_chunks) + { + klimit = _ALIGN(klimit, sizeof(u32)); + mschunks_map.mapping = (u32 *)klimit; +@@ -499,6 +495,8 @@ + itVpdAreas.xSlicMaxLogicalProcs); + printk("Max physical processors = %d\n", + itVpdAreas.xSlicMaxPhysicalProcs); ++ ++ iSeries_pcibios_init(); + } + + static void iSeries_show_cpuinfo(struct seq_file *m) +@@ -641,24 +639,25 @@ + } + + define_machine(iseries) { +- .name = "iSeries", +- .setup_arch = iSeries_setup_arch, +- .show_cpuinfo = iSeries_show_cpuinfo, +- .init_IRQ = iSeries_init_IRQ, +- .get_irq = iSeries_get_irq, +- .init_early = iSeries_init_early, +- .pcibios_fixup = iSeries_pci_final_fixup, +- .restart = mf_reboot, +- .power_off = mf_power_off, +- .halt = mf_power_off, +- .get_boot_time = iSeries_get_boot_time, +- .set_rtc_time = iSeries_set_rtc_time, +- .get_rtc_time = iSeries_get_rtc_time, +- .calibrate_decr = generic_calibrate_decr, +- .progress = iSeries_progress, +- .probe = iseries_probe, +- .ioremap = iseries_ioremap, +- .iounmap = iseries_iounmap, ++ .name = "iSeries", ++ .setup_arch = iSeries_setup_arch, ++ .show_cpuinfo = iSeries_show_cpuinfo, ++ .init_IRQ = iSeries_init_IRQ, ++ .get_irq = iSeries_get_irq, ++ .init_early = iSeries_init_early, ++ .pcibios_fixup = iSeries_pci_final_fixup, ++ .pcibios_fixup_resources= iSeries_pcibios_fixup_resources, ++ .restart = mf_reboot, ++ .power_off = mf_power_off, ++ .halt = mf_power_off, ++ .get_boot_time = iSeries_get_boot_time, ++ .set_rtc_time = iSeries_set_rtc_time, ++ .get_rtc_time = iSeries_get_rtc_time, ++ .calibrate_decr = generic_calibrate_decr, ++ .progress = iSeries_progress, ++ .probe = iseries_probe, ++ .ioremap = iseries_ioremap, ++ .iounmap = iseries_iounmap, + /* XXX Implement enable_pmcs for iSeries */ + }; + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/iseries/setup.h powerpc.git/arch/powerpc/platforms/iseries/setup.h +--- linux-2.6.24/arch/powerpc/platforms/iseries/setup.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/iseries/setup.h 2008-01-28 20:25:49.000000000 +0100 +@@ -17,6 +17,7 @@ + #ifndef __ISERIES_SETUP_H__ + #define __ISERIES_SETUP_H__ + ++extern void *iSeries_early_setup(void); + extern unsigned long iSeries_get_boot_time(void); + extern int iSeries_set_rtc_time(struct rtc_time *tm); + extern void iSeries_get_rtc_time(struct rtc_time *tm); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/iseries/vpdinfo.c powerpc.git/arch/powerpc/platforms/iseries/vpdinfo.c +--- linux-2.6.24/arch/powerpc/platforms/iseries/vpdinfo.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/iseries/vpdinfo.c 1970-01-01 01:00:00.000000000 +0100 +@@ -1,275 +0,0 @@ +-/* +- * This code gets the card location of the hardware +- * Copyright (C) 2001 <Allan H Trautman> <IBM Corp> +- * Copyright (C) 2005 Stephen Rothwel, IBM Corp +- * +- * This program is free software; you can redistribute it and/or modify +- * it under the terms of the GNU General Public License as published by +- * the Free Software Foundation; either version 2 of the License, or +- * (at your option) any later version. +- * +- * This program is distributed in the hope that it will be useful, +- * but WITHOUT ANY WARRANTY; without even the implied warranty of +- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +- * GNU General Public License for more details. +- * +- * You should have received a copy of the GNU General Public License +- * along with this program; if not, write to the: +- * Free Software Foundation, Inc., +- * 59 Temple Place, Suite 330, +- * Boston, MA 02111-1307 USA +- * +- * Change Activity: +- * Created, Feb 2, 2001 +- * Ported to ppc64, August 20, 2001 +- * End Change Activity +- */ +-#include <linux/init.h> +-#include <linux/module.h> +-#include <linux/pci.h> +- +-#include <asm/types.h> +-#include <asm/resource.h> +-#include <asm/abs_addr.h> +-#include <asm/pci-bridge.h> +-#include <asm/iseries/hv_types.h> +- +-#include "pci.h" +-#include "call_pci.h" +- +-/* +- * Size of Bus VPD data +- */ +-#define BUS_VPDSIZE 1024 +- +-/* +- * Bus Vpd Tags +- */ +-#define VpdEndOfAreaTag 0x79 +-#define VpdIdStringTag 0x82 +-#define VpdVendorAreaTag 0x84 +- +-/* +- * Mfg Area Tags +- */ +-#define VpdFruFrameId 0x4649 // "FI" +-#define VpdSlotMapFormat 0x4D46 // "MF" +-#define VpdSlotMap 0x534D // "SM" +- +-/* +- * Structures of the areas +- */ +-struct MfgVpdAreaStruct { +- u16 Tag; +- u8 TagLength; +- u8 AreaData1; +- u8 AreaData2; +-}; +-typedef struct MfgVpdAreaStruct MfgArea; +-#define MFG_ENTRY_SIZE 3 +- +-struct SlotMapStruct { +- u8 AgentId; +- u8 SecondaryAgentId; +- u8 PhbId; +- char CardLocation[3]; +- char Parms[8]; +- char Reserved[2]; +-}; +-typedef struct SlotMapStruct SlotMap; +-#define SLOT_ENTRY_SIZE 16 +- +-/* +- * Parse the Slot Area +- */ +-static void __init iSeries_Parse_SlotArea(SlotMap *MapPtr, int MapLen, +- HvAgentId agent, u8 *PhbId, char card[4]) +-{ +- int SlotMapLen = MapLen; +- SlotMap *SlotMapPtr = MapPtr; +- +- /* +- * Parse Slot label until we find the one requested +- */ +- while (SlotMapLen > 0) { +- if (SlotMapPtr->AgentId == agent) { +- /* +- * If Phb wasn't found, grab the entry first one found. +- */ +- if (*PhbId == 0xff) +- *PhbId = SlotMapPtr->PhbId; +- /* Found it, extract the data. */ +- if (SlotMapPtr->PhbId == *PhbId) { +- memcpy(card, &SlotMapPtr->CardLocation, 3); +- card[3] = 0; +- break; +- } +- } +- /* Point to the next Slot */ +- SlotMapPtr = (SlotMap *)((char *)SlotMapPtr + SLOT_ENTRY_SIZE); +- SlotMapLen -= SLOT_ENTRY_SIZE; +- } +-} +- +-/* +- * Parse the Mfg Area +- */ +-static void __init iSeries_Parse_MfgArea(u8 *AreaData, int AreaLen, +- HvAgentId agent, u8 *PhbId, +- u8 *frame, char card[4]) +-{ +- MfgArea *MfgAreaPtr = (MfgArea *)AreaData; +- int MfgAreaLen = AreaLen; +- u16 SlotMapFmt = 0; +- +- /* Parse Mfg Data */ +- while (MfgAreaLen > 0) { +- int MfgTagLen = MfgAreaPtr->TagLength; +- /* Frame ID (FI 4649020310 ) */ +- if (MfgAreaPtr->Tag == VpdFruFrameId) /* FI */ +- *frame = MfgAreaPtr->AreaData1; +- /* Slot Map Format (MF 4D46020004 ) */ +- else if (MfgAreaPtr->Tag == VpdSlotMapFormat) /* MF */ +- SlotMapFmt = (MfgAreaPtr->AreaData1 * 256) +- + MfgAreaPtr->AreaData2; +- /* Slot Map (SM 534D90 */ +- else if (MfgAreaPtr->Tag == VpdSlotMap) { /* SM */ +- SlotMap *SlotMapPtr; +- +- if (SlotMapFmt == 0x1004) +- SlotMapPtr = (SlotMap *)((char *)MfgAreaPtr +- + MFG_ENTRY_SIZE + 1); +- else +- SlotMapPtr = (SlotMap *)((char *)MfgAreaPtr +- + MFG_ENTRY_SIZE); +- iSeries_Parse_SlotArea(SlotMapPtr, MfgTagLen, +- agent, PhbId, card); +- } +- /* +- * Point to the next Mfg Area +- * Use defined size, sizeof give wrong answer +- */ +- MfgAreaPtr = (MfgArea *)((char *)MfgAreaPtr + MfgTagLen +- + MFG_ENTRY_SIZE); +- MfgAreaLen -= (MfgTagLen + MFG_ENTRY_SIZE); +- } +-} +- +-/* +- * Look for "BUS".. Data is not Null terminated. +- * PHBID of 0xFF indicates PHB was not found in VPD Data. +- */ +-static int __init iSeries_Parse_PhbId(u8 *AreaPtr, int AreaLength) +-{ +- u8 *PhbPtr = AreaPtr; +- int DataLen = AreaLength; +- char PhbId = 0xFF; +- +- while (DataLen > 0) { +- if ((*PhbPtr == 'B') && (*(PhbPtr + 1) == 'U') +- && (*(PhbPtr + 2) == 'S')) { +- PhbPtr += 3; +- while (*PhbPtr == ' ') +- ++PhbPtr; +- PhbId = (*PhbPtr & 0x0F); +- break; +- } +- ++PhbPtr; +- --DataLen; +- } +- return PhbId; +-} +- +-/* +- * Parse out the VPD Areas +- */ +-static void __init iSeries_Parse_Vpd(u8 *VpdData, int VpdDataLen, +- HvAgentId agent, u8 *frame, char card[4]) +-{ +- u8 *TagPtr = VpdData; +- int DataLen = VpdDataLen - 3; +- u8 PhbId = 0xff; +- +- while ((*TagPtr != VpdEndOfAreaTag) && (DataLen > 0)) { +- int AreaLen = *(TagPtr + 1) + (*(TagPtr + 2) * 256); +- u8 *AreaData = TagPtr + 3; +- +- if (*TagPtr == VpdIdStringTag) +- PhbId = iSeries_Parse_PhbId(AreaData, AreaLen); +- else if (*TagPtr == VpdVendorAreaTag) +- iSeries_Parse_MfgArea(AreaData, AreaLen, +- agent, &PhbId, frame, card); +- /* Point to next Area. */ +- TagPtr = AreaData + AreaLen; +- DataLen -= AreaLen; +- } +-} +- +-static int __init iSeries_Get_Location_Code(u16 bus, HvAgentId agent, +- u8 *frame, char card[4]) +-{ +- int status = 0; +- int BusVpdLen = 0; +- u8 *BusVpdPtr = kmalloc(BUS_VPDSIZE, GFP_KERNEL); +- +- if (BusVpdPtr == NULL) { +- printk("PCI: Bus VPD Buffer allocation failure.\n"); +- return 0; +- } +- BusVpdLen = HvCallPci_getBusVpd(bus, iseries_hv_addr(BusVpdPtr), +- BUS_VPDSIZE); +- if (BusVpdLen == 0) { +- printk("PCI: Bus VPD Buffer zero length.\n"); +- goto out_free; +- } +- /* printk("PCI: BusVpdPtr: %p, %d\n",BusVpdPtr, BusVpdLen); */ +- /* Make sure this is what I think it is */ +- if (*BusVpdPtr != VpdIdStringTag) { /* 0x82 */ +- printk("PCI: Bus VPD Buffer missing starting tag.\n"); +- goto out_free; +- } +- iSeries_Parse_Vpd(BusVpdPtr, BusVpdLen, agent, frame, card); +- status = 1; +-out_free: +- kfree(BusVpdPtr); +- return status; +-} +- +-/* +- * Prints the device information. +- * - Pass in pci_dev* pointer to the device. +- * - Pass in the device count +- * +- * Format: +- * PCI: Bus 0, Device 26, Vendor 0x12AE Frame 1, Card C10 Ethernet +- * controller +- */ +-void __init iSeries_Device_Information(struct pci_dev *PciDev, int count) +-{ +- struct device_node *DevNode = PciDev->sysdata; +- struct pci_dn *pdn; +- u16 bus; +- u8 frame = 0; +- char card[4]; +- HvSubBusNumber subbus; +- HvAgentId agent; +- +- if (DevNode == NULL) { +- printk("%d. PCI: iSeries_Device_Information DevNode is NULL\n", +- count); +- return; +- } +- +- pdn = PCI_DN(DevNode); +- bus = pdn->busno; +- subbus = pdn->bussubno; +- agent = ISERIES_PCI_AGENTID(ISERIES_GET_DEVICE_FROM_SUBBUS(subbus), +- ISERIES_GET_FUNCTION_FROM_SUBBUS(subbus)); +- +- if (iSeries_Get_Location_Code(bus, agent, &frame, card)) { +- printk("%d. PCI: Bus%3d, Device%3d, Vendor %04X Frame%3d, " +- "Card %4s 0x%04X\n", count, bus, +- PCI_SLOT(PciDev->devfn), PciDev->vendor, frame, +- card, (int)(PciDev->class >> 8)); +- } +-} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/maple/Kconfig powerpc.git/arch/powerpc/platforms/maple/Kconfig +--- linux-2.6.24/arch/powerpc/platforms/maple/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/maple/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -1,6 +1,7 @@ + config PPC_MAPLE + depends on PPC_MULTIPLATFORM && PPC64 + bool "Maple 970FX Evaluation Board" ++ select PCI + select MPIC + select U3_DART + select MPIC_U3_HT_IRQS +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/maple/pci.c powerpc.git/arch/powerpc/platforms/maple/pci.c +--- linux-2.6.24/arch/powerpc/platforms/maple/pci.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/maple/pci.c 2008-01-28 20:25:49.000000000 +0100 +@@ -558,7 +558,7 @@ + * safe assumptions hopefully. + */ + if (u3_agp) { +- struct device_node *np = u3_agp->arch_data; ++ struct device_node *np = u3_agp->dn; + PCI_DN(np)->busno = 0xf0; + for (np = np->child; np; np = np->sibling) + PCI_DN(np)->busno = 0xf0; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/maple/setup.c powerpc.git/arch/powerpc/platforms/maple/setup.c +--- linux-2.6.24/arch/powerpc/platforms/maple/setup.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/maple/setup.c 2008-01-28 20:25:49.000000000 +0100 +@@ -42,6 +42,7 @@ + #include <linux/serial.h> + #include <linux/smp.h> + #include <linux/bitops.h> ++#include <linux/of_device.h> + + #include <asm/processor.h> + #include <asm/sections.h> +@@ -56,7 +57,6 @@ + #include <asm/dma.h> + #include <asm/cputable.h> + #include <asm/time.h> +-#include <asm/of_device.h> + #include <asm/lmb.h> + #include <asm/mpic.h> + #include <asm/rtas.h> +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pasemi/Kconfig powerpc.git/arch/powerpc/platforms/pasemi/Kconfig +--- linux-2.6.24/arch/powerpc/platforms/pasemi/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pasemi/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -3,6 +3,7 @@ + bool "PA Semi SoC-based platforms" + default n + select MPIC ++ select PCI + select PPC_UDBG_16550 + select PPC_NATIVE + select MPIC_BROKEN_REGREAD +@@ -17,7 +18,7 @@ + bool "PA Semi IOMMU support" + depends on PPC_PASEMI + help +- IOMMU support for PA6T-1682M ++ IOMMU support for PA Semi PWRficient + + config PPC_PASEMI_IOMMU_DMA_FORCE + bool "Force DMA engine to use IOMMU" +@@ -36,13 +37,4 @@ + help + Driver for MDIO via GPIO on PWRficient platforms + +-config ELECTRA_IDE +- tristate "Electra IDE driver" +- default y +- depends on PPC_PASEMI && ATA +- select PATA_PLATFORM +- help +- This includes driver support for the Electra on-board IDE +- interface. +- + endmenu +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pasemi/Makefile powerpc.git/arch/powerpc/platforms/pasemi/Makefile +--- linux-2.6.24/arch/powerpc/platforms/pasemi/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pasemi/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -1,4 +1,3 @@ + obj-y += setup.o pci.o time.o idle.o powersave.o iommu.o + obj-$(CONFIG_PPC_PASEMI_MDIO) += gpio_mdio.o +-obj-$(CONFIG_ELECTRA_IDE) += electra_ide.o + obj-$(CONFIG_PPC_PASEMI_CPUFREQ) += cpufreq.o +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pasemi/cpufreq.c powerpc.git/arch/powerpc/platforms/pasemi/cpufreq.c +--- linux-2.6.24/arch/powerpc/platforms/pasemi/cpufreq.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pasemi/cpufreq.c 2008-01-28 20:25:49.000000000 +0100 +@@ -32,6 +32,7 @@ + #include <asm/io.h> + #include <asm/prom.h> + #include <asm/time.h> ++#include <asm/smp.h> + + #define SDCASR_REG 0x0100 + #define SDCASR_REG_STRIDE 0x1000 +@@ -124,6 +125,11 @@ + local_irq_restore(flags); + } + ++int check_astate(void) ++{ ++ return get_cur_astate(hard_smp_processor_id()); ++} ++ + void restore_astate(int cpu) + { + set_astate(cpu, current_astate); +@@ -147,7 +153,10 @@ + if (!cpu) + goto out; + +- dn = of_find_compatible_node(NULL, "sdc", "1682m-sdc"); ++ dn = of_find_compatible_node(NULL, NULL, "1682m-sdc"); ++ if (!dn) ++ dn = of_find_compatible_node(NULL, NULL, ++ "pasemi,pwrficient-sdc"); + if (!dn) + goto out; + err = of_address_to_resource(dn, 0, &res); +@@ -160,7 +169,10 @@ + goto out; + } + +- dn = of_find_compatible_node(NULL, "gizmo", "1682m-gizmo"); ++ dn = of_find_compatible_node(NULL, NULL, "1682m-gizmo"); ++ if (!dn) ++ dn = of_find_compatible_node(NULL, NULL, ++ "pasemi,pwrficient-gizmo"); + if (!dn) { + err = -ENODEV; + goto out_unmap_sdcasr; +@@ -292,7 +304,8 @@ + + static int __init pas_cpufreq_init(void) + { +- if (!machine_is_compatible("PA6T-1682M")) ++ if (!machine_is_compatible("PA6T-1682M") && ++ !machine_is_compatible("pasemi,pwrficient")) + return -ENODEV; + + return cpufreq_register_driver(&pas_cpufreq_driver); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pasemi/electra_ide.c powerpc.git/arch/powerpc/platforms/pasemi/electra_ide.c +--- linux-2.6.24/arch/powerpc/platforms/pasemi/electra_ide.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pasemi/electra_ide.c 1970-01-01 01:00:00.000000000 +0100 +@@ -1,96 +0,0 @@ +-/* +- * Copyright (C) 2007 PA Semi, Inc +- * +- * Maintained by: Olof Johansson <olof@lixom.net> +- * +- * This program is free software; you can redistribute it and/or modify +- * it under the terms of the GNU General Public License version 2 as +- * published by the Free Software Foundation. +- * +- * This program is distributed in the hope that it will be useful, +- * but WITHOUT ANY WARRANTY; without even the implied warranty of +- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +- * GNU General Public License for more details. +- * +- * You should have received a copy of the GNU General Public License +- * along with this program; if not, write to the Free Software +- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +- */ +- +-#include <linux/platform_device.h> +- +-#include <asm/prom.h> +-#include <asm/system.h> +- +-/* The electra IDE interface is incredibly simple: Just a device on the localbus +- * with interrupts hooked up to one of the GPIOs. The device tree contains the +- * address window and interrupt mappings already, and the pata_platform driver handles +- * the rest. We just need to hook the two up. +- */ +- +-#define MAX_IFS 4 /* really, we have only one */ +- +-static struct platform_device *pdevs[MAX_IFS]; +- +-static int __devinit electra_ide_init(void) +-{ +- struct device_node *np; +- struct resource r[3]; +- int ret = 0; +- int i; +- +- np = of_find_compatible_node(NULL, "ide", "electra-ide"); +- i = 0; +- +- while (np && i < MAX_IFS) { +- memset(r, 0, sizeof(r)); +- +- /* pata_platform wants two address ranges: one for the base registers, +- * another for the control (altstatus). It's located at offset 0x3f6 in +- * the window, but the device tree only has one large register window +- * that covers both ranges. So we need to split it up by hand here: +- */ +- +- ret = of_address_to_resource(np, 0, &r[0]); +- if (ret) +- goto out; +- ret = of_address_to_resource(np, 0, &r[1]); +- if (ret) +- goto out; +- +- r[1].start += 0x3f6; +- r[0].end = r[1].start-1; +- +- r[2].start = irq_of_parse_and_map(np, 0); +- r[2].end = irq_of_parse_and_map(np, 0); +- r[2].flags = IORESOURCE_IRQ; +- +- pr_debug("registering platform device at 0x%lx/0x%lx, irq is %ld\n", +- r[0].start, r[1].start, r[2].start); +- pdevs[i] = platform_device_register_simple("pata_platform", i, r, 3); +- if (IS_ERR(pdevs[i])) { +- ret = PTR_ERR(pdevs[i]); +- pdevs[i] = NULL; +- goto out; +- } +- np = of_find_compatible_node(np, "ide", "electra-ide"); +- } +-out: +- return ret; +-} +-module_init(electra_ide_init); +- +-static void __devexit electra_ide_exit(void) +-{ +- int i; +- +- for (i = 0; i < MAX_IFS; i++) +- if (pdevs[i]) +- platform_device_unregister(pdevs[i]); +-} +-module_exit(electra_ide_exit); +- +- +-MODULE_LICENSE("GPL"); +-MODULE_AUTHOR ("Olof Johansson <olof@lixom.net>"); +-MODULE_DESCRIPTION("PA Semi Electra IDE driver"); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pasemi/gpio_mdio.c powerpc.git/arch/powerpc/platforms/pasemi/gpio_mdio.c +--- linux-2.6.24/arch/powerpc/platforms/pasemi/gpio_mdio.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pasemi/gpio_mdio.c 2008-01-28 20:25:49.000000000 +0100 +@@ -30,7 +30,7 @@ + #include <linux/interrupt.h> + #include <linux/phy.h> + #include <linux/platform_device.h> +-#include <asm/of_platform.h> ++#include <linux/of_platform.h> + + #define DELAY 1 + +@@ -218,45 +218,27 @@ + const struct of_device_id *match) + { + struct device *dev = &ofdev->dev; +- struct device_node *np = ofdev->node; +- struct device_node *gpio_np; ++ struct device_node *phy_dn, *np = ofdev->node; + struct mii_bus *new_bus; +- struct resource res; + struct gpio_priv *priv; + const unsigned int *prop; +- int err = 0; ++ int err; + int i; + +- gpio_np = of_find_compatible_node(NULL, "gpio", "1682m-gpio"); +- +- if (!gpio_np) +- return -ENODEV; +- +- err = of_address_to_resource(gpio_np, 0, &res); +- of_node_put(gpio_np); +- +- if (err) +- return -EINVAL; +- +- if (!gpio_regs) +- gpio_regs = ioremap(res.start, 0x100); +- +- if (!gpio_regs) +- return -EPERM; +- ++ err = -ENOMEM; + priv = kzalloc(sizeof(struct gpio_priv), GFP_KERNEL); +- if (priv == NULL) +- return -ENOMEM; ++ if (!priv) ++ goto out; + + new_bus = kzalloc(sizeof(struct mii_bus), GFP_KERNEL); + +- if (new_bus == NULL) +- return -ENOMEM; ++ if (!new_bus) ++ goto out_free_priv; + +- new_bus->name = "pasemi gpio mdio bus", +- new_bus->read = &gpio_mdio_read, +- new_bus->write = &gpio_mdio_write, +- new_bus->reset = &gpio_mdio_reset, ++ new_bus->name = "pasemi gpio mdio bus"; ++ new_bus->read = &gpio_mdio_read; ++ new_bus->write = &gpio_mdio_write; ++ new_bus->reset = &gpio_mdio_reset; + + prop = of_get_property(np, "reg", NULL); + new_bus->id = *prop; +@@ -265,9 +247,24 @@ + new_bus->phy_mask = 0; + + new_bus->irq = kmalloc(sizeof(int)*PHY_MAX_ADDR, GFP_KERNEL); +- for(i = 0; i < PHY_MAX_ADDR; ++i) +- new_bus->irq[i] = irq_create_mapping(NULL, 10); + ++ if (!new_bus->irq) ++ goto out_free_bus; ++ ++ for (i = 0; i < PHY_MAX_ADDR; i++) ++ new_bus->irq[i] = NO_IRQ; ++ ++ for (phy_dn = of_get_next_child(np, NULL); ++ phy_dn != NULL; ++ phy_dn = of_get_next_child(np, phy_dn)) { ++ const unsigned int *ip, *regp; ++ ++ ip = of_get_property(phy_dn, "interrupts", NULL); ++ regp = of_get_property(phy_dn, "reg", NULL); ++ if (!ip || !regp || *regp >= PHY_MAX_ADDR) ++ continue; ++ new_bus->irq[*regp] = irq_create_mapping(NULL, *ip); ++ } + + prop = of_get_property(np, "mdc-pin", NULL); + priv->mdc_pin = *prop; +@@ -280,17 +277,21 @@ + + err = mdiobus_register(new_bus); + +- if (0 != err) { ++ if (err != 0) { + printk(KERN_ERR "%s: Cannot register as MDIO bus, err %d\n", + new_bus->name, err); +- goto bus_register_fail; ++ goto out_free_irq; + } + + return 0; + +-bus_register_fail: ++out_free_irq: ++ kfree(new_bus->irq); ++out_free_bus: + kfree(new_bus); +- ++out_free_priv: ++ kfree(priv); ++out: + return err; + } + +@@ -317,6 +318,7 @@ + }, + {}, + }; ++MODULE_DEVICE_TABLE(of, gpio_mdio_match); + + static struct of_platform_driver gpio_mdio_driver = + { +@@ -330,12 +332,32 @@ + + int gpio_mdio_init(void) + { ++ struct device_node *np; ++ ++ np = of_find_compatible_node(NULL, NULL, "1682m-gpio"); ++ if (!np) ++ np = of_find_compatible_node(NULL, NULL, ++ "pasemi,pwrficient-gpio"); ++ if (!np) ++ return -ENODEV; ++ gpio_regs = of_iomap(np, 0); ++ of_node_put(np); ++ ++ if (!gpio_regs) ++ return -ENODEV; ++ + return of_register_platform_driver(&gpio_mdio_driver); + } ++module_init(gpio_mdio_init); + + void gpio_mdio_exit(void) + { + of_unregister_platform_driver(&gpio_mdio_driver); ++ if (gpio_regs) ++ iounmap(gpio_regs); + } +-device_initcall(gpio_mdio_init); ++module_exit(gpio_mdio_exit); + ++MODULE_LICENSE("GPL"); ++MODULE_AUTHOR("Olof Johansson <olof@lixom.net>"); ++MODULE_DESCRIPTION("Driver for MDIO over GPIO on PA Semi PWRficient-based boards"); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pasemi/idle.c powerpc.git/arch/powerpc/platforms/pasemi/idle.c +--- linux-2.6.24/arch/powerpc/platforms/pasemi/idle.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pasemi/idle.c 2008-01-28 20:25:49.000000000 +0100 +@@ -74,9 +74,6 @@ + + static int __init pasemi_idle_init(void) + { +- if (!machine_is(pasemi)) +- return -ENODEV; +- + #ifndef CONFIG_PPC_PASEMI_CPUFREQ + printk(KERN_WARNING "No cpufreq driver, powersavings modes disabled\n"); + current_mode = 0; +@@ -88,7 +85,7 @@ + + return 0; + } +-late_initcall(pasemi_idle_init); ++machine_late_initcall(pasemi, pasemi_idle_init); + + static int __init idle_param(char *p) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pasemi/pasemi.h powerpc.git/arch/powerpc/platforms/pasemi/pasemi.h +--- linux-2.6.24/arch/powerpc/platforms/pasemi/pasemi.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pasemi/pasemi.h 2008-01-28 20:25:49.000000000 +0100 +@@ -16,8 +16,14 @@ + + /* Restore astate to last set */ + #ifdef CONFIG_PPC_PASEMI_CPUFREQ ++extern int check_astate(void); + extern void restore_astate(int cpu); + #else ++static inline int check_astate(void) ++{ ++ /* Always return >0 so we never power save */ ++ return 1; ++} + static inline void restore_astate(int cpu) + { + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pasemi/powersave.S powerpc.git/arch/powerpc/platforms/pasemi/powersave.S +--- linux-2.6.24/arch/powerpc/platforms/pasemi/powersave.S 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pasemi/powersave.S 2008-01-28 20:25:49.000000000 +0100 +@@ -62,7 +62,16 @@ + mflr r0 + std r0, 16(r1) + stdu r1,-64(r1) ++#ifdef CONFIG_PPC_PASEMI_CPUFREQ ++ std r3, 48(r1) + ++ /* Only do power savings when in astate 0 */ ++ bl .check_astate ++ cmpwi r3,0 ++ bne 1f ++ ++ ld r3, 48(r1) ++#endif + LOAD_REG_IMMEDIATE(r6,MSR_DR|MSR_IR|MSR_ME|MSR_EE) + mfmsr r4 + andc r5,r4,r6 +@@ -73,7 +82,7 @@ + + mtmsrd r4,0 + +- addi r1,r1,64 ++1: addi r1,r1,64 + ld r0,16(r1) + mtlr r0 + blr +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pasemi/setup.c powerpc.git/arch/powerpc/platforms/pasemi/setup.c +--- linux-2.6.24/arch/powerpc/platforms/pasemi/setup.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pasemi/setup.c 2008-01-28 20:25:49.000000000 +0100 +@@ -27,6 +27,7 @@ + #include <linux/delay.h> + #include <linux/console.h> + #include <linux/pci.h> ++#include <linux/of_platform.h> + + #include <asm/prom.h> + #include <asm/system.h> +@@ -35,7 +36,7 @@ + #include <asm/mpic.h> + #include <asm/smp.h> + #include <asm/time.h> +-#include <asm/of_platform.h> ++#include <asm/mmu.h> + + #include <pcmcia/ss.h> + #include <pcmcia/cistpl.h> +@@ -43,6 +44,10 @@ + + #include "pasemi.h" + ++#if !defined(CONFIG_SMP) ++static void smp_send_stop(void) {} ++#endif ++ + /* SDC reset register, must be pre-mapped at reset time */ + static void __iomem *reset_reg; + +@@ -56,10 +61,14 @@ + + static struct mce_regs mce_regs[MAX_MCE_REGS]; + static int num_mce_regs; ++static int nmi_virq = NO_IRQ; + + + static void pas_restart(char *cmd) + { ++ /* Need to put others cpu in hold loop so they're not sleeping */ ++ smp_send_stop(); ++ udelay(10000); + printk("Restarting...\n"); + while (1) + out_le32(reset_reg, 0x6000000); +@@ -126,9 +135,6 @@ + struct pci_dev *dev; + int reg; + +- if (!machine_is(pasemi)) +- return -ENODEV; +- + /* Remap various SoC status registers for use by the MCE handler */ + + reg = 0; +@@ -172,7 +178,7 @@ + + return 0; + } +-device_initcall(pas_setup_mce_regs); ++machine_device_initcall(pasemi, pas_setup_mce_regs); + + static __init void pas_init_IRQ(void) + { +@@ -181,6 +187,8 @@ + unsigned long openpic_addr; + const unsigned int *opprop; + int naddr, opplen; ++ int mpic_flags; ++ const unsigned int *nmiprop; + struct mpic *mpic; + + mpic_node = NULL; +@@ -213,13 +221,26 @@ + openpic_addr = of_read_number(opprop, naddr); + printk(KERN_DEBUG "OpenPIC addr: %lx\n", openpic_addr); + ++ mpic_flags = MPIC_PRIMARY | MPIC_LARGE_VECTORS | MPIC_NO_BIAS; ++ ++ nmiprop = of_get_property(mpic_node, "nmi-source", NULL); ++ if (nmiprop) ++ mpic_flags |= MPIC_ENABLE_MCK; ++ + mpic = mpic_alloc(mpic_node, openpic_addr, +- MPIC_PRIMARY|MPIC_LARGE_VECTORS, +- 0, 0, " PAS-OPIC "); ++ mpic_flags, 0, 0, "PASEMI-OPIC"); + BUG_ON(!mpic); + + mpic_assign_isu(mpic, 0, openpic_addr + 0x10000); + mpic_init(mpic); ++ /* The NMI/MCK source needs to be prio 15 */ ++ if (nmiprop) { ++ nmi_virq = irq_create_mapping(NULL, *nmiprop); ++ mpic_irq_set_priority(nmi_virq, 15); ++ set_irq_type(nmi_virq, IRQ_TYPE_EDGE_RISING); ++ mpic_unmask_irq(nmi_virq); ++ } ++ + of_node_put(mpic_node); + of_node_put(root); + } +@@ -239,6 +260,14 @@ + + srr0 = regs->nip; + srr1 = regs->msr; ++ ++ if (nmi_virq != NO_IRQ && mpic_get_mcirq() == nmi_virq) { ++ printk(KERN_ERR "NMI delivered\n"); ++ debugger(regs); ++ mpic_end_irq(nmi_virq); ++ goto out; ++ } ++ + dsisr = mfspr(SPRN_DSISR); + printk(KERN_ERR "Machine Check on CPU %d\n", cpu); + printk(KERN_ERR "SRR0 0x%016lx SRR1 0x%016lx\n", srr0, srr1); +@@ -295,14 +324,14 @@ + int i; + + printk(KERN_ERR "slb contents:\n"); +- for (i = 0; i < SLB_NUM_ENTRIES; i++) { ++ for (i = 0; i < mmu_slb_size; i++) { + asm volatile("slbmfee %0,%1" : "=r" (e) : "r" (i)); + asm volatile("slbmfev %0,%1" : "=r" (v) : "r" (i)); + printk(KERN_ERR "%02d %016lx %016lx\n", i, e, v); + } + } + +- ++out: + /* SRR1[62] is from MSR[62] if recoverable, so pass that back */ + return !!(srr1 & 0x2); + } +@@ -362,16 +391,17 @@ + + + static struct of_device_id pasemi_bus_ids[] = { ++ /* Unfortunately needed for legacy firmwares */ + { .type = "localbus", }, + { .type = "sdc", }, ++ /* These are the proper entries, which newer firmware uses */ ++ { .compatible = "pasemi,localbus", }, ++ { .compatible = "pasemi,sdc", }, + {}, + }; + + static int __init pasemi_publish_devices(void) + { +- if (!machine_is(pasemi)) +- return 0; +- + pasemi_pcmcia_init(); + + /* Publish OF platform devices for SDC and other non-PCI devices */ +@@ -379,7 +409,7 @@ + + return 0; + } +-device_initcall(pasemi_publish_devices); ++machine_device_initcall(pasemi, pasemi_publish_devices); + + + /* +@@ -389,7 +419,8 @@ + { + unsigned long root = of_get_flat_dt_root(); + +- if (!of_flat_dt_is_compatible(root, "PA6T-1682M")) ++ if (!of_flat_dt_is_compatible(root, "PA6T-1682M") && ++ !of_flat_dt_is_compatible(root, "pasemi,pwrficient")) + return 0; + + hpte_init_native(); +@@ -400,7 +431,7 @@ + } + + define_machine(pasemi) { +- .name = "PA Semi PA6T-1682M", ++ .name = "PA Semi PWRficient", + .probe = pas_probe, + .setup_arch = pas_setup_arch, + .init_early = pas_init_early, +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/powermac/low_i2c.c powerpc.git/arch/powerpc/platforms/powermac/low_i2c.c +--- linux-2.6.24/arch/powerpc/platforms/powermac/low_i2c.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/powermac/low_i2c.c 2008-01-28 20:25:49.000000000 +0100 +@@ -585,8 +585,7 @@ + struct device_node *np, *child, *parent; + + /* Probe keywest-i2c busses */ +- for (np = NULL; +- (np = of_find_compatible_node(np, "i2c","keywest-i2c")) != NULL;){ ++ for_each_compatible_node(np, "i2c","keywest-i2c") { + struct pmac_i2c_host_kw *host; + int multibus, chans, i; + +@@ -1462,9 +1461,6 @@ + return 0; + i2c_inited = 1; + +- if (!machine_is(powermac)) +- return 0; +- + /* Probe keywest-i2c busses */ + kw_i2c_probe(); + +@@ -1483,7 +1479,7 @@ + + return 0; + } +-arch_initcall(pmac_i2c_init); ++machine_arch_initcall(powermac, pmac_i2c_init); + + /* Since pmac_i2c_init can be called too early for the platform device + * registration, we need to do it at a later time. In our case, subsys +@@ -1515,4 +1511,4 @@ + + return 0; + } +-subsys_initcall(pmac_i2c_create_platform_devices); ++machine_subsys_initcall(powermac, pmac_i2c_create_platform_devices); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/powermac/pci.c powerpc.git/arch/powerpc/platforms/powermac/pci.c +--- linux-2.6.24/arch/powerpc/platforms/powermac/pci.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/powermac/pci.c 2008-01-28 20:25:49.000000000 +0100 +@@ -40,8 +40,6 @@ + static int has_uninorth; + #ifdef CONFIG_PPC64 + static struct pci_controller *u3_agp; +-static struct pci_controller *u4_pcie; +-static struct pci_controller *u3_ht; + #else + static int has_second_ohare; + #endif /* CONFIG_PPC64 */ +@@ -314,12 +312,15 @@ + + /* We only allow config cycles to devices that are in OF device-tree + * as we are apparently having some weird things going on with some +- * revs of K2 on recent G5s ++ * revs of K2 on recent G5s, except for the host bridge itself, which ++ * is missing from the tree but we know we can probe. + */ + if (bus->self) + busdn = pci_device_to_OF_node(bus->self); ++ else if (devfn == 0) ++ return 0; + else +- busdn = hose->arch_data; ++ busdn = hose->dn; + for (dn = busdn->child; dn; dn = dn->sibling) + if (PCI_DN(dn) && PCI_DN(dn)->devfn == devfn) + break; +@@ -344,14 +345,15 @@ + + (((unsigned int)bus) << 16) \ + + 0x01000000UL) + +-static volatile void __iomem *u3_ht_cfg_access(struct pci_controller* hose, +- u8 bus, u8 devfn, u8 offset) ++static void __iomem *u3_ht_cfg_access(struct pci_controller *hose, u8 bus, ++ u8 devfn, u8 offset, int *swap) + { ++ *swap = 1; + if (bus == hose->first_busno) { +- /* For now, we don't self probe U3 HT bridge */ +- if (PCI_SLOT(devfn) == 0) +- return NULL; +- return hose->cfg_data + U3_HT_CFA0(devfn, offset); ++ if (devfn != 0) ++ return hose->cfg_data + U3_HT_CFA0(devfn, offset); ++ *swap = 0; ++ return ((void __iomem *)hose->cfg_addr) + (offset << 2); + } else + return hose->cfg_data + U3_HT_CFA1(bus, devfn, offset); + } +@@ -360,14 +362,15 @@ + int offset, int len, u32 *val) + { + struct pci_controller *hose; +- volatile void __iomem *addr; ++ void __iomem *addr; ++ int swap; + + hose = pci_bus_to_host(bus); + if (hose == NULL) + return PCIBIOS_DEVICE_NOT_FOUND; + if (offset >= 0x100) + return PCIBIOS_BAD_REGISTER_NUMBER; +- addr = u3_ht_cfg_access(hose, bus->number, devfn, offset); ++ addr = u3_ht_cfg_access(hose, bus->number, devfn, offset, &swap); + if (!addr) + return PCIBIOS_DEVICE_NOT_FOUND; + +@@ -397,10 +400,10 @@ + *val = in_8(addr); + break; + case 2: +- *val = in_le16(addr); ++ *val = swap ? in_le16(addr) : in_be16(addr); + break; + default: +- *val = in_le32(addr); ++ *val = swap ? in_le32(addr) : in_be32(addr); + break; + } + return PCIBIOS_SUCCESSFUL; +@@ -410,14 +413,15 @@ + int offset, int len, u32 val) + { + struct pci_controller *hose; +- volatile void __iomem *addr; ++ void __iomem *addr; ++ int swap; + + hose = pci_bus_to_host(bus); + if (hose == NULL) + return PCIBIOS_DEVICE_NOT_FOUND; + if (offset >= 0x100) + return PCIBIOS_BAD_REGISTER_NUMBER; +- addr = u3_ht_cfg_access(hose, bus->number, devfn, offset); ++ addr = u3_ht_cfg_access(hose, bus->number, devfn, offset, &swap); + if (!addr) + return PCIBIOS_DEVICE_NOT_FOUND; + +@@ -439,10 +443,10 @@ + out_8(addr, val); + break; + case 2: +- out_le16(addr, val); ++ swap ? out_le16(addr, val) : out_be16(addr, val); + break; + default: +- out_le32((u32 __iomem *)addr, val); ++ swap ? out_le32(addr, val) : out_be32(addr, val); + break; + } + return PCIBIOS_SUCCESSFUL; +@@ -725,7 +729,7 @@ + static int __init setup_uninorth(struct pci_controller *hose, + struct resource *addr) + { +- pci_assign_all_buses = 1; ++ ppc_pci_flags |= PPC_PCI_REASSIGN_ALL_BUS; + has_uninorth = 1; + hose->ops = ¯isc_pci_ops; + hose->cfg_addr = ioremap(addr->start + 0x800000, 0x1000); +@@ -773,31 +777,72 @@ + */ + hose->first_busno = 0x00; + hose->last_busno = 0xff; +- u4_pcie = hose; + } + +-static void __init setup_u3_ht(struct pci_controller* hose) ++static void __init parse_region_decode(struct pci_controller *hose, ++ u32 decode) + { +- struct device_node *np = (struct device_node *)hose->arch_data; +- struct pci_controller *other = NULL; +- int i, cur; ++ unsigned long base, end, next = -1; ++ int i, cur = -1; + ++ /* Iterate through all bits. We ignore the last bit as this region is ++ * reserved for the ROM among other niceties ++ */ ++ for (i = 0; i < 31; i++) { ++ if ((decode & (0x80000000 >> i)) == 0) ++ continue; ++ if (i < 16) { ++ base = 0xf0000000 | (((u32)i) << 24); ++ end = base + 0x00ffffff; ++ } else { ++ base = ((u32)i-16) << 28; ++ end = base + 0x0fffffff; ++ } ++ if (base != next) { ++ if (++cur >= 3) { ++ printk(KERN_WARNING "PCI: Too many ranges !\n"); ++ break; ++ } ++ hose->mem_resources[cur].flags = IORESOURCE_MEM; ++ hose->mem_resources[cur].name = hose->dn->full_name; ++ hose->mem_resources[cur].start = base; ++ hose->mem_resources[cur].end = end; ++ DBG(" %d: 0x%08lx-0x%08lx\n", cur, base, end); ++ } else { ++ DBG(" : -0x%08lx\n", end); ++ hose->mem_resources[cur].end = end; ++ } ++ next = end + 1; ++ } ++} ++ ++static void __init setup_u3_ht(struct pci_controller* hose) ++{ ++ struct device_node *np = hose->dn; ++ struct resource cfg_res, self_res; ++ u32 decode; + + hose->ops = &u3_ht_pci_ops; + +- /* We hard code the address because of the different size of +- * the reg address cell, we shall fix that by killing struct +- * reg_property and using some accessor functions instead ++ /* Get base addresses from OF tree + */ +- hose->cfg_data = ioremap(0xf2000000, 0x02000000); ++ if (of_address_to_resource(np, 0, &cfg_res) || ++ of_address_to_resource(np, 1, &self_res)) { ++ printk(KERN_ERR "PCI: Failed to get U3/U4 HT resources !\n"); ++ return; ++ } ++ ++ /* Map external cfg space access into cfg_data and self registers ++ * into cfg_addr ++ */ ++ hose->cfg_data = ioremap(cfg_res.start, 0x02000000); ++ hose->cfg_addr = ioremap(self_res.start, ++ self_res.end - self_res.start + 1); + + /* +- * /ht node doesn't expose a "ranges" property, so we "remove" +- * regions that have been allocated to AGP. So far, this version of +- * the code doesn't assign any of the 0xfxxxxxxx "fine" memory regions +- * to /ht. We need to fix that sooner or later by either parsing all +- * child "ranges" properties or figuring out the U3 address space +- * decoding logic and then read its configuration register (if any). ++ * /ht node doesn't expose a "ranges" property, we read the register ++ * that controls the decoding logic and use that for memory regions. ++ * The IO region is hard coded since it is fixed in HW as well. + */ + hose->io_base_phys = 0xf4000000; + hose->pci_io_size = 0x00400000; +@@ -808,76 +853,33 @@ + hose->pci_mem_offset = 0; + hose->first_busno = 0; + hose->last_busno = 0xef; +- hose->mem_resources[0].name = np->full_name; +- hose->mem_resources[0].start = 0x80000000; +- hose->mem_resources[0].end = 0xefffffff; +- hose->mem_resources[0].flags = IORESOURCE_MEM; +- +- u3_ht = hose; +- +- if (u3_agp != NULL) +- other = u3_agp; +- else if (u4_pcie != NULL) +- other = u4_pcie; + +- if (other == NULL) { +- DBG("U3/4 has no AGP/PCIE, using full resource range\n"); +- return; +- } ++ /* Note: fix offset when cfg_addr becomes a void * */ ++ decode = in_be32(hose->cfg_addr + 0x80); + +- /* Fixup bus range vs. PCIE */ +- if (u4_pcie) +- hose->last_busno = u4_pcie->first_busno - 1; +- +- /* We "remove" the AGP resources from the resources allocated to HT, +- * that is we create "holes". However, that code does assumptions +- * that so far happen to be true (cross fingers...), typically that +- * resources in the AGP node are properly ordered +- */ +- cur = 0; +- for (i=0; i<3; i++) { +- struct resource *res = &other->mem_resources[i]; +- if (res->flags != IORESOURCE_MEM) +- continue; +- /* We don't care about "fine" resources */ +- if (res->start >= 0xf0000000) +- continue; +- /* Check if it's just a matter of "shrinking" us in one +- * direction +- */ +- if (hose->mem_resources[cur].start == res->start) { +- DBG("U3/HT: shrink start of %d, %08lx -> %08lx\n", +- cur, hose->mem_resources[cur].start, +- res->end + 1); +- hose->mem_resources[cur].start = res->end + 1; +- continue; +- } +- if (hose->mem_resources[cur].end == res->end) { +- DBG("U3/HT: shrink end of %d, %08lx -> %08lx\n", +- cur, hose->mem_resources[cur].end, +- res->start - 1); +- hose->mem_resources[cur].end = res->start - 1; +- continue; +- } +- /* No, it's not the case, we need a hole */ +- if (cur == 2) { +- /* not enough resources for a hole, we drop part +- * of the range +- */ +- printk(KERN_WARNING "Running out of resources" +- " for /ht host !\n"); +- hose->mem_resources[cur].end = res->start - 1; +- continue; +- } +- cur++; +- DBG("U3/HT: hole, %d end at %08lx, %d start at %08lx\n", +- cur-1, res->start - 1, cur, res->end + 1); +- hose->mem_resources[cur].name = np->full_name; +- hose->mem_resources[cur].flags = IORESOURCE_MEM; +- hose->mem_resources[cur].start = res->end + 1; +- hose->mem_resources[cur].end = hose->mem_resources[cur-1].end; +- hose->mem_resources[cur-1].end = res->start - 1; +- } ++ DBG("PCI: Apple HT bridge decode register: 0x%08x\n", decode); ++ ++ /* NOTE: The decode register setup is a bit weird... region ++ * 0xf8000000 for example is marked as enabled in there while it's ++ & actually the memory controller registers. ++ * That means that we are incorrectly attributing it to HT. ++ * ++ * In a similar vein, region 0xf4000000 is actually the HT IO space but ++ * also marked as enabled in here and 0xf9000000 is used by some other ++ * internal bits of the northbridge. ++ * ++ * Unfortunately, we can't just mask out those bit as we would end ++ * up with more regions than we can cope (linux can only cope with ++ * 3 memory regions for a PHB at this stage). ++ * ++ * So for now, we just do a little hack. We happen to -know- that ++ * Apple firmware doesn't assign things below 0xfa000000 for that ++ * bridge anyway so we mask out all bits we don't want. ++ */ ++ decode &= 0x003fffff; ++ ++ /* Now parse the resulting bits and build resources */ ++ parse_region_decode(hose, decode); + } + #endif /* CONFIG_PPC64 */ + +@@ -994,6 +996,8 @@ + struct device_node *np, *root; + struct device_node *ht = NULL; + ++ ppc_pci_flags = PPC_PCI_CAN_SKIP_ISA_ALIGN; ++ + root = of_find_node_by_path("/"); + if (root == NULL) { + printk(KERN_CRIT "pmac_pci_init: can't find root " +@@ -1032,15 +1036,15 @@ + * future though + */ + if (u3_agp) { +- struct device_node *np = u3_agp->arch_data; ++ struct device_node *np = u3_agp->dn; + PCI_DN(np)->busno = 0xf0; + for (np = np->child; np; np = np->sibling) + PCI_DN(np)->busno = 0xf0; + } + /* pmac_check_ht_link(); */ + +- /* Tell pci.c to not use the common resource allocation mechanism */ +- pci_probe_only = 1; ++ /* We can allocate missing resources if any */ ++ pci_probe_only = 0; + + #else /* CONFIG_PPC64 */ + init_p2pbridge(); +@@ -1051,13 +1055,13 @@ + * some offset between bus number and domains for now when we + * assign all busses should help for now + */ +- if (pci_assign_all_buses) ++ if (ppc_pci_flags & PPC_PCI_REASSIGN_ALL_BUS) + pcibios_assign_bus_offset = 0x10; + #endif + } + +-int +-pmac_pci_enable_device_hook(struct pci_dev *dev, int initial) ++#ifdef CONFIG_PPC32 ++int pmac_pci_enable_device_hook(struct pci_dev *dev) + { + struct device_node* node; + int updatecfg = 0; +@@ -1099,24 +1103,21 @@ + updatecfg = 1; + } + ++ /* ++ * Fixup various header fields on 32 bits. We don't do that on ++ * 64 bits as some of these have strange values behind the HT ++ * bridge and we must not, for example, enable MWI or set the ++ * cache line size on them. ++ */ + if (updatecfg) { + u16 cmd; + +- /* +- * Make sure PCI is correctly configured +- * +- * We use old pci_bios versions of the function since, by +- * default, gmac is not powered up, and so will be absent +- * from the kernel initial PCI lookup. +- * +- * Should be replaced by 2.4 new PCI mechanisms and really +- * register the device. +- */ + pci_read_config_word(dev, PCI_COMMAND, &cmd); + cmd |= PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER + | PCI_COMMAND_INVALIDATE; + pci_write_config_word(dev, PCI_COMMAND, cmd); + pci_write_config_byte(dev, PCI_LATENCY_TIMER, 16); ++ + pci_write_config_byte(dev, PCI_CACHE_LINE_SIZE, + L1_CACHE_BYTES >> 2); + } +@@ -1124,6 +1125,18 @@ + return 0; + } + ++void __devinit pmac_pci_fixup_ohci(struct pci_dev *dev) ++{ ++ struct device_node *node = pci_device_to_OF_node(dev); ++ ++ /* We don't want to assign resources to USB controllers ++ * absent from the OF tree (iBook second controller) ++ */ ++ if (dev->class == PCI_CLASS_SERIAL_USB_OHCI && !node) ++ dev->resource[0].flags = 0; ++} ++DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_APPLE, PCI_ANY_ID, pmac_pci_fixup_ohci); ++ + /* We power down some devices after they have been probed. They'll + * be powered back on later on + */ +@@ -1171,7 +1184,6 @@ + of_node_put(nd); + } + +-#ifdef CONFIG_PPC32 + void pmac_pci_fixup_cardbus(struct pci_dev* dev) + { + if (!machine_is(powermac)) +@@ -1259,7 +1271,7 @@ + } + } + DECLARE_PCI_FIXUP_EARLY(PCI_ANY_ID, PCI_ANY_ID, pmac_pci_fixup_pciata); +-#endif ++#endif /* CONFIG_PPC32 */ + + /* + * Disable second function on K2-SATA, it's broken +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/powermac/pfunc_base.c powerpc.git/arch/powerpc/platforms/powermac/pfunc_base.c +--- linux-2.6.24/arch/powerpc/platforms/powermac/pfunc_base.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/powermac/pfunc_base.c 2008-01-28 20:25:49.000000000 +0100 +@@ -363,8 +363,7 @@ + + return 0; + } +- +-arch_initcall(pmac_pfunc_base_install); ++machine_arch_initcall(powermac, pmac_pfunc_base_install); + + #ifdef CONFIG_PM + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/powermac/pic.c powerpc.git/arch/powerpc/platforms/powermac/pic.c +--- linux-2.6.24/arch/powerpc/platforms/powermac/pic.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/powermac/pic.c 2008-01-28 20:25:49.000000000 +0100 +@@ -690,6 +690,5 @@ + sysdev_driver_register(&pmacpic_sysclass, &driver_pmacpic); + return 0; + } +- +-subsys_initcall(init_pmacpic_sysfs); ++machine_subsys_initcall(powermac, init_pmacpic_sysfs); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/powermac/pmac.h powerpc.git/arch/powerpc/platforms/powermac/pmac.h +--- linux-2.6.24/arch/powerpc/platforms/powermac/pmac.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/powermac/pmac.h 2008-01-28 20:25:49.000000000 +0100 +@@ -26,7 +26,7 @@ + extern void pmac_nvram_update(void); + extern unsigned char pmac_nvram_read_byte(int addr); + extern void pmac_nvram_write_byte(int addr, unsigned char val); +-extern int pmac_pci_enable_device_hook(struct pci_dev *dev, int initial); ++extern int pmac_pci_enable_device_hook(struct pci_dev *dev); + extern void pmac_pcibios_after_init(void); + extern int of_show_percpuinfo(struct seq_file *m, int i); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/powermac/setup.c powerpc.git/arch/powerpc/platforms/powermac/setup.c +--- linux-2.6.24/arch/powerpc/platforms/powermac/setup.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/powermac/setup.c 2008-01-28 20:25:49.000000000 +0100 +@@ -51,6 +51,8 @@ + #include <linux/root_dev.h> + #include <linux/bitops.h> + #include <linux/suspend.h> ++#include <linux/of_device.h> ++#include <linux/of_platform.h> + + #include <asm/reg.h> + #include <asm/sections.h> +@@ -68,8 +70,6 @@ + #include <asm/btext.h> + #include <asm/pmac_feature.h> + #include <asm/time.h> +-#include <asm/of_device.h> +-#include <asm/of_platform.h> + #include <asm/mmu_context.h> + #include <asm/iommu.h> + #include <asm/smu.h> +@@ -94,7 +94,6 @@ + #define DEFAULT_ROOT_DEVICE Root_SDA1 /* sda1 - slightly silly choice */ + + #ifdef CONFIG_PPC64 +-#include <asm/udbg.h> + int sccdbg; + #endif + +@@ -398,17 +397,13 @@ + + static int pmac_late_init(void) + { +- if (!machine_is(powermac)) +- return -ENODEV; +- + initializing = 0; + /* this is udbg (which is __init) and we can later use it during + * cpu hotplug (in smp_core99_kick_cpu) */ + ppc_md.progress = NULL; + return 0; + } +- +-late_initcall(pmac_late_init); ++machine_late_initcall(powermac, pmac_late_init); + + /* + * This is __init_refok because we check for "initializing" before +@@ -535,9 +530,6 @@ + if (machine_is(chrp)) + return -1; + +- if (!machine_is(powermac)) +- return 0; +- + np = of_find_node_by_name(NULL, "valkyrie"); + if (np) + of_platform_device_create(np, "valkyrie", NULL); +@@ -552,8 +544,7 @@ + + return 0; + } +- +-device_initcall(pmac_declare_of_platform_devices); ++machine_device_initcall(powermac, pmac_declare_of_platform_devices); + + /* + * Called very early, MMU is off, device-tree isn't unflattened +@@ -613,9 +604,11 @@ + + /* We need to use normal PCI probing for the AGP bus, + * since the device for the AGP bridge isn't in the tree. ++ * Same for the PCIe host on U4 and the HT host bridge. + */ + if (bus->self == NULL && (of_device_is_compatible(node, "u3-agp") || +- of_device_is_compatible(node, "u4-pcie"))) ++ of_device_is_compatible(node, "u4-pcie") || ++ of_device_is_compatible(node, "u3-ht"))) + return PCI_PROBE_NORMAL; + return PCI_PROBE_DEVTREE; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/powermac/time.c powerpc.git/arch/powerpc/platforms/powermac/time.c +--- linux-2.6.24/arch/powerpc/platforms/powermac/time.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/powermac/time.c 2008-01-28 20:25:49.000000000 +0100 +@@ -84,12 +84,14 @@ + return delta; + } + ++#if defined(CONFIG_ADB_CUDA) || defined(CONFIG_ADB_PMU) + static void to_rtc_time(unsigned long now, struct rtc_time *tm) + { + to_tm(now, tm); + tm->tm_year -= 1900; + tm->tm_mon -= 1; + } ++#endif + + static unsigned long from_rtc_time(struct rtc_time *tm) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/ps3/Kconfig powerpc.git/arch/powerpc/platforms/ps3/Kconfig +--- linux-2.6.24/arch/powerpc/platforms/ps3/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/ps3/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -61,17 +61,6 @@ + This support is mainly for Linux kernel development. If unsure, + say N. + +-config PS3_USE_LPAR_ADDR +- depends on PPC_PS3 && EXPERIMENTAL +- bool "PS3 use lpar address space" +- default y +- help +- This option is solely for experimentation by experts. Disables +- translation of lpar addresses. SPE support currently won't work +- without this set to y. +- +- If you have any doubt, choose the default y. +- + config PS3_VUART + depends on PPC_PS3 + tristate +@@ -138,4 +127,17 @@ + be disabled on the kernel command line using "ps3flash=off", to + not allocate this fixed buffer. + ++config PS3_LPM ++ tristate "PS3 Logical Performance Monitor support" ++ depends on PPC_PS3 ++ help ++ Include support for the PS3 Logical Performance Monitor. ++ ++ This support is required to use the logical performance monitor ++ of the PS3's LV1 hypervisor. ++ ++ If you intend to use the advanced performance monitoring and ++ profiling support of the Cell processor with programs like ++ oprofile and perfmon2, then say Y or M, otherwise say N. ++ + endmenu +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/ps3/device-init.c powerpc.git/arch/powerpc/platforms/ps3/device-init.c +--- linux-2.6.24/arch/powerpc/platforms/ps3/device-init.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/ps3/device-init.c 2008-01-28 20:25:49.000000000 +0100 +@@ -23,6 +23,7 @@ + #include <linux/kernel.h> + #include <linux/kthread.h> + #include <linux/init.h> ++#include <linux/reboot.h> + + #include <asm/firmware.h> + #include <asm/lv1call.h> +@@ -30,6 +31,89 @@ + + #include "platform.h" + ++static int __init ps3_register_lpm_devices(void) ++{ ++ int result; ++ u64 tmp1; ++ u64 tmp2; ++ struct ps3_system_bus_device *dev; ++ ++ pr_debug(" -> %s:%d\n", __func__, __LINE__); ++ ++ dev = kzalloc(sizeof(*dev), GFP_KERNEL); ++ if (!dev) ++ return -ENOMEM; ++ ++ dev->match_id = PS3_MATCH_ID_LPM; ++ dev->dev_type = PS3_DEVICE_TYPE_LPM; ++ ++ /* The current lpm driver only supports a single BE processor. */ ++ ++ result = ps3_repository_read_be_node_id(0, &dev->lpm.node_id); ++ ++ if (result) { ++ pr_debug("%s:%d: ps3_repository_read_be_node_id failed \n", ++ __func__, __LINE__); ++ goto fail_read_repo; ++ } ++ ++ result = ps3_repository_read_lpm_privileges(dev->lpm.node_id, &tmp1, ++ &dev->lpm.rights); ++ ++ if (result) { ++ pr_debug("%s:%d: ps3_repository_read_lpm_privleges failed \n", ++ __func__, __LINE__); ++ goto fail_read_repo; ++ } ++ ++ lv1_get_logical_partition_id(&tmp2); ++ ++ if (tmp1 != tmp2) { ++ pr_debug("%s:%d: wrong lpar\n", ++ __func__, __LINE__); ++ result = -ENODEV; ++ goto fail_rights; ++ } ++ ++ if (!(dev->lpm.rights & PS3_LPM_RIGHTS_USE_LPM)) { ++ pr_debug("%s:%d: don't have rights to use lpm\n", ++ __func__, __LINE__); ++ result = -EPERM; ++ goto fail_rights; ++ } ++ ++ pr_debug("%s:%d: pu_id %lu, rights %lu(%lxh)\n", ++ __func__, __LINE__, dev->lpm.pu_id, dev->lpm.rights, ++ dev->lpm.rights); ++ ++ result = ps3_repository_read_pu_id(0, &dev->lpm.pu_id); ++ ++ if (result) { ++ pr_debug("%s:%d: ps3_repository_read_pu_id failed \n", ++ __func__, __LINE__); ++ goto fail_read_repo; ++ } ++ ++ result = ps3_system_bus_device_register(dev); ++ ++ if (result) { ++ pr_debug("%s:%d ps3_system_bus_device_register failed\n", ++ __func__, __LINE__); ++ goto fail_register; ++ } ++ ++ pr_debug(" <- %s:%d\n", __func__, __LINE__); ++ return 0; ++ ++ ++fail_register: ++fail_rights: ++fail_read_repo: ++ kfree(dev); ++ pr_debug(" <- %s:%d: failed\n", __func__, __LINE__); ++ return result; ++} ++ + /** + * ps3_setup_gelic_device - Setup and register a gelic device instance. + * +@@ -238,166 +322,6 @@ + return result; + } + +-static int ps3stor_wait_for_completion(u64 dev_id, u64 tag, +- unsigned int timeout) +-{ +- int result = -1; +- unsigned int retries = 0; +- u64 status; +- +- for (retries = 0; retries < timeout; retries++) { +- result = lv1_storage_check_async_status(dev_id, tag, &status); +- if (!result) +- break; +- +- msleep(1); +- } +- +- if (result) +- pr_debug("%s:%u: check_async_status: %s, status %lx\n", +- __func__, __LINE__, ps3_result(result), status); +- +- return result; +-} +- +-/** +- * ps3_storage_wait_for_device - Wait for a storage device to become ready. +- * @repo: The repository device to wait for. +- * +- * Uses the hypervisor's storage device notification mechanism to wait until +- * a storage device is ready. The device notification mechanism uses a +- * psuedo device (id = -1) to asynchronously notify the guest when storage +- * devices become ready. The notification device has a block size of 512 +- * bytes. +- */ +- +-static int ps3_storage_wait_for_device(const struct ps3_repository_device *repo) +-{ +- int error = -ENODEV; +- int result; +- const u64 notification_dev_id = (u64)-1LL; +- const unsigned int timeout = HZ; +- u64 lpar; +- u64 tag; +- void *buf; +- enum ps3_notify_type { +- notify_device_ready = 0, +- notify_region_probe = 1, +- notify_region_update = 2, +- }; +- struct { +- u64 operation_code; /* must be zero */ +- u64 event_mask; /* OR of 1UL << enum ps3_notify_type */ +- } *notify_cmd; +- struct { +- u64 event_type; /* enum ps3_notify_type */ +- u64 bus_id; +- u64 dev_id; +- u64 dev_type; +- u64 dev_port; +- } *notify_event; +- +- pr_debug(" -> %s:%u: (%u:%u:%u)\n", __func__, __LINE__, repo->bus_id, +- repo->dev_id, repo->dev_type); +- +- buf = kzalloc(512, GFP_KERNEL); +- if (!buf) +- return -ENOMEM; +- +- lpar = ps3_mm_phys_to_lpar(__pa(buf)); +- notify_cmd = buf; +- notify_event = buf; +- +- result = lv1_open_device(repo->bus_id, notification_dev_id, 0); +- if (result) { +- printk(KERN_ERR "%s:%u: lv1_open_device %s\n", __func__, +- __LINE__, ps3_result(result)); +- goto fail_free; +- } +- +- /* Setup and write the request for device notification. */ +- +- notify_cmd->operation_code = 0; /* must be zero */ +- notify_cmd->event_mask = 1UL << notify_region_probe; +- +- result = lv1_storage_write(notification_dev_id, 0, 0, 1, 0, lpar, +- &tag); +- if (result) { +- printk(KERN_ERR "%s:%u: write failed %s\n", __func__, __LINE__, +- ps3_result(result)); +- goto fail_close; +- } +- +- /* Wait for the write completion */ +- +- result = ps3stor_wait_for_completion(notification_dev_id, tag, +- timeout); +- if (result) { +- printk(KERN_ERR "%s:%u: write not completed %s\n", __func__, +- __LINE__, ps3_result(result)); +- goto fail_close; +- } +- +- /* Loop here processing the requested notification events. */ +- +- while (1) { +- memset(notify_event, 0, sizeof(*notify_event)); +- +- result = lv1_storage_read(notification_dev_id, 0, 0, 1, 0, +- lpar, &tag); +- if (result) { +- printk(KERN_ERR "%s:%u: write failed %s\n", __func__, +- __LINE__, ps3_result(result)); +- break; +- } +- +- result = ps3stor_wait_for_completion(notification_dev_id, tag, +- timeout); +- if (result) { +- printk(KERN_ERR "%s:%u: read not completed %s\n", +- __func__, __LINE__, ps3_result(result)); +- break; +- } +- +- pr_debug("%s:%d: notify event (%u:%u:%u): event_type 0x%lx, " +- "port %lu\n", __func__, __LINE__, repo->bus_index, +- repo->dev_index, repo->dev_type, +- notify_event->event_type, notify_event->dev_port); +- +- if (notify_event->event_type != notify_region_probe || +- notify_event->bus_id != repo->bus_id) { +- pr_debug("%s:%u: bad notify_event: event %lu, " +- "dev_id %lu, dev_type %lu\n", +- __func__, __LINE__, notify_event->event_type, +- notify_event->dev_id, notify_event->dev_type); +- break; +- } +- +- if (notify_event->dev_id == repo->dev_id && +- notify_event->dev_type == repo->dev_type) { +- pr_debug("%s:%u: device ready (%u:%u:%u)\n", __func__, +- __LINE__, repo->bus_index, repo->dev_index, +- repo->dev_type); +- error = 0; +- break; +- } +- +- if (notify_event->dev_id == repo->dev_id && +- notify_event->dev_type == PS3_DEV_TYPE_NOACCESS) { +- pr_debug("%s:%u: no access: dev_id %u\n", __func__, +- __LINE__, repo->dev_id); +- break; +- } +- } +- +-fail_close: +- lv1_close_device(repo->bus_id, notification_dev_id); +-fail_free: +- kfree(buf); +- pr_debug(" <- %s:%u\n", __func__, __LINE__); +- return error; +-} +- + static int ps3_setup_storage_dev(const struct ps3_repository_device *repo, + enum ps3_match_id match_id) + { +@@ -449,16 +373,6 @@ + goto fail_find_interrupt; + } + +- /* FIXME: Arrange to only do this on a 'cold' boot */ +- +- result = ps3_storage_wait_for_device(repo); +- if (result) { +- printk(KERN_ERR "%s:%u: storage_notification failed %d\n", +- __func__, __LINE__, result); +- result = -ENODEV; +- goto fail_probe_notification; +- } +- + for (i = 0; i < num_regions; i++) { + unsigned int id; + u64 start, size; +@@ -494,7 +408,6 @@ + + fail_device_register: + fail_read_region: +-fail_probe_notification: + fail_find_interrupt: + kfree(p); + fail_malloc: +@@ -659,62 +572,268 @@ + return result; + } + ++static void ps3_find_and_add_device(u64 bus_id, u64 dev_id) ++{ ++ struct ps3_repository_device repo; ++ int res; ++ unsigned int retries; ++ unsigned long rem; ++ ++ /* ++ * On some firmware versions (e.g. 1.90), the device may not show up ++ * in the repository immediately ++ */ ++ for (retries = 0; retries < 10; retries++) { ++ res = ps3_repository_find_device_by_id(&repo, bus_id, dev_id); ++ if (!res) ++ goto found; ++ ++ rem = msleep_interruptible(100); ++ if (rem) ++ break; ++ } ++ pr_warning("%s:%u: device %lu:%lu not found\n", __func__, __LINE__, ++ bus_id, dev_id); ++ return; ++ ++found: ++ if (retries) ++ pr_debug("%s:%u: device %lu:%lu found after %u retries\n", ++ __func__, __LINE__, bus_id, dev_id, retries); ++ ++ ps3_register_repository_device(&repo); ++ return; ++} ++ ++#define PS3_NOTIFICATION_DEV_ID ULONG_MAX ++#define PS3_NOTIFICATION_INTERRUPT_ID 0 ++ ++struct ps3_notification_device { ++ struct ps3_system_bus_device sbd; ++ spinlock_t lock; ++ u64 tag; ++ u64 lv1_status; ++ struct completion done; ++}; ++ ++enum ps3_notify_type { ++ notify_device_ready = 0, ++ notify_region_probe = 1, ++ notify_region_update = 2, ++}; ++ ++struct ps3_notify_cmd { ++ u64 operation_code; /* must be zero */ ++ u64 event_mask; /* OR of 1UL << enum ps3_notify_type */ ++}; ++ ++struct ps3_notify_event { ++ u64 event_type; /* enum ps3_notify_type */ ++ u64 bus_id; ++ u64 dev_id; ++ u64 dev_type; ++ u64 dev_port; ++}; ++ ++static irqreturn_t ps3_notification_interrupt(int irq, void *data) ++{ ++ struct ps3_notification_device *dev = data; ++ int res; ++ u64 tag, status; ++ ++ spin_lock(&dev->lock); ++ res = lv1_storage_get_async_status(PS3_NOTIFICATION_DEV_ID, &tag, ++ &status); ++ if (tag != dev->tag) ++ pr_err("%s:%u: tag mismatch, got %lx, expected %lx\n", ++ __func__, __LINE__, tag, dev->tag); ++ ++ if (res) { ++ pr_err("%s:%u: res %d status 0x%lx\n", __func__, __LINE__, res, ++ status); ++ } else { ++ pr_debug("%s:%u: completed, status 0x%lx\n", __func__, ++ __LINE__, status); ++ dev->lv1_status = status; ++ complete(&dev->done); ++ } ++ spin_unlock(&dev->lock); ++ return IRQ_HANDLED; ++} ++ ++static int ps3_notification_read_write(struct ps3_notification_device *dev, ++ u64 lpar, int write) ++{ ++ const char *op = write ? "write" : "read"; ++ unsigned long flags; ++ int res; ++ ++ init_completion(&dev->done); ++ spin_lock_irqsave(&dev->lock, flags); ++ res = write ? lv1_storage_write(dev->sbd.dev_id, 0, 0, 1, 0, lpar, ++ &dev->tag) ++ : lv1_storage_read(dev->sbd.dev_id, 0, 0, 1, 0, lpar, ++ &dev->tag); ++ spin_unlock_irqrestore(&dev->lock, flags); ++ if (res) { ++ pr_err("%s:%u: %s failed %d\n", __func__, __LINE__, op, res); ++ return -EPERM; ++ } ++ pr_debug("%s:%u: notification %s issued\n", __func__, __LINE__, op); ++ ++ res = wait_event_interruptible(dev->done.wait, ++ dev->done.done || kthread_should_stop()); ++ if (kthread_should_stop()) ++ res = -EINTR; ++ if (res) { ++ pr_debug("%s:%u: interrupted %s\n", __func__, __LINE__, op); ++ return res; ++ } ++ ++ if (dev->lv1_status) { ++ pr_err("%s:%u: %s not completed, status 0x%lx\n", __func__, ++ __LINE__, op, dev->lv1_status); ++ return -EIO; ++ } ++ pr_debug("%s:%u: notification %s completed\n", __func__, __LINE__, op); ++ ++ return 0; ++} ++ ++static struct task_struct *probe_task; ++ + /** + * ps3_probe_thread - Background repository probing at system startup. + * + * This implementation only supports background probing on a single bus. ++ * It uses the hypervisor's storage device notification mechanism to wait until ++ * a storage device is ready. The device notification mechanism uses a ++ * pseudo device to asynchronously notify the guest when storage devices become ++ * ready. The notification device has a block size of 512 bytes. + */ + + static int ps3_probe_thread(void *data) + { +- struct ps3_repository_device *repo = data; +- int result; +- unsigned int ms = 250; ++ struct ps3_notification_device dev; ++ int res; ++ unsigned int irq; ++ u64 lpar; ++ void *buf; ++ struct ps3_notify_cmd *notify_cmd; ++ struct ps3_notify_event *notify_event; + + pr_debug(" -> %s:%u: kthread started\n", __func__, __LINE__); + +- do { +- try_to_freeze(); ++ buf = kzalloc(512, GFP_KERNEL); ++ if (!buf) ++ return -ENOMEM; + +- pr_debug("%s:%u: probing...\n", __func__, __LINE__); ++ lpar = ps3_mm_phys_to_lpar(__pa(buf)); ++ notify_cmd = buf; ++ notify_event = buf; ++ ++ /* dummy system bus device */ ++ dev.sbd.bus_id = (u64)data; ++ dev.sbd.dev_id = PS3_NOTIFICATION_DEV_ID; ++ dev.sbd.interrupt_id = PS3_NOTIFICATION_INTERRUPT_ID; ++ ++ res = lv1_open_device(dev.sbd.bus_id, dev.sbd.dev_id, 0); ++ if (res) { ++ pr_err("%s:%u: lv1_open_device failed %s\n", __func__, ++ __LINE__, ps3_result(res)); ++ goto fail_free; ++ } ++ ++ res = ps3_sb_event_receive_port_setup(&dev.sbd, PS3_BINDING_CPU_ANY, ++ &irq); ++ if (res) { ++ pr_err("%s:%u: ps3_sb_event_receive_port_setup failed %d\n", ++ __func__, __LINE__, res); ++ goto fail_close_device; ++ } ++ ++ spin_lock_init(&dev.lock); ++ ++ res = request_irq(irq, ps3_notification_interrupt, IRQF_DISABLED, ++ "ps3_notification", &dev); ++ if (res) { ++ pr_err("%s:%u: request_irq failed %d\n", __func__, __LINE__, ++ res); ++ goto fail_sb_event_receive_port_destroy; ++ } ++ ++ /* Setup and write the request for device notification. */ ++ notify_cmd->operation_code = 0; /* must be zero */ ++ notify_cmd->event_mask = 1UL << notify_region_probe; + +- do { +- result = ps3_repository_find_device(repo); ++ res = ps3_notification_read_write(&dev, lpar, 1); ++ if (res) ++ goto fail_free_irq; + +- if (result == -ENODEV) +- pr_debug("%s:%u: nothing new\n", __func__, +- __LINE__); +- else if (result) +- pr_debug("%s:%u: find device error.\n", +- __func__, __LINE__); +- else { +- pr_debug("%s:%u: found device (%u:%u:%u)\n", +- __func__, __LINE__, repo->bus_index, +- repo->dev_index, repo->dev_type); +- ps3_register_repository_device(repo); +- ps3_repository_bump_device(repo); +- ms = 250; +- } +- } while (!result); ++ /* Loop here processing the requested notification events. */ ++ do { ++ try_to_freeze(); + +- pr_debug("%s:%u: ms %u\n", __func__, __LINE__, ms); ++ memset(notify_event, 0, sizeof(*notify_event)); + +- if ( ms > 60000) ++ res = ps3_notification_read_write(&dev, lpar, 0); ++ if (res) + break; + +- msleep_interruptible(ms); ++ pr_debug("%s:%u: notify event type 0x%lx bus id %lu dev id %lu" ++ " type %lu port %lu\n", __func__, __LINE__, ++ notify_event->event_type, notify_event->bus_id, ++ notify_event->dev_id, notify_event->dev_type, ++ notify_event->dev_port); ++ ++ if (notify_event->event_type != notify_region_probe || ++ notify_event->bus_id != dev.sbd.bus_id) { ++ pr_warning("%s:%u: bad notify_event: event %lu, " ++ "dev_id %lu, dev_type %lu\n", ++ __func__, __LINE__, notify_event->event_type, ++ notify_event->dev_id, ++ notify_event->dev_type); ++ continue; ++ } + +- /* An exponential backoff. */ +- ms <<= 1; ++ ps3_find_and_add_device(dev.sbd.bus_id, notify_event->dev_id); + + } while (!kthread_should_stop()); + ++fail_free_irq: ++ free_irq(irq, &dev); ++fail_sb_event_receive_port_destroy: ++ ps3_sb_event_receive_port_destroy(&dev.sbd, irq); ++fail_close_device: ++ lv1_close_device(dev.sbd.bus_id, dev.sbd.dev_id); ++fail_free: ++ kfree(buf); ++ ++ probe_task = NULL; ++ + pr_debug(" <- %s:%u: kthread finished\n", __func__, __LINE__); + + return 0; + } + + /** ++ * ps3_stop_probe_thread - Stops the background probe thread. ++ * ++ */ ++ ++static int ps3_stop_probe_thread(struct notifier_block *nb, unsigned long code, ++ void *data) ++{ ++ if (probe_task) ++ kthread_stop(probe_task); ++ return 0; ++} ++ ++static struct notifier_block nb = { ++ .notifier_call = ps3_stop_probe_thread ++}; ++ ++/** + * ps3_start_probe_thread - Starts the background probe thread. + * + */ +@@ -723,7 +842,7 @@ + { + int result; + struct task_struct *task; +- static struct ps3_repository_device repo; /* must be static */ ++ struct ps3_repository_device repo; + + pr_debug(" -> %s:%d\n", __func__, __LINE__); + +@@ -746,7 +865,8 @@ + return -ENODEV; + } + +- task = kthread_run(ps3_probe_thread, &repo, "ps3-probe-%u", bus_type); ++ task = kthread_run(ps3_probe_thread, (void *)repo.bus_id, ++ "ps3-probe-%u", bus_type); + + if (IS_ERR(task)) { + result = PTR_ERR(task); +@@ -755,6 +875,9 @@ + return result; + } + ++ probe_task = task; ++ register_reboot_notifier(&nb); ++ + pr_debug(" <- %s:%d\n", __func__, __LINE__); + return 0; + } +@@ -787,6 +910,8 @@ + + ps3_register_sound_devices(); + ++ ps3_register_lpm_devices(); ++ + pr_debug(" <- %s:%d\n", __func__, __LINE__); + return 0; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/ps3/mm.c powerpc.git/arch/powerpc/platforms/ps3/mm.c +--- linux-2.6.24/arch/powerpc/platforms/ps3/mm.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/ps3/mm.c 2008-01-28 20:25:49.000000000 +0100 +@@ -36,11 +36,6 @@ + #endif + + enum { +-#if defined(CONFIG_PS3_USE_LPAR_ADDR) +- USE_LPAR_ADDR = 1, +-#else +- USE_LPAR_ADDR = 0, +-#endif + #if defined(CONFIG_PS3_DYNAMIC_DMA) + USE_DYNAMIC_DMA = 1, + #else +@@ -137,11 +132,8 @@ + unsigned long ps3_mm_phys_to_lpar(unsigned long phys_addr) + { + BUG_ON(is_kernel_addr(phys_addr)); +- if (USE_LPAR_ADDR) +- return phys_addr; +- else +- return (phys_addr < map.rm.size || phys_addr >= map.total) +- ? phys_addr : phys_addr + map.r1.offset; ++ return (phys_addr < map.rm.size || phys_addr >= map.total) ++ ? phys_addr : phys_addr + map.r1.offset; + } + + EXPORT_SYMBOL(ps3_mm_phys_to_lpar); +@@ -309,7 +301,7 @@ + + BUG_ON(!mem_init_done); + +- start_addr = USE_LPAR_ADDR ? map.r1.base : map.rm.size; ++ start_addr = map.rm.size; + start_pfn = start_addr >> PAGE_SHIFT; + nr_pages = (map.r1.size + PAGE_SIZE - 1) >> PAGE_SHIFT; + +@@ -359,7 +351,7 @@ + static void __maybe_unused _dma_dump_region(const struct ps3_dma_region *r, + const char *func, int line) + { +- DBG("%s:%d: dev %u:%u\n", func, line, r->dev->bus_id, ++ DBG("%s:%d: dev %lu:%lu\n", func, line, r->dev->bus_id, + r->dev->dev_id); + DBG("%s:%d: page_size %u\n", func, line, r->page_size); + DBG("%s:%d: bus_addr %lxh\n", func, line, r->bus_addr); +@@ -394,7 +386,7 @@ + static void _dma_dump_chunk (const struct dma_chunk* c, const char* func, + int line) + { +- DBG("%s:%d: r.dev %u:%u\n", func, line, ++ DBG("%s:%d: r.dev %lu:%lu\n", func, line, + c->region->dev->bus_id, c->region->dev->dev_id); + DBG("%s:%d: r.bus_addr %lxh\n", func, line, c->region->bus_addr); + DBG("%s:%d: r.page_size %u\n", func, line, c->region->page_size); +@@ -658,7 +650,7 @@ + BUG_ON(!r); + + if (!r->dev->bus_id) { +- pr_info("%s:%d: %u:%u no dma\n", __func__, __LINE__, ++ pr_info("%s:%d: %lu:%lu no dma\n", __func__, __LINE__, + r->dev->bus_id, r->dev->dev_id); + return 0; + } +@@ -724,7 +716,7 @@ + BUG_ON(!r); + + if (!r->dev->bus_id) { +- pr_info("%s:%d: %u:%u no dma\n", __func__, __LINE__, ++ pr_info("%s:%d: %lu:%lu no dma\n", __func__, __LINE__, + r->dev->bus_id, r->dev->dev_id); + return 0; + } +@@ -1007,7 +999,7 @@ + + if (r->offset + r->len > map.rm.size) { + /* Map (part of) 2nd RAM chunk */ +- virt_addr = USE_LPAR_ADDR ? map.r1.base : map.rm.size; ++ virt_addr = map.rm.size; + len = r->len; + if (r->offset >= map.rm.size) + virt_addr += r->offset - map.rm.size; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/ps3/platform.h powerpc.git/arch/powerpc/platforms/ps3/platform.h +--- linux-2.6.24/arch/powerpc/platforms/ps3/platform.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/ps3/platform.h 2008-01-28 20:25:49.000000000 +0100 +@@ -89,13 +89,11 @@ + PS3_DEV_TYPE_STOR_ROM = TYPE_ROM, /* 5 */ + PS3_DEV_TYPE_SB_GPIO = 6, + PS3_DEV_TYPE_STOR_FLASH = TYPE_RBC, /* 14 */ +- PS3_DEV_TYPE_STOR_DUMMY = 32, +- PS3_DEV_TYPE_NOACCESS = 255, + }; + + int ps3_repository_read_bus_str(unsigned int bus_index, const char *bus_str, + u64 *value); +-int ps3_repository_read_bus_id(unsigned int bus_index, unsigned int *bus_id); ++int ps3_repository_read_bus_id(unsigned int bus_index, u64 *bus_id); + int ps3_repository_read_bus_type(unsigned int bus_index, + enum ps3_bus_type *bus_type); + int ps3_repository_read_bus_num_dev(unsigned int bus_index, +@@ -119,7 +117,7 @@ + int ps3_repository_read_dev_str(unsigned int bus_index, + unsigned int dev_index, const char *dev_str, u64 *value); + int ps3_repository_read_dev_id(unsigned int bus_index, unsigned int dev_index, +- unsigned int *dev_id); ++ u64 *dev_id); + int ps3_repository_read_dev_type(unsigned int bus_index, + unsigned int dev_index, enum ps3_dev_type *dev_type); + int ps3_repository_read_dev_intr(unsigned int bus_index, +@@ -138,21 +136,17 @@ + /* repository bus enumerators */ + + struct ps3_repository_device { +- enum ps3_bus_type bus_type; + unsigned int bus_index; +- unsigned int bus_id; +- enum ps3_dev_type dev_type; + unsigned int dev_index; +- unsigned int dev_id; ++ enum ps3_bus_type bus_type; ++ enum ps3_dev_type dev_type; ++ u64 bus_id; ++ u64 dev_id; + }; + +-static inline struct ps3_repository_device *ps3_repository_bump_device( +- struct ps3_repository_device *repo) +-{ +- repo->dev_index++; +- return repo; +-} + int ps3_repository_find_device(struct ps3_repository_device *repo); ++int ps3_repository_find_device_by_id(struct ps3_repository_device *repo, ++ u64 bus_id, u64 dev_id); + int ps3_repository_find_devices(enum ps3_bus_type bus_type, + int (*callback)(const struct ps3_repository_device *repo)); + int ps3_repository_find_bus(enum ps3_bus_type bus_type, unsigned int from, +@@ -186,10 +180,10 @@ + unsigned int dev_index, unsigned int region_index, + unsigned int *region_id, u64 *region_start, u64 *region_size); + +-/* repository pu and memory info */ ++/* repository logical pu and memory info */ + +-int ps3_repository_read_num_pu(unsigned int *num_pu); +-int ps3_repository_read_ppe_id(unsigned int *pu_index, unsigned int *ppe_id); ++int ps3_repository_read_num_pu(u64 *num_pu); ++int ps3_repository_read_pu_id(unsigned int pu_index, u64 *pu_id); + int ps3_repository_read_rm_base(unsigned int ppe_id, u64 *rm_base); + int ps3_repository_read_rm_size(unsigned int ppe_id, u64 *rm_size); + int ps3_repository_read_region_total(u64 *region_total); +@@ -200,9 +194,15 @@ + + int ps3_repository_read_num_be(unsigned int *num_be); + int ps3_repository_read_be_node_id(unsigned int be_index, u64 *node_id); ++int ps3_repository_read_be_id(u64 node_id, u64 *be_id); + int ps3_repository_read_tb_freq(u64 node_id, u64 *tb_freq); + int ps3_repository_read_be_tb_freq(unsigned int be_index, u64 *tb_freq); + ++/* repository performance monitor info */ ++ ++int ps3_repository_read_lpm_privileges(unsigned int be_index, u64 *lpar, ++ u64 *rights); ++ + /* repository 'Other OS' area */ + + int ps3_repository_read_boot_dat_addr(u64 *lpar_addr); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/ps3/repository.c powerpc.git/arch/powerpc/platforms/ps3/repository.c +--- linux-2.6.24/arch/powerpc/platforms/ps3/repository.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/ps3/repository.c 2008-01-28 20:25:49.000000000 +0100 +@@ -33,7 +33,7 @@ + }; + + #define dump_field(_a, _b) _dump_field(_a, _b, __func__, __LINE__) +-static void _dump_field(const char *hdr, u64 n, const char* func, int line) ++static void _dump_field(const char *hdr, u64 n, const char *func, int line) + { + #if defined(DEBUG) + char s[16]; +@@ -50,8 +50,8 @@ + + #define dump_node_name(_a, _b, _c, _d, _e) \ + _dump_node_name(_a, _b, _c, _d, _e, __func__, __LINE__) +-static void _dump_node_name (unsigned int lpar_id, u64 n1, u64 n2, u64 n3, +- u64 n4, const char* func, int line) ++static void _dump_node_name(unsigned int lpar_id, u64 n1, u64 n2, u64 n3, ++ u64 n4, const char *func, int line) + { + pr_debug("%s:%d: lpar: %u\n", func, line, lpar_id); + _dump_field("n1: ", n1, func, line); +@@ -63,7 +63,7 @@ + #define dump_node(_a, _b, _c, _d, _e, _f, _g) \ + _dump_node(_a, _b, _c, _d, _e, _f, _g, __func__, __LINE__) + static void _dump_node(unsigned int lpar_id, u64 n1, u64 n2, u64 n3, u64 n4, +- u64 v1, u64 v2, const char* func, int line) ++ u64 v1, u64 v2, const char *func, int line) + { + pr_debug("%s:%d: lpar: %u\n", func, line, lpar_id); + _dump_field("n1: ", n1, func, line); +@@ -165,21 +165,18 @@ + make_first_field("bus", bus_index), + make_field(bus_str, 0), + 0, 0, +- value, 0); ++ value, NULL); + } + +-int ps3_repository_read_bus_id(unsigned int bus_index, unsigned int *bus_id) ++int ps3_repository_read_bus_id(unsigned int bus_index, u64 *bus_id) + { + int result; +- u64 v1; +- u64 v2; /* unused */ + + result = read_node(PS3_LPAR_ID_PME, + make_first_field("bus", bus_index), + make_field("id", 0), + 0, 0, +- &v1, &v2); +- *bus_id = v1; ++ bus_id, NULL); + return result; + } + +@@ -193,7 +190,7 @@ + make_first_field("bus", bus_index), + make_field("type", 0), + 0, 0, +- &v1, 0); ++ &v1, NULL); + *bus_type = v1; + return result; + } +@@ -208,7 +205,7 @@ + make_first_field("bus", bus_index), + make_field("num_dev", 0), + 0, 0, +- &v1, 0); ++ &v1, NULL); + *num_dev = v1; + return result; + } +@@ -221,22 +218,20 @@ + make_field("dev", dev_index), + make_field(dev_str, 0), + 0, +- value, 0); ++ value, NULL); + } + + int ps3_repository_read_dev_id(unsigned int bus_index, unsigned int dev_index, +- unsigned int *dev_id) ++ u64 *dev_id) + { + int result; +- u64 v1; + + result = read_node(PS3_LPAR_ID_PME, + make_first_field("bus", bus_index), + make_field("dev", dev_index), + make_field("id", 0), + 0, +- &v1, 0); +- *dev_id = v1; ++ dev_id, NULL); + return result; + } + +@@ -251,14 +246,14 @@ + make_field("dev", dev_index), + make_field("type", 0), + 0, +- &v1, 0); ++ &v1, NULL); + *dev_type = v1; + return result; + } + + int ps3_repository_read_dev_intr(unsigned int bus_index, + unsigned int dev_index, unsigned int intr_index, +- enum ps3_interrupt_type *intr_type, unsigned int* interrupt_id) ++ enum ps3_interrupt_type *intr_type, unsigned int *interrupt_id) + { + int result; + u64 v1; +@@ -287,7 +282,7 @@ + make_field("dev", dev_index), + make_field("reg", reg_index), + make_field("type", 0), +- &v1, 0); ++ &v1, NULL); + *reg_type = v1; + return result; + } +@@ -332,7 +327,7 @@ + return result; + } + +- pr_debug("%s:%d: bus_type %u, bus_index %u, bus_id %u, num_dev %u\n", ++ pr_debug("%s:%d: bus_type %u, bus_index %u, bus_id %lu, num_dev %u\n", + __func__, __LINE__, tmp.bus_type, tmp.bus_index, tmp.bus_id, + num_dev); + +@@ -349,47 +344,95 @@ + return result; + } + +- if (tmp.bus_type == PS3_BUS_TYPE_STORAGE) { +- /* +- * A storage device may show up in the repository before the +- * hypervisor has finished probing its type and regions +- */ +- unsigned int num_regions; +- +- if (tmp.dev_type == PS3_DEV_TYPE_STOR_DUMMY) { +- pr_debug("%s:%u storage device not ready\n", __func__, +- __LINE__); +- return -ENODEV; +- } ++ result = ps3_repository_read_dev_id(tmp.bus_index, tmp.dev_index, ++ &tmp.dev_id); + +- result = ps3_repository_read_stor_dev_num_regions(tmp.bus_index, +- tmp.dev_index, +- &num_regions); ++ if (result) { ++ pr_debug("%s:%d ps3_repository_read_dev_id failed\n", __func__, ++ __LINE__); ++ return result; ++ } ++ ++ pr_debug("%s:%d: found: dev_type %u, dev_index %u, dev_id %lu\n", ++ __func__, __LINE__, tmp.dev_type, tmp.dev_index, tmp.dev_id); ++ ++ *repo = tmp; ++ return 0; ++} ++ ++int ps3_repository_find_device_by_id(struct ps3_repository_device *repo, ++ u64 bus_id, u64 dev_id) ++{ ++ int result = -ENODEV; ++ struct ps3_repository_device tmp; ++ unsigned int num_dev; ++ ++ pr_debug(" -> %s:%u: find device by id %lu:%lu\n", __func__, __LINE__, ++ bus_id, dev_id); ++ ++ for (tmp.bus_index = 0; tmp.bus_index < 10; tmp.bus_index++) { ++ result = ps3_repository_read_bus_id(tmp.bus_index, ++ &tmp.bus_id); + if (result) { +- pr_debug("%s:%d read_stor_dev_num_regions failed\n", +- __func__, __LINE__); ++ pr_debug("%s:%u read_bus_id(%u) failed\n", __func__, ++ __LINE__, tmp.bus_index); + return result; + } + +- if (!num_regions) { +- pr_debug("%s:%u storage device has no regions yet\n", +- __func__, __LINE__); +- return -ENODEV; +- } ++ if (tmp.bus_id == bus_id) ++ goto found_bus; ++ ++ pr_debug("%s:%u: skip, bus_id %lu\n", __func__, __LINE__, ++ tmp.bus_id); + } ++ pr_debug(" <- %s:%u: bus not found\n", __func__, __LINE__); ++ return result; + +- result = ps3_repository_read_dev_id(tmp.bus_index, tmp.dev_index, +- &tmp.dev_id); ++found_bus: ++ result = ps3_repository_read_bus_type(tmp.bus_index, &tmp.bus_type); ++ if (result) { ++ pr_debug("%s:%u read_bus_type(%u) failed\n", __func__, ++ __LINE__, tmp.bus_index); ++ return result; ++ } + ++ result = ps3_repository_read_bus_num_dev(tmp.bus_index, &num_dev); + if (result) { +- pr_debug("%s:%d ps3_repository_read_dev_id failed\n", __func__, +- __LINE__); ++ pr_debug("%s:%u read_bus_num_dev failed\n", __func__, ++ __LINE__); + return result; + } + +- pr_debug("%s:%d: found: dev_type %u, dev_index %u, dev_id %u\n", +- __func__, __LINE__, tmp.dev_type, tmp.dev_index, tmp.dev_id); ++ for (tmp.dev_index = 0; tmp.dev_index < num_dev; tmp.dev_index++) { ++ result = ps3_repository_read_dev_id(tmp.bus_index, ++ tmp.dev_index, ++ &tmp.dev_id); ++ if (result) { ++ pr_debug("%s:%u read_dev_id(%u:%u) failed\n", __func__, ++ __LINE__, tmp.bus_index, tmp.dev_index); ++ return result; ++ } ++ ++ if (tmp.dev_id == dev_id) ++ goto found_dev; ++ ++ pr_debug("%s:%u: skip, dev_id %lu\n", __func__, __LINE__, ++ tmp.dev_id); ++ } ++ pr_debug(" <- %s:%u: dev not found\n", __func__, __LINE__); ++ return result; ++ ++found_dev: ++ result = ps3_repository_read_dev_type(tmp.bus_index, tmp.dev_index, ++ &tmp.dev_type); ++ if (result) { ++ pr_debug("%s:%u read_dev_type failed\n", __func__, __LINE__); ++ return result; ++ } + ++ pr_debug(" <- %s:%u: found: type (%u:%u) index (%u:%u) id (%lu:%lu)\n", ++ __func__, __LINE__, tmp.bus_type, tmp.dev_type, tmp.bus_index, ++ tmp.dev_index, tmp.bus_id, tmp.dev_id); + *repo = tmp; + return 0; + } +@@ -402,50 +445,34 @@ + + pr_debug(" -> %s:%d: find bus_type %u\n", __func__, __LINE__, bus_type); + +- for (repo.bus_index = 0; repo.bus_index < 10; repo.bus_index++) { ++ repo.bus_type = bus_type; ++ result = ps3_repository_find_bus(repo.bus_type, 0, &repo.bus_index); ++ if (result) { ++ pr_debug(" <- %s:%u: bus not found\n", __func__, __LINE__); ++ return result; ++ } + +- result = ps3_repository_read_bus_type(repo.bus_index, +- &repo.bus_type); ++ result = ps3_repository_read_bus_id(repo.bus_index, &repo.bus_id); ++ if (result) { ++ pr_debug("%s:%d read_bus_id(%u) failed\n", __func__, __LINE__, ++ repo.bus_index); ++ return result; ++ } + +- if (result) { +- pr_debug("%s:%d read_bus_type(%u) failed\n", +- __func__, __LINE__, repo.bus_index); ++ for (repo.dev_index = 0; ; repo.dev_index++) { ++ result = ps3_repository_find_device(&repo); ++ if (result == -ENODEV) { ++ result = 0; ++ break; ++ } else if (result) + break; +- } +- +- if (repo.bus_type != bus_type) { +- pr_debug("%s:%d: skip, bus_type %u\n", __func__, +- __LINE__, repo.bus_type); +- continue; +- } +- +- result = ps3_repository_read_bus_id(repo.bus_index, +- &repo.bus_id); + ++ result = callback(&repo); + if (result) { +- pr_debug("%s:%d read_bus_id(%u) failed\n", +- __func__, __LINE__, repo.bus_index); +- continue; +- } +- +- for (repo.dev_index = 0; ; repo.dev_index++) { +- result = ps3_repository_find_device(&repo); +- +- if (result == -ENODEV) { +- result = 0; +- break; +- } else if (result) +- break; +- +- result = callback(&repo); +- +- if (result) { +- pr_debug("%s:%d: abort at callback\n", __func__, +- __LINE__); +- break; +- } ++ pr_debug("%s:%d: abort at callback\n", __func__, ++ __LINE__); ++ break; + } +- break; + } + + pr_debug(" <- %s:%d\n", __func__, __LINE__); +@@ -561,7 +588,7 @@ + make_first_field("bus", bus_index), + make_field("dev", dev_index), + make_field("port", 0), +- 0, port, 0); ++ 0, port, NULL); + } + + int ps3_repository_read_stor_dev_blk_size(unsigned int bus_index, +@@ -571,7 +598,7 @@ + make_first_field("bus", bus_index), + make_field("dev", dev_index), + make_field("blk_size", 0), +- 0, blk_size, 0); ++ 0, blk_size, NULL); + } + + int ps3_repository_read_stor_dev_num_blocks(unsigned int bus_index, +@@ -581,7 +608,7 @@ + make_first_field("bus", bus_index), + make_field("dev", dev_index), + make_field("n_blocks", 0), +- 0, num_blocks, 0); ++ 0, num_blocks, NULL); + } + + int ps3_repository_read_stor_dev_num_regions(unsigned int bus_index, +@@ -594,7 +621,7 @@ + make_first_field("bus", bus_index), + make_field("dev", dev_index), + make_field("n_regs", 0), +- 0, &v1, 0); ++ 0, &v1, NULL); + *num_regions = v1; + return result; + } +@@ -611,7 +638,7 @@ + make_field("dev", dev_index), + make_field("region", region_index), + make_field("id", 0), +- &v1, 0); ++ &v1, NULL); + *region_id = v1; + return result; + } +@@ -624,7 +651,7 @@ + make_field("dev", dev_index), + make_field("region", region_index), + make_field("size", 0), +- region_size, 0); ++ region_size, NULL); + } + + int ps3_repository_read_stor_dev_region_start(unsigned int bus_index, +@@ -635,7 +662,7 @@ + make_field("dev", dev_index), + make_field("region", region_index), + make_field("start", 0), +- region_start, 0); ++ region_start, NULL); + } + + int ps3_repository_read_stor_dev_info(unsigned int bus_index, +@@ -684,6 +711,35 @@ + return result; + } + ++/** ++ * ps3_repository_read_num_pu - Number of logical PU processors for this lpar. ++ */ ++ ++int ps3_repository_read_num_pu(u64 *num_pu) ++{ ++ *num_pu = 0; ++ return read_node(PS3_LPAR_ID_CURRENT, ++ make_first_field("bi", 0), ++ make_field("pun", 0), ++ 0, 0, ++ num_pu, NULL); ++} ++ ++/** ++ * ps3_repository_read_pu_id - Read the logical PU id. ++ * @pu_index: Zero based index. ++ * @pu_id: The logical PU id. ++ */ ++ ++int ps3_repository_read_pu_id(unsigned int pu_index, u64 *pu_id) ++{ ++ return read_node(PS3_LPAR_ID_CURRENT, ++ make_first_field("bi", 0), ++ make_field("pu", pu_index), ++ 0, 0, ++ pu_id, NULL); ++} ++ + int ps3_repository_read_rm_size(unsigned int ppe_id, u64 *rm_size) + { + return read_node(PS3_LPAR_ID_CURRENT, +@@ -691,7 +747,7 @@ + make_field("pu", 0), + ppe_id, + make_field("rm_size", 0), +- rm_size, 0); ++ rm_size, NULL); + } + + int ps3_repository_read_region_total(u64 *region_total) +@@ -700,7 +756,7 @@ + make_first_field("bi", 0), + make_field("rgntotal", 0), + 0, 0, +- region_total, 0); ++ region_total, NULL); + } + + /** +@@ -736,7 +792,7 @@ + make_first_field("bi", 0), + make_field("spun", 0), + 0, 0, +- &v1, 0); ++ &v1, NULL); + *num_spu_reserved = v1; + return result; + } +@@ -755,7 +811,7 @@ + make_first_field("bi", 0), + make_field("spursvn", 0), + 0, 0, +- &v1, 0); ++ &v1, NULL); + *num_resource_id = v1; + return result; + } +@@ -768,7 +824,7 @@ + */ + + int ps3_repository_read_spu_resource_id(unsigned int res_index, +- enum ps3_spu_resource_type* resource_type, unsigned int *resource_id) ++ enum ps3_spu_resource_type *resource_type, unsigned int *resource_id) + { + int result; + u64 v1; +@@ -785,14 +841,14 @@ + return result; + } + +-int ps3_repository_read_boot_dat_address(u64 *address) ++static int ps3_repository_read_boot_dat_address(u64 *address) + { + return read_node(PS3_LPAR_ID_CURRENT, + make_first_field("bi", 0), + make_field("boot_dat", 0), + make_field("address", 0), + 0, +- address, 0); ++ address, NULL); + } + + int ps3_repository_read_boot_dat_size(unsigned int *size) +@@ -805,7 +861,7 @@ + make_field("boot_dat", 0), + make_field("size", 0), + 0, +- &v1, 0); ++ &v1, NULL); + *size = v1; + return result; + } +@@ -820,7 +876,7 @@ + make_field("vir_uart", 0), + make_field("port", 0), + make_field("avset", 0), +- &v1, 0); ++ &v1, NULL); + *port = v1; + return result; + } +@@ -835,7 +891,7 @@ + make_field("vir_uart", 0), + make_field("port", 0), + make_field("sysmgr", 0), +- &v1, 0); ++ &v1, NULL); + *port = v1; + return result; + } +@@ -856,6 +912,10 @@ + : ps3_repository_read_boot_dat_size(size); + } + ++/** ++ * ps3_repository_read_num_be - Number of physical BE processors in the system. ++ */ ++ + int ps3_repository_read_num_be(unsigned int *num_be) + { + int result; +@@ -866,11 +926,17 @@ + 0, + 0, + 0, +- &v1, 0); ++ &v1, NULL); + *num_be = v1; + return result; + } + ++/** ++ * ps3_repository_read_be_node_id - Read the physical BE processor node id. ++ * @be_index: Zero based index. ++ * @node_id: The BE processor node id. ++ */ ++ + int ps3_repository_read_be_node_id(unsigned int be_index, u64 *node_id) + { + return read_node(PS3_LPAR_ID_PME, +@@ -878,7 +944,23 @@ + 0, + 0, + 0, +- node_id, 0); ++ node_id, NULL); ++} ++ ++/** ++ * ps3_repository_read_be_id - Read the physical BE processor id. ++ * @node_id: The BE processor node id. ++ * @be_id: The BE processor id. ++ */ ++ ++int ps3_repository_read_be_id(u64 node_id, u64 *be_id) ++{ ++ return read_node(PS3_LPAR_ID_PME, ++ make_first_field("be", 0), ++ node_id, ++ 0, ++ 0, ++ be_id, NULL); + } + + int ps3_repository_read_tb_freq(u64 node_id, u64 *tb_freq) +@@ -888,7 +970,7 @@ + node_id, + make_field("clock", 0), + 0, +- tb_freq, 0); ++ tb_freq, NULL); + } + + int ps3_repository_read_be_tb_freq(unsigned int be_index, u64 *tb_freq) +@@ -897,11 +979,29 @@ + u64 node_id; + + *tb_freq = 0; +- result = ps3_repository_read_be_node_id(0, &node_id); ++ result = ps3_repository_read_be_node_id(be_index, &node_id); + return result ? result + : ps3_repository_read_tb_freq(node_id, tb_freq); + } + ++int ps3_repository_read_lpm_privileges(unsigned int be_index, u64 *lpar, ++ u64 *rights) ++{ ++ int result; ++ u64 node_id; ++ ++ *lpar = 0; ++ *rights = 0; ++ result = ps3_repository_read_be_node_id(be_index, &node_id); ++ return result ? result ++ : read_node(PS3_LPAR_ID_PME, ++ make_first_field("be", 0), ++ node_id, ++ make_field("lpm", 0), ++ make_field("priv", 0), ++ lpar, rights); ++} ++ + #if defined(DEBUG) + + int ps3_repository_dump_resource_info(const struct ps3_repository_device *repo) +@@ -1034,7 +1134,7 @@ + continue; + } + +- pr_debug("%s:%d (%u:%u): dev_type %u, dev_id %u\n", __func__, ++ pr_debug("%s:%d (%u:%u): dev_type %u, dev_id %lu\n", __func__, + __LINE__, repo->bus_index, repo->dev_index, + repo->dev_type, repo->dev_id); + +@@ -1091,7 +1191,7 @@ + continue; + } + +- pr_debug("%s:%d bus_%u: bus_type %u, bus_id %u, num_dev %u\n", ++ pr_debug("%s:%d bus_%u: bus_type %u, bus_id %lu, num_dev %u\n", + __func__, __LINE__, repo.bus_index, repo.bus_type, + repo.bus_id, num_dev); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/ps3/spu.c powerpc.git/arch/powerpc/platforms/ps3/spu.c +--- linux-2.6.24/arch/powerpc/platforms/ps3/spu.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/ps3/spu.c 2008-01-28 20:25:49.000000000 +0100 +@@ -28,6 +28,7 @@ + #include <asm/spu_priv1.h> + #include <asm/lv1call.h> + ++#include "../cell/spufs/spufs.h" + #include "platform.h" + + /* spu_management_ops */ +@@ -419,10 +420,34 @@ + return 0; + } + ++/** ++ * ps3_enable_spu - Enable SPU run control. ++ * ++ * An outstanding enhancement for the PS3 would be to add a guard to check ++ * for incorrect access to the spu problem state when the spu context is ++ * disabled. This check could be implemented with a flag added to the spu ++ * context that would inhibit mapping problem state pages, and a routine ++ * to unmap spu problem state pages. When the spu is enabled with ++ * ps3_enable_spu() the flag would be set allowing pages to be mapped, ++ * and when the spu is disabled with ps3_disable_spu() the flag would be ++ * cleared and the mapped problem state pages would be unmapped. ++ */ ++ ++static void ps3_enable_spu(struct spu_context *ctx) ++{ ++} ++ ++static void ps3_disable_spu(struct spu_context *ctx) ++{ ++ ctx->ops->runcntl_stop(ctx); ++} ++ + const struct spu_management_ops spu_management_ps3_ops = { + .enumerate_spus = ps3_enumerate_spus, + .create_spu = ps3_create_spu, + .destroy_spu = ps3_destroy_spu, ++ .enable_spu = ps3_enable_spu, ++ .disable_spu = ps3_disable_spu, + .init_affinity = ps3_init_affinity, + }; + +@@ -505,8 +530,6 @@ + static const u64 allowed = ~(MFC_STATE1_LOCAL_STORAGE_DECODE_MASK + | MFC_STATE1_PROBLEM_STATE_MASK); + +- sr1 |= MFC_STATE1_MASTER_RUN_CONTROL_MASK; +- + BUG_ON((sr1 & allowed) != (spu_pdata(spu)->cache.sr1 & allowed)); + + spu_pdata(spu)->cache.sr1 = sr1; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/ps3/system-bus.c powerpc.git/arch/powerpc/platforms/ps3/system-bus.c +--- linux-2.6.24/arch/powerpc/platforms/ps3/system-bus.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/ps3/system-bus.c 2008-01-28 20:25:49.000000000 +0100 +@@ -42,8 +42,8 @@ + int gpu; + } static usage_hack; + +-static int ps3_is_device(struct ps3_system_bus_device *dev, +- unsigned int bus_id, unsigned int dev_id) ++static int ps3_is_device(struct ps3_system_bus_device *dev, u64 bus_id, ++ u64 dev_id) + { + return dev->bus_id == bus_id && dev->dev_id == dev_id; + } +@@ -182,8 +182,8 @@ + case PS3_MATCH_ID_SYSTEM_MANAGER: + pr_debug("%s:%d: unsupported match_id: %u\n", __func__, + __LINE__, dev->match_id); +- pr_debug("%s:%d: bus_id: %u\n", __func__, +- __LINE__, dev->bus_id); ++ pr_debug("%s:%d: bus_id: %lu\n", __func__, __LINE__, ++ dev->bus_id); + BUG(); + return -EINVAL; + +@@ -220,8 +220,8 @@ + case PS3_MATCH_ID_SYSTEM_MANAGER: + pr_debug("%s:%d: unsupported match_id: %u\n", __func__, + __LINE__, dev->match_id); +- pr_debug("%s:%d: bus_id: %u\n", __func__, +- __LINE__, dev->bus_id); ++ pr_debug("%s:%d: bus_id: %lu\n", __func__, __LINE__, ++ dev->bus_id); + BUG(); + return -EINVAL; + +@@ -240,7 +240,7 @@ + static void _dump_mmio_region(const struct ps3_mmio_region* r, + const char* func, int line) + { +- pr_debug("%s:%d: dev %u:%u\n", func, line, r->dev->bus_id, ++ pr_debug("%s:%d: dev %lu:%lu\n", func, line, r->dev->bus_id, + r->dev->dev_id); + pr_debug("%s:%d: bus_addr %lxh\n", func, line, r->bus_addr); + pr_debug("%s:%d: len %lxh\n", func, line, r->len); +@@ -715,6 +715,7 @@ + static unsigned int dev_ioc0_count; + static unsigned int dev_sb_count; + static unsigned int dev_vuart_count; ++ static unsigned int dev_lpm_count; + + if (!dev->core.parent) + dev->core.parent = &ps3_system_bus; +@@ -737,6 +738,10 @@ + snprintf(dev->core.bus_id, sizeof(dev->core.bus_id), + "vuart_%02x", ++dev_vuart_count); + break; ++ case PS3_DEVICE_TYPE_LPM: ++ snprintf(dev->core.bus_id, sizeof(dev->core.bus_id), ++ "lpm_%02x", ++dev_lpm_count); ++ break; + default: + BUG(); + }; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pseries/eeh.c powerpc.git/arch/powerpc/platforms/pseries/eeh.c +--- linux-2.6.24/arch/powerpc/platforms/pseries/eeh.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pseries/eeh.c 2008-01-28 20:25:49.000000000 +0100 +@@ -29,6 +29,8 @@ + #include <linux/rbtree.h> + #include <linux/seq_file.h> + #include <linux/spinlock.h> ++#include <linux/of.h> ++ + #include <asm/atomic.h> + #include <asm/eeh.h> + #include <asm/eeh_event.h> +@@ -169,7 +171,6 @@ + */ + static size_t gather_pci_data(struct pci_dn *pdn, char * buf, size_t len) + { +- struct device_node *dn; + struct pci_dev *dev = pdn->pcidev; + u32 cfg; + int cap, i; +@@ -243,12 +244,12 @@ + + /* Gather status on devices under the bridge */ + if (dev->class >> 16 == PCI_BASE_CLASS_BRIDGE) { +- dn = pdn->node->child; +- while (dn) { ++ struct device_node *dn; ++ ++ for_each_child_of_node(pdn->node, dn) { + pdn = PCI_DN(dn); + if (pdn) + n += gather_pci_data(pdn, buf+n, len-n); +- dn = dn->sibling; + } + } + +@@ -372,7 +373,7 @@ + return dn; + } + +-/** Mark all devices that are peers of this device as failed. ++/** Mark all devices that are children of this device as failed. + * Mark the device driver too, so that it can see the failure + * immediately; this is critical, since some drivers poll + * status registers in interrupts ... If a driver is polling, +@@ -380,9 +381,11 @@ + * an interrupt context, which is bad. + */ + +-static void __eeh_mark_slot (struct device_node *dn, int mode_flag) ++static void __eeh_mark_slot(struct device_node *parent, int mode_flag) + { +- while (dn) { ++ struct device_node *dn; ++ ++ for_each_child_of_node(parent, dn) { + if (PCI_DN(dn)) { + /* Mark the pci device driver too */ + struct pci_dev *dev = PCI_DN(dn)->pcidev; +@@ -392,10 +395,8 @@ + if (dev && dev->driver) + dev->error_state = pci_channel_io_frozen; + +- if (dn->child) +- __eeh_mark_slot (dn->child, mode_flag); ++ __eeh_mark_slot(dn, mode_flag); + } +- dn = dn->sibling; + } + } + +@@ -415,19 +416,19 @@ + if (dev) + dev->error_state = pci_channel_io_frozen; + +- __eeh_mark_slot (dn->child, mode_flag); ++ __eeh_mark_slot(dn, mode_flag); + } + +-static void __eeh_clear_slot (struct device_node *dn, int mode_flag) ++static void __eeh_clear_slot(struct device_node *parent, int mode_flag) + { +- while (dn) { ++ struct device_node *dn; ++ ++ for_each_child_of_node(parent, dn) { + if (PCI_DN(dn)) { + PCI_DN(dn)->eeh_mode &= ~mode_flag; + PCI_DN(dn)->eeh_check_count = 0; +- if (dn->child) +- __eeh_clear_slot (dn->child, mode_flag); ++ __eeh_clear_slot(dn, mode_flag); + } +- dn = dn->sibling; + } + } + +@@ -444,7 +445,7 @@ + + PCI_DN(dn)->eeh_mode &= ~mode_flag; + PCI_DN(dn)->eeh_check_count = 0; +- __eeh_clear_slot (dn->child, mode_flag); ++ __eeh_clear_slot(dn, mode_flag); + spin_unlock_irqrestore(&confirm_error_lock, flags); + } + +@@ -480,6 +481,7 @@ + no_dn++; + return 0; + } ++ dn = find_device_pe(dn); + pdn = PCI_DN(dn); + + /* Access to IO BARs might get this far and still not want checking. */ +@@ -545,7 +547,7 @@ + + /* Note that config-io to empty slots may fail; + * they are empty when they don't have children. */ +- if ((rets[0] == 5) && (dn->child == NULL)) { ++ if ((rets[0] == 5) && (rets[2] == 0) && (dn->child == NULL)) { + false_positives++; + pdn->eeh_false_positives ++; + rc = 0; +@@ -848,11 +850,8 @@ + if ((pdn->eeh_mode & EEH_MODE_SUPPORTED) && !IS_BRIDGE(pdn->class_code)) + __restore_bars (pdn); + +- dn = pdn->node->child; +- while (dn) { ++ for_each_child_of_node(pdn->node, dn) + eeh_restore_bars (PCI_DN(dn)); +- dn = dn->sibling; +- } + } + + /** +@@ -1130,7 +1129,8 @@ + void eeh_add_device_tree_early(struct device_node *dn) + { + struct device_node *sib; +- for (sib = dn->child; sib; sib = sib->sibling) ++ ++ for_each_child_of_node(dn, sib) + eeh_add_device_tree_early(sib); + eeh_add_device_early(dn); + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pseries/eeh_driver.c powerpc.git/arch/powerpc/platforms/pseries/eeh_driver.c +--- linux-2.6.24/arch/powerpc/platforms/pseries/eeh_driver.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pseries/eeh_driver.c 2008-01-28 20:25:49.000000000 +0100 +@@ -310,8 +310,6 @@ + const char *location, *pci_str, *drv_str; + + frozen_dn = find_device_pe(event->dn); +- frozen_bus = pcibios_find_pci_bus(frozen_dn); +- + if (!frozen_dn) { + + location = of_get_property(event->dn, "ibm,loc-code", NULL); +@@ -321,6 +319,8 @@ + location, pci_name(event->dev)); + return NULL; + } ++ ++ frozen_bus = pcibios_find_pci_bus(frozen_dn); + location = of_get_property(frozen_dn, "ibm,loc-code", NULL); + location = location ? location : "unknown"; + +@@ -354,13 +354,6 @@ + if (frozen_pdn->eeh_freeze_count > EEH_MAX_ALLOWED_FREEZES) + goto excess_failures; + +- /* Get the current PCI slot state. */ +- rc = eeh_wait_for_slot_status (frozen_pdn, MAX_WAIT_FOR_RECOVERY*1000); +- if (rc < 0) { +- printk(KERN_WARNING "EEH: Permanent failure\n"); +- goto hard_fail; +- } +- + printk(KERN_WARNING + "EEH: This PCI device has failed %d times in the last hour:\n", + frozen_pdn->eeh_freeze_count); +@@ -376,6 +369,14 @@ + */ + pci_walk_bus(frozen_bus, eeh_report_error, &result); + ++ /* Get the current PCI slot state. This can take a long time, ++ * sometimes over 3 seconds for certain systems. */ ++ rc = eeh_wait_for_slot_status (frozen_pdn, MAX_WAIT_FOR_RECOVERY*1000); ++ if (rc < 0) { ++ printk(KERN_WARNING "EEH: Permanent failure\n"); ++ goto hard_fail; ++ } ++ + /* Since rtas may enable MMIO when posting the error log, + * don't post the error log until after all dev drivers + * have been informed. +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pseries/iommu.c powerpc.git/arch/powerpc/platforms/pseries/iommu.c +--- linux-2.6.24/arch/powerpc/platforms/pseries/iommu.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pseries/iommu.c 2008-01-28 20:25:49.000000000 +0100 +@@ -251,7 +251,7 @@ + const unsigned long *basep; + const u32 *sizep; + +- node = (struct device_node *)phb->arch_data; ++ node = phb->dn; + + basep = of_get_property(node, "linux,tce-base", NULL); + sizep = of_get_property(node, "linux,tce-size", NULL); +@@ -296,11 +296,12 @@ + static void iommu_table_setparms_lpar(struct pci_controller *phb, + struct device_node *dn, + struct iommu_table *tbl, +- const void *dma_window) ++ const void *dma_window, ++ int bussubno) + { + unsigned long offset, size; + +- tbl->it_busno = PCI_DN(dn)->bussubno; ++ tbl->it_busno = bussubno; + of_parse_dma_window(dn, dma_window, &tbl->it_index, &offset, &size); + + tbl->it_base = 0; +@@ -420,17 +421,10 @@ + pdn->full_name, ppci->iommu_table); + + if (!ppci->iommu_table) { +- /* Bussubno hasn't been copied yet. +- * Do it now because iommu_table_setparms_lpar needs it. +- */ +- +- ppci->bussubno = bus->number; +- + tbl = kmalloc_node(sizeof(struct iommu_table), GFP_KERNEL, + ppci->phb->node); +- +- iommu_table_setparms_lpar(ppci->phb, pdn, tbl, dma_window); +- ++ iommu_table_setparms_lpar(ppci->phb, pdn, tbl, dma_window, ++ bus->number); + ppci->iommu_table = iommu_init_table(tbl, ppci->phb->node); + DBG(" created table: %p\n", ppci->iommu_table); + } +@@ -523,14 +517,10 @@ + + pci = PCI_DN(pdn); + if (!pci->iommu_table) { +- /* iommu_table_setparms_lpar needs bussubno. */ +- pci->bussubno = pci->phb->bus->number; +- + tbl = kmalloc_node(sizeof(struct iommu_table), GFP_KERNEL, + pci->phb->node); +- +- iommu_table_setparms_lpar(pci->phb, pdn, tbl, dma_window); +- ++ iommu_table_setparms_lpar(pci->phb, pdn, tbl, dma_window, ++ pci->phb->bus->number); + pci->iommu_table = iommu_init_table(tbl, pci->phb->node); + DBG(" created table: %p\n", pci->iommu_table); + } else { +@@ -556,7 +546,7 @@ + case PSERIES_RECONFIG_REMOVE: + if (pci && pci->iommu_table && + of_get_property(np, "ibm,dma-window", NULL)) +- iommu_free_table(np); ++ iommu_free_table(pci->iommu_table, np->full_name); + break; + default: + err = NOTIFY_DONE; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pseries/pci_dlpar.c powerpc.git/arch/powerpc/platforms/pseries/pci_dlpar.c +--- linux-2.6.24/arch/powerpc/platforms/pseries/pci_dlpar.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pseries/pci_dlpar.c 2008-01-28 20:25:49.000000000 +0100 +@@ -83,7 +83,7 @@ + + /* Must be called before pci_bus_add_devices */ + void +-pcibios_fixup_new_pci_devices(struct pci_bus *bus, int fix_bus) ++pcibios_fixup_new_pci_devices(struct pci_bus *bus) + { + struct pci_dev *dev; + +@@ -98,8 +98,6 @@ + /* Fill device archdata and setup iommu table */ + pcibios_setup_new_device(dev); + +- if(fix_bus) +- pcibios_fixup_device_resources(dev, bus); + pci_read_irq_line(dev); + for (i = 0; i < PCI_NUM_RESOURCES; i++) { + struct resource *r = &dev->resource[i]; +@@ -132,8 +130,8 @@ + + pci_scan_child_bus(child_bus); + +- /* Fixup new pci devices without touching bus struct */ +- pcibios_fixup_new_pci_devices(child_bus, 0); ++ /* Fixup new pci devices */ ++ pcibios_fixup_new_pci_devices(child_bus); + + /* Make the discovered devices available */ + pci_bus_add_devices(child_bus); +@@ -169,7 +167,7 @@ + /* use ofdt-based probe */ + of_scan_bus(dn, bus); + if (!list_empty(&bus->devices)) { +- pcibios_fixup_new_pci_devices(bus, 0); ++ pcibios_fixup_new_pci_devices(bus); + pci_bus_add_devices(bus); + eeh_add_device_tree_late(bus); + } +@@ -178,7 +176,7 @@ + slotno = PCI_SLOT(PCI_DN(dn->child)->devfn); + num = pci_scan_slot(bus, PCI_DEVFN(slotno, 0)); + if (num) { +- pcibios_fixup_new_pci_devices(bus, 1); ++ pcibios_fixup_new_pci_devices(bus); + pci_bus_add_devices(bus); + eeh_add_device_tree_late(bus); + } +@@ -208,7 +206,7 @@ + eeh_add_device_tree_early(dn); + + scan_phb(phb); +- pcibios_fixup_new_pci_devices(phb->bus, 0); ++ pcibios_fixup_new_pci_devices(phb->bus); + pci_bus_add_devices(phb->bus); + eeh_add_device_tree_late(phb->bus); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pseries/plpar_wrappers.h powerpc.git/arch/powerpc/platforms/pseries/plpar_wrappers.h +--- linux-2.6.24/arch/powerpc/platforms/pseries/plpar_wrappers.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pseries/plpar_wrappers.h 2008-01-28 20:25:49.000000000 +0100 +@@ -8,11 +8,6 @@ + return plpar_hcall_norets(H_POLL_PENDING); + } + +-static inline long prod_processor(void) +-{ +- return plpar_hcall_norets(H_PROD); +-} +- + static inline long cede_processor(void) + { + return plpar_hcall_norets(H_CEDE); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pseries/smp.c powerpc.git/arch/powerpc/platforms/pseries/smp.c +--- linux-2.6.24/arch/powerpc/platforms/pseries/smp.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pseries/smp.c 2008-01-28 20:25:49.000000000 +0100 +@@ -46,6 +46,7 @@ + #include <asm/pSeries_reconfig.h> + #include <asm/mpic.h> + #include <asm/vdso_datapage.h> ++#include <asm/cputhreads.h> + + #include "plpar_wrappers.h" + #include "pseries.h" +@@ -202,7 +203,7 @@ + */ + if (system_state < SYSTEM_RUNNING && + cpu_has_feature(CPU_FTR_SMT) && +- !smt_enabled_at_boot && nr % 2 != 0) ++ !smt_enabled_at_boot && cpu_thread_in_core(nr) != 0) + return 0; + + return 1; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pseries/xics.c powerpc.git/arch/powerpc/platforms/pseries/xics.c +--- linux-2.6.24/arch/powerpc/platforms/pseries/xics.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pseries/xics.c 2008-01-28 20:25:49.000000000 +0100 +@@ -87,19 +87,25 @@ + /* Direct HW low level accessors */ + + +-static inline unsigned int direct_xirr_info_get(int n_cpu) ++static inline unsigned int direct_xirr_info_get(void) + { +- return in_be32(&xics_per_cpu[n_cpu]->xirr.word); ++ int cpu = smp_processor_id(); ++ ++ return in_be32(&xics_per_cpu[cpu]->xirr.word); + } + +-static inline void direct_xirr_info_set(int n_cpu, int value) ++static inline void direct_xirr_info_set(int value) + { +- out_be32(&xics_per_cpu[n_cpu]->xirr.word, value); ++ int cpu = smp_processor_id(); ++ ++ out_be32(&xics_per_cpu[cpu]->xirr.word, value); + } + +-static inline void direct_cppr_info(int n_cpu, u8 value) ++static inline void direct_cppr_info(u8 value) + { +- out_8(&xics_per_cpu[n_cpu]->xirr.bytes[0], value); ++ int cpu = smp_processor_id(); ++ ++ out_8(&xics_per_cpu[cpu]->xirr.bytes[0], value); + } + + static inline void direct_qirr_info(int n_cpu, u8 value) +@@ -111,7 +117,7 @@ + /* LPAR low level accessors */ + + +-static inline unsigned int lpar_xirr_info_get(int n_cpu) ++static inline unsigned int lpar_xirr_info_get(void) + { + unsigned long lpar_rc; + unsigned long return_value; +@@ -122,7 +128,7 @@ + return (unsigned int)return_value; + } + +-static inline void lpar_xirr_info_set(int n_cpu, int value) ++static inline void lpar_xirr_info_set(int value) + { + unsigned long lpar_rc; + unsigned long val64 = value & 0xffffffff; +@@ -133,7 +139,7 @@ + val64); + } + +-static inline void lpar_cppr_info(int n_cpu, u8 value) ++static inline void lpar_cppr_info(u8 value) + { + unsigned long lpar_rc; + +@@ -275,21 +281,19 @@ + + static void xics_eoi_direct(unsigned int virq) + { +- int cpu = smp_processor_id(); + unsigned int irq = (unsigned int)irq_map[virq].hwirq; + + iosync(); +- direct_xirr_info_set(cpu, (0xff << 24) | irq); ++ direct_xirr_info_set((0xff << 24) | irq); + } + + + static void xics_eoi_lpar(unsigned int virq) + { +- int cpu = smp_processor_id(); + unsigned int irq = (unsigned int)irq_map[virq].hwirq; + + iosync(); +- lpar_xirr_info_set(cpu, (0xff << 24) | irq); ++ lpar_xirr_info_set((0xff << 24) | irq); + } + + static inline unsigned int xics_remap_irq(unsigned int vec) +@@ -312,16 +316,12 @@ + + static unsigned int xics_get_irq_direct(void) + { +- unsigned int cpu = smp_processor_id(); +- +- return xics_remap_irq(direct_xirr_info_get(cpu)); ++ return xics_remap_irq(direct_xirr_info_get()); + } + + static unsigned int xics_get_irq_lpar(void) + { +- unsigned int cpu = smp_processor_id(); +- +- return xics_remap_irq(lpar_xirr_info_get(cpu)); ++ return xics_remap_irq(lpar_xirr_info_get()); + } + + #ifdef CONFIG_SMP +@@ -387,12 +387,12 @@ + + #endif /* CONFIG_SMP */ + +-static void xics_set_cpu_priority(int cpu, unsigned char cppr) ++static void xics_set_cpu_priority(unsigned char cppr) + { + if (firmware_has_feature(FW_FEATURE_LPAR)) +- lpar_cppr_info(cpu, cppr); ++ lpar_cppr_info(cppr); + else +- direct_cppr_info(cpu, cppr); ++ direct_cppr_info(cppr); + iosync(); + } + +@@ -440,9 +440,7 @@ + + void xics_setup_cpu(void) + { +- int cpu = smp_processor_id(); +- +- xics_set_cpu_priority(cpu, 0xff); ++ xics_set_cpu_priority(0xff); + + /* + * Put the calling processor into the GIQ. This is really only +@@ -783,7 +781,7 @@ + unsigned int ipi; + struct irq_desc *desc; + +- xics_set_cpu_priority(cpu, 0); ++ xics_set_cpu_priority(0); + + /* + * Clear IPI +@@ -824,10 +822,11 @@ + void xics_migrate_irqs_away(void) + { + int status; +- unsigned int irq, virq, cpu = smp_processor_id(); ++ int cpu = smp_processor_id(), hw_cpu = hard_smp_processor_id(); ++ unsigned int irq, virq; + + /* Reject any interrupt that was queued to us... */ +- xics_set_cpu_priority(cpu, 0); ++ xics_set_cpu_priority(0); + + /* remove ourselves from the global interrupt queue */ + status = rtas_set_indicator_fast(GLOBAL_INTERRUPT_QUEUE, +@@ -835,7 +834,7 @@ + WARN_ON(status < 0); + + /* Allow IPIs again... */ +- xics_set_cpu_priority(cpu, DEFAULT_PRIORITY); ++ xics_set_cpu_priority(DEFAULT_PRIORITY); + + for_each_irq(virq) { + struct irq_desc *desc; +@@ -874,7 +873,7 @@ + * The irq has to be migrated only in the single cpu + * case. + */ +- if (xics_status[0] != get_hard_smp_processor_id(cpu)) ++ if (xics_status[0] != hw_cpu) + goto unlock; + + printk(KERN_WARNING "IRQ %u affinity broken off cpu %u\n", +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/platforms/pseries/xics.h powerpc.git/arch/powerpc/platforms/pseries/xics.h +--- linux-2.6.24/arch/powerpc/platforms/pseries/xics.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/platforms/pseries/xics.h 2008-01-28 20:25:49.000000000 +0100 +@@ -21,9 +21,6 @@ + extern void xics_request_IPIs(void); + extern void xics_migrate_irqs_away(void); + +-/* first argument is ignored for now*/ +-void pSeriesLP_cppr_info(int n_cpu, u8 value); +- + struct xics_ipi_struct { + volatile unsigned long value; + } ____cacheline_aligned; +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/Kconfig powerpc.git/arch/powerpc/sysdev/Kconfig +--- linux-2.6.24/arch/powerpc/sysdev/Kconfig 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,8 @@ ++# For a description of the syntax of this configuration file, ++# see Documentation/kbuild/kconfig-language.txt. ++# ++ ++config PPC4xx_PCI_EXPRESS ++ bool ++ depends on PCI && 4xx ++ default n +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/Makefile powerpc.git/arch/powerpc/sysdev/Makefile +--- linux-2.6.24/arch/powerpc/sysdev/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/Makefile 2008-01-28 20:25:49.000000000 +0100 +@@ -2,7 +2,7 @@ + EXTRA_CFLAGS += -mno-minimal-toc + endif + +-mpic-msi-obj-$(CONFIG_PCI_MSI) += mpic_msi.o mpic_u3msi.o ++mpic-msi-obj-$(CONFIG_PCI_MSI) += mpic_msi.o mpic_u3msi.o mpic_pasemi_msi.o + obj-$(CONFIG_MPIC) += mpic.o $(mpic-msi-obj-y) + + obj-$(CONFIG_PPC_MPC106) += grackle.o +@@ -12,6 +12,7 @@ + obj-$(CONFIG_MMIO_NVRAM) += mmio_nvram.o + obj-$(CONFIG_FSL_SOC) += fsl_soc.o + obj-$(CONFIG_FSL_PCI) += fsl_pci.o ++obj-$(CONFIG_RAPIDIO) += fsl_rio.o + obj-$(CONFIG_TSI108_BRIDGE) += tsi108_pci.o tsi108_dev.o + obj-$(CONFIG_QUICC_ENGINE) += qe_lib/ + obj-$(CONFIG_PPC_BESTCOMM) += bestcomm/ +@@ -24,9 +25,13 @@ + ifeq ($(CONFIG_PPC_MERGE),y) + obj-$(CONFIG_PPC_INDIRECT_PCI) += indirect_pci.o + obj-$(CONFIG_PPC_I8259) += i8259.o +-obj-$(CONFIG_PPC_83xx) += ipic.o ++obj-$(CONFIG_IPIC) += ipic.o + obj-$(CONFIG_4xx) += uic.o + obj-$(CONFIG_XILINX_VIRTEX) += xilinx_intc.o ++obj-$(CONFIG_OF_RTC) += of_rtc.o ++ifeq ($(CONFIG_PCI),y) ++obj-$(CONFIG_4xx) += ppc4xx_pci.o ++endif + endif + + # Temporary hack until we have migrated to asm-powerpc +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/axonram.c powerpc.git/arch/powerpc/sysdev/axonram.c +--- linux-2.6.24/arch/powerpc/sysdev/axonram.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/axonram.c 2008-01-28 20:25:49.000000000 +0100 +@@ -42,8 +42,9 @@ + #include <linux/slab.h> + #include <linux/string.h> + #include <linux/types.h> +-#include <asm/of_device.h> +-#include <asm/of_platform.h> ++#include <linux/of_device.h> ++#include <linux/of_platform.h> ++ + #include <asm/page.h> + #include <asm/prom.h> + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/bestcomm/bestcomm.h powerpc.git/arch/powerpc/sysdev/bestcomm/bestcomm.h +--- linux-2.6.24/arch/powerpc/sysdev/bestcomm/bestcomm.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/bestcomm/bestcomm.h 2008-01-28 20:25:49.000000000 +0100 +@@ -20,7 +20,7 @@ + + + /* ======================================================================== */ +-/* Generic task managment */ ++/* Generic task management */ + /* ======================================================================== */ + + /** +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/commproc.c powerpc.git/arch/powerpc/sysdev/commproc.c +--- linux-2.6.24/arch/powerpc/sysdev/commproc.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/commproc.c 2008-01-28 20:25:49.000000000 +0100 +@@ -240,6 +240,34 @@ + #endif + } + ++static DEFINE_SPINLOCK(cmd_lock); ++ ++#define MAX_CR_CMD_LOOPS 10000 ++ ++int cpm_command(u32 command, u8 opcode) ++{ ++ int i, ret; ++ unsigned long flags; ++ ++ if (command & 0xffffff0f) ++ return -EINVAL; ++ ++ spin_lock_irqsave(&cmd_lock, flags); ++ ++ ret = 0; ++ out_be16(&cpmp->cp_cpcr, command | CPM_CR_FLG | (opcode << 8)); ++ for (i = 0; i < MAX_CR_CMD_LOOPS; i++) ++ if ((in_be16(&cpmp->cp_cpcr) & CPM_CR_FLG) == 0) ++ goto out; ++ ++ printk(KERN_ERR "%s(): Not able to issue CPM command\n", __FUNCTION__); ++ ret = -EIO; ++out: ++ spin_unlock_irqrestore(&cmd_lock, flags); ++ return ret; ++} ++EXPORT_SYMBOL(cpm_command); ++ + /* We used to do this earlier, but have to postpone as long as possible + * to ensure the kernel VM is now running. + */ +@@ -408,7 +436,7 @@ + #endif /* !CONFIG_PPC_CPM_NEW_BINDING */ + + struct cpm_ioport16 { +- __be16 dir, par, sor, dat, intr; ++ __be16 dir, par, odr_sor, dat, intr; + __be16 res[3]; + }; + +@@ -438,6 +466,13 @@ + else + clrbits32(&iop->par, pin); + ++ if (port == CPM_PORTB) { ++ if (flags & CPM_PIN_OPENDRAIN) ++ setbits16(&mpc8xx_immr->im_cpm.cp_pbodr, pin); ++ else ++ clrbits16(&mpc8xx_immr->im_cpm.cp_pbodr, pin); ++ } ++ + if (port == CPM_PORTE) { + if (flags & CPM_PIN_SECONDARY) + setbits32(&iop->sor, pin); +@@ -471,11 +506,17 @@ + else + clrbits16(&iop->par, pin); + ++ if (port == CPM_PORTA) { ++ if (flags & CPM_PIN_OPENDRAIN) ++ setbits16(&iop->odr_sor, pin); ++ else ++ clrbits16(&iop->odr_sor, pin); ++ } + if (port == CPM_PORTC) { + if (flags & CPM_PIN_SECONDARY) +- setbits16(&iop->sor, pin); ++ setbits16(&iop->odr_sor, pin); + else +- clrbits16(&iop->sor, pin); ++ clrbits16(&iop->odr_sor, pin); + } + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/cpm2_common.c powerpc.git/arch/powerpc/sysdev/cpm2_common.c +--- linux-2.6.24/arch/powerpc/sysdev/cpm2_common.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/cpm2_common.c 2008-01-28 20:25:49.000000000 +0100 +@@ -82,6 +82,31 @@ + cpmp = &cpm2_immr->im_cpm; + } + ++static DEFINE_SPINLOCK(cmd_lock); ++ ++#define MAX_CR_CMD_LOOPS 10000 ++ ++int cpm_command(u32 command, u8 opcode) ++{ ++ int i, ret; ++ unsigned long flags; ++ ++ spin_lock_irqsave(&cmd_lock, flags); ++ ++ ret = 0; ++ out_be32(&cpmp->cp_cpcr, command | opcode | CPM_CR_FLG); ++ for (i = 0; i < MAX_CR_CMD_LOOPS; i++) ++ if ((in_be32(&cpmp->cp_cpcr) & CPM_CR_FLG) == 0) ++ goto out; ++ ++ printk(KERN_ERR "%s(): Not able to issue CPM command\n", __FUNCTION__); ++ ret = -EIO; ++out: ++ spin_unlock_irqrestore(&cmd_lock, flags); ++ return ret; ++} ++EXPORT_SYMBOL(cpm_command); ++ + /* Set a baud rate generator. This needs lots of work. There are + * eight BRGs, which can be connected to the CPM channels or output + * as clocks. The BRGs are in two different block of internal +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/fsl_pci.c powerpc.git/arch/powerpc/sysdev/fsl_pci.c +--- linux-2.6.24/arch/powerpc/sysdev/fsl_pci.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/fsl_pci.c 2008-01-28 20:25:49.000000000 +0100 +@@ -33,8 +33,8 @@ + struct ccsr_pci __iomem *pci; + int i; + +- pr_debug("PCI memory map start 0x%x, size 0x%x\n", rsrc->start, +- rsrc->end - rsrc->start + 1); ++ pr_debug("PCI memory map start 0x%016llx, size 0x%016llx\n", ++ (u64)rsrc->start, (u64)rsrc->end - (u64)rsrc->start + 1); + pci = ioremap(rsrc->start, rsrc->end - rsrc->start + 1); + + /* Disable all windows (except powar0 since its ignored) */ +@@ -46,17 +46,17 @@ + /* Setup outbound MEM window */ + for(i = 0; i < 3; i++) + if (hose->mem_resources[i].flags & IORESOURCE_MEM){ +- pr_debug("PCI MEM resource start 0x%08x, size 0x%08x.\n", +- hose->mem_resources[i].start, +- hose->mem_resources[i].end +- - hose->mem_resources[i].start + 1); +- out_be32(&pci->pow[i+1].potar, +- (hose->mem_resources[i].start >> 12) +- & 0x000fffff); ++ resource_size_t pci_addr_start = ++ hose->mem_resources[i].start - ++ hose->pci_mem_offset; ++ pr_debug("PCI MEM resource start 0x%016llx, size 0x%016llx.\n", ++ (u64)hose->mem_resources[i].start, ++ (u64)hose->mem_resources[i].end ++ - (u64)hose->mem_resources[i].start + 1); ++ out_be32(&pci->pow[i+1].potar, (pci_addr_start >> 12)); + out_be32(&pci->pow[i+1].potear, 0); + out_be32(&pci->pow[i+1].powbar, +- (hose->mem_resources[i].start >> 12) +- & 0x000fffff); ++ (hose->mem_resources[i].start >> 12)); + /* Enable, Mem R/W */ + out_be32(&pci->pow[i+1].powar, 0x80044000 + | (__ilog2(hose->mem_resources[i].end +@@ -65,15 +65,14 @@ + + /* Setup outbound IO window */ + if (hose->io_resource.flags & IORESOURCE_IO){ +- pr_debug("PCI IO resource start 0x%08x, size 0x%08x, phy base 0x%08x.\n", +- hose->io_resource.start, +- hose->io_resource.end - hose->io_resource.start + 1, +- hose->io_base_phys); +- out_be32(&pci->pow[i+1].potar, (hose->io_resource.start >> 12) +- & 0x000fffff); ++ pr_debug("PCI IO resource start 0x%016llx, size 0x%016llx, " ++ "phy base 0x%016llx.\n", ++ (u64)hose->io_resource.start, ++ (u64)hose->io_resource.end - (u64)hose->io_resource.start + 1, ++ (u64)hose->io_base_phys); ++ out_be32(&pci->pow[i+1].potar, (hose->io_resource.start >> 12)); + out_be32(&pci->pow[i+1].potear, 0); +- out_be32(&pci->pow[i+1].powbar, (hose->io_base_phys >> 12) +- & 0x000fffff); ++ out_be32(&pci->pow[i+1].powbar, (hose->io_base_phys >> 12)); + /* Enable, IO R/W */ + out_be32(&pci->pow[i+1].powar, 0x80088000 + | (__ilog2(hose->io_resource.end +@@ -107,55 +106,17 @@ + } + } + +-static void __init quirk_fsl_pcie_transparent(struct pci_dev *dev) +-{ +- struct resource *res; +- int i, res_idx = PCI_BRIDGE_RESOURCES; +- struct pci_controller *hose; ++static int fsl_pcie_bus_fixup; + ++static void __init quirk_fsl_pcie_header(struct pci_dev *dev) ++{ + /* if we aren't a PCIe don't bother */ + if (!pci_find_capability(dev, PCI_CAP_ID_EXP)) + return ; + +- /* +- * Make the bridge be transparent. +- */ +- dev->transparent = 1; +- +- hose = pci_bus_to_host(dev->bus); +- if (!hose) { +- printk(KERN_ERR "Can't find hose for bus %d\n", +- dev->bus->number); +- return; +- } +- +- /* Clear out any of the virtual P2P bridge registers */ +- pci_write_config_word(dev, PCI_IO_BASE_UPPER16, 0); +- pci_write_config_word(dev, PCI_IO_LIMIT_UPPER16, 0); +- pci_write_config_byte(dev, PCI_IO_BASE, 0x10); +- pci_write_config_byte(dev, PCI_IO_LIMIT, 0); +- pci_write_config_word(dev, PCI_MEMORY_BASE, 0x10); +- pci_write_config_word(dev, PCI_MEMORY_LIMIT, 0); +- pci_write_config_word(dev, PCI_PREF_BASE_UPPER32, 0x0); +- pci_write_config_word(dev, PCI_PREF_LIMIT_UPPER32, 0x0); +- pci_write_config_word(dev, PCI_PREF_MEMORY_BASE, 0x10); +- pci_write_config_word(dev, PCI_PREF_MEMORY_LIMIT, 0); +- +- if (hose->io_resource.flags) { +- res = &dev->resource[res_idx++]; +- res->start = hose->io_resource.start; +- res->end = hose->io_resource.end; +- res->flags = hose->io_resource.flags; +- update_bridge_resource(dev, res); +- } +- +- for (i = 0; i < 3; i++) { +- res = &dev->resource[res_idx + i]; +- res->start = hose->mem_resources[i].start; +- res->end = hose->mem_resources[i].end; +- res->flags = hose->mem_resources[i].flags; +- update_bridge_resource(dev, res); +- } ++ dev->class = PCI_CLASS_BRIDGE_PCI << 8; ++ fsl_pcie_bus_fixup = 1; ++ return ; + } + + int __init fsl_pcie_check_link(struct pci_controller *hose) +@@ -172,11 +133,24 @@ + struct pci_controller *hose = (struct pci_controller *) bus->sysdata; + int i; + +- /* deal with bogus pci_bus when we don't have anything connected on PCIe */ +- if (hose->indirect_type & PPC_INDIRECT_TYPE_NO_PCIE_LINK) { +- if (bus->parent) { +- for (i = 0; i < 4; ++i) +- bus->resource[i] = bus->parent->resource[i]; ++ if ((bus->parent == hose->bus) && ++ ((fsl_pcie_bus_fixup && ++ early_find_capability(hose, 0, 0, PCI_CAP_ID_EXP)) || ++ (hose->indirect_type & PPC_INDIRECT_TYPE_NO_PCIE_LINK))) ++ { ++ for (i = 0; i < 4; ++i) { ++ struct resource *res = bus->resource[i]; ++ struct resource *par = bus->parent->resource[i]; ++ if (res) { ++ res->start = 0; ++ res->end = 0; ++ res->flags = 0; ++ } ++ if (res && par) { ++ res->start = par->start; ++ res->end = par->end; ++ res->flags = par->flags; ++ } + } + } + } +@@ -202,7 +176,7 @@ + printk(KERN_WARNING "Can't get bus-range for %s, assume" + " bus 0\n", dev->full_name); + +- pci_assign_all_buses = 1; ++ ppc_pci_flags |= PPC_PCI_REASSIGN_ALL_BUS; + hose = pcibios_alloc_controller(dev); + if (!hose) + return -ENOMEM; +@@ -222,7 +196,7 @@ + hose->indirect_type |= PPC_INDIRECT_TYPE_NO_PCIE_LINK; + } + +- printk(KERN_INFO "Found FSL PCI host bridge at 0x%016llx." ++ printk(KERN_INFO "Found FSL PCI host bridge at 0x%016llx. " + "Firmware bus number: %d->%d\n", + (unsigned long long)rsrc.start, hose->first_busno, + hose->last_busno); +@@ -240,23 +214,23 @@ + return 0; + } + +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8548E, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8548, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8543E, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8543, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8547E, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8545E, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8545, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8568E, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8568, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8567E, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8567, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8533E, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8533, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8544E, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8544, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8572E, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8572, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8641, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8641D, quirk_fsl_pcie_transparent); +-DECLARE_PCI_FIXUP_EARLY(0x1957, PCI_DEVICE_ID_MPC8610, quirk_fsl_pcie_transparent); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8548E, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8548, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8543E, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8543, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8547E, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8545E, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8545, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8568E, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8568, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8567E, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8567, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8533E, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8533, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8544E, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8544, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8572E, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8572, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8641, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8641D, quirk_fsl_pcie_header); ++DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8610, quirk_fsl_pcie_header); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/fsl_rio.c powerpc.git/arch/powerpc/sysdev/fsl_rio.c +--- linux-2.6.24/arch/powerpc/sysdev/fsl_rio.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/fsl_rio.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,932 @@ ++/* ++ * MPC85xx RapidIO support ++ * ++ * Copyright 2005 MontaVista Software, Inc. ++ * Matt Porter <mporter@kernel.crashing.org> ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++#include <linux/init.h> ++#include <linux/module.h> ++#include <linux/types.h> ++#include <linux/dma-mapping.h> ++#include <linux/interrupt.h> ++#include <linux/rio.h> ++#include <linux/rio_drv.h> ++ ++#include <asm/io.h> ++ ++#define RIO_REGS_BASE (CCSRBAR + 0xc0000) ++#define RIO_ATMU_REGS_OFFSET 0x10c00 ++#define RIO_MSG_REGS_OFFSET 0x11000 ++#define RIO_MAINT_WIN_SIZE 0x400000 ++#define RIO_DBELL_WIN_SIZE 0x1000 ++ ++#define RIO_MSG_OMR_MUI 0x00000002 ++#define RIO_MSG_OSR_TE 0x00000080 ++#define RIO_MSG_OSR_QOI 0x00000020 ++#define RIO_MSG_OSR_QFI 0x00000010 ++#define RIO_MSG_OSR_MUB 0x00000004 ++#define RIO_MSG_OSR_EOMI 0x00000002 ++#define RIO_MSG_OSR_QEI 0x00000001 ++ ++#define RIO_MSG_IMR_MI 0x00000002 ++#define RIO_MSG_ISR_TE 0x00000080 ++#define RIO_MSG_ISR_QFI 0x00000010 ++#define RIO_MSG_ISR_DIQI 0x00000001 ++ ++#define RIO_MSG_DESC_SIZE 32 ++#define RIO_MSG_BUFFER_SIZE 4096 ++#define RIO_MIN_TX_RING_SIZE 2 ++#define RIO_MAX_TX_RING_SIZE 2048 ++#define RIO_MIN_RX_RING_SIZE 2 ++#define RIO_MAX_RX_RING_SIZE 2048 ++ ++#define DOORBELL_DMR_DI 0x00000002 ++#define DOORBELL_DSR_TE 0x00000080 ++#define DOORBELL_DSR_QFI 0x00000010 ++#define DOORBELL_DSR_DIQI 0x00000001 ++#define DOORBELL_TID_OFFSET 0x03 ++#define DOORBELL_SID_OFFSET 0x05 ++#define DOORBELL_INFO_OFFSET 0x06 ++ ++#define DOORBELL_MESSAGE_SIZE 0x08 ++#define DBELL_SID(x) (*(u8 *)(x + DOORBELL_SID_OFFSET)) ++#define DBELL_TID(x) (*(u8 *)(x + DOORBELL_TID_OFFSET)) ++#define DBELL_INF(x) (*(u16 *)(x + DOORBELL_INFO_OFFSET)) ++ ++struct rio_atmu_regs { ++ u32 rowtar; ++ u32 pad1; ++ u32 rowbar; ++ u32 pad2; ++ u32 rowar; ++ u32 pad3[3]; ++}; ++ ++struct rio_msg_regs { ++ u32 omr; ++ u32 osr; ++ u32 pad1; ++ u32 odqdpar; ++ u32 pad2; ++ u32 osar; ++ u32 odpr; ++ u32 odatr; ++ u32 odcr; ++ u32 pad3; ++ u32 odqepar; ++ u32 pad4[13]; ++ u32 imr; ++ u32 isr; ++ u32 pad5; ++ u32 ifqdpar; ++ u32 pad6; ++ u32 ifqepar; ++ u32 pad7[250]; ++ u32 dmr; ++ u32 dsr; ++ u32 pad8; ++ u32 dqdpar; ++ u32 pad9; ++ u32 dqepar; ++ u32 pad10[26]; ++ u32 pwmr; ++ u32 pwsr; ++ u32 pad11; ++ u32 pwqbar; ++}; ++ ++struct rio_tx_desc { ++ u32 res1; ++ u32 saddr; ++ u32 dport; ++ u32 dattr; ++ u32 res2; ++ u32 res3; ++ u32 dwcnt; ++ u32 res4; ++}; ++ ++static u32 regs_win; ++static struct rio_atmu_regs *atmu_regs; ++static struct rio_atmu_regs *maint_atmu_regs; ++static struct rio_atmu_regs *dbell_atmu_regs; ++static u32 dbell_win; ++static u32 maint_win; ++static struct rio_msg_regs *msg_regs; ++ ++static struct rio_dbell_ring { ++ void *virt; ++ dma_addr_t phys; ++} dbell_ring; ++ ++static struct rio_msg_tx_ring { ++ void *virt; ++ dma_addr_t phys; ++ void *virt_buffer[RIO_MAX_TX_RING_SIZE]; ++ dma_addr_t phys_buffer[RIO_MAX_TX_RING_SIZE]; ++ int tx_slot; ++ int size; ++ void *dev_id; ++} msg_tx_ring; ++ ++static struct rio_msg_rx_ring { ++ void *virt; ++ dma_addr_t phys; ++ void *virt_buffer[RIO_MAX_RX_RING_SIZE]; ++ int rx_slot; ++ int size; ++ void *dev_id; ++} msg_rx_ring; ++ ++/** ++ * mpc85xx_rio_doorbell_send - Send a MPC85xx doorbell message ++ * @index: ID of RapidIO interface ++ * @destid: Destination ID of target device ++ * @data: 16-bit info field of RapidIO doorbell message ++ * ++ * Sends a MPC85xx doorbell message. Returns %0 on success or ++ * %-EINVAL on failure. ++ */ ++static int mpc85xx_rio_doorbell_send(int index, u16 destid, u16 data) ++{ ++ pr_debug("mpc85xx_doorbell_send: index %d destid %4.4x data %4.4x\n", ++ index, destid, data); ++ out_be32((void *)&dbell_atmu_regs->rowtar, destid << 22); ++ out_be16((void *)(dbell_win), data); ++ ++ return 0; ++} ++ ++/** ++ * mpc85xx_local_config_read - Generate a MPC85xx local config space read ++ * @index: ID of RapdiIO interface ++ * @offset: Offset into configuration space ++ * @len: Length (in bytes) of the maintenance transaction ++ * @data: Value to be read into ++ * ++ * Generates a MPC85xx local configuration space read. Returns %0 on ++ * success or %-EINVAL on failure. ++ */ ++static int mpc85xx_local_config_read(int index, u32 offset, int len, u32 * data) ++{ ++ pr_debug("mpc85xx_local_config_read: index %d offset %8.8x\n", index, ++ offset); ++ *data = in_be32((void *)(regs_win + offset)); ++ ++ return 0; ++} ++ ++/** ++ * mpc85xx_local_config_write - Generate a MPC85xx local config space write ++ * @index: ID of RapdiIO interface ++ * @offset: Offset into configuration space ++ * @len: Length (in bytes) of the maintenance transaction ++ * @data: Value to be written ++ * ++ * Generates a MPC85xx local configuration space write. Returns %0 on ++ * success or %-EINVAL on failure. ++ */ ++static int mpc85xx_local_config_write(int index, u32 offset, int len, u32 data) ++{ ++ pr_debug ++ ("mpc85xx_local_config_write: index %d offset %8.8x data %8.8x\n", ++ index, offset, data); ++ out_be32((void *)(regs_win + offset), data); ++ ++ return 0; ++} ++ ++/** ++ * mpc85xx_rio_config_read - Generate a MPC85xx read maintenance transaction ++ * @index: ID of RapdiIO interface ++ * @destid: Destination ID of transaction ++ * @hopcount: Number of hops to target device ++ * @offset: Offset into configuration space ++ * @len: Length (in bytes) of the maintenance transaction ++ * @val: Location to be read into ++ * ++ * Generates a MPC85xx read maintenance transaction. Returns %0 on ++ * success or %-EINVAL on failure. ++ */ ++static int ++mpc85xx_rio_config_read(int index, u16 destid, u8 hopcount, u32 offset, int len, ++ u32 * val) ++{ ++ u8 *data; ++ ++ pr_debug ++ ("mpc85xx_rio_config_read: index %d destid %d hopcount %d offset %8.8x len %d\n", ++ index, destid, hopcount, offset, len); ++ out_be32((void *)&maint_atmu_regs->rowtar, ++ (destid << 22) | (hopcount << 12) | ((offset & ~0x3) >> 9)); ++ ++ data = (u8 *) maint_win + offset; ++ switch (len) { ++ case 1: ++ *val = in_8((u8 *) data); ++ break; ++ case 2: ++ *val = in_be16((u16 *) data); ++ break; ++ default: ++ *val = in_be32((u32 *) data); ++ break; ++ } ++ ++ return 0; ++} ++ ++/** ++ * mpc85xx_rio_config_write - Generate a MPC85xx write maintenance transaction ++ * @index: ID of RapdiIO interface ++ * @destid: Destination ID of transaction ++ * @hopcount: Number of hops to target device ++ * @offset: Offset into configuration space ++ * @len: Length (in bytes) of the maintenance transaction ++ * @val: Value to be written ++ * ++ * Generates an MPC85xx write maintenance transaction. Returns %0 on ++ * success or %-EINVAL on failure. ++ */ ++static int ++mpc85xx_rio_config_write(int index, u16 destid, u8 hopcount, u32 offset, ++ int len, u32 val) ++{ ++ u8 *data; ++ pr_debug ++ ("mpc85xx_rio_config_write: index %d destid %d hopcount %d offset %8.8x len %d val %8.8x\n", ++ index, destid, hopcount, offset, len, val); ++ out_be32((void *)&maint_atmu_regs->rowtar, ++ (destid << 22) | (hopcount << 12) | ((offset & ~0x3) >> 9)); ++ ++ data = (u8 *) maint_win + offset; ++ switch (len) { ++ case 1: ++ out_8((u8 *) data, val); ++ break; ++ case 2: ++ out_be16((u16 *) data, val); ++ break; ++ default: ++ out_be32((u32 *) data, val); ++ break; ++ } ++ ++ return 0; ++} ++ ++/** ++ * rio_hw_add_outb_message - Add message to the MPC85xx outbound message queue ++ * @mport: Master port with outbound message queue ++ * @rdev: Target of outbound message ++ * @mbox: Outbound mailbox ++ * @buffer: Message to add to outbound queue ++ * @len: Length of message ++ * ++ * Adds the @buffer message to the MPC85xx outbound message queue. Returns ++ * %0 on success or %-EINVAL on failure. ++ */ ++int ++rio_hw_add_outb_message(struct rio_mport *mport, struct rio_dev *rdev, int mbox, ++ void *buffer, size_t len) ++{ ++ u32 omr; ++ struct rio_tx_desc *desc = ++ (struct rio_tx_desc *)msg_tx_ring.virt + msg_tx_ring.tx_slot; ++ int ret = 0; ++ ++ pr_debug ++ ("RIO: rio_hw_add_outb_message(): destid %4.4x mbox %d buffer %8.8x len %8.8x\n", ++ rdev->destid, mbox, (int)buffer, len); ++ ++ if ((len < 8) || (len > RIO_MAX_MSG_SIZE)) { ++ ret = -EINVAL; ++ goto out; ++ } ++ ++ /* Copy and clear rest of buffer */ ++ memcpy(msg_tx_ring.virt_buffer[msg_tx_ring.tx_slot], buffer, len); ++ if (len < (RIO_MAX_MSG_SIZE - 4)) ++ memset((void *)((u32) msg_tx_ring. ++ virt_buffer[msg_tx_ring.tx_slot] + len), 0, ++ RIO_MAX_MSG_SIZE - len); ++ ++ /* Set mbox field for message */ ++ desc->dport = mbox & 0x3; ++ ++ /* Enable EOMI interrupt, set priority, and set destid */ ++ desc->dattr = 0x28000000 | (rdev->destid << 2); ++ ++ /* Set transfer size aligned to next power of 2 (in double words) */ ++ desc->dwcnt = is_power_of_2(len) ? len : 1 << get_bitmask_order(len); ++ ++ /* Set snooping and source buffer address */ ++ desc->saddr = 0x00000004 | msg_tx_ring.phys_buffer[msg_tx_ring.tx_slot]; ++ ++ /* Increment enqueue pointer */ ++ omr = in_be32((void *)&msg_regs->omr); ++ out_be32((void *)&msg_regs->omr, omr | RIO_MSG_OMR_MUI); ++ ++ /* Go to next descriptor */ ++ if (++msg_tx_ring.tx_slot == msg_tx_ring.size) ++ msg_tx_ring.tx_slot = 0; ++ ++ out: ++ return ret; ++} ++ ++EXPORT_SYMBOL_GPL(rio_hw_add_outb_message); ++ ++/** ++ * mpc85xx_rio_tx_handler - MPC85xx outbound message interrupt handler ++ * @irq: Linux interrupt number ++ * @dev_instance: Pointer to interrupt-specific data ++ * ++ * Handles outbound message interrupts. Executes a register outbound ++ * mailbox event handler and acks the interrupt occurrence. ++ */ ++static irqreturn_t ++mpc85xx_rio_tx_handler(int irq, void *dev_instance) ++{ ++ int osr; ++ struct rio_mport *port = (struct rio_mport *)dev_instance; ++ ++ osr = in_be32((void *)&msg_regs->osr); ++ ++ if (osr & RIO_MSG_OSR_TE) { ++ pr_info("RIO: outbound message transmission error\n"); ++ out_be32((void *)&msg_regs->osr, RIO_MSG_OSR_TE); ++ goto out; ++ } ++ ++ if (osr & RIO_MSG_OSR_QOI) { ++ pr_info("RIO: outbound message queue overflow\n"); ++ out_be32((void *)&msg_regs->osr, RIO_MSG_OSR_QOI); ++ goto out; ++ } ++ ++ if (osr & RIO_MSG_OSR_EOMI) { ++ u32 dqp = in_be32((void *)&msg_regs->odqdpar); ++ int slot = (dqp - msg_tx_ring.phys) >> 5; ++ port->outb_msg[0].mcback(port, msg_tx_ring.dev_id, -1, slot); ++ ++ /* Ack the end-of-message interrupt */ ++ out_be32((void *)&msg_regs->osr, RIO_MSG_OSR_EOMI); ++ } ++ ++ out: ++ return IRQ_HANDLED; ++} ++ ++/** ++ * rio_open_outb_mbox - Initialize MPC85xx outbound mailbox ++ * @mport: Master port implementing the outbound message unit ++ * @dev_id: Device specific pointer to pass on event ++ * @mbox: Mailbox to open ++ * @entries: Number of entries in the outbound mailbox ring ++ * ++ * Initializes buffer ring, request the outbound message interrupt, ++ * and enables the outbound message unit. Returns %0 on success and ++ * %-EINVAL or %-ENOMEM on failure. ++ */ ++int rio_open_outb_mbox(struct rio_mport *mport, void *dev_id, int mbox, int entries) ++{ ++ int i, j, rc = 0; ++ ++ if ((entries < RIO_MIN_TX_RING_SIZE) || ++ (entries > RIO_MAX_TX_RING_SIZE) || (!is_power_of_2(entries))) { ++ rc = -EINVAL; ++ goto out; ++ } ++ ++ /* Initialize shadow copy ring */ ++ msg_tx_ring.dev_id = dev_id; ++ msg_tx_ring.size = entries; ++ ++ for (i = 0; i < msg_tx_ring.size; i++) { ++ if (! ++ (msg_tx_ring.virt_buffer[i] = ++ dma_alloc_coherent(NULL, RIO_MSG_BUFFER_SIZE, ++ &msg_tx_ring.phys_buffer[i], ++ GFP_KERNEL))) { ++ rc = -ENOMEM; ++ for (j = 0; j < msg_tx_ring.size; j++) ++ if (msg_tx_ring.virt_buffer[j]) ++ dma_free_coherent(NULL, ++ RIO_MSG_BUFFER_SIZE, ++ msg_tx_ring. ++ virt_buffer[j], ++ msg_tx_ring. ++ phys_buffer[j]); ++ goto out; ++ } ++ } ++ ++ /* Initialize outbound message descriptor ring */ ++ if (!(msg_tx_ring.virt = dma_alloc_coherent(NULL, ++ msg_tx_ring.size * ++ RIO_MSG_DESC_SIZE, ++ &msg_tx_ring.phys, ++ GFP_KERNEL))) { ++ rc = -ENOMEM; ++ goto out_dma; ++ } ++ memset(msg_tx_ring.virt, 0, msg_tx_ring.size * RIO_MSG_DESC_SIZE); ++ msg_tx_ring.tx_slot = 0; ++ ++ /* Point dequeue/enqueue pointers at first entry in ring */ ++ out_be32((void *)&msg_regs->odqdpar, msg_tx_ring.phys); ++ out_be32((void *)&msg_regs->odqepar, msg_tx_ring.phys); ++ ++ /* Configure for snooping */ ++ out_be32((void *)&msg_regs->osar, 0x00000004); ++ ++ /* Clear interrupt status */ ++ out_be32((void *)&msg_regs->osr, 0x000000b3); ++ ++ /* Hook up outbound message handler */ ++ if ((rc = ++ request_irq(MPC85xx_IRQ_RIO_TX, mpc85xx_rio_tx_handler, 0, ++ "msg_tx", (void *)mport)) < 0) ++ goto out_irq; ++ ++ /* ++ * Configure outbound message unit ++ * Snooping ++ * Interrupts (all enabled, except QEIE) ++ * Chaining mode ++ * Disable ++ */ ++ out_be32((void *)&msg_regs->omr, 0x00100220); ++ ++ /* Set number of entries */ ++ out_be32((void *)&msg_regs->omr, ++ in_be32((void *)&msg_regs->omr) | ++ ((get_bitmask_order(entries) - 2) << 12)); ++ ++ /* Now enable the unit */ ++ out_be32((void *)&msg_regs->omr, in_be32((void *)&msg_regs->omr) | 0x1); ++ ++ out: ++ return rc; ++ ++ out_irq: ++ dma_free_coherent(NULL, msg_tx_ring.size * RIO_MSG_DESC_SIZE, ++ msg_tx_ring.virt, msg_tx_ring.phys); ++ ++ out_dma: ++ for (i = 0; i < msg_tx_ring.size; i++) ++ dma_free_coherent(NULL, RIO_MSG_BUFFER_SIZE, ++ msg_tx_ring.virt_buffer[i], ++ msg_tx_ring.phys_buffer[i]); ++ ++ return rc; ++} ++ ++/** ++ * rio_close_outb_mbox - Shut down MPC85xx outbound mailbox ++ * @mport: Master port implementing the outbound message unit ++ * @mbox: Mailbox to close ++ * ++ * Disables the outbound message unit, free all buffers, and ++ * frees the outbound message interrupt. ++ */ ++void rio_close_outb_mbox(struct rio_mport *mport, int mbox) ++{ ++ /* Disable inbound message unit */ ++ out_be32((void *)&msg_regs->omr, 0); ++ ++ /* Free ring */ ++ dma_free_coherent(NULL, msg_tx_ring.size * RIO_MSG_DESC_SIZE, ++ msg_tx_ring.virt, msg_tx_ring.phys); ++ ++ /* Free interrupt */ ++ free_irq(MPC85xx_IRQ_RIO_TX, (void *)mport); ++} ++ ++/** ++ * mpc85xx_rio_rx_handler - MPC85xx inbound message interrupt handler ++ * @irq: Linux interrupt number ++ * @dev_instance: Pointer to interrupt-specific data ++ * ++ * Handles inbound message interrupts. Executes a registered inbound ++ * mailbox event handler and acks the interrupt occurrence. ++ */ ++static irqreturn_t ++mpc85xx_rio_rx_handler(int irq, void *dev_instance) ++{ ++ int isr; ++ struct rio_mport *port = (struct rio_mport *)dev_instance; ++ ++ isr = in_be32((void *)&msg_regs->isr); ++ ++ if (isr & RIO_MSG_ISR_TE) { ++ pr_info("RIO: inbound message reception error\n"); ++ out_be32((void *)&msg_regs->isr, RIO_MSG_ISR_TE); ++ goto out; ++ } ++ ++ /* XXX Need to check/dispatch until queue empty */ ++ if (isr & RIO_MSG_ISR_DIQI) { ++ /* ++ * We implement *only* mailbox 0, but can receive messages ++ * for any mailbox/letter to that mailbox destination. So, ++ * make the callback with an unknown/invalid mailbox number ++ * argument. ++ */ ++ port->inb_msg[0].mcback(port, msg_rx_ring.dev_id, -1, -1); ++ ++ /* Ack the queueing interrupt */ ++ out_be32((void *)&msg_regs->isr, RIO_MSG_ISR_DIQI); ++ } ++ ++ out: ++ return IRQ_HANDLED; ++} ++ ++/** ++ * rio_open_inb_mbox - Initialize MPC85xx inbound mailbox ++ * @mport: Master port implementing the inbound message unit ++ * @dev_id: Device specific pointer to pass on event ++ * @mbox: Mailbox to open ++ * @entries: Number of entries in the inbound mailbox ring ++ * ++ * Initializes buffer ring, request the inbound message interrupt, ++ * and enables the inbound message unit. Returns %0 on success ++ * and %-EINVAL or %-ENOMEM on failure. ++ */ ++int rio_open_inb_mbox(struct rio_mport *mport, void *dev_id, int mbox, int entries) ++{ ++ int i, rc = 0; ++ ++ if ((entries < RIO_MIN_RX_RING_SIZE) || ++ (entries > RIO_MAX_RX_RING_SIZE) || (!is_power_of_2(entries))) { ++ rc = -EINVAL; ++ goto out; ++ } ++ ++ /* Initialize client buffer ring */ ++ msg_rx_ring.dev_id = dev_id; ++ msg_rx_ring.size = entries; ++ msg_rx_ring.rx_slot = 0; ++ for (i = 0; i < msg_rx_ring.size; i++) ++ msg_rx_ring.virt_buffer[i] = NULL; ++ ++ /* Initialize inbound message ring */ ++ if (!(msg_rx_ring.virt = dma_alloc_coherent(NULL, ++ msg_rx_ring.size * ++ RIO_MAX_MSG_SIZE, ++ &msg_rx_ring.phys, ++ GFP_KERNEL))) { ++ rc = -ENOMEM; ++ goto out; ++ } ++ ++ /* Point dequeue/enqueue pointers at first entry in ring */ ++ out_be32((void *)&msg_regs->ifqdpar, (u32) msg_rx_ring.phys); ++ out_be32((void *)&msg_regs->ifqepar, (u32) msg_rx_ring.phys); ++ ++ /* Clear interrupt status */ ++ out_be32((void *)&msg_regs->isr, 0x00000091); ++ ++ /* Hook up inbound message handler */ ++ if ((rc = ++ request_irq(MPC85xx_IRQ_RIO_RX, mpc85xx_rio_rx_handler, 0, ++ "msg_rx", (void *)mport)) < 0) { ++ dma_free_coherent(NULL, RIO_MSG_BUFFER_SIZE, ++ msg_tx_ring.virt_buffer[i], ++ msg_tx_ring.phys_buffer[i]); ++ goto out; ++ } ++ ++ /* ++ * Configure inbound message unit: ++ * Snooping ++ * 4KB max message size ++ * Unmask all interrupt sources ++ * Disable ++ */ ++ out_be32((void *)&msg_regs->imr, 0x001b0060); ++ ++ /* Set number of queue entries */ ++ out_be32((void *)&msg_regs->imr, ++ in_be32((void *)&msg_regs->imr) | ++ ((get_bitmask_order(entries) - 2) << 12)); ++ ++ /* Now enable the unit */ ++ out_be32((void *)&msg_regs->imr, in_be32((void *)&msg_regs->imr) | 0x1); ++ ++ out: ++ return rc; ++} ++ ++/** ++ * rio_close_inb_mbox - Shut down MPC85xx inbound mailbox ++ * @mport: Master port implementing the inbound message unit ++ * @mbox: Mailbox to close ++ * ++ * Disables the inbound message unit, free all buffers, and ++ * frees the inbound message interrupt. ++ */ ++void rio_close_inb_mbox(struct rio_mport *mport, int mbox) ++{ ++ /* Disable inbound message unit */ ++ out_be32((void *)&msg_regs->imr, 0); ++ ++ /* Free ring */ ++ dma_free_coherent(NULL, msg_rx_ring.size * RIO_MAX_MSG_SIZE, ++ msg_rx_ring.virt, msg_rx_ring.phys); ++ ++ /* Free interrupt */ ++ free_irq(MPC85xx_IRQ_RIO_RX, (void *)mport); ++} ++ ++/** ++ * rio_hw_add_inb_buffer - Add buffer to the MPC85xx inbound message queue ++ * @mport: Master port implementing the inbound message unit ++ * @mbox: Inbound mailbox number ++ * @buf: Buffer to add to inbound queue ++ * ++ * Adds the @buf buffer to the MPC85xx inbound message queue. Returns ++ * %0 on success or %-EINVAL on failure. ++ */ ++int rio_hw_add_inb_buffer(struct rio_mport *mport, int mbox, void *buf) ++{ ++ int rc = 0; ++ ++ pr_debug("RIO: rio_hw_add_inb_buffer(), msg_rx_ring.rx_slot %d\n", ++ msg_rx_ring.rx_slot); ++ ++ if (msg_rx_ring.virt_buffer[msg_rx_ring.rx_slot]) { ++ printk(KERN_ERR ++ "RIO: error adding inbound buffer %d, buffer exists\n", ++ msg_rx_ring.rx_slot); ++ rc = -EINVAL; ++ goto out; ++ } ++ ++ msg_rx_ring.virt_buffer[msg_rx_ring.rx_slot] = buf; ++ if (++msg_rx_ring.rx_slot == msg_rx_ring.size) ++ msg_rx_ring.rx_slot = 0; ++ ++ out: ++ return rc; ++} ++ ++EXPORT_SYMBOL_GPL(rio_hw_add_inb_buffer); ++ ++/** ++ * rio_hw_get_inb_message - Fetch inbound message from the MPC85xx message unit ++ * @mport: Master port implementing the inbound message unit ++ * @mbox: Inbound mailbox number ++ * ++ * Gets the next available inbound message from the inbound message queue. ++ * A pointer to the message is returned on success or NULL on failure. ++ */ ++void *rio_hw_get_inb_message(struct rio_mport *mport, int mbox) ++{ ++ u32 imr; ++ u32 phys_buf, virt_buf; ++ void *buf = NULL; ++ int buf_idx; ++ ++ phys_buf = in_be32((void *)&msg_regs->ifqdpar); ++ ++ /* If no more messages, then bail out */ ++ if (phys_buf == in_be32((void *)&msg_regs->ifqepar)) ++ goto out2; ++ ++ virt_buf = (u32) msg_rx_ring.virt + (phys_buf - msg_rx_ring.phys); ++ buf_idx = (phys_buf - msg_rx_ring.phys) / RIO_MAX_MSG_SIZE; ++ buf = msg_rx_ring.virt_buffer[buf_idx]; ++ ++ if (!buf) { ++ printk(KERN_ERR ++ "RIO: inbound message copy failed, no buffers\n"); ++ goto out1; ++ } ++ ++ /* Copy max message size, caller is expected to allocate that big */ ++ memcpy(buf, (void *)virt_buf, RIO_MAX_MSG_SIZE); ++ ++ /* Clear the available buffer */ ++ msg_rx_ring.virt_buffer[buf_idx] = NULL; ++ ++ out1: ++ imr = in_be32((void *)&msg_regs->imr); ++ out_be32((void *)&msg_regs->imr, imr | RIO_MSG_IMR_MI); ++ ++ out2: ++ return buf; ++} ++ ++EXPORT_SYMBOL_GPL(rio_hw_get_inb_message); ++ ++/** ++ * mpc85xx_rio_dbell_handler - MPC85xx doorbell interrupt handler ++ * @irq: Linux interrupt number ++ * @dev_instance: Pointer to interrupt-specific data ++ * ++ * Handles doorbell interrupts. Parses a list of registered ++ * doorbell event handlers and executes a matching event handler. ++ */ ++static irqreturn_t ++mpc85xx_rio_dbell_handler(int irq, void *dev_instance) ++{ ++ int dsr; ++ struct rio_mport *port = (struct rio_mport *)dev_instance; ++ ++ dsr = in_be32((void *)&msg_regs->dsr); ++ ++ if (dsr & DOORBELL_DSR_TE) { ++ pr_info("RIO: doorbell reception error\n"); ++ out_be32((void *)&msg_regs->dsr, DOORBELL_DSR_TE); ++ goto out; ++ } ++ ++ if (dsr & DOORBELL_DSR_QFI) { ++ pr_info("RIO: doorbell queue full\n"); ++ out_be32((void *)&msg_regs->dsr, DOORBELL_DSR_QFI); ++ goto out; ++ } ++ ++ /* XXX Need to check/dispatch until queue empty */ ++ if (dsr & DOORBELL_DSR_DIQI) { ++ u32 dmsg = ++ (u32) dbell_ring.virt + ++ (in_be32((void *)&msg_regs->dqdpar) & 0xfff); ++ u32 dmr; ++ struct rio_dbell *dbell; ++ int found = 0; ++ ++ pr_debug ++ ("RIO: processing doorbell, sid %2.2x tid %2.2x info %4.4x\n", ++ DBELL_SID(dmsg), DBELL_TID(dmsg), DBELL_INF(dmsg)); ++ ++ list_for_each_entry(dbell, &port->dbells, node) { ++ if ((dbell->res->start <= DBELL_INF(dmsg)) && ++ (dbell->res->end >= DBELL_INF(dmsg))) { ++ found = 1; ++ break; ++ } ++ } ++ if (found) { ++ dbell->dinb(port, dbell->dev_id, DBELL_SID(dmsg), DBELL_TID(dmsg), ++ DBELL_INF(dmsg)); ++ } else { ++ pr_debug ++ ("RIO: spurious doorbell, sid %2.2x tid %2.2x info %4.4x\n", ++ DBELL_SID(dmsg), DBELL_TID(dmsg), DBELL_INF(dmsg)); ++ } ++ dmr = in_be32((void *)&msg_regs->dmr); ++ out_be32((void *)&msg_regs->dmr, dmr | DOORBELL_DMR_DI); ++ out_be32((void *)&msg_regs->dsr, DOORBELL_DSR_DIQI); ++ } ++ ++ out: ++ return IRQ_HANDLED; ++} ++ ++/** ++ * mpc85xx_rio_doorbell_init - MPC85xx doorbell interface init ++ * @mport: Master port implementing the inbound doorbell unit ++ * ++ * Initializes doorbell unit hardware and inbound DMA buffer ++ * ring. Called from mpc85xx_rio_setup(). Returns %0 on success ++ * or %-ENOMEM on failure. ++ */ ++static int mpc85xx_rio_doorbell_init(struct rio_mport *mport) ++{ ++ int rc = 0; ++ ++ /* Map outbound doorbell window immediately after maintenance window */ ++ if (!(dbell_win = ++ (u32) ioremap(mport->iores.start + RIO_MAINT_WIN_SIZE, ++ RIO_DBELL_WIN_SIZE))) { ++ printk(KERN_ERR ++ "RIO: unable to map outbound doorbell window\n"); ++ rc = -ENOMEM; ++ goto out; ++ } ++ ++ /* Initialize inbound doorbells */ ++ if (!(dbell_ring.virt = dma_alloc_coherent(NULL, ++ 512 * DOORBELL_MESSAGE_SIZE, ++ &dbell_ring.phys, ++ GFP_KERNEL))) { ++ printk(KERN_ERR "RIO: unable allocate inbound doorbell ring\n"); ++ rc = -ENOMEM; ++ iounmap((void *)dbell_win); ++ goto out; ++ } ++ ++ /* Point dequeue/enqueue pointers at first entry in ring */ ++ out_be32((void *)&msg_regs->dqdpar, (u32) dbell_ring.phys); ++ out_be32((void *)&msg_regs->dqepar, (u32) dbell_ring.phys); ++ ++ /* Clear interrupt status */ ++ out_be32((void *)&msg_regs->dsr, 0x00000091); ++ ++ /* Hook up doorbell handler */ ++ if ((rc = ++ request_irq(MPC85xx_IRQ_RIO_BELL, mpc85xx_rio_dbell_handler, 0, ++ "dbell_rx", (void *)mport) < 0)) { ++ iounmap((void *)dbell_win); ++ dma_free_coherent(NULL, 512 * DOORBELL_MESSAGE_SIZE, ++ dbell_ring.virt, dbell_ring.phys); ++ printk(KERN_ERR ++ "MPC85xx RIO: unable to request inbound doorbell irq"); ++ goto out; ++ } ++ ++ /* Configure doorbells for snooping, 512 entries, and enable */ ++ out_be32((void *)&msg_regs->dmr, 0x00108161); ++ ++ out: ++ return rc; ++} ++ ++static char *cmdline = NULL; ++ ++static int mpc85xx_rio_get_hdid(int index) ++{ ++ /* XXX Need to parse multiple entries in some format */ ++ if (!cmdline) ++ return -1; ++ ++ return simple_strtol(cmdline, NULL, 0); ++} ++ ++static int mpc85xx_rio_get_cmdline(char *s) ++{ ++ if (!s) ++ return 0; ++ ++ cmdline = s; ++ return 1; ++} ++ ++__setup("riohdid=", mpc85xx_rio_get_cmdline); ++ ++/** ++ * mpc85xx_rio_setup - Setup MPC85xx RapidIO interface ++ * @law_start: Starting physical address of RapidIO LAW ++ * @law_size: Size of RapidIO LAW ++ * ++ * Initializes MPC85xx RapidIO hardware interface, configures ++ * master port with system-specific info, and registers the ++ * master port with the RapidIO subsystem. ++ */ ++void mpc85xx_rio_setup(int law_start, int law_size) ++{ ++ struct rio_ops *ops; ++ struct rio_mport *port; ++ ++ ops = kmalloc(sizeof(struct rio_ops), GFP_KERNEL); ++ ops->lcread = mpc85xx_local_config_read; ++ ops->lcwrite = mpc85xx_local_config_write; ++ ops->cread = mpc85xx_rio_config_read; ++ ops->cwrite = mpc85xx_rio_config_write; ++ ops->dsend = mpc85xx_rio_doorbell_send; ++ ++ port = kmalloc(sizeof(struct rio_mport), GFP_KERNEL); ++ port->id = 0; ++ port->index = 0; ++ INIT_LIST_HEAD(&port->dbells); ++ port->iores.start = law_start; ++ port->iores.end = law_start + law_size; ++ port->iores.flags = IORESOURCE_MEM; ++ ++ rio_init_dbell_res(&port->riores[RIO_DOORBELL_RESOURCE], 0, 0xffff); ++ rio_init_mbox_res(&port->riores[RIO_INB_MBOX_RESOURCE], 0, 0); ++ rio_init_mbox_res(&port->riores[RIO_OUTB_MBOX_RESOURCE], 0, 0); ++ strcpy(port->name, "RIO0 mport"); ++ ++ port->ops = ops; ++ port->host_deviceid = mpc85xx_rio_get_hdid(port->id); ++ ++ rio_register_mport(port); ++ ++ regs_win = (u32) ioremap(RIO_REGS_BASE, 0x20000); ++ atmu_regs = (struct rio_atmu_regs *)(regs_win + RIO_ATMU_REGS_OFFSET); ++ maint_atmu_regs = atmu_regs + 1; ++ dbell_atmu_regs = atmu_regs + 2; ++ msg_regs = (struct rio_msg_regs *)(regs_win + RIO_MSG_REGS_OFFSET); ++ ++ /* Configure maintenance transaction window */ ++ out_be32((void *)&maint_atmu_regs->rowbar, 0x000c0000); ++ out_be32((void *)&maint_atmu_regs->rowar, 0x80077015); ++ ++ maint_win = (u32) ioremap(law_start, RIO_MAINT_WIN_SIZE); ++ ++ /* Configure outbound doorbell window */ ++ out_be32((void *)&dbell_atmu_regs->rowbar, 0x000c0400); ++ out_be32((void *)&dbell_atmu_regs->rowar, 0x8004200b); ++ mpc85xx_rio_doorbell_init(port); ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/fsl_rio.h powerpc.git/arch/powerpc/sysdev/fsl_rio.h +--- linux-2.6.24/arch/powerpc/sysdev/fsl_rio.h 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/fsl_rio.h 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,20 @@ ++/* ++ * MPC85xx RapidIO definitions ++ * ++ * Copyright 2005 MontaVista Software, Inc. ++ * Matt Porter <mporter@kernel.crashing.org> ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++ ++#ifndef __PPC_SYSLIB_PPC85XX_RIO_H ++#define __PPC_SYSLIB_PPC85XX_RIO_H ++ ++#include <linux/init.h> ++ ++extern void mpc85xx_rio_setup(int law_start, int law_size); ++ ++#endif /* __PPC_SYSLIB_PPC85XX_RIO_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/fsl_soc.c powerpc.git/arch/powerpc/sysdev/fsl_soc.c +--- linux-2.6.24/arch/powerpc/sysdev/fsl_soc.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/fsl_soc.c 2008-01-28 20:25:49.000000000 +0100 +@@ -24,6 +24,7 @@ + #include <linux/platform_device.h> + #include <linux/of_platform.h> + #include <linux/phy.h> ++#include <linux/phy_fixed.h> + #include <linux/spi/spi.h> + #include <linux/fsl_devices.h> + #include <linux/fs_enet_pd.h> +@@ -54,10 +55,18 @@ + soc = of_find_node_by_type(NULL, "soc"); + if (soc) { + int size; +- const void *prop = of_get_property(soc, "reg", &size); ++ u32 naddr; ++ const u32 *prop = of_get_property(soc, "#address-cells", &size); + ++ if (prop && size == 4) ++ naddr = *prop; ++ else ++ naddr = 2; ++ ++ prop = of_get_property(soc, "ranges", &size); + if (prop) +- immrbase = of_translate_address(soc, prop); ++ immrbase = of_translate_address(soc, prop + naddr); ++ + of_node_put(soc); + } + +@@ -130,17 +139,51 @@ + EXPORT_SYMBOL(get_baudrate); + #endif /* CONFIG_CPM2 */ + +-static int __init gfar_mdio_of_init(void) ++#ifdef CONFIG_FIXED_PHY ++static int __init of_add_fixed_phys(void) + { ++ int ret; + struct device_node *np; +- unsigned int i; ++ u32 *fixed_link; ++ struct fixed_phy_status status = {}; ++ ++ for_each_node_by_name(np, "ethernet") { ++ fixed_link = (u32 *)of_get_property(np, "fixed-link", NULL); ++ if (!fixed_link) ++ continue; ++ ++ status.link = 1; ++ status.duplex = fixed_link[1]; ++ status.speed = fixed_link[2]; ++ status.pause = fixed_link[3]; ++ status.asym_pause = fixed_link[4]; ++ ++ ret = fixed_phy_add(PHY_POLL, fixed_link[0], &status); ++ if (ret) { ++ of_node_put(np); ++ return ret; ++ } ++ } ++ ++ return 0; ++} ++arch_initcall(of_add_fixed_phys); ++#endif /* CONFIG_FIXED_PHY */ ++ ++static int __init gfar_mdio_of_init(void) ++{ ++ struct device_node *np = NULL; + struct platform_device *mdio_dev; + struct resource res; + int ret; + +- for (np = NULL, i = 0; +- (np = of_find_compatible_node(np, "mdio", "gianfar")) != NULL; +- i++) { ++ np = of_find_compatible_node(np, NULL, "fsl,gianfar-mdio"); ++ ++ /* try the deprecated version */ ++ if (!np) ++ np = of_find_compatible_node(np, "mdio", "gianfar"); ++ ++ if (np) { + int k; + struct device_node *child = NULL; + struct gianfar_mdio_data mdio_data; +@@ -179,11 +222,13 @@ + goto unreg; + } + ++ of_node_put(np); + return 0; + + unreg: + platform_device_unregister(mdio_dev); + err: ++ of_node_put(np); + return ret; + } + +@@ -193,7 +238,6 @@ + static const char *gfar_rx_intr = "rx"; + static const char *gfar_err_intr = "error"; + +- + static int __init gfar_of_init(void) + { + struct device_node *np; +@@ -277,29 +321,43 @@ + gfar_data.interface = PHY_INTERFACE_MODE_MII; + + ph = of_get_property(np, "phy-handle", NULL); +- phy = of_find_node_by_phandle(*ph); ++ if (ph == NULL) { ++ u32 *fixed_link; + +- if (phy == NULL) { +- ret = -ENODEV; +- goto unreg; +- } ++ fixed_link = (u32 *)of_get_property(np, "fixed-link", ++ NULL); ++ if (!fixed_link) { ++ ret = -ENODEV; ++ goto unreg; ++ } + +- mdio = of_get_parent(phy); ++ gfar_data.bus_id = 0; ++ gfar_data.phy_id = fixed_link[0]; ++ } else { ++ phy = of_find_node_by_phandle(*ph); ++ ++ if (phy == NULL) { ++ ret = -ENODEV; ++ goto unreg; ++ } ++ ++ mdio = of_get_parent(phy); ++ ++ id = of_get_property(phy, "reg", NULL); ++ ret = of_address_to_resource(mdio, 0, &res); ++ if (ret) { ++ of_node_put(phy); ++ of_node_put(mdio); ++ goto unreg; ++ } ++ ++ gfar_data.phy_id = *id; ++ gfar_data.bus_id = res.start; + +- id = of_get_property(phy, "reg", NULL); +- ret = of_address_to_resource(mdio, 0, &res); +- if (ret) { + of_node_put(phy); + of_node_put(mdio); +- goto unreg; + } + +- gfar_data.phy_id = *id; +- gfar_data.bus_id = res.start; +- +- of_node_put(phy); +- of_node_put(mdio); +- + ret = + platform_device_add_data(gfar_dev, &gfar_data, + sizeof(struct +@@ -390,13 +448,11 @@ + static int __init fsl_i2c_of_init(void) + { + struct device_node *np; +- unsigned int i; ++ unsigned int i = 0; + struct platform_device *i2c_dev; + int ret; + +- for (np = NULL, i = 0; +- (np = of_find_compatible_node(np, "i2c", "fsl-i2c")) != NULL; +- i++) { ++ for_each_compatible_node(np, NULL, "fsl-i2c") { + struct resource r[2]; + struct fsl_i2c_platform_data i2c_data; + const unsigned char *flags = NULL; +@@ -432,7 +488,7 @@ + if (ret) + goto unreg; + +- of_register_i2c_devices(np, i); ++ of_register_i2c_devices(np, i++); + } + + return 0; +@@ -528,14 +584,12 @@ + static int __init fsl_usb_of_init(void) + { + struct device_node *np; +- unsigned int i; ++ unsigned int i = 0; + struct platform_device *usb_dev_mph = NULL, *usb_dev_dr_host = NULL, + *usb_dev_dr_client = NULL; + int ret; + +- for (np = NULL, i = 0; +- (np = of_find_compatible_node(np, "usb", "fsl-usb2-mph")) != NULL; +- i++) { ++ for_each_compatible_node(np, NULL, "fsl-usb2-mph") { + struct resource r[2]; + struct fsl_usb2_platform_data usb_data; + const unsigned char *prop = NULL; +@@ -578,11 +632,10 @@ + fsl_usb2_platform_data)); + if (ret) + goto unreg_mph; ++ i++; + } + +- for (np = NULL; +- (np = of_find_compatible_node(np, "usb", "fsl-usb2-dr")) != NULL; +- i++) { ++ for_each_compatible_node(np, NULL, "fsl-usb2-dr") { + struct resource r[2]; + struct fsl_usb2_platform_data usb_data; + const unsigned char *prop = NULL; +@@ -654,6 +707,7 @@ + fsl_usb2_platform_data)))) + goto unreg_dr; + } ++ i++; + } + return 0; + +@@ -1125,13 +1179,12 @@ + + static int __init fsl_pcmcia_of_init(void) + { +- struct device_node *np = NULL; ++ struct device_node *np; + /* + * Register all the devices which type is "pcmcia" + */ +- while ((np = of_find_compatible_node(np, +- "pcmcia", "fsl,pq-pcmcia")) != NULL) +- of_platform_device_create(np, "m8xx-pcmcia", NULL); ++ for_each_compatible_node(np, "pcmcia", "fsl,pq-pcmcia") ++ of_platform_device_create(np, "m8xx-pcmcia", NULL); + return 0; + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/grackle.c powerpc.git/arch/powerpc/sysdev/grackle.c +--- linux-2.6.24/arch/powerpc/sysdev/grackle.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/grackle.c 2008-01-28 20:25:49.000000000 +0100 +@@ -57,7 +57,7 @@ + { + setup_indirect_pci(hose, 0xfec00000, 0xfee00000, 0); + if (machine_is_compatible("PowerMac1,1")) +- pci_assign_all_buses = 1; ++ ppc_pci_flags |= PPC_PCI_REASSIGN_ALL_BUS; + if (machine_is_compatible("AAPL,PowerBook1998")) + grackle_set_loop_snoop(hose, 1); + #if 0 /* Disabled for now, HW problems ??? */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/ipic.c powerpc.git/arch/powerpc/sysdev/ipic.c +--- linux-2.6.24/arch/powerpc/sysdev/ipic.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/ipic.c 2008-01-28 20:25:49.000000000 +0100 +@@ -30,11 +30,67 @@ + #include "ipic.h" + + static struct ipic * primary_ipic; ++static struct irq_chip ipic_level_irq_chip, ipic_edge_irq_chip; + static DEFINE_SPINLOCK(ipic_lock); + + static struct ipic_info ipic_info[] = { ++ [1] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_C, ++ .force = IPIC_SIFCR_H, ++ .bit = 16, ++ .prio_mask = 0, ++ }, ++ [2] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_C, ++ .force = IPIC_SIFCR_H, ++ .bit = 17, ++ .prio_mask = 1, ++ }, ++ [3] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_C, ++ .force = IPIC_SIFCR_H, ++ .bit = 18, ++ .prio_mask = 2, ++ }, ++ [4] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_C, ++ .force = IPIC_SIFCR_H, ++ .bit = 19, ++ .prio_mask = 3, ++ }, ++ [5] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_C, ++ .force = IPIC_SIFCR_H, ++ .bit = 20, ++ .prio_mask = 4, ++ }, ++ [6] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_C, ++ .force = IPIC_SIFCR_H, ++ .bit = 21, ++ .prio_mask = 5, ++ }, ++ [7] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_C, ++ .force = IPIC_SIFCR_H, ++ .bit = 22, ++ .prio_mask = 6, ++ }, ++ [8] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_C, ++ .force = IPIC_SIFCR_H, ++ .bit = 23, ++ .prio_mask = 7, ++ }, + [9] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_D, + .force = IPIC_SIFCR_H, +@@ -42,7 +98,6 @@ + .prio_mask = 0, + }, + [10] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_D, + .force = IPIC_SIFCR_H, +@@ -50,15 +105,27 @@ + .prio_mask = 1, + }, + [11] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_D, + .force = IPIC_SIFCR_H, + .bit = 26, + .prio_mask = 2, + }, ++ [12] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_D, ++ .force = IPIC_SIFCR_H, ++ .bit = 27, ++ .prio_mask = 3, ++ }, ++ [13] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_D, ++ .force = IPIC_SIFCR_H, ++ .bit = 28, ++ .prio_mask = 4, ++ }, + [14] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_D, + .force = IPIC_SIFCR_H, +@@ -66,7 +133,6 @@ + .prio_mask = 5, + }, + [15] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_D, + .force = IPIC_SIFCR_H, +@@ -74,7 +140,6 @@ + .prio_mask = 6, + }, + [16] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_D, + .force = IPIC_SIFCR_H, +@@ -82,7 +147,7 @@ + .prio_mask = 7, + }, + [17] = { +- .pend = IPIC_SEPNR, ++ .ack = IPIC_SEPNR, + .mask = IPIC_SEMSR, + .prio = IPIC_SMPRR_A, + .force = IPIC_SEFCR, +@@ -90,7 +155,7 @@ + .prio_mask = 5, + }, + [18] = { +- .pend = IPIC_SEPNR, ++ .ack = IPIC_SEPNR, + .mask = IPIC_SEMSR, + .prio = IPIC_SMPRR_A, + .force = IPIC_SEFCR, +@@ -98,7 +163,7 @@ + .prio_mask = 6, + }, + [19] = { +- .pend = IPIC_SEPNR, ++ .ack = IPIC_SEPNR, + .mask = IPIC_SEMSR, + .prio = IPIC_SMPRR_A, + .force = IPIC_SEFCR, +@@ -106,7 +171,7 @@ + .prio_mask = 7, + }, + [20] = { +- .pend = IPIC_SEPNR, ++ .ack = IPIC_SEPNR, + .mask = IPIC_SEMSR, + .prio = IPIC_SMPRR_B, + .force = IPIC_SEFCR, +@@ -114,7 +179,7 @@ + .prio_mask = 4, + }, + [21] = { +- .pend = IPIC_SEPNR, ++ .ack = IPIC_SEPNR, + .mask = IPIC_SEMSR, + .prio = IPIC_SMPRR_B, + .force = IPIC_SEFCR, +@@ -122,7 +187,7 @@ + .prio_mask = 5, + }, + [22] = { +- .pend = IPIC_SEPNR, ++ .ack = IPIC_SEPNR, + .mask = IPIC_SEMSR, + .prio = IPIC_SMPRR_B, + .force = IPIC_SEFCR, +@@ -130,7 +195,7 @@ + .prio_mask = 6, + }, + [23] = { +- .pend = IPIC_SEPNR, ++ .ack = IPIC_SEPNR, + .mask = IPIC_SEMSR, + .prio = IPIC_SMPRR_B, + .force = IPIC_SEFCR, +@@ -138,7 +203,6 @@ + .prio_mask = 7, + }, + [32] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_A, + .force = IPIC_SIFCR_H, +@@ -146,7 +210,6 @@ + .prio_mask = 0, + }, + [33] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_A, + .force = IPIC_SIFCR_H, +@@ -154,7 +217,6 @@ + .prio_mask = 1, + }, + [34] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_A, + .force = IPIC_SIFCR_H, +@@ -162,7 +224,6 @@ + .prio_mask = 2, + }, + [35] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_A, + .force = IPIC_SIFCR_H, +@@ -170,7 +231,6 @@ + .prio_mask = 3, + }, + [36] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_A, + .force = IPIC_SIFCR_H, +@@ -178,7 +238,6 @@ + .prio_mask = 4, + }, + [37] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_A, + .force = IPIC_SIFCR_H, +@@ -186,7 +245,6 @@ + .prio_mask = 5, + }, + [38] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_A, + .force = IPIC_SIFCR_H, +@@ -194,15 +252,69 @@ + .prio_mask = 6, + }, + [39] = { +- .pend = IPIC_SIPNR_H, + .mask = IPIC_SIMSR_H, + .prio = IPIC_SIPRR_A, + .force = IPIC_SIFCR_H, + .bit = 7, + .prio_mask = 7, + }, ++ [40] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_B, ++ .force = IPIC_SIFCR_H, ++ .bit = 8, ++ .prio_mask = 0, ++ }, ++ [41] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_B, ++ .force = IPIC_SIFCR_H, ++ .bit = 9, ++ .prio_mask = 1, ++ }, ++ [42] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_B, ++ .force = IPIC_SIFCR_H, ++ .bit = 10, ++ .prio_mask = 2, ++ }, ++ [43] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_B, ++ .force = IPIC_SIFCR_H, ++ .bit = 11, ++ .prio_mask = 3, ++ }, ++ [44] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_B, ++ .force = IPIC_SIFCR_H, ++ .bit = 12, ++ .prio_mask = 4, ++ }, ++ [45] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_B, ++ .force = IPIC_SIFCR_H, ++ .bit = 13, ++ .prio_mask = 5, ++ }, ++ [46] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_B, ++ .force = IPIC_SIFCR_H, ++ .bit = 14, ++ .prio_mask = 6, ++ }, ++ [47] = { ++ .mask = IPIC_SIMSR_H, ++ .prio = IPIC_SIPRR_B, ++ .force = IPIC_SIFCR_H, ++ .bit = 15, ++ .prio_mask = 7, ++ }, + [48] = { +- .pend = IPIC_SEPNR, + .mask = IPIC_SEMSR, + .prio = IPIC_SMPRR_A, + .force = IPIC_SEFCR, +@@ -210,7 +322,6 @@ + .prio_mask = 4, + }, + [64] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = IPIC_SMPRR_A, + .force = IPIC_SIFCR_L, +@@ -218,7 +329,6 @@ + .prio_mask = 0, + }, + [65] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = IPIC_SMPRR_A, + .force = IPIC_SIFCR_L, +@@ -226,7 +336,6 @@ + .prio_mask = 1, + }, + [66] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = IPIC_SMPRR_A, + .force = IPIC_SIFCR_L, +@@ -234,7 +343,6 @@ + .prio_mask = 2, + }, + [67] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = IPIC_SMPRR_A, + .force = IPIC_SIFCR_L, +@@ -242,7 +350,6 @@ + .prio_mask = 3, + }, + [68] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = IPIC_SMPRR_B, + .force = IPIC_SIFCR_L, +@@ -250,7 +357,6 @@ + .prio_mask = 0, + }, + [69] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = IPIC_SMPRR_B, + .force = IPIC_SIFCR_L, +@@ -258,7 +364,6 @@ + .prio_mask = 1, + }, + [70] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = IPIC_SMPRR_B, + .force = IPIC_SIFCR_L, +@@ -266,7 +371,6 @@ + .prio_mask = 2, + }, + [71] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = IPIC_SMPRR_B, + .force = IPIC_SIFCR_L, +@@ -274,91 +378,120 @@ + .prio_mask = 3, + }, + [72] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = 0, + .force = IPIC_SIFCR_L, + .bit = 8, + }, + [73] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = 0, + .force = IPIC_SIFCR_L, + .bit = 9, + }, + [74] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = 0, + .force = IPIC_SIFCR_L, + .bit = 10, + }, + [75] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = 0, + .force = IPIC_SIFCR_L, + .bit = 11, + }, + [76] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = 0, + .force = IPIC_SIFCR_L, + .bit = 12, + }, + [77] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = 0, + .force = IPIC_SIFCR_L, + .bit = 13, + }, + [78] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = 0, + .force = IPIC_SIFCR_L, + .bit = 14, + }, + [79] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = 0, + .force = IPIC_SIFCR_L, + .bit = 15, + }, + [80] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = 0, + .force = IPIC_SIFCR_L, + .bit = 16, + }, ++ [81] = { ++ .mask = IPIC_SIMSR_L, ++ .prio = 0, ++ .force = IPIC_SIFCR_L, ++ .bit = 17, ++ }, ++ [82] = { ++ .mask = IPIC_SIMSR_L, ++ .prio = 0, ++ .force = IPIC_SIFCR_L, ++ .bit = 18, ++ }, ++ [83] = { ++ .mask = IPIC_SIMSR_L, ++ .prio = 0, ++ .force = IPIC_SIFCR_L, ++ .bit = 19, ++ }, + [84] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = 0, + .force = IPIC_SIFCR_L, + .bit = 20, + }, + [85] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = 0, + .force = IPIC_SIFCR_L, + .bit = 21, + }, ++ [86] = { ++ .mask = IPIC_SIMSR_L, ++ .prio = 0, ++ .force = IPIC_SIFCR_L, ++ .bit = 22, ++ }, ++ [87] = { ++ .mask = IPIC_SIMSR_L, ++ .prio = 0, ++ .force = IPIC_SIFCR_L, ++ .bit = 23, ++ }, ++ [88] = { ++ .mask = IPIC_SIMSR_L, ++ .prio = 0, ++ .force = IPIC_SIFCR_L, ++ .bit = 24, ++ }, ++ [89] = { ++ .mask = IPIC_SIMSR_L, ++ .prio = 0, ++ .force = IPIC_SIFCR_L, ++ .bit = 25, ++ }, + [90] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = 0, + .force = IPIC_SIFCR_L, + .bit = 26, + }, + [91] = { +- .pend = IPIC_SIPNR_L, + .mask = IPIC_SIMSR_L, + .prio = 0, + .force = IPIC_SIFCR_L, +@@ -412,6 +545,10 @@ + temp &= ~(1 << (31 - ipic_info[src].bit)); + ipic_write(ipic->regs, ipic_info[src].mask, temp); + ++ /* mb() can't guarantee that masking is finished. But it does finish ++ * for nearly all cases. */ ++ mb(); ++ + spin_unlock_irqrestore(&ipic_lock, flags); + } + +@@ -424,9 +561,13 @@ + + spin_lock_irqsave(&ipic_lock, flags); + +- temp = ipic_read(ipic->regs, ipic_info[src].pend); ++ temp = ipic_read(ipic->regs, ipic_info[src].ack); + temp |= (1 << (31 - ipic_info[src].bit)); +- ipic_write(ipic->regs, ipic_info[src].pend, temp); ++ ipic_write(ipic->regs, ipic_info[src].ack, temp); ++ ++ /* mb() can't guarantee that ack is finished. But it does finish ++ * for nearly all cases. */ ++ mb(); + + spin_unlock_irqrestore(&ipic_lock, flags); + } +@@ -444,9 +585,13 @@ + temp &= ~(1 << (31 - ipic_info[src].bit)); + ipic_write(ipic->regs, ipic_info[src].mask, temp); + +- temp = ipic_read(ipic->regs, ipic_info[src].pend); ++ temp = ipic_read(ipic->regs, ipic_info[src].ack); + temp |= (1 << (31 - ipic_info[src].bit)); +- ipic_write(ipic->regs, ipic_info[src].pend, temp); ++ ipic_write(ipic->regs, ipic_info[src].ack, temp); ++ ++ /* mb() can't guarantee that ack is finished. But it does finish ++ * for nearly all cases. */ ++ mb(); + + spin_unlock_irqrestore(&ipic_lock, flags); + } +@@ -468,14 +613,22 @@ + flow_type); + return -EINVAL; + } ++ /* ipic supports only edge mode on external interrupts */ ++ if ((flow_type & IRQ_TYPE_EDGE_FALLING) && !ipic_info[src].ack) { ++ printk(KERN_ERR "ipic: edge sense not supported on internal " ++ "interrupts\n"); ++ return -EINVAL; ++ } + + desc->status &= ~(IRQ_TYPE_SENSE_MASK | IRQ_LEVEL); + desc->status |= flow_type & IRQ_TYPE_SENSE_MASK; + if (flow_type & IRQ_TYPE_LEVEL_LOW) { + desc->status |= IRQ_LEVEL; + desc->handle_irq = handle_level_irq; ++ desc->chip = &ipic_level_irq_chip; + } else { + desc->handle_irq = handle_edge_irq; ++ desc->chip = &ipic_edge_irq_chip; + } + + /* only EXT IRQ senses are programmable on ipic +@@ -500,7 +653,16 @@ + return 0; + } + +-static struct irq_chip ipic_irq_chip = { ++/* level interrupts and edge interrupts have different ack operations */ ++static struct irq_chip ipic_level_irq_chip = { ++ .typename = " IPIC ", ++ .unmask = ipic_unmask_irq, ++ .mask = ipic_mask_irq, ++ .mask_ack = ipic_mask_irq, ++ .set_type = ipic_set_irq_type, ++}; ++ ++static struct irq_chip ipic_edge_irq_chip = { + .typename = " IPIC ", + .unmask = ipic_unmask_irq, + .mask = ipic_mask_irq, +@@ -519,13 +681,9 @@ + irq_hw_number_t hw) + { + struct ipic *ipic = h->host_data; +- struct irq_chip *chip; +- +- /* Default chip */ +- chip = &ipic->hc_irq; + + set_irq_chip_data(virq, ipic); +- set_irq_chip_and_handler(virq, chip, handle_level_irq); ++ set_irq_chip_and_handler(virq, &ipic_level_irq_chip, handle_level_irq); + + /* Set default irq type */ + set_irq_type(virq, IRQ_TYPE_NONE); +@@ -584,7 +742,6 @@ + ipic->regs = ioremap(res.start, res.end - res.start + 1); + + ipic->irqhost->host_data = ipic; +- ipic->hc_irq = ipic_irq_chip; + + /* init hw */ + ipic_write(ipic->regs, IPIC_SICNR, 0x0); +@@ -593,6 +750,10 @@ + * configure SICFR accordingly */ + if (flags & IPIC_SPREADMODE_GRP_A) + temp |= SICFR_IPSA; ++ if (flags & IPIC_SPREADMODE_GRP_B) ++ temp |= SICFR_IPSB; ++ if (flags & IPIC_SPREADMODE_GRP_C) ++ temp |= SICFR_IPSC; + if (flags & IPIC_SPREADMODE_GRP_D) + temp |= SICFR_IPSD; + if (flags & IPIC_SPREADMODE_MIX_A) +@@ -600,7 +761,7 @@ + if (flags & IPIC_SPREADMODE_MIX_B) + temp |= SICFR_MPSB; + +- ipic_write(ipic->regs, IPIC_SICNR, temp); ++ ipic_write(ipic->regs, IPIC_SICFR, temp); + + /* handle MCP route */ + temp = 0; +@@ -672,10 +833,12 @@ + + void ipic_set_default_priority(void) + { +- ipic_write(primary_ipic->regs, IPIC_SIPRR_A, IPIC_SIPRR_A_DEFAULT); +- ipic_write(primary_ipic->regs, IPIC_SIPRR_D, IPIC_SIPRR_D_DEFAULT); +- ipic_write(primary_ipic->regs, IPIC_SMPRR_A, IPIC_SMPRR_A_DEFAULT); +- ipic_write(primary_ipic->regs, IPIC_SMPRR_B, IPIC_SMPRR_B_DEFAULT); ++ ipic_write(primary_ipic->regs, IPIC_SIPRR_A, IPIC_PRIORITY_DEFAULT); ++ ipic_write(primary_ipic->regs, IPIC_SIPRR_B, IPIC_PRIORITY_DEFAULT); ++ ipic_write(primary_ipic->regs, IPIC_SIPRR_C, IPIC_PRIORITY_DEFAULT); ++ ipic_write(primary_ipic->regs, IPIC_SIPRR_D, IPIC_PRIORITY_DEFAULT); ++ ipic_write(primary_ipic->regs, IPIC_SMPRR_A, IPIC_PRIORITY_DEFAULT); ++ ipic_write(primary_ipic->regs, IPIC_SMPRR_B, IPIC_PRIORITY_DEFAULT); + } + + void ipic_enable_mcp(enum ipic_mcp_irq mcp_irq) +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/ipic.h powerpc.git/arch/powerpc/sysdev/ipic.h +--- linux-2.6.24/arch/powerpc/sysdev/ipic.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/ipic.h 2008-01-28 20:25:49.000000000 +0100 +@@ -23,13 +23,12 @@ + #define IPIC_IRQ_EXT7 23 + + /* Default Priority Registers */ +-#define IPIC_SIPRR_A_DEFAULT 0x05309770 +-#define IPIC_SIPRR_D_DEFAULT 0x05309770 +-#define IPIC_SMPRR_A_DEFAULT 0x05309770 +-#define IPIC_SMPRR_B_DEFAULT 0x05309770 ++#define IPIC_PRIORITY_DEFAULT 0x05309770 + + /* System Global Interrupt Configuration Register */ + #define SICFR_IPSA 0x00010000 ++#define SICFR_IPSB 0x00020000 ++#define SICFR_IPSC 0x00040000 + #define SICFR_IPSD 0x00080000 + #define SICFR_MPSA 0x00200000 + #define SICFR_MPSB 0x00400000 +@@ -45,13 +44,11 @@ + + /* The remapper for this IPIC */ + struct irq_host *irqhost; +- +- /* The "linux" controller struct */ +- struct irq_chip hc_irq; + }; + + struct ipic_info { +- u8 pend; /* pending register offset from base */ ++ u8 ack; /* pending register offset from base if the irq ++ supports ack operation */ + u8 mask; /* mask register offset from base */ + u8 prio; /* priority register offset from base */ + u8 force; /* force register offset from base */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/mmio_nvram.c powerpc.git/arch/powerpc/sysdev/mmio_nvram.c +--- linux-2.6.24/arch/powerpc/sysdev/mmio_nvram.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/mmio_nvram.c 2008-01-28 20:25:49.000000000 +0100 +@@ -99,7 +99,7 @@ + nvram_addr = r.start; + mmio_nvram_len = r.end - r.start + 1; + if ( (!mmio_nvram_len) || (!nvram_addr) ) { +- printk(KERN_WARNING "nvram: address or lenght is 0\n"); ++ printk(KERN_WARNING "nvram: address or length is 0\n"); + ret = -EIO; + goto out; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/mpic.c powerpc.git/arch/powerpc/sysdev/mpic.c +--- linux-2.6.24/arch/powerpc/sysdev/mpic.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/mpic.c 2008-01-28 20:25:49.000000000 +0100 +@@ -83,6 +83,7 @@ + MPIC_CPU_WHOAMI, + MPIC_CPU_INTACK, + MPIC_CPU_EOI, ++ MPIC_CPU_MCACK, + + MPIC_IRQ_BASE, + MPIC_IRQ_STRIDE, +@@ -121,6 +122,7 @@ + TSI108_CPU_WHOAMI, + TSI108_CPU_INTACK, + TSI108_CPU_EOI, ++ TSI108_CPU_MCACK, + + TSI108_IRQ_BASE, + TSI108_IRQ_STRIDE, +@@ -265,7 +267,7 @@ + */ + + +-static void _mpic_map_mmio(struct mpic *mpic, unsigned long phys_addr, ++static void _mpic_map_mmio(struct mpic *mpic, phys_addr_t phys_addr, + struct mpic_reg_bank *rb, unsigned int offset, + unsigned int size) + { +@@ -285,7 +287,7 @@ + BUG_ON(!DCR_MAP_OK(rb->dhost)); + } + +-static inline void mpic_map(struct mpic *mpic, unsigned long phys_addr, ++static inline void mpic_map(struct mpic *mpic, phys_addr_t phys_addr, + struct mpic_reg_bank *rb, unsigned int offset, + unsigned int size) + { +@@ -612,12 +614,11 @@ + } + + #ifdef CONFIG_SMP +-static irqreturn_t mpic_ipi_action(int irq, void *dev_id) ++static irqreturn_t mpic_ipi_action(int irq, void *data) + { +- struct mpic *mpic; ++ long ipi = (long)data; + +- mpic = mpic_find(irq, NULL); +- smp_message_recv(mpic_irq_to_hw(irq) - mpic->ipi_vecs[0]); ++ smp_message_recv(ipi); + + return IRQ_HANDLED; + } +@@ -842,6 +843,24 @@ + return 0; + } + ++void mpic_set_vector(unsigned int virq, unsigned int vector) ++{ ++ struct mpic *mpic = mpic_from_irq(virq); ++ unsigned int src = mpic_irq_to_hw(virq); ++ unsigned int vecpri; ++ ++ DBG("mpic: set_vector(mpic:@%p,virq:%d,src:%d,vector:0x%x)\n", ++ mpic, virq, src, vector); ++ ++ if (src >= mpic->irq_count) ++ return; ++ ++ vecpri = mpic_irq_read(src, MPIC_INFO(IRQ_VECTOR_PRI)); ++ vecpri = vecpri & ~MPIC_INFO(VECPRI_VECTOR_MASK); ++ vecpri |= vector; ++ mpic_irq_write(src, MPIC_INFO(IRQ_VECTOR_PRI), vecpri); ++} ++ + static struct irq_chip mpic_irq_chip = { + .mask = mpic_mask_irq, + .unmask = mpic_unmask_irq, +@@ -1109,6 +1128,11 @@ + mb(); + } + ++ if (flags & MPIC_ENABLE_MCK) ++ mpic_write(mpic->gregs, MPIC_INFO(GREG_GLOBAL_CONF_0), ++ mpic_read(mpic->gregs, MPIC_INFO(GREG_GLOBAL_CONF_0)) ++ | MPIC_GREG_GCONF_MCK); ++ + /* Read feature register, calculate num CPUs and, for non-ISU + * MPICs, num sources as well. On ISU MPICs, sources are counted + * as ISUs are added +@@ -1230,6 +1254,8 @@ + mpic_u3msi_init(mpic); + } + ++ mpic_pasemi_msi_init(mpic); ++ + for (i = 0; i < mpic->num_sources; i++) { + /* start with vector = source number, and masked */ + u32 vecpri = MPIC_VECPRI_MASK | i | +@@ -1253,6 +1279,11 @@ + mpic_read(mpic->gregs, MPIC_INFO(GREG_GLOBAL_CONF_0)) + | MPIC_GREG_GCONF_8259_PTHROU_DIS); + ++ if (mpic->flags & MPIC_NO_BIAS) ++ mpic_write(mpic->gregs, MPIC_INFO(GREG_GLOBAL_CONF_0), ++ mpic_read(mpic->gregs, MPIC_INFO(GREG_GLOBAL_CONF_0)) ++ | MPIC_GREG_GCONF_NO_BIAS); ++ + /* Set current processor priority to 0 */ + mpic_cpu_write(MPIC_INFO(CPU_CURRENT_TASK_PRI), 0); + +@@ -1419,13 +1450,13 @@ + mpic_physmask(cpu_mask & cpus_addr(cpu_online_map)[0])); + } + +-unsigned int mpic_get_one_irq(struct mpic *mpic) ++static unsigned int _mpic_get_one_irq(struct mpic *mpic, int reg) + { + u32 src; + +- src = mpic_cpu_read(MPIC_INFO(CPU_INTACK)) & MPIC_INFO(VECPRI_VECTOR_MASK); ++ src = mpic_cpu_read(reg) & MPIC_INFO(VECPRI_VECTOR_MASK); + #ifdef DEBUG_LOW +- DBG("%s: get_one_irq(): %d\n", mpic->name, src); ++ DBG("%s: get_one_irq(reg 0x%x): %d\n", mpic->name, reg, src); + #endif + if (unlikely(src == mpic->spurious_vec)) { + if (mpic->flags & MPIC_SPV_EOI) +@@ -1443,6 +1474,11 @@ + return irq_linear_revmap(mpic->irqhost, src); + } + ++unsigned int mpic_get_one_irq(struct mpic *mpic) ++{ ++ return _mpic_get_one_irq(mpic, MPIC_INFO(CPU_INTACK)); ++} ++ + unsigned int mpic_get_irq(void) + { + struct mpic *mpic = mpic_primary; +@@ -1452,12 +1488,20 @@ + return mpic_get_one_irq(mpic); + } + ++unsigned int mpic_get_mcirq(void) ++{ ++ struct mpic *mpic = mpic_primary; ++ ++ BUG_ON(mpic == NULL); ++ ++ return _mpic_get_one_irq(mpic, MPIC_INFO(CPU_MCACK)); ++} + + #ifdef CONFIG_SMP + void mpic_request_ipis(void) + { + struct mpic *mpic = mpic_primary; +- int i, err; ++ long i, err; + static char *ipi_names[] = { + "IPI0 (call function)", + "IPI1 (reschedule)", +@@ -1472,14 +1516,14 @@ + unsigned int vipi = irq_create_mapping(mpic->irqhost, + mpic->ipi_vecs[0] + i); + if (vipi == NO_IRQ) { +- printk(KERN_ERR "Failed to map IPI %d\n", i); ++ printk(KERN_ERR "Failed to map IPI %ld\n", i); + break; + } + err = request_irq(vipi, mpic_ipi_action, + IRQF_DISABLED|IRQF_PERCPU, +- ipi_names[i], mpic); ++ ipi_names[i], (void *)i); + if (err) { +- printk(KERN_ERR "Request of irq %d for IPI %d failed\n", ++ printk(KERN_ERR "Request of irq %d for IPI %ld failed\n", + vipi, i); + break; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/mpic.h powerpc.git/arch/powerpc/sysdev/mpic.h +--- linux-2.6.24/arch/powerpc/sysdev/mpic.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/mpic.h 2008-01-28 20:25:49.000000000 +0100 +@@ -17,6 +17,7 @@ + extern irq_hw_number_t mpic_msi_alloc_hwirqs(struct mpic *mpic, int num); + extern void mpic_msi_free_hwirqs(struct mpic *mpic, int offset, int num); + extern int mpic_u3msi_init(struct mpic *mpic); ++extern int mpic_pasemi_msi_init(struct mpic *mpic); + #else + static inline void mpic_msi_reserve_hwirq(struct mpic *mpic, + irq_hw_number_t hwirq) +@@ -28,12 +29,15 @@ + { + return -1; + } ++ ++static inline int mpic_pasemi_msi_init(struct mpic *mpic) ++{ ++ return -1; ++} + #endif + + extern int mpic_set_irq_type(unsigned int virq, unsigned int flow_type); +-extern void mpic_end_irq(unsigned int irq); +-extern void mpic_mask_irq(unsigned int irq); +-extern void mpic_unmask_irq(unsigned int irq); ++extern void mpic_set_vector(unsigned int virq, unsigned int vector); + extern void mpic_set_affinity(unsigned int irq, cpumask_t cpumask); + + #endif /* _POWERPC_SYSDEV_MPIC_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/mpic_pasemi_msi.c powerpc.git/arch/powerpc/sysdev/mpic_pasemi_msi.c +--- linux-2.6.24/arch/powerpc/sysdev/mpic_pasemi_msi.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/mpic_pasemi_msi.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,172 @@ ++/* ++ * Copyright 2007, Olof Johansson, PA Semi ++ * ++ * Based on arch/powerpc/sysdev/mpic_u3msi.c: ++ * ++ * Copyright 2006, Segher Boessenkool, IBM Corporation. ++ * Copyright 2006-2007, Michael Ellerman, IBM Corporation. ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License ++ * as published by the Free Software Foundation; version 2 of the ++ * License. ++ * ++ */ ++ ++#undef DEBUG ++ ++#include <linux/irq.h> ++#include <linux/bootmem.h> ++#include <linux/msi.h> ++#include <asm/mpic.h> ++#include <asm/prom.h> ++#include <asm/hw_irq.h> ++#include <asm/ppc-pci.h> ++ ++#include "mpic.h" ++ ++/* Allocate 16 interrupts per device, to give an alignment of 16, ++ * since that's the size of the grouping w.r.t. affinity. If someone ++ * needs more than 32 MSI's down the road we'll have to rethink this, ++ * but it should be OK for now. ++ */ ++#define ALLOC_CHUNK 16 ++ ++#define PASEMI_MSI_ADDR 0xfc080000 ++ ++/* A bit ugly, can we get this from the pci_dev somehow? */ ++static struct mpic *msi_mpic; ++ ++ ++static void mpic_pasemi_msi_mask_irq(unsigned int irq) ++{ ++ pr_debug("mpic_pasemi_msi_mask_irq %d\n", irq); ++ mask_msi_irq(irq); ++ mpic_mask_irq(irq); ++} ++ ++static void mpic_pasemi_msi_unmask_irq(unsigned int irq) ++{ ++ pr_debug("mpic_pasemi_msi_unmask_irq %d\n", irq); ++ mpic_unmask_irq(irq); ++ unmask_msi_irq(irq); ++} ++ ++static struct irq_chip mpic_pasemi_msi_chip = { ++ .shutdown = mpic_pasemi_msi_mask_irq, ++ .mask = mpic_pasemi_msi_mask_irq, ++ .unmask = mpic_pasemi_msi_unmask_irq, ++ .eoi = mpic_end_irq, ++ .set_type = mpic_set_irq_type, ++ .set_affinity = mpic_set_affinity, ++ .typename = "PASEMI-MSI ", ++}; ++ ++static int pasemi_msi_check_device(struct pci_dev *pdev, int nvec, int type) ++{ ++ if (type == PCI_CAP_ID_MSIX) ++ pr_debug("pasemi_msi: MSI-X untested, trying anyway\n"); ++ ++ return 0; ++} ++ ++static void pasemi_msi_teardown_msi_irqs(struct pci_dev *pdev) ++{ ++ struct msi_desc *entry; ++ ++ pr_debug("pasemi_msi_teardown_msi_irqs, pdev %p\n", pdev); ++ ++ list_for_each_entry(entry, &pdev->msi_list, list) { ++ if (entry->irq == NO_IRQ) ++ continue; ++ ++ set_irq_msi(entry->irq, NULL); ++ mpic_msi_free_hwirqs(msi_mpic, virq_to_hw(entry->irq), ++ ALLOC_CHUNK); ++ irq_dispose_mapping(entry->irq); ++ } ++ ++ return; ++} ++ ++static int pasemi_msi_setup_msi_irqs(struct pci_dev *pdev, int nvec, int type) ++{ ++ irq_hw_number_t hwirq; ++ unsigned int virq; ++ struct msi_desc *entry; ++ struct msi_msg msg; ++ u64 addr; ++ ++ pr_debug("pasemi_msi_setup_msi_irqs, pdev %p nvec %d type %d\n", ++ pdev, nvec, type); ++ ++ msg.address_hi = 0; ++ msg.address_lo = PASEMI_MSI_ADDR; ++ ++ list_for_each_entry(entry, &pdev->msi_list, list) { ++ /* Allocate 16 interrupts for now, since that's the grouping for ++ * affinity. This can be changed later if it turns out 32 is too ++ * few MSIs for someone, but restrictions will apply to how the ++ * sources can be changed independently. ++ */ ++ hwirq = mpic_msi_alloc_hwirqs(msi_mpic, ALLOC_CHUNK); ++ if (hwirq < 0) { ++ pr_debug("pasemi_msi: failed allocating hwirq\n"); ++ return hwirq; ++ } ++ ++ virq = irq_create_mapping(msi_mpic->irqhost, hwirq); ++ if (virq == NO_IRQ) { ++ pr_debug("pasemi_msi: failed mapping hwirq 0x%lx\n", hwirq); ++ mpic_msi_free_hwirqs(msi_mpic, hwirq, ALLOC_CHUNK); ++ return -ENOSPC; ++ } ++ ++ /* Vector on MSI is really an offset, the hardware adds ++ * it to the value written at the magic address. So set ++ * it to 0 to remain sane. ++ */ ++ mpic_set_vector(virq, 0); ++ ++ set_irq_msi(virq, entry); ++ set_irq_chip(virq, &mpic_pasemi_msi_chip); ++ set_irq_type(virq, IRQ_TYPE_EDGE_RISING); ++ ++ pr_debug("pasemi_msi: allocated virq 0x%x (hw 0x%lx) addr 0x%lx\n", ++ virq, hwirq, addr); ++ ++ /* Likewise, the device writes [0...511] into the target ++ * register to generate MSI [512...1023] ++ */ ++ msg.data = hwirq-0x200; ++ write_msi_msg(virq, &msg); ++ } ++ ++ return 0; ++} ++ ++int mpic_pasemi_msi_init(struct mpic *mpic) ++{ ++ int rc; ++ ++ if (!mpic->irqhost->of_node || ++ !of_device_is_compatible(mpic->irqhost->of_node, ++ "pasemi,pwrficient-openpic")) ++ return -ENODEV; ++ ++ rc = mpic_msi_init_allocator(mpic); ++ if (rc) { ++ pr_debug("pasemi_msi: Error allocating bitmap!\n"); ++ return rc; ++ } ++ ++ pr_debug("pasemi_msi: Registering PA Semi MPIC MSI callbacks\n"); ++ ++ msi_mpic = mpic; ++ WARN_ON(ppc_md.setup_msi_irqs); ++ ppc_md.setup_msi_irqs = pasemi_msi_setup_msi_irqs; ++ ppc_md.teardown_msi_irqs = pasemi_msi_teardown_msi_irqs; ++ ppc_md.msi_check_device = pasemi_msi_check_device; ++ ++ return 0; ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/mv64x60_dev.c powerpc.git/arch/powerpc/sysdev/mv64x60_dev.c +--- linux-2.6.24/arch/powerpc/sysdev/mv64x60_dev.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/mv64x60_dev.c 2008-01-28 20:25:49.000000000 +0100 +@@ -241,7 +241,7 @@ + + /* only register the shared platform device the first time through */ + if (id == 0 && (err = eth_register_shared_pdev(np))) +- return err;; ++ return err; + + memset(r, 0, sizeof(r)); + of_irq_to_resource(np, 0, &r[0]); +@@ -451,22 +451,19 @@ + int id; + int err; + +- for (id = 0; +- (np = of_find_compatible_node(np, "serial", "marvell,mpsc")); id++) +- if ((err = mv64x60_mpsc_device_setup(np, id))) ++ id = 0; ++ for_each_compatible_node(np, "serial", "marvell,mpsc") ++ if ((err = mv64x60_mpsc_device_setup(np, id++))) + goto error; + +- for (id = 0; +- (np = of_find_compatible_node(np, "network", +- "marvell,mv64x60-eth")); +- id++) +- if ((err = mv64x60_eth_device_setup(np, id))) ++ id = 0; ++ for_each_compatible_node(np, "network", "marvell,mv64x60-eth") ++ if ((err = mv64x60_eth_device_setup(np, id++))) + goto error; + +- for (id = 0; +- (np = of_find_compatible_node(np, "i2c", "marvell,mv64x60-i2c")); +- id++) +- if ((err = mv64x60_i2c_device_setup(np, id))) ++ id = 0; ++ for_each_compatible_node(np, "i2c", "marvell,mv64x60-i2c") ++ if ((err = mv64x60_i2c_device_setup(np, id++))) + goto error; + + /* support up to one watchdog timer */ +@@ -477,7 +474,6 @@ + of_node_put(np); + } + +- + return 0; + + error: +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/mv64x60_pci.c powerpc.git/arch/powerpc/sysdev/mv64x60_pci.c +--- linux-2.6.24/arch/powerpc/sysdev/mv64x60_pci.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/mv64x60_pci.c 2008-01-28 20:25:49.000000000 +0100 +@@ -164,8 +164,8 @@ + + void __init mv64x60_pci_init(void) + { +- struct device_node *np = NULL; ++ struct device_node *np; + +- while ((np = of_find_compatible_node(np, "pci", "marvell,mv64x60-pci"))) ++ for_each_compatible_node(np, "pci", "marvell,mv64x60-pci") + mv64x60_add_bridge(np); + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/mv64x60_udbg.c powerpc.git/arch/powerpc/sysdev/mv64x60_udbg.c +--- linux-2.6.24/arch/powerpc/sysdev/mv64x60_udbg.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/mv64x60_udbg.c 2008-01-28 20:25:49.000000000 +0100 +@@ -85,10 +85,10 @@ + if (!stdout) + return; + +- for (np = NULL; +- (np = of_find_compatible_node(np, "serial", "marvell,mpsc")); ) ++ for_each_compatible_node(np, "serial", "marvell,mpsc") { + if (np == stdout) + break; ++ } + + of_node_put(stdout); + if (!np) +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/of_rtc.c powerpc.git/arch/powerpc/sysdev/of_rtc.c +--- linux-2.6.24/arch/powerpc/sysdev/of_rtc.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/of_rtc.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,59 @@ ++/* ++ * Instantiate mmio-mapped RTC chips based on device tree information ++ * ++ * Copyright 2007 David Gibson <dwg@au1.ibm.com>, IBM Corporation. ++ * ++ * This program is free software; you can redistribute it and/or modify it ++ * under the terms of the GNU General Public License as published by the ++ * Free Software Foundation; either version 2 of the License, or (at your ++ * option) any later version. ++ */ ++#include <linux/kernel.h> ++#include <linux/of.h> ++#include <linux/init.h> ++#include <linux/of_platform.h> ++ ++static __initdata struct { ++ const char *compatible; ++ char *plat_name; ++} of_rtc_table[] = { ++ { "ds1743-nvram", "rtc-ds1742" }, ++}; ++ ++void __init of_instantiate_rtc(void) ++{ ++ struct device_node *node; ++ int err; ++ int i; ++ ++ for (i = 0; i < ARRAY_SIZE(of_rtc_table); i++) { ++ char *plat_name = of_rtc_table[i].plat_name; ++ ++ for_each_compatible_node(node, NULL, ++ of_rtc_table[i].compatible) { ++ struct resource *res; ++ ++ res = kmalloc(sizeof(*res), GFP_KERNEL); ++ if (!res) { ++ printk(KERN_ERR "OF RTC: Out of memory " ++ "allocating resource structure for %s\n", ++ node->full_name); ++ continue; ++ } ++ ++ err = of_address_to_resource(node, 0, res); ++ if (err) { ++ printk(KERN_ERR "OF RTC: Error " ++ "translating resources for %s\n", ++ node->full_name); ++ continue; ++ } ++ ++ printk(KERN_INFO "OF_RTC: %s is a %s @ 0x%llx-0x%llx\n", ++ node->full_name, plat_name, ++ (unsigned long long)res->start, ++ (unsigned long long)res->end); ++ platform_device_register_simple(plat_name, -1, res, 1); ++ } ++ } ++} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/pmi.c powerpc.git/arch/powerpc/sysdev/pmi.c +--- linux-2.6.24/arch/powerpc/sysdev/pmi.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/pmi.c 2008-01-28 20:25:49.000000000 +0100 +@@ -28,9 +28,9 @@ + #include <linux/completion.h> + #include <linux/spinlock.h> + #include <linux/workqueue.h> ++#include <linux/of_device.h> ++#include <linux/of_platform.h> + +-#include <asm/of_device.h> +-#include <asm/of_platform.h> + #include <asm/io.h> + #include <asm/pmi.h> + #include <asm/prom.h> +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/ppc4xx_pci.c powerpc.git/arch/powerpc/sysdev/ppc4xx_pci.c +--- linux-2.6.24/arch/powerpc/sysdev/ppc4xx_pci.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/ppc4xx_pci.c 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,1528 @@ ++/* ++ * PCI / PCI-X / PCI-Express support for 4xx parts ++ * ++ * Copyright 2007 Ben. Herrenschmidt <benh@kernel.crashing.org>, IBM Corp. ++ * ++ * Most PCI Express code is coming from Stefan Roese implementation for ++ * arch/ppc in the Denx tree, slightly reworked by me. ++ * ++ * Copyright 2007 DENX Software Engineering, Stefan Roese <sr@denx.de> ++ * ++ * Some of that comes itself from a previous implementation for 440SPE only ++ * by Roland Dreier: ++ * ++ * Copyright (c) 2005 Cisco Systems. All rights reserved. ++ * Roland Dreier <rolandd@cisco.com> ++ * ++ */ ++ ++#undef DEBUG ++ ++#include <linux/kernel.h> ++#include <linux/pci.h> ++#include <linux/init.h> ++#include <linux/of.h> ++#include <linux/bootmem.h> ++#include <linux/delay.h> ++ ++#include <asm/io.h> ++#include <asm/pci-bridge.h> ++#include <asm/machdep.h> ++#include <asm/dcr.h> ++#include <asm/dcr-regs.h> ++ ++#include "ppc4xx_pci.h" ++ ++static int dma_offset_set; ++ ++/* Move that to a useable header */ ++extern unsigned long total_memory; ++ ++#define U64_TO_U32_LOW(val) ((u32)((val) & 0x00000000ffffffffULL)) ++#define U64_TO_U32_HIGH(val) ((u32)((val) >> 32)) ++ ++#ifdef CONFIG_RESOURCES_64BIT ++#define RES_TO_U32_LOW(val) U64_TO_U32_LOW(val) ++#define RES_TO_U32_HIGH(val) U64_TO_U32_HIGH(val) ++#else ++#define RES_TO_U32_LOW(val) (val) ++#define RES_TO_U32_HIGH(val) (0) ++#endif ++ ++static inline int ppc440spe_revA(void) ++{ ++ /* Catch both 440SPe variants, with and without RAID6 support */ ++ if ((mfspr(SPRN_PVR) & 0xffefffff) == 0x53421890) ++ return 1; ++ else ++ return 0; ++} ++ ++static void fixup_ppc4xx_pci_bridge(struct pci_dev *dev) ++{ ++ struct pci_controller *hose; ++ int i; ++ ++ if (dev->devfn != 0 || dev->bus->self != NULL) ++ return; ++ ++ hose = pci_bus_to_host(dev->bus); ++ if (hose == NULL) ++ return; ++ ++ if (!of_device_is_compatible(hose->dn, "ibm,plb-pciex") && ++ !of_device_is_compatible(hose->dn, "ibm,plb-pcix") && ++ !of_device_is_compatible(hose->dn, "ibm,plb-pci")) ++ return; ++ ++ /* Hide the PCI host BARs from the kernel as their content doesn't ++ * fit well in the resource management ++ */ ++ for (i = 0; i < DEVICE_COUNT_RESOURCE; i++) { ++ dev->resource[i].start = dev->resource[i].end = 0; ++ dev->resource[i].flags = 0; ++ } ++ ++ printk(KERN_INFO "PCI: Hiding 4xx host bridge resources %s\n", ++ pci_name(dev)); ++} ++DECLARE_PCI_FIXUP_HEADER(PCI_ANY_ID, PCI_ANY_ID, fixup_ppc4xx_pci_bridge); ++ ++static int __init ppc4xx_parse_dma_ranges(struct pci_controller *hose, ++ void __iomem *reg, ++ struct resource *res) ++{ ++ u64 size; ++ const u32 *ranges; ++ int rlen; ++ int pna = of_n_addr_cells(hose->dn); ++ int np = pna + 5; ++ ++ /* Default */ ++ res->start = 0; ++ res->end = size = 0x80000000; ++ res->flags = IORESOURCE_MEM | IORESOURCE_PREFETCH; ++ ++ /* Get dma-ranges property */ ++ ranges = of_get_property(hose->dn, "dma-ranges", &rlen); ++ if (ranges == NULL) ++ goto out; ++ ++ /* Walk it */ ++ while ((rlen -= np * 4) >= 0) { ++ u32 pci_space = ranges[0]; ++ u64 pci_addr = of_read_number(ranges + 1, 2); ++ u64 cpu_addr = of_translate_dma_address(hose->dn, ranges + 3); ++ size = of_read_number(ranges + pna + 3, 2); ++ ranges += np; ++ if (cpu_addr == OF_BAD_ADDR || size == 0) ++ continue; ++ ++ /* We only care about memory */ ++ if ((pci_space & 0x03000000) != 0x02000000) ++ continue; ++ ++ /* We currently only support memory at 0, and pci_addr ++ * within 32 bits space ++ */ ++ if (cpu_addr != 0 || pci_addr > 0xffffffff) { ++ printk(KERN_WARNING "%s: Ignored unsupported dma range" ++ " 0x%016llx...0x%016llx -> 0x%016llx\n", ++ hose->dn->full_name, ++ pci_addr, pci_addr + size - 1, cpu_addr); ++ continue; ++ } ++ ++ /* Check if not prefetchable */ ++ if (!(pci_space & 0x40000000)) ++ res->flags &= ~IORESOURCE_PREFETCH; ++ ++ ++ /* Use that */ ++ res->start = pci_addr; ++#ifndef CONFIG_RESOURCES_64BIT ++ /* Beware of 32 bits resources */ ++ if ((pci_addr + size) > 0x100000000ull) ++ res->end = 0xffffffff; ++ else ++#endif ++ res->end = res->start + size - 1; ++ break; ++ } ++ ++ /* We only support one global DMA offset */ ++ if (dma_offset_set && pci_dram_offset != res->start) { ++ printk(KERN_ERR "%s: dma-ranges(s) mismatch\n", ++ hose->dn->full_name); ++ return -ENXIO; ++ } ++ ++ /* Check that we can fit all of memory as we don't support ++ * DMA bounce buffers ++ */ ++ if (size < total_memory) { ++ printk(KERN_ERR "%s: dma-ranges too small " ++ "(size=%llx total_memory=%lx)\n", ++ hose->dn->full_name, size, total_memory); ++ return -ENXIO; ++ } ++ ++ /* Check we are a power of 2 size and that base is a multiple of size*/ ++ if (!is_power_of_2(size) || ++ (res->start & (size - 1)) != 0) { ++ printk(KERN_ERR "%s: dma-ranges unaligned\n", ++ hose->dn->full_name); ++ return -ENXIO; ++ } ++ ++ /* Check that we are fully contained within 32 bits space */ ++ if (res->end > 0xffffffff) { ++ printk(KERN_ERR "%s: dma-ranges outside of 32 bits space\n", ++ hose->dn->full_name); ++ return -ENXIO; ++ } ++ out: ++ dma_offset_set = 1; ++ pci_dram_offset = res->start; ++ ++ printk(KERN_INFO "4xx PCI DMA offset set to 0x%08lx\n", ++ pci_dram_offset); ++ return 0; ++} ++ ++/* ++ * 4xx PCI 2.x part ++ */ ++ ++static void __init ppc4xx_configure_pci_PMMs(struct pci_controller *hose, ++ void __iomem *reg) ++{ ++ u32 la, ma, pcila, pciha; ++ int i, j; ++ ++ /* Setup outbound memory windows */ ++ for (i = j = 0; i < 3; i++) { ++ struct resource *res = &hose->mem_resources[i]; ++ ++ /* we only care about memory windows */ ++ if (!(res->flags & IORESOURCE_MEM)) ++ continue; ++ if (j > 2) { ++ printk(KERN_WARNING "%s: Too many ranges\n", ++ hose->dn->full_name); ++ break; ++ } ++ ++ /* Calculate register values */ ++ la = res->start; ++ pciha = RES_TO_U32_HIGH(res->start - hose->pci_mem_offset); ++ pcila = RES_TO_U32_LOW(res->start - hose->pci_mem_offset); ++ ++ ma = res->end + 1 - res->start; ++ if (!is_power_of_2(ma) || ma < 0x1000 || ma > 0xffffffffu) { ++ printk(KERN_WARNING "%s: Resource out of range\n", ++ hose->dn->full_name); ++ continue; ++ } ++ ma = (0xffffffffu << ilog2(ma)) | 0x1; ++ if (res->flags & IORESOURCE_PREFETCH) ++ ma |= 0x2; ++ ++ /* Program register values */ ++ writel(la, reg + PCIL0_PMM0LA + (0x10 * j)); ++ writel(pcila, reg + PCIL0_PMM0PCILA + (0x10 * j)); ++ writel(pciha, reg + PCIL0_PMM0PCIHA + (0x10 * j)); ++ writel(ma, reg + PCIL0_PMM0MA + (0x10 * j)); ++ j++; ++ } ++} ++ ++static void __init ppc4xx_configure_pci_PTMs(struct pci_controller *hose, ++ void __iomem *reg, ++ const struct resource *res) ++{ ++ resource_size_t size = res->end - res->start + 1; ++ u32 sa; ++ ++ /* Calculate window size */ ++ sa = (0xffffffffu << ilog2(size)) | 1; ++ sa |= 0x1; ++ ++ /* RAM is always at 0 local for now */ ++ writel(0, reg + PCIL0_PTM1LA); ++ writel(sa, reg + PCIL0_PTM1MS); ++ ++ /* Map on PCI side */ ++ early_write_config_dword(hose, hose->first_busno, 0, ++ PCI_BASE_ADDRESS_1, res->start); ++ early_write_config_dword(hose, hose->first_busno, 0, ++ PCI_BASE_ADDRESS_2, 0x00000000); ++ early_write_config_word(hose, hose->first_busno, 0, ++ PCI_COMMAND, 0x0006); ++} ++ ++static void __init ppc4xx_probe_pci_bridge(struct device_node *np) ++{ ++ /* NYI */ ++ struct resource rsrc_cfg; ++ struct resource rsrc_reg; ++ struct resource dma_window; ++ struct pci_controller *hose = NULL; ++ void __iomem *reg = NULL; ++ const int *bus_range; ++ int primary = 0; ++ ++ /* Fetch config space registers address */ ++ if (of_address_to_resource(np, 0, &rsrc_cfg)) { ++ printk(KERN_ERR "%s:Can't get PCI config register base !", ++ np->full_name); ++ return; ++ } ++ /* Fetch host bridge internal registers address */ ++ if (of_address_to_resource(np, 3, &rsrc_reg)) { ++ printk(KERN_ERR "%s: Can't get PCI internal register base !", ++ np->full_name); ++ return; ++ } ++ ++ /* Check if primary bridge */ ++ if (of_get_property(np, "primary", NULL)) ++ primary = 1; ++ ++ /* Get bus range if any */ ++ bus_range = of_get_property(np, "bus-range", NULL); ++ ++ /* Map registers */ ++ reg = ioremap(rsrc_reg.start, rsrc_reg.end + 1 - rsrc_reg.start); ++ if (reg == NULL) { ++ printk(KERN_ERR "%s: Can't map registers !", np->full_name); ++ goto fail; ++ } ++ ++ /* Allocate the host controller data structure */ ++ hose = pcibios_alloc_controller(np); ++ if (!hose) ++ goto fail; ++ ++ hose->first_busno = bus_range ? bus_range[0] : 0x0; ++ hose->last_busno = bus_range ? bus_range[1] : 0xff; ++ ++ /* Setup config space */ ++ setup_indirect_pci(hose, rsrc_cfg.start, rsrc_cfg.start + 0x4, 0); ++ ++ /* Disable all windows */ ++ writel(0, reg + PCIL0_PMM0MA); ++ writel(0, reg + PCIL0_PMM1MA); ++ writel(0, reg + PCIL0_PMM2MA); ++ writel(0, reg + PCIL0_PTM1MS); ++ writel(0, reg + PCIL0_PTM2MS); ++ ++ /* Parse outbound mapping resources */ ++ pci_process_bridge_OF_ranges(hose, np, primary); ++ ++ /* Parse inbound mapping resources */ ++ if (ppc4xx_parse_dma_ranges(hose, reg, &dma_window) != 0) ++ goto fail; ++ ++ /* Configure outbound ranges POMs */ ++ ppc4xx_configure_pci_PMMs(hose, reg); ++ ++ /* Configure inbound ranges PIMs */ ++ ppc4xx_configure_pci_PTMs(hose, reg, &dma_window); ++ ++ /* We don't need the registers anymore */ ++ iounmap(reg); ++ return; ++ ++ fail: ++ if (hose) ++ pcibios_free_controller(hose); ++ if (reg) ++ iounmap(reg); ++} ++ ++/* ++ * 4xx PCI-X part ++ */ ++ ++static void __init ppc4xx_configure_pcix_POMs(struct pci_controller *hose, ++ void __iomem *reg) ++{ ++ u32 lah, lal, pciah, pcial, sa; ++ int i, j; ++ ++ /* Setup outbound memory windows */ ++ for (i = j = 0; i < 3; i++) { ++ struct resource *res = &hose->mem_resources[i]; ++ ++ /* we only care about memory windows */ ++ if (!(res->flags & IORESOURCE_MEM)) ++ continue; ++ if (j > 1) { ++ printk(KERN_WARNING "%s: Too many ranges\n", ++ hose->dn->full_name); ++ break; ++ } ++ ++ /* Calculate register values */ ++ lah = RES_TO_U32_HIGH(res->start); ++ lal = RES_TO_U32_LOW(res->start); ++ pciah = RES_TO_U32_HIGH(res->start - hose->pci_mem_offset); ++ pcial = RES_TO_U32_LOW(res->start - hose->pci_mem_offset); ++ sa = res->end + 1 - res->start; ++ if (!is_power_of_2(sa) || sa < 0x100000 || ++ sa > 0xffffffffu) { ++ printk(KERN_WARNING "%s: Resource out of range\n", ++ hose->dn->full_name); ++ continue; ++ } ++ sa = (0xffffffffu << ilog2(sa)) | 0x1; ++ ++ /* Program register values */ ++ if (j == 0) { ++ writel(lah, reg + PCIX0_POM0LAH); ++ writel(lal, reg + PCIX0_POM0LAL); ++ writel(pciah, reg + PCIX0_POM0PCIAH); ++ writel(pcial, reg + PCIX0_POM0PCIAL); ++ writel(sa, reg + PCIX0_POM0SA); ++ } else { ++ writel(lah, reg + PCIX0_POM1LAH); ++ writel(lal, reg + PCIX0_POM1LAL); ++ writel(pciah, reg + PCIX0_POM1PCIAH); ++ writel(pcial, reg + PCIX0_POM1PCIAL); ++ writel(sa, reg + PCIX0_POM1SA); ++ } ++ j++; ++ } ++} ++ ++static void __init ppc4xx_configure_pcix_PIMs(struct pci_controller *hose, ++ void __iomem *reg, ++ const struct resource *res, ++ int big_pim, ++ int enable_msi_hole) ++{ ++ resource_size_t size = res->end - res->start + 1; ++ u32 sa; ++ ++ /* RAM is always at 0 */ ++ writel(0x00000000, reg + PCIX0_PIM0LAH); ++ writel(0x00000000, reg + PCIX0_PIM0LAL); ++ ++ /* Calculate window size */ ++ sa = (0xffffffffu << ilog2(size)) | 1; ++ sa |= 0x1; ++ if (res->flags & IORESOURCE_PREFETCH) ++ sa |= 0x2; ++ if (enable_msi_hole) ++ sa |= 0x4; ++ writel(sa, reg + PCIX0_PIM0SA); ++ if (big_pim) ++ writel(0xffffffff, reg + PCIX0_PIM0SAH); ++ ++ /* Map on PCI side */ ++ writel(0x00000000, reg + PCIX0_BAR0H); ++ writel(res->start, reg + PCIX0_BAR0L); ++ writew(0x0006, reg + PCIX0_COMMAND); ++} ++ ++static void __init ppc4xx_probe_pcix_bridge(struct device_node *np) ++{ ++ struct resource rsrc_cfg; ++ struct resource rsrc_reg; ++ struct resource dma_window; ++ struct pci_controller *hose = NULL; ++ void __iomem *reg = NULL; ++ const int *bus_range; ++ int big_pim = 0, msi = 0, primary = 0; ++ ++ /* Fetch config space registers address */ ++ if (of_address_to_resource(np, 0, &rsrc_cfg)) { ++ printk(KERN_ERR "%s:Can't get PCI-X config register base !", ++ np->full_name); ++ return; ++ } ++ /* Fetch host bridge internal registers address */ ++ if (of_address_to_resource(np, 3, &rsrc_reg)) { ++ printk(KERN_ERR "%s: Can't get PCI-X internal register base !", ++ np->full_name); ++ return; ++ } ++ ++ /* Check if it supports large PIMs (440GX) */ ++ if (of_get_property(np, "large-inbound-windows", NULL)) ++ big_pim = 1; ++ ++ /* Check if we should enable MSIs inbound hole */ ++ if (of_get_property(np, "enable-msi-hole", NULL)) ++ msi = 1; ++ ++ /* Check if primary bridge */ ++ if (of_get_property(np, "primary", NULL)) ++ primary = 1; ++ ++ /* Get bus range if any */ ++ bus_range = of_get_property(np, "bus-range", NULL); ++ ++ /* Map registers */ ++ reg = ioremap(rsrc_reg.start, rsrc_reg.end + 1 - rsrc_reg.start); ++ if (reg == NULL) { ++ printk(KERN_ERR "%s: Can't map registers !", np->full_name); ++ goto fail; ++ } ++ ++ /* Allocate the host controller data structure */ ++ hose = pcibios_alloc_controller(np); ++ if (!hose) ++ goto fail; ++ ++ hose->first_busno = bus_range ? bus_range[0] : 0x0; ++ hose->last_busno = bus_range ? bus_range[1] : 0xff; ++ ++ /* Setup config space */ ++ setup_indirect_pci(hose, rsrc_cfg.start, rsrc_cfg.start + 0x4, 0); ++ ++ /* Disable all windows */ ++ writel(0, reg + PCIX0_POM0SA); ++ writel(0, reg + PCIX0_POM1SA); ++ writel(0, reg + PCIX0_POM2SA); ++ writel(0, reg + PCIX0_PIM0SA); ++ writel(0, reg + PCIX0_PIM1SA); ++ writel(0, reg + PCIX0_PIM2SA); ++ if (big_pim) { ++ writel(0, reg + PCIX0_PIM0SAH); ++ writel(0, reg + PCIX0_PIM2SAH); ++ } ++ ++ /* Parse outbound mapping resources */ ++ pci_process_bridge_OF_ranges(hose, np, primary); ++ ++ /* Parse inbound mapping resources */ ++ if (ppc4xx_parse_dma_ranges(hose, reg, &dma_window) != 0) ++ goto fail; ++ ++ /* Configure outbound ranges POMs */ ++ ppc4xx_configure_pcix_POMs(hose, reg); ++ ++ /* Configure inbound ranges PIMs */ ++ ppc4xx_configure_pcix_PIMs(hose, reg, &dma_window, big_pim, msi); ++ ++ /* We don't need the registers anymore */ ++ iounmap(reg); ++ return; ++ ++ fail: ++ if (hose) ++ pcibios_free_controller(hose); ++ if (reg) ++ iounmap(reg); ++} ++ ++#ifdef CONFIG_PPC4xx_PCI_EXPRESS ++ ++/* ++ * 4xx PCI-Express part ++ * ++ * We support 3 parts currently based on the compatible property: ++ * ++ * ibm,plb-pciex-440spe ++ * ibm,plb-pciex-405ex ++ * ++ * Anything else will be rejected for now as they are all subtly ++ * different unfortunately. ++ * ++ */ ++ ++#define MAX_PCIE_BUS_MAPPED 0x40 ++ ++struct ppc4xx_pciex_port ++{ ++ struct pci_controller *hose; ++ struct device_node *node; ++ unsigned int index; ++ int endpoint; ++ int link; ++ int has_ibpre; ++ unsigned int sdr_base; ++ dcr_host_t dcrs; ++ struct resource cfg_space; ++ struct resource utl_regs; ++ void __iomem *utl_base; ++}; ++ ++static struct ppc4xx_pciex_port *ppc4xx_pciex_ports; ++static unsigned int ppc4xx_pciex_port_count; ++ ++struct ppc4xx_pciex_hwops ++{ ++ int (*core_init)(struct device_node *np); ++ int (*port_init_hw)(struct ppc4xx_pciex_port *port); ++ int (*setup_utl)(struct ppc4xx_pciex_port *port); ++}; ++ ++static struct ppc4xx_pciex_hwops *ppc4xx_pciex_hwops; ++ ++#ifdef CONFIG_44x ++ ++/* Check various reset bits of the 440SPe PCIe core */ ++static int __init ppc440spe_pciex_check_reset(struct device_node *np) ++{ ++ u32 valPE0, valPE1, valPE2; ++ int err = 0; ++ ++ /* SDR0_PEGPLLLCT1 reset */ ++ if (!(mfdcri(SDR0, PESDR0_PLLLCT1) & 0x01000000)) { ++ /* ++ * the PCIe core was probably already initialised ++ * by firmware - let's re-reset RCSSET regs ++ * ++ * -- Shouldn't we also re-reset the whole thing ? -- BenH ++ */ ++ pr_debug("PCIE: SDR0_PLLLCT1 already reset.\n"); ++ mtdcri(SDR0, PESDR0_440SPE_RCSSET, 0x01010000); ++ mtdcri(SDR0, PESDR1_440SPE_RCSSET, 0x01010000); ++ mtdcri(SDR0, PESDR2_440SPE_RCSSET, 0x01010000); ++ } ++ ++ valPE0 = mfdcri(SDR0, PESDR0_440SPE_RCSSET); ++ valPE1 = mfdcri(SDR0, PESDR1_440SPE_RCSSET); ++ valPE2 = mfdcri(SDR0, PESDR2_440SPE_RCSSET); ++ ++ /* SDR0_PExRCSSET rstgu */ ++ if (!(valPE0 & 0x01000000) || ++ !(valPE1 & 0x01000000) || ++ !(valPE2 & 0x01000000)) { ++ printk(KERN_INFO "PCIE: SDR0_PExRCSSET rstgu error\n"); ++ err = -1; ++ } ++ ++ /* SDR0_PExRCSSET rstdl */ ++ if (!(valPE0 & 0x00010000) || ++ !(valPE1 & 0x00010000) || ++ !(valPE2 & 0x00010000)) { ++ printk(KERN_INFO "PCIE: SDR0_PExRCSSET rstdl error\n"); ++ err = -1; ++ } ++ ++ /* SDR0_PExRCSSET rstpyn */ ++ if ((valPE0 & 0x00001000) || ++ (valPE1 & 0x00001000) || ++ (valPE2 & 0x00001000)) { ++ printk(KERN_INFO "PCIE: SDR0_PExRCSSET rstpyn error\n"); ++ err = -1; ++ } ++ ++ /* SDR0_PExRCSSET hldplb */ ++ if ((valPE0 & 0x10000000) || ++ (valPE1 & 0x10000000) || ++ (valPE2 & 0x10000000)) { ++ printk(KERN_INFO "PCIE: SDR0_PExRCSSET hldplb error\n"); ++ err = -1; ++ } ++ ++ /* SDR0_PExRCSSET rdy */ ++ if ((valPE0 & 0x00100000) || ++ (valPE1 & 0x00100000) || ++ (valPE2 & 0x00100000)) { ++ printk(KERN_INFO "PCIE: SDR0_PExRCSSET rdy error\n"); ++ err = -1; ++ } ++ ++ /* SDR0_PExRCSSET shutdown */ ++ if ((valPE0 & 0x00000100) || ++ (valPE1 & 0x00000100) || ++ (valPE2 & 0x00000100)) { ++ printk(KERN_INFO "PCIE: SDR0_PExRCSSET shutdown error\n"); ++ err = -1; ++ } ++ ++ return err; ++} ++ ++/* Global PCIe core initializations for 440SPe core */ ++static int __init ppc440spe_pciex_core_init(struct device_node *np) ++{ ++ int time_out = 20; ++ ++ /* Set PLL clock receiver to LVPECL */ ++ mtdcri(SDR0, PESDR0_PLLLCT1, mfdcri(SDR0, PESDR0_PLLLCT1) | 1 << 28); ++ ++ /* Shouldn't we do all the calibration stuff etc... here ? */ ++ if (ppc440spe_pciex_check_reset(np)) ++ return -ENXIO; ++ ++ if (!(mfdcri(SDR0, PESDR0_PLLLCT2) & 0x10000)) { ++ printk(KERN_INFO "PCIE: PESDR_PLLCT2 resistance calibration " ++ "failed (0x%08x)\n", ++ mfdcri(SDR0, PESDR0_PLLLCT2)); ++ return -1; ++ } ++ ++ /* De-assert reset of PCIe PLL, wait for lock */ ++ mtdcri(SDR0, PESDR0_PLLLCT1, ++ mfdcri(SDR0, PESDR0_PLLLCT1) & ~(1 << 24)); ++ udelay(3); ++ ++ while (time_out) { ++ if (!(mfdcri(SDR0, PESDR0_PLLLCT3) & 0x10000000)) { ++ time_out--; ++ udelay(1); ++ } else ++ break; ++ } ++ if (!time_out) { ++ printk(KERN_INFO "PCIE: VCO output not locked\n"); ++ return -1; ++ } ++ ++ pr_debug("PCIE initialization OK\n"); ++ ++ return 3; ++} ++ ++static int ppc440spe_pciex_init_port_hw(struct ppc4xx_pciex_port *port) ++{ ++ u32 val = 1 << 24; ++ ++ if (port->endpoint) ++ val = PTYPE_LEGACY_ENDPOINT << 20; ++ else ++ val = PTYPE_ROOT_PORT << 20; ++ ++ if (port->index == 0) ++ val |= LNKW_X8 << 12; ++ else ++ val |= LNKW_X4 << 12; ++ ++ mtdcri(SDR0, port->sdr_base + PESDRn_DLPSET, val); ++ mtdcri(SDR0, port->sdr_base + PESDRn_UTLSET1, 0x20222222); ++ if (ppc440spe_revA()) ++ mtdcri(SDR0, port->sdr_base + PESDRn_UTLSET2, 0x11000000); ++ mtdcri(SDR0, port->sdr_base + PESDRn_440SPE_HSSL0SET1, 0x35000000); ++ mtdcri(SDR0, port->sdr_base + PESDRn_440SPE_HSSL1SET1, 0x35000000); ++ mtdcri(SDR0, port->sdr_base + PESDRn_440SPE_HSSL2SET1, 0x35000000); ++ mtdcri(SDR0, port->sdr_base + PESDRn_440SPE_HSSL3SET1, 0x35000000); ++ if (port->index == 0) { ++ mtdcri(SDR0, port->sdr_base + PESDRn_440SPE_HSSL4SET1, ++ 0x35000000); ++ mtdcri(SDR0, port->sdr_base + PESDRn_440SPE_HSSL5SET1, ++ 0x35000000); ++ mtdcri(SDR0, port->sdr_base + PESDRn_440SPE_HSSL6SET1, ++ 0x35000000); ++ mtdcri(SDR0, port->sdr_base + PESDRn_440SPE_HSSL7SET1, ++ 0x35000000); ++ } ++ val = mfdcri(SDR0, port->sdr_base + PESDRn_RCSSET); ++ mtdcri(SDR0, port->sdr_base + PESDRn_RCSSET, ++ (val & ~(1 << 24 | 1 << 16)) | 1 << 12); ++ ++ return 0; ++} ++ ++static int ppc440speA_pciex_init_port_hw(struct ppc4xx_pciex_port *port) ++{ ++ return ppc440spe_pciex_init_port_hw(port); ++} ++ ++static int ppc440speB_pciex_init_port_hw(struct ppc4xx_pciex_port *port) ++{ ++ int rc = ppc440spe_pciex_init_port_hw(port); ++ ++ port->has_ibpre = 1; ++ ++ return rc; ++} ++ ++static int ppc440speA_pciex_init_utl(struct ppc4xx_pciex_port *port) ++{ ++ /* XXX Check what that value means... I hate magic */ ++ dcr_write(port->dcrs, DCRO_PEGPL_SPECIAL, 0x68782800); ++ ++ /* ++ * Set buffer allocations and then assert VRB and TXE. ++ */ ++ out_be32(port->utl_base + PEUTL_OUTTR, 0x08000000); ++ out_be32(port->utl_base + PEUTL_INTR, 0x02000000); ++ out_be32(port->utl_base + PEUTL_OPDBSZ, 0x10000000); ++ out_be32(port->utl_base + PEUTL_PBBSZ, 0x53000000); ++ out_be32(port->utl_base + PEUTL_IPHBSZ, 0x08000000); ++ out_be32(port->utl_base + PEUTL_IPDBSZ, 0x10000000); ++ out_be32(port->utl_base + PEUTL_RCIRQEN, 0x00f00000); ++ out_be32(port->utl_base + PEUTL_PCTL, 0x80800066); ++ ++ return 0; ++} ++ ++static int ppc440speB_pciex_init_utl(struct ppc4xx_pciex_port *port) ++{ ++ /* Report CRS to the operating system */ ++ out_be32(port->utl_base + PEUTL_PBCTL, 0x08000000); ++ ++ return 0; ++} ++ ++static struct ppc4xx_pciex_hwops ppc440speA_pcie_hwops __initdata = ++{ ++ .core_init = ppc440spe_pciex_core_init, ++ .port_init_hw = ppc440speA_pciex_init_port_hw, ++ .setup_utl = ppc440speA_pciex_init_utl, ++}; ++ ++static struct ppc4xx_pciex_hwops ppc440speB_pcie_hwops __initdata = ++{ ++ .core_init = ppc440spe_pciex_core_init, ++ .port_init_hw = ppc440speB_pciex_init_port_hw, ++ .setup_utl = ppc440speB_pciex_init_utl, ++}; ++ ++#endif /* CONFIG_44x */ ++ ++#ifdef CONFIG_40x ++ ++static int __init ppc405ex_pciex_core_init(struct device_node *np) ++{ ++ /* Nothing to do, return 2 ports */ ++ return 2; ++} ++ ++static void ppc405ex_pcie_phy_reset(struct ppc4xx_pciex_port *port) ++{ ++ /* Assert the PE0_PHY reset */ ++ mtdcri(SDR0, port->sdr_base + PESDRn_RCSSET, 0x01010000); ++ msleep(1); ++ ++ /* deassert the PE0_hotreset */ ++ if (port->endpoint) ++ mtdcri(SDR0, port->sdr_base + PESDRn_RCSSET, 0x01111000); ++ else ++ mtdcri(SDR0, port->sdr_base + PESDRn_RCSSET, 0x01101000); ++ ++ /* poll for phy !reset */ ++ /* XXX FIXME add timeout */ ++ while (!(mfdcri(SDR0, port->sdr_base + PESDRn_405EX_PHYSTA) & 0x00001000)) ++ ; ++ ++ /* deassert the PE0_gpl_utl_reset */ ++ mtdcri(SDR0, port->sdr_base + PESDRn_RCSSET, 0x00101000); ++} ++ ++static int ppc405ex_pciex_init_port_hw(struct ppc4xx_pciex_port *port) ++{ ++ u32 val; ++ ++ if (port->endpoint) ++ val = PTYPE_LEGACY_ENDPOINT; ++ else ++ val = PTYPE_ROOT_PORT; ++ ++ mtdcri(SDR0, port->sdr_base + PESDRn_DLPSET, ++ 1 << 24 | val << 20 | LNKW_X1 << 12); ++ ++ mtdcri(SDR0, port->sdr_base + PESDRn_UTLSET1, 0x00000000); ++ mtdcri(SDR0, port->sdr_base + PESDRn_UTLSET2, 0x01010000); ++ mtdcri(SDR0, port->sdr_base + PESDRn_405EX_PHYSET1, 0x720F0000); ++ mtdcri(SDR0, port->sdr_base + PESDRn_405EX_PHYSET2, 0x70600003); ++ ++ /* ++ * Only reset the PHY when no link is currently established. ++ * This is for the Atheros PCIe board which has problems to establish ++ * the link (again) after this PHY reset. All other currently tested ++ * PCIe boards don't show this problem. ++ * This has to be re-tested and fixed in a later release! ++ */ ++#if 0 /* XXX FIXME: Not resetting the PHY will leave all resources ++ * configured as done previously by U-Boot. Then Linux will currently ++ * not reassign them. So the PHY reset is now done always. This will ++ * lead to problems with the Atheros PCIe board again. ++ */ ++ val = mfdcri(SDR0, port->sdr_base + PESDRn_LOOP); ++ if (!(val & 0x00001000)) ++ ppc405ex_pcie_phy_reset(port); ++#else ++ ppc405ex_pcie_phy_reset(port); ++#endif ++ ++ dcr_write(port->dcrs, DCRO_PEGPL_CFG, 0x10000000); /* guarded on */ ++ ++ port->has_ibpre = 1; ++ ++ return 0; ++} ++ ++static int ppc405ex_pciex_init_utl(struct ppc4xx_pciex_port *port) ++{ ++ dcr_write(port->dcrs, DCRO_PEGPL_SPECIAL, 0x0); ++ ++ /* ++ * Set buffer allocations and then assert VRB and TXE. ++ */ ++ out_be32(port->utl_base + PEUTL_OUTTR, 0x02000000); ++ out_be32(port->utl_base + PEUTL_INTR, 0x02000000); ++ out_be32(port->utl_base + PEUTL_OPDBSZ, 0x04000000); ++ out_be32(port->utl_base + PEUTL_PBBSZ, 0x21000000); ++ out_be32(port->utl_base + PEUTL_IPHBSZ, 0x02000000); ++ out_be32(port->utl_base + PEUTL_IPDBSZ, 0x04000000); ++ out_be32(port->utl_base + PEUTL_RCIRQEN, 0x00f00000); ++ out_be32(port->utl_base + PEUTL_PCTL, 0x80800066); ++ ++ out_be32(port->utl_base + PEUTL_PBCTL, 0x08000000); ++ ++ return 0; ++} ++ ++static struct ppc4xx_pciex_hwops ppc405ex_pcie_hwops __initdata = ++{ ++ .core_init = ppc405ex_pciex_core_init, ++ .port_init_hw = ppc405ex_pciex_init_port_hw, ++ .setup_utl = ppc405ex_pciex_init_utl, ++}; ++ ++#endif /* CONFIG_40x */ ++ ++ ++/* Check that the core has been initied and if not, do it */ ++static int __init ppc4xx_pciex_check_core_init(struct device_node *np) ++{ ++ static int core_init; ++ int count = -ENODEV; ++ ++ if (core_init++) ++ return 0; ++ ++#ifdef CONFIG_44x ++ if (of_device_is_compatible(np, "ibm,plb-pciex-440spe")) { ++ if (ppc440spe_revA()) ++ ppc4xx_pciex_hwops = &ppc440speA_pcie_hwops; ++ else ++ ppc4xx_pciex_hwops = &ppc440speB_pcie_hwops; ++ } ++#endif /* CONFIG_44x */ ++#ifdef CONFIG_40x ++ if (of_device_is_compatible(np, "ibm,plb-pciex-405ex")) ++ ppc4xx_pciex_hwops = &ppc405ex_pcie_hwops; ++#endif ++ if (ppc4xx_pciex_hwops == NULL) { ++ printk(KERN_WARNING "PCIE: unknown host type %s\n", ++ np->full_name); ++ return -ENODEV; ++ } ++ ++ count = ppc4xx_pciex_hwops->core_init(np); ++ if (count > 0) { ++ ppc4xx_pciex_ports = ++ kzalloc(count * sizeof(struct ppc4xx_pciex_port), ++ GFP_KERNEL); ++ if (ppc4xx_pciex_ports) { ++ ppc4xx_pciex_port_count = count; ++ return 0; ++ } ++ printk(KERN_WARNING "PCIE: failed to allocate ports array\n"); ++ return -ENOMEM; ++ } ++ return -ENODEV; ++} ++ ++static void __init ppc4xx_pciex_port_init_mapping(struct ppc4xx_pciex_port *port) ++{ ++ /* We map PCI Express configuration based on the reg property */ ++ dcr_write(port->dcrs, DCRO_PEGPL_CFGBAH, ++ RES_TO_U32_HIGH(port->cfg_space.start)); ++ dcr_write(port->dcrs, DCRO_PEGPL_CFGBAL, ++ RES_TO_U32_LOW(port->cfg_space.start)); ++ ++ /* XXX FIXME: Use size from reg property. For now, map 512M */ ++ dcr_write(port->dcrs, DCRO_PEGPL_CFGMSK, 0xe0000001); ++ ++ /* We map UTL registers based on the reg property */ ++ dcr_write(port->dcrs, DCRO_PEGPL_REGBAH, ++ RES_TO_U32_HIGH(port->utl_regs.start)); ++ dcr_write(port->dcrs, DCRO_PEGPL_REGBAL, ++ RES_TO_U32_LOW(port->utl_regs.start)); ++ ++ /* XXX FIXME: Use size from reg property */ ++ dcr_write(port->dcrs, DCRO_PEGPL_REGMSK, 0x00007001); ++ ++ /* Disable all other outbound windows */ ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR1MSKL, 0); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR2MSKL, 0); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR3MSKL, 0); ++ dcr_write(port->dcrs, DCRO_PEGPL_MSGMSK, 0); ++} ++ ++static int __init ppc4xx_pciex_wait_on_sdr(struct ppc4xx_pciex_port *port, ++ unsigned int sdr_offset, ++ unsigned int mask, ++ unsigned int value, ++ int timeout_ms) ++{ ++ u32 val; ++ ++ while(timeout_ms--) { ++ val = mfdcri(SDR0, port->sdr_base + sdr_offset); ++ if ((val & mask) == value) { ++ pr_debug("PCIE%d: Wait on SDR %x success with tm %d (%08x)\n", ++ port->index, sdr_offset, timeout_ms, val); ++ return 0; ++ } ++ msleep(1); ++ } ++ return -1; ++} ++ ++static int __init ppc4xx_pciex_port_init(struct ppc4xx_pciex_port *port) ++{ ++ int rc = 0; ++ ++ /* Init HW */ ++ if (ppc4xx_pciex_hwops->port_init_hw) ++ rc = ppc4xx_pciex_hwops->port_init_hw(port); ++ if (rc != 0) ++ return rc; ++ ++ printk(KERN_INFO "PCIE%d: Checking link...\n", ++ port->index); ++ ++ /* Wait for reset to complete */ ++ if (ppc4xx_pciex_wait_on_sdr(port, PESDRn_RCSSTS, 1 << 20, 0, 10)) { ++ printk(KERN_WARNING "PCIE%d: PGRST failed\n", ++ port->index); ++ return -1; ++ } ++ ++ /* Check for card presence detect if supported, if not, just wait for ++ * link unconditionally. ++ * ++ * note that we don't fail if there is no link, we just filter out ++ * config space accesses. That way, it will be easier to implement ++ * hotplug later on. ++ */ ++ if (!port->has_ibpre || ++ !ppc4xx_pciex_wait_on_sdr(port, PESDRn_LOOP, ++ 1 << 28, 1 << 28, 100)) { ++ printk(KERN_INFO ++ "PCIE%d: Device detected, waiting for link...\n", ++ port->index); ++ if (ppc4xx_pciex_wait_on_sdr(port, PESDRn_LOOP, ++ 0x1000, 0x1000, 2000)) ++ printk(KERN_WARNING ++ "PCIE%d: Link up failed\n", port->index); ++ else { ++ printk(KERN_INFO ++ "PCIE%d: link is up !\n", port->index); ++ port->link = 1; ++ } ++ } else ++ printk(KERN_INFO "PCIE%d: No device detected.\n", port->index); ++ ++ /* ++ * Initialize mapping: disable all regions and configure ++ * CFG and REG regions based on resources in the device tree ++ */ ++ ppc4xx_pciex_port_init_mapping(port); ++ ++ /* ++ * Map UTL ++ */ ++ port->utl_base = ioremap(port->utl_regs.start, 0x100); ++ BUG_ON(port->utl_base == NULL); ++ ++ /* ++ * Setup UTL registers --BenH. ++ */ ++ if (ppc4xx_pciex_hwops->setup_utl) ++ ppc4xx_pciex_hwops->setup_utl(port); ++ ++ /* ++ * Check for VC0 active and assert RDY. ++ */ ++ if (port->link && ++ ppc4xx_pciex_wait_on_sdr(port, PESDRn_RCSSTS, ++ 1 << 16, 1 << 16, 5000)) { ++ printk(KERN_INFO "PCIE%d: VC0 not active\n", port->index); ++ port->link = 0; ++ } ++ ++ mtdcri(SDR0, port->sdr_base + PESDRn_RCSSET, ++ mfdcri(SDR0, port->sdr_base + PESDRn_RCSSET) | 1 << 20); ++ msleep(100); ++ ++ return 0; ++} ++ ++static int ppc4xx_pciex_validate_bdf(struct ppc4xx_pciex_port *port, ++ struct pci_bus *bus, ++ unsigned int devfn) ++{ ++ static int message; ++ ++ /* Endpoint can not generate upstream(remote) config cycles */ ++ if (port->endpoint && bus->number != port->hose->first_busno) ++ return PCIBIOS_DEVICE_NOT_FOUND; ++ ++ /* Check we are within the mapped range */ ++ if (bus->number > port->hose->last_busno) { ++ if (!message) { ++ printk(KERN_WARNING "Warning! Probing bus %u" ++ " out of range !\n", bus->number); ++ message++; ++ } ++ return PCIBIOS_DEVICE_NOT_FOUND; ++ } ++ ++ /* The root complex has only one device / function */ ++ if (bus->number == port->hose->first_busno && devfn != 0) ++ return PCIBIOS_DEVICE_NOT_FOUND; ++ ++ /* The other side of the RC has only one device as well */ ++ if (bus->number == (port->hose->first_busno + 1) && ++ PCI_SLOT(devfn) != 0) ++ return PCIBIOS_DEVICE_NOT_FOUND; ++ ++ /* Check if we have a link */ ++ if ((bus->number != port->hose->first_busno) && !port->link) ++ return PCIBIOS_DEVICE_NOT_FOUND; ++ ++ return 0; ++} ++ ++static void __iomem *ppc4xx_pciex_get_config_base(struct ppc4xx_pciex_port *port, ++ struct pci_bus *bus, ++ unsigned int devfn) ++{ ++ int relbus; ++ ++ /* Remove the casts when we finally remove the stupid volatile ++ * in struct pci_controller ++ */ ++ if (bus->number == port->hose->first_busno) ++ return (void __iomem *)port->hose->cfg_addr; ++ ++ relbus = bus->number - (port->hose->first_busno + 1); ++ return (void __iomem *)port->hose->cfg_data + ++ ((relbus << 20) | (devfn << 12)); ++} ++ ++static int ppc4xx_pciex_read_config(struct pci_bus *bus, unsigned int devfn, ++ int offset, int len, u32 *val) ++{ ++ struct pci_controller *hose = (struct pci_controller *) bus->sysdata; ++ struct ppc4xx_pciex_port *port = ++ &ppc4xx_pciex_ports[hose->indirect_type]; ++ void __iomem *addr; ++ u32 gpl_cfg; ++ ++ BUG_ON(hose != port->hose); ++ ++ if (ppc4xx_pciex_validate_bdf(port, bus, devfn) != 0) ++ return PCIBIOS_DEVICE_NOT_FOUND; ++ ++ addr = ppc4xx_pciex_get_config_base(port, bus, devfn); ++ ++ /* ++ * Reading from configuration space of non-existing device can ++ * generate transaction errors. For the read duration we suppress ++ * assertion of machine check exceptions to avoid those. ++ */ ++ gpl_cfg = dcr_read(port->dcrs, DCRO_PEGPL_CFG); ++ dcr_write(port->dcrs, DCRO_PEGPL_CFG, gpl_cfg | GPL_DMER_MASK_DISA); ++ ++ /* Make sure no CRS is recorded */ ++ out_be32(port->utl_base + PEUTL_RCSTA, 0x00040000); ++ ++ switch (len) { ++ case 1: ++ *val = in_8((u8 *)(addr + offset)); ++ break; ++ case 2: ++ *val = in_le16((u16 *)(addr + offset)); ++ break; ++ default: ++ *val = in_le32((u32 *)(addr + offset)); ++ break; ++ } ++ ++ pr_debug("pcie-config-read: bus=%3d [%3d..%3d] devfn=0x%04x" ++ " offset=0x%04x len=%d, addr=0x%p val=0x%08x\n", ++ bus->number, hose->first_busno, hose->last_busno, ++ devfn, offset, len, addr + offset, *val); ++ ++ /* Check for CRS (440SPe rev B does that for us but heh ..) */ ++ if (in_be32(port->utl_base + PEUTL_RCSTA) & 0x00040000) { ++ pr_debug("Got CRS !\n"); ++ if (len != 4 || offset != 0) ++ return PCIBIOS_DEVICE_NOT_FOUND; ++ *val = 0xffff0001; ++ } ++ ++ dcr_write(port->dcrs, DCRO_PEGPL_CFG, gpl_cfg); ++ ++ return PCIBIOS_SUCCESSFUL; ++} ++ ++static int ppc4xx_pciex_write_config(struct pci_bus *bus, unsigned int devfn, ++ int offset, int len, u32 val) ++{ ++ struct pci_controller *hose = (struct pci_controller *) bus->sysdata; ++ struct ppc4xx_pciex_port *port = ++ &ppc4xx_pciex_ports[hose->indirect_type]; ++ void __iomem *addr; ++ u32 gpl_cfg; ++ ++ if (ppc4xx_pciex_validate_bdf(port, bus, devfn) != 0) ++ return PCIBIOS_DEVICE_NOT_FOUND; ++ ++ addr = ppc4xx_pciex_get_config_base(port, bus, devfn); ++ ++ /* ++ * Reading from configuration space of non-existing device can ++ * generate transaction errors. For the read duration we suppress ++ * assertion of machine check exceptions to avoid those. ++ */ ++ gpl_cfg = dcr_read(port->dcrs, DCRO_PEGPL_CFG); ++ dcr_write(port->dcrs, DCRO_PEGPL_CFG, gpl_cfg | GPL_DMER_MASK_DISA); ++ ++ pr_debug("pcie-config-write: bus=%3d [%3d..%3d] devfn=0x%04x" ++ " offset=0x%04x len=%d, addr=0x%p val=0x%08x\n", ++ bus->number, hose->first_busno, hose->last_busno, ++ devfn, offset, len, addr + offset, val); ++ ++ switch (len) { ++ case 1: ++ out_8((u8 *)(addr + offset), val); ++ break; ++ case 2: ++ out_le16((u16 *)(addr + offset), val); ++ break; ++ default: ++ out_le32((u32 *)(addr + offset), val); ++ break; ++ } ++ ++ dcr_write(port->dcrs, DCRO_PEGPL_CFG, gpl_cfg); ++ ++ return PCIBIOS_SUCCESSFUL; ++} ++ ++static struct pci_ops ppc4xx_pciex_pci_ops = ++{ ++ .read = ppc4xx_pciex_read_config, ++ .write = ppc4xx_pciex_write_config, ++}; ++ ++static void __init ppc4xx_configure_pciex_POMs(struct ppc4xx_pciex_port *port, ++ struct pci_controller *hose, ++ void __iomem *mbase) ++{ ++ u32 lah, lal, pciah, pcial, sa; ++ int i, j; ++ ++ /* Setup outbound memory windows */ ++ for (i = j = 0; i < 3; i++) { ++ struct resource *res = &hose->mem_resources[i]; ++ ++ /* we only care about memory windows */ ++ if (!(res->flags & IORESOURCE_MEM)) ++ continue; ++ if (j > 1) { ++ printk(KERN_WARNING "%s: Too many ranges\n", ++ port->node->full_name); ++ break; ++ } ++ ++ /* Calculate register values */ ++ lah = RES_TO_U32_HIGH(res->start); ++ lal = RES_TO_U32_LOW(res->start); ++ pciah = RES_TO_U32_HIGH(res->start - hose->pci_mem_offset); ++ pcial = RES_TO_U32_LOW(res->start - hose->pci_mem_offset); ++ sa = res->end + 1 - res->start; ++ if (!is_power_of_2(sa) || sa < 0x100000 || ++ sa > 0xffffffffu) { ++ printk(KERN_WARNING "%s: Resource out of range\n", ++ port->node->full_name); ++ continue; ++ } ++ sa = (0xffffffffu << ilog2(sa)) | 0x1; ++ ++ /* Program register values */ ++ switch (j) { ++ case 0: ++ out_le32(mbase + PECFG_POM0LAH, pciah); ++ out_le32(mbase + PECFG_POM0LAL, pcial); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR1BAH, lah); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR1BAL, lal); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR1MSKH, 0x7fffffff); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR1MSKL, sa | 3); ++ break; ++ case 1: ++ out_le32(mbase + PECFG_POM1LAH, pciah); ++ out_le32(mbase + PECFG_POM1LAL, pcial); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR2BAH, lah); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR2BAL, lal); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR2MSKH, 0x7fffffff); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR2MSKL, sa | 3); ++ break; ++ } ++ j++; ++ } ++ ++ /* Configure IO, always 64K starting at 0 */ ++ if (hose->io_resource.flags & IORESOURCE_IO) { ++ lah = RES_TO_U32_HIGH(hose->io_base_phys); ++ lal = RES_TO_U32_LOW(hose->io_base_phys); ++ out_le32(mbase + PECFG_POM2LAH, 0); ++ out_le32(mbase + PECFG_POM2LAL, 0); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR3BAH, lah); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR3BAL, lal); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR3MSKH, 0x7fffffff); ++ dcr_write(port->dcrs, DCRO_PEGPL_OMR3MSKL, 0xffff0000 | 3); ++ } ++} ++ ++static void __init ppc4xx_configure_pciex_PIMs(struct ppc4xx_pciex_port *port, ++ struct pci_controller *hose, ++ void __iomem *mbase, ++ struct resource *res) ++{ ++ resource_size_t size = res->end - res->start + 1; ++ u64 sa; ++ ++ /* Calculate window size */ ++ sa = (0xffffffffffffffffull << ilog2(size));; ++ if (res->flags & IORESOURCE_PREFETCH) ++ sa |= 0x8; ++ ++ out_le32(mbase + PECFG_BAR0HMPA, RES_TO_U32_HIGH(sa)); ++ out_le32(mbase + PECFG_BAR0LMPA, RES_TO_U32_LOW(sa)); ++ ++ /* The setup of the split looks weird to me ... let's see if it works */ ++ out_le32(mbase + PECFG_PIM0LAL, 0x00000000); ++ out_le32(mbase + PECFG_PIM0LAH, 0x00000000); ++ out_le32(mbase + PECFG_PIM1LAL, 0x00000000); ++ out_le32(mbase + PECFG_PIM1LAH, 0x00000000); ++ out_le32(mbase + PECFG_PIM01SAH, 0xffff0000); ++ out_le32(mbase + PECFG_PIM01SAL, 0x00000000); ++ ++ /* Enable inbound mapping */ ++ out_le32(mbase + PECFG_PIMEN, 0x1); ++ ++ out_le32(mbase + PCI_BASE_ADDRESS_0, RES_TO_U32_LOW(res->start)); ++ out_le32(mbase + PCI_BASE_ADDRESS_1, RES_TO_U32_HIGH(res->start)); ++ ++ /* Enable I/O, Mem, and Busmaster cycles */ ++ out_le16(mbase + PCI_COMMAND, ++ in_le16(mbase + PCI_COMMAND) | ++ PCI_COMMAND_IO | PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER); ++} ++ ++static void __init ppc4xx_pciex_port_setup_hose(struct ppc4xx_pciex_port *port) ++{ ++ struct resource dma_window; ++ struct pci_controller *hose = NULL; ++ const int *bus_range; ++ int primary = 0, busses; ++ void __iomem *mbase = NULL, *cfg_data = NULL; ++ ++ /* XXX FIXME: Handle endpoint mode properly */ ++ if (port->endpoint) { ++ printk(KERN_WARNING "PCIE%d: Port in endpoint mode !\n", ++ port->index); ++ return; ++ } ++ ++ /* Check if primary bridge */ ++ if (of_get_property(port->node, "primary", NULL)) ++ primary = 1; ++ ++ /* Get bus range if any */ ++ bus_range = of_get_property(port->node, "bus-range", NULL); ++ ++ /* Allocate the host controller data structure */ ++ hose = pcibios_alloc_controller(port->node); ++ if (!hose) ++ goto fail; ++ ++ /* We stick the port number in "indirect_type" so the config space ++ * ops can retrieve the port data structure easily ++ */ ++ hose->indirect_type = port->index; ++ ++ /* Get bus range */ ++ hose->first_busno = bus_range ? bus_range[0] : 0x0; ++ hose->last_busno = bus_range ? bus_range[1] : 0xff; ++ ++ /* Because of how big mapping the config space is (1M per bus), we ++ * limit how many busses we support. In the long run, we could replace ++ * that with something akin to kmap_atomic instead. We set aside 1 bus ++ * for the host itself too. ++ */ ++ busses = hose->last_busno - hose->first_busno; /* This is off by 1 */ ++ if (busses > MAX_PCIE_BUS_MAPPED) { ++ busses = MAX_PCIE_BUS_MAPPED; ++ hose->last_busno = hose->first_busno + busses; ++ } ++ ++ /* We map the external config space in cfg_data and the host config ++ * space in cfg_addr. External space is 1M per bus, internal space ++ * is 4K ++ */ ++ cfg_data = ioremap(port->cfg_space.start + ++ (hose->first_busno + 1) * 0x100000, ++ busses * 0x100000); ++ mbase = ioremap(port->cfg_space.start + 0x10000000, 0x1000); ++ if (cfg_data == NULL || mbase == NULL) { ++ printk(KERN_ERR "%s: Can't map config space !", ++ port->node->full_name); ++ goto fail; ++ } ++ ++ hose->cfg_data = cfg_data; ++ hose->cfg_addr = mbase; ++ ++ pr_debug("PCIE %s, bus %d..%d\n", port->node->full_name, ++ hose->first_busno, hose->last_busno); ++ pr_debug(" config space mapped at: root @0x%p, other @0x%p\n", ++ hose->cfg_addr, hose->cfg_data); ++ ++ /* Setup config space */ ++ hose->ops = &ppc4xx_pciex_pci_ops; ++ port->hose = hose; ++ mbase = (void __iomem *)hose->cfg_addr; ++ ++ /* ++ * Set bus numbers on our root port ++ */ ++ out_8(mbase + PCI_PRIMARY_BUS, hose->first_busno); ++ out_8(mbase + PCI_SECONDARY_BUS, hose->first_busno + 1); ++ out_8(mbase + PCI_SUBORDINATE_BUS, hose->last_busno); ++ ++ /* ++ * OMRs are already reset, also disable PIMs ++ */ ++ out_le32(mbase + PECFG_PIMEN, 0); ++ ++ /* Parse outbound mapping resources */ ++ pci_process_bridge_OF_ranges(hose, port->node, primary); ++ ++ /* Parse inbound mapping resources */ ++ if (ppc4xx_parse_dma_ranges(hose, mbase, &dma_window) != 0) ++ goto fail; ++ ++ /* Configure outbound ranges POMs */ ++ ppc4xx_configure_pciex_POMs(port, hose, mbase); ++ ++ /* Configure inbound ranges PIMs */ ++ ppc4xx_configure_pciex_PIMs(port, hose, mbase, &dma_window); ++ ++ /* The root complex doesn't show up if we don't set some vendor ++ * and device IDs into it. Those are the same bogus one that the ++ * initial code in arch/ppc add. We might want to change that. ++ */ ++ out_le16(mbase + 0x200, 0xaaa0 + port->index); ++ out_le16(mbase + 0x202, 0xbed0 + port->index); ++ ++ /* Set Class Code to PCI-PCI bridge and Revision Id to 1 */ ++ out_le32(mbase + 0x208, 0x06040001); ++ ++ printk(KERN_INFO "PCIE%d: successfully set as root-complex\n", ++ port->index); ++ return; ++ fail: ++ if (hose) ++ pcibios_free_controller(hose); ++ if (cfg_data) ++ iounmap(cfg_data); ++ if (mbase) ++ iounmap(mbase); ++} ++ ++static void __init ppc4xx_probe_pciex_bridge(struct device_node *np) ++{ ++ struct ppc4xx_pciex_port *port; ++ const u32 *pval; ++ int portno; ++ unsigned int dcrs; ++ ++ /* First, proceed to core initialization as we assume there's ++ * only one PCIe core in the system ++ */ ++ if (ppc4xx_pciex_check_core_init(np)) ++ return; ++ ++ /* Get the port number from the device-tree */ ++ pval = of_get_property(np, "port", NULL); ++ if (pval == NULL) { ++ printk(KERN_ERR "PCIE: Can't find port number for %s\n", ++ np->full_name); ++ return; ++ } ++ portno = *pval; ++ if (portno >= ppc4xx_pciex_port_count) { ++ printk(KERN_ERR "PCIE: port number out of range for %s\n", ++ np->full_name); ++ return; ++ } ++ port = &ppc4xx_pciex_ports[portno]; ++ port->index = portno; ++ port->node = of_node_get(np); ++ pval = of_get_property(np, "sdr-base", NULL); ++ if (pval == NULL) { ++ printk(KERN_ERR "PCIE: missing sdr-base for %s\n", ++ np->full_name); ++ return; ++ } ++ port->sdr_base = *pval; ++ ++ /* XXX Currently, we only support root complex mode */ ++ port->endpoint = 0; ++ ++ /* Fetch config space registers address */ ++ if (of_address_to_resource(np, 0, &port->cfg_space)) { ++ printk(KERN_ERR "%s: Can't get PCI-E config space !", ++ np->full_name); ++ return; ++ } ++ /* Fetch host bridge internal registers address */ ++ if (of_address_to_resource(np, 1, &port->utl_regs)) { ++ printk(KERN_ERR "%s: Can't get UTL register base !", ++ np->full_name); ++ return; ++ } ++ ++ /* Map DCRs */ ++ dcrs = dcr_resource_start(np, 0); ++ if (dcrs == 0) { ++ printk(KERN_ERR "%s: Can't get DCR register base !", ++ np->full_name); ++ return; ++ } ++ port->dcrs = dcr_map(np, dcrs, dcr_resource_len(np, 0)); ++ ++ /* Initialize the port specific registers */ ++ if (ppc4xx_pciex_port_init(port)) { ++ printk(KERN_WARNING "PCIE%d: Port init failed\n", port->index); ++ return; ++ } ++ ++ /* Setup the linux hose data structure */ ++ ppc4xx_pciex_port_setup_hose(port); ++} ++ ++#endif /* CONFIG_PPC4xx_PCI_EXPRESS */ ++ ++static int __init ppc4xx_pci_find_bridges(void) ++{ ++ struct device_node *np; ++ ++#ifdef CONFIG_PPC4xx_PCI_EXPRESS ++ for_each_compatible_node(np, NULL, "ibm,plb-pciex") ++ ppc4xx_probe_pciex_bridge(np); ++#endif ++ for_each_compatible_node(np, NULL, "ibm,plb-pcix") ++ ppc4xx_probe_pcix_bridge(np); ++ for_each_compatible_node(np, NULL, "ibm,plb-pci") ++ ppc4xx_probe_pci_bridge(np); ++ ++ return 0; ++} ++arch_initcall(ppc4xx_pci_find_bridges); ++ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/ppc4xx_pci.h powerpc.git/arch/powerpc/sysdev/ppc4xx_pci.h +--- linux-2.6.24/arch/powerpc/sysdev/ppc4xx_pci.h 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/ppc4xx_pci.h 2008-01-28 20:25:49.000000000 +0100 +@@ -0,0 +1,369 @@ ++/* ++ * PCI / PCI-X / PCI-Express support for 4xx parts ++ * ++ * Copyright 2007 Ben. Herrenschmidt <benh@kernel.crashing.org>, IBM Corp. ++ * ++ * Bits and pieces extracted from arch/ppc support by ++ * ++ * Matt Porter <mporter@kernel.crashing.org> ++ * ++ * Copyright 2002-2005 MontaVista Software Inc. ++ */ ++#ifndef __PPC4XX_PCI_H__ ++#define __PPC4XX_PCI_H__ ++ ++/* ++ * 4xx PCI-X bridge register definitions ++ */ ++#define PCIX0_VENDID 0x000 ++#define PCIX0_DEVID 0x002 ++#define PCIX0_COMMAND 0x004 ++#define PCIX0_STATUS 0x006 ++#define PCIX0_REVID 0x008 ++#define PCIX0_CLS 0x009 ++#define PCIX0_CACHELS 0x00c ++#define PCIX0_LATTIM 0x00d ++#define PCIX0_HDTYPE 0x00e ++#define PCIX0_BIST 0x00f ++#define PCIX0_BAR0L 0x010 ++#define PCIX0_BAR0H 0x014 ++#define PCIX0_BAR1 0x018 ++#define PCIX0_BAR2L 0x01c ++#define PCIX0_BAR2H 0x020 ++#define PCIX0_BAR3 0x024 ++#define PCIX0_CISPTR 0x028 ++#define PCIX0_SBSYSVID 0x02c ++#define PCIX0_SBSYSID 0x02e ++#define PCIX0_EROMBA 0x030 ++#define PCIX0_CAP 0x034 ++#define PCIX0_RES0 0x035 ++#define PCIX0_RES1 0x036 ++#define PCIX0_RES2 0x038 ++#define PCIX0_INTLN 0x03c ++#define PCIX0_INTPN 0x03d ++#define PCIX0_MINGNT 0x03e ++#define PCIX0_MAXLTNCY 0x03f ++#define PCIX0_BRDGOPT1 0x040 ++#define PCIX0_BRDGOPT2 0x044 ++#define PCIX0_ERREN 0x050 ++#define PCIX0_ERRSTS 0x054 ++#define PCIX0_PLBBESR 0x058 ++#define PCIX0_PLBBEARL 0x05c ++#define PCIX0_PLBBEARH 0x060 ++#define PCIX0_POM0LAL 0x068 ++#define PCIX0_POM0LAH 0x06c ++#define PCIX0_POM0SA 0x070 ++#define PCIX0_POM0PCIAL 0x074 ++#define PCIX0_POM0PCIAH 0x078 ++#define PCIX0_POM1LAL 0x07c ++#define PCIX0_POM1LAH 0x080 ++#define PCIX0_POM1SA 0x084 ++#define PCIX0_POM1PCIAL 0x088 ++#define PCIX0_POM1PCIAH 0x08c ++#define PCIX0_POM2SA 0x090 ++#define PCIX0_PIM0SAL 0x098 ++#define PCIX0_PIM0SA PCIX0_PIM0SAL ++#define PCIX0_PIM0LAL 0x09c ++#define PCIX0_PIM0LAH 0x0a0 ++#define PCIX0_PIM1SA 0x0a4 ++#define PCIX0_PIM1LAL 0x0a8 ++#define PCIX0_PIM1LAH 0x0ac ++#define PCIX0_PIM2SAL 0x0b0 ++#define PCIX0_PIM2SA PCIX0_PIM2SAL ++#define PCIX0_PIM2LAL 0x0b4 ++#define PCIX0_PIM2LAH 0x0b8 ++#define PCIX0_OMCAPID 0x0c0 ++#define PCIX0_OMNIPTR 0x0c1 ++#define PCIX0_OMMC 0x0c2 ++#define PCIX0_OMMA 0x0c4 ++#define PCIX0_OMMUA 0x0c8 ++#define PCIX0_OMMDATA 0x0cc ++#define PCIX0_OMMEOI 0x0ce ++#define PCIX0_PMCAPID 0x0d0 ++#define PCIX0_PMNIPTR 0x0d1 ++#define PCIX0_PMC 0x0d2 ++#define PCIX0_PMCSR 0x0d4 ++#define PCIX0_PMCSRBSE 0x0d6 ++#define PCIX0_PMDATA 0x0d7 ++#define PCIX0_PMSCRR 0x0d8 ++#define PCIX0_CAPID 0x0dc ++#define PCIX0_NIPTR 0x0dd ++#define PCIX0_CMD 0x0de ++#define PCIX0_STS 0x0e0 ++#define PCIX0_IDR 0x0e4 ++#define PCIX0_CID 0x0e8 ++#define PCIX0_RID 0x0ec ++#define PCIX0_PIM0SAH 0x0f8 ++#define PCIX0_PIM2SAH 0x0fc ++#define PCIX0_MSGIL 0x100 ++#define PCIX0_MSGIH 0x104 ++#define PCIX0_MSGOL 0x108 ++#define PCIX0_MSGOH 0x10c ++#define PCIX0_IM 0x1f8 ++ ++/* ++ * 4xx PCI bridge register definitions ++ */ ++#define PCIL0_PMM0LA 0x00 ++#define PCIL0_PMM0MA 0x04 ++#define PCIL0_PMM0PCILA 0x08 ++#define PCIL0_PMM0PCIHA 0x0c ++#define PCIL0_PMM1LA 0x10 ++#define PCIL0_PMM1MA 0x14 ++#define PCIL0_PMM1PCILA 0x18 ++#define PCIL0_PMM1PCIHA 0x1c ++#define PCIL0_PMM2LA 0x20 ++#define PCIL0_PMM2MA 0x24 ++#define PCIL0_PMM2PCILA 0x28 ++#define PCIL0_PMM2PCIHA 0x2c ++#define PCIL0_PTM1MS 0x30 ++#define PCIL0_PTM1LA 0x34 ++#define PCIL0_PTM2MS 0x38 ++#define PCIL0_PTM2LA 0x3c ++ ++/* ++ * 4xx PCIe bridge register definitions ++ */ ++ ++/* DCR offsets */ ++#define DCRO_PEGPL_CFGBAH 0x00 ++#define DCRO_PEGPL_CFGBAL 0x01 ++#define DCRO_PEGPL_CFGMSK 0x02 ++#define DCRO_PEGPL_MSGBAH 0x03 ++#define DCRO_PEGPL_MSGBAL 0x04 ++#define DCRO_PEGPL_MSGMSK 0x05 ++#define DCRO_PEGPL_OMR1BAH 0x06 ++#define DCRO_PEGPL_OMR1BAL 0x07 ++#define DCRO_PEGPL_OMR1MSKH 0x08 ++#define DCRO_PEGPL_OMR1MSKL 0x09 ++#define DCRO_PEGPL_OMR2BAH 0x0a ++#define DCRO_PEGPL_OMR2BAL 0x0b ++#define DCRO_PEGPL_OMR2MSKH 0x0c ++#define DCRO_PEGPL_OMR2MSKL 0x0d ++#define DCRO_PEGPL_OMR3BAH 0x0e ++#define DCRO_PEGPL_OMR3BAL 0x0f ++#define DCRO_PEGPL_OMR3MSKH 0x10 ++#define DCRO_PEGPL_OMR3MSKL 0x11 ++#define DCRO_PEGPL_REGBAH 0x12 ++#define DCRO_PEGPL_REGBAL 0x13 ++#define DCRO_PEGPL_REGMSK 0x14 ++#define DCRO_PEGPL_SPECIAL 0x15 ++#define DCRO_PEGPL_CFG 0x16 ++#define DCRO_PEGPL_ESR 0x17 ++#define DCRO_PEGPL_EARH 0x18 ++#define DCRO_PEGPL_EARL 0x19 ++#define DCRO_PEGPL_EATR 0x1a ++ ++/* DMER mask */ ++#define GPL_DMER_MASK_DISA 0x02000000 ++ ++/* ++ * System DCRs (SDRs) ++ */ ++#define PESDR0_PLLLCT1 0x03a0 ++#define PESDR0_PLLLCT2 0x03a1 ++#define PESDR0_PLLLCT3 0x03a2 ++ ++/* ++ * 440SPe additional DCRs ++ */ ++#define PESDR0_440SPE_UTLSET1 0x0300 ++#define PESDR0_440SPE_UTLSET2 0x0301 ++#define PESDR0_440SPE_DLPSET 0x0302 ++#define PESDR0_440SPE_LOOP 0x0303 ++#define PESDR0_440SPE_RCSSET 0x0304 ++#define PESDR0_440SPE_RCSSTS 0x0305 ++#define PESDR0_440SPE_HSSL0SET1 0x0306 ++#define PESDR0_440SPE_HSSL0SET2 0x0307 ++#define PESDR0_440SPE_HSSL0STS 0x0308 ++#define PESDR0_440SPE_HSSL1SET1 0x0309 ++#define PESDR0_440SPE_HSSL1SET2 0x030a ++#define PESDR0_440SPE_HSSL1STS 0x030b ++#define PESDR0_440SPE_HSSL2SET1 0x030c ++#define PESDR0_440SPE_HSSL2SET2 0x030d ++#define PESDR0_440SPE_HSSL2STS 0x030e ++#define PESDR0_440SPE_HSSL3SET1 0x030f ++#define PESDR0_440SPE_HSSL3SET2 0x0310 ++#define PESDR0_440SPE_HSSL3STS 0x0311 ++#define PESDR0_440SPE_HSSL4SET1 0x0312 ++#define PESDR0_440SPE_HSSL4SET2 0x0313 ++#define PESDR0_440SPE_HSSL4STS 0x0314 ++#define PESDR0_440SPE_HSSL5SET1 0x0315 ++#define PESDR0_440SPE_HSSL5SET2 0x0316 ++#define PESDR0_440SPE_HSSL5STS 0x0317 ++#define PESDR0_440SPE_HSSL6SET1 0x0318 ++#define PESDR0_440SPE_HSSL6SET2 0x0319 ++#define PESDR0_440SPE_HSSL6STS 0x031a ++#define PESDR0_440SPE_HSSL7SET1 0x031b ++#define PESDR0_440SPE_HSSL7SET2 0x031c ++#define PESDR0_440SPE_HSSL7STS 0x031d ++#define PESDR0_440SPE_HSSCTLSET 0x031e ++#define PESDR0_440SPE_LANE_ABCD 0x031f ++#define PESDR0_440SPE_LANE_EFGH 0x0320 ++ ++#define PESDR1_440SPE_UTLSET1 0x0340 ++#define PESDR1_440SPE_UTLSET2 0x0341 ++#define PESDR1_440SPE_DLPSET 0x0342 ++#define PESDR1_440SPE_LOOP 0x0343 ++#define PESDR1_440SPE_RCSSET 0x0344 ++#define PESDR1_440SPE_RCSSTS 0x0345 ++#define PESDR1_440SPE_HSSL0SET1 0x0346 ++#define PESDR1_440SPE_HSSL0SET2 0x0347 ++#define PESDR1_440SPE_HSSL0STS 0x0348 ++#define PESDR1_440SPE_HSSL1SET1 0x0349 ++#define PESDR1_440SPE_HSSL1SET2 0x034a ++#define PESDR1_440SPE_HSSL1STS 0x034b ++#define PESDR1_440SPE_HSSL2SET1 0x034c ++#define PESDR1_440SPE_HSSL2SET2 0x034d ++#define PESDR1_440SPE_HSSL2STS 0x034e ++#define PESDR1_440SPE_HSSL3SET1 0x034f ++#define PESDR1_440SPE_HSSL3SET2 0x0350 ++#define PESDR1_440SPE_HSSL3STS 0x0351 ++#define PESDR1_440SPE_HSSCTLSET 0x0352 ++#define PESDR1_440SPE_LANE_ABCD 0x0353 ++ ++#define PESDR2_440SPE_UTLSET1 0x0370 ++#define PESDR2_440SPE_UTLSET2 0x0371 ++#define PESDR2_440SPE_DLPSET 0x0372 ++#define PESDR2_440SPE_LOOP 0x0373 ++#define PESDR2_440SPE_RCSSET 0x0374 ++#define PESDR2_440SPE_RCSSTS 0x0375 ++#define PESDR2_440SPE_HSSL0SET1 0x0376 ++#define PESDR2_440SPE_HSSL0SET2 0x0377 ++#define PESDR2_440SPE_HSSL0STS 0x0378 ++#define PESDR2_440SPE_HSSL1SET1 0x0379 ++#define PESDR2_440SPE_HSSL1SET2 0x037a ++#define PESDR2_440SPE_HSSL1STS 0x037b ++#define PESDR2_440SPE_HSSL2SET1 0x037c ++#define PESDR2_440SPE_HSSL2SET2 0x037d ++#define PESDR2_440SPE_HSSL2STS 0x037e ++#define PESDR2_440SPE_HSSL3SET1 0x037f ++#define PESDR2_440SPE_HSSL3SET2 0x0380 ++#define PESDR2_440SPE_HSSL3STS 0x0381 ++#define PESDR2_440SPE_HSSCTLSET 0x0382 ++#define PESDR2_440SPE_LANE_ABCD 0x0383 ++ ++/* ++ * 405EX additional DCRs ++ */ ++#define PESDR0_405EX_UTLSET1 0x0400 ++#define PESDR0_405EX_UTLSET2 0x0401 ++#define PESDR0_405EX_DLPSET 0x0402 ++#define PESDR0_405EX_LOOP 0x0403 ++#define PESDR0_405EX_RCSSET 0x0404 ++#define PESDR0_405EX_RCSSTS 0x0405 ++#define PESDR0_405EX_PHYSET1 0x0406 ++#define PESDR0_405EX_PHYSET2 0x0407 ++#define PESDR0_405EX_BIST 0x0408 ++#define PESDR0_405EX_LPB 0x040B ++#define PESDR0_405EX_PHYSTA 0x040C ++ ++#define PESDR1_405EX_UTLSET1 0x0440 ++#define PESDR1_405EX_UTLSET2 0x0441 ++#define PESDR1_405EX_DLPSET 0x0442 ++#define PESDR1_405EX_LOOP 0x0443 ++#define PESDR1_405EX_RCSSET 0x0444 ++#define PESDR1_405EX_RCSSTS 0x0445 ++#define PESDR1_405EX_PHYSET1 0x0446 ++#define PESDR1_405EX_PHYSET2 0x0447 ++#define PESDR1_405EX_BIST 0x0448 ++#define PESDR1_405EX_LPB 0x044B ++#define PESDR1_405EX_PHYSTA 0x044C ++ ++/* ++ * Of the above, some are common offsets from the base ++ */ ++#define PESDRn_UTLSET1 0x00 ++#define PESDRn_UTLSET2 0x01 ++#define PESDRn_DLPSET 0x02 ++#define PESDRn_LOOP 0x03 ++#define PESDRn_RCSSET 0x04 ++#define PESDRn_RCSSTS 0x05 ++ ++/* 440spe only */ ++#define PESDRn_440SPE_HSSL0SET1 0x06 ++#define PESDRn_440SPE_HSSL0SET2 0x07 ++#define PESDRn_440SPE_HSSL0STS 0x08 ++#define PESDRn_440SPE_HSSL1SET1 0x09 ++#define PESDRn_440SPE_HSSL1SET2 0x0a ++#define PESDRn_440SPE_HSSL1STS 0x0b ++#define PESDRn_440SPE_HSSL2SET1 0x0c ++#define PESDRn_440SPE_HSSL2SET2 0x0d ++#define PESDRn_440SPE_HSSL2STS 0x0e ++#define PESDRn_440SPE_HSSL3SET1 0x0f ++#define PESDRn_440SPE_HSSL3SET2 0x10 ++#define PESDRn_440SPE_HSSL3STS 0x11 ++ ++/* 440spe port 0 only */ ++#define PESDRn_440SPE_HSSL4SET1 0x12 ++#define PESDRn_440SPE_HSSL4SET2 0x13 ++#define PESDRn_440SPE_HSSL4STS 0x14 ++#define PESDRn_440SPE_HSSL5SET1 0x15 ++#define PESDRn_440SPE_HSSL5SET2 0x16 ++#define PESDRn_440SPE_HSSL5STS 0x17 ++#define PESDRn_440SPE_HSSL6SET1 0x18 ++#define PESDRn_440SPE_HSSL6SET2 0x19 ++#define PESDRn_440SPE_HSSL6STS 0x1a ++#define PESDRn_440SPE_HSSL7SET1 0x1b ++#define PESDRn_440SPE_HSSL7SET2 0x1c ++#define PESDRn_440SPE_HSSL7STS 0x1d ++ ++/* 405ex only */ ++#define PESDRn_405EX_PHYSET1 0x06 ++#define PESDRn_405EX_PHYSET2 0x07 ++#define PESDRn_405EX_PHYSTA 0x0c ++ ++/* ++ * UTL register offsets ++ */ ++#define PEUTL_PBCTL 0x00 ++#define PEUTL_PBBSZ 0x20 ++#define PEUTL_OPDBSZ 0x68 ++#define PEUTL_IPHBSZ 0x70 ++#define PEUTL_IPDBSZ 0x78 ++#define PEUTL_OUTTR 0x90 ++#define PEUTL_INTR 0x98 ++#define PEUTL_PCTL 0xa0 ++#define PEUTL_RCSTA 0xB0 ++#define PEUTL_RCIRQEN 0xb8 ++ ++/* ++ * Config space register offsets ++ */ ++#define PECFG_ECRTCTL 0x074 ++ ++#define PECFG_BAR0LMPA 0x210 ++#define PECFG_BAR0HMPA 0x214 ++#define PECFG_BAR1MPA 0x218 ++#define PECFG_BAR2LMPA 0x220 ++#define PECFG_BAR2HMPA 0x224 ++ ++#define PECFG_PIMEN 0x33c ++#define PECFG_PIM0LAL 0x340 ++#define PECFG_PIM0LAH 0x344 ++#define PECFG_PIM1LAL 0x348 ++#define PECFG_PIM1LAH 0x34c ++#define PECFG_PIM01SAL 0x350 ++#define PECFG_PIM01SAH 0x354 ++ ++#define PECFG_POM0LAL 0x380 ++#define PECFG_POM0LAH 0x384 ++#define PECFG_POM1LAL 0x388 ++#define PECFG_POM1LAH 0x38c ++#define PECFG_POM2LAL 0x390 ++#define PECFG_POM2LAH 0x394 ++ ++ ++enum ++{ ++ PTYPE_ENDPOINT = 0x0, ++ PTYPE_LEGACY_ENDPOINT = 0x1, ++ PTYPE_ROOT_PORT = 0x4, ++ ++ LNKW_X1 = 0x1, ++ LNKW_X4 = 0x4, ++ LNKW_X8 = 0x8 ++}; ++ ++ ++#endif /* __PPC4XX_PCI_H__ */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/qe_lib/Kconfig powerpc.git/arch/powerpc/sysdev/qe_lib/Kconfig +--- linux-2.6.24/arch/powerpc/sysdev/qe_lib/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/qe_lib/Kconfig 2008-01-28 20:25:49.000000000 +0100 +@@ -4,7 +4,7 @@ + + config UCC_SLOW + bool +- default n ++ default y if SERIAL_QE + help + This option provides qe_lib support to UCC slow + protocols: UART, BISYNC, QMC +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/qe_lib/qe.c powerpc.git/arch/powerpc/sysdev/qe_lib/qe.c +--- linux-2.6.24/arch/powerpc/sysdev/qe_lib/qe.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/qe_lib/qe.c 2008-01-28 20:25:49.000000000 +0100 +@@ -25,6 +25,7 @@ + #include <linux/module.h> + #include <linux/delay.h> + #include <linux/ioport.h> ++#include <linux/crc32.h> + #include <asm/irq.h> + #include <asm/page.h> + #include <asm/pgtable.h> +@@ -167,19 +168,20 @@ + + /* Program the BRG to the given sampling rate and multiplier + * +- * @brg: the BRG, 1-16 ++ * @brg: the BRG, QE_BRG1 - QE_BRG16 + * @rate: the desired sampling rate + * @multiplier: corresponds to the value programmed in GUMR_L[RDCR] or + * GUMR_L[TDCR]. E.g., if this BRG is the RX clock, and GUMR_L[RDCR]=01, + * then 'multiplier' should be 8. +- * +- * Also note that the value programmed into the BRGC register must be even. + */ +-void qe_setbrg(unsigned int brg, unsigned int rate, unsigned int multiplier) ++int qe_setbrg(enum qe_clock brg, unsigned int rate, unsigned int multiplier) + { + u32 divisor, tempval; + u32 div16 = 0; + ++ if ((brg < QE_BRG1) || (brg > QE_BRG16)) ++ return -EINVAL; ++ + divisor = get_brg_clk() / (rate * multiplier); + + if (divisor > QE_BRGC_DIVISOR_MAX + 1) { +@@ -196,8 +198,43 @@ + tempval = ((divisor - 1) << QE_BRGC_DIVISOR_SHIFT) | + QE_BRGC_ENABLE | div16; + +- out_be32(&qe_immr->brg.brgc[brg - 1], tempval); ++ out_be32(&qe_immr->brg.brgc[brg - QE_BRG1], tempval); ++ ++ return 0; ++} ++EXPORT_SYMBOL(qe_setbrg); ++ ++/* Convert a string to a QE clock source enum ++ * ++ * This function takes a string, typically from a property in the device ++ * tree, and returns the corresponding "enum qe_clock" value. ++*/ ++enum qe_clock qe_clock_source(const char *source) ++{ ++ unsigned int i; ++ ++ if (strcasecmp(source, "none") == 0) ++ return QE_CLK_NONE; ++ ++ if (strncasecmp(source, "brg", 3) == 0) { ++ i = simple_strtoul(source + 3, NULL, 10); ++ if ((i >= 1) && (i <= 16)) ++ return (QE_BRG1 - 1) + i; ++ else ++ return QE_CLK_DUMMY; ++ } ++ ++ if (strncasecmp(source, "clk", 3) == 0) { ++ i = simple_strtoul(source + 3, NULL, 10); ++ if ((i >= 1) && (i <= 24)) ++ return (QE_CLK1 - 1) + i; ++ else ++ return QE_CLK_DUMMY; ++ } ++ ++ return QE_CLK_DUMMY; + } ++EXPORT_SYMBOL(qe_clock_source); + + /* Initialize SNUMs (thread serial numbers) according to + * QE Module Control chapter, SNUM table +@@ -358,3 +395,249 @@ + return (void *)&qe_immr->muram[offset]; + } + EXPORT_SYMBOL(qe_muram_addr); ++ ++/* The maximum number of RISCs we support */ ++#define MAX_QE_RISC 2 ++ ++/* Firmware information stored here for qe_get_firmware_info() */ ++static struct qe_firmware_info qe_firmware_info; ++ ++/* ++ * Set to 1 if QE firmware has been uploaded, and therefore ++ * qe_firmware_info contains valid data. ++ */ ++static int qe_firmware_uploaded; ++ ++/* ++ * Upload a QE microcode ++ * ++ * This function is a worker function for qe_upload_firmware(). It does ++ * the actual uploading of the microcode. ++ */ ++static void qe_upload_microcode(const void *base, ++ const struct qe_microcode *ucode) ++{ ++ const __be32 *code = base + be32_to_cpu(ucode->code_offset); ++ unsigned int i; ++ ++ if (ucode->major || ucode->minor || ucode->revision) ++ printk(KERN_INFO "qe-firmware: " ++ "uploading microcode '%s' version %u.%u.%u\n", ++ ucode->id, ucode->major, ucode->minor, ucode->revision); ++ else ++ printk(KERN_INFO "qe-firmware: " ++ "uploading microcode '%s'\n", ucode->id); ++ ++ /* Use auto-increment */ ++ out_be32(&qe_immr->iram.iadd, be32_to_cpu(ucode->iram_offset) | ++ QE_IRAM_IADD_AIE | QE_IRAM_IADD_BADDR); ++ ++ for (i = 0; i < be32_to_cpu(ucode->count); i++) ++ out_be32(&qe_immr->iram.idata, be32_to_cpu(code[i])); ++} ++ ++/* ++ * Upload a microcode to the I-RAM at a specific address. ++ * ++ * See Documentation/powerpc/qe-firmware.txt for information on QE microcode ++ * uploading. ++ * ++ * Currently, only version 1 is supported, so the 'version' field must be ++ * set to 1. ++ * ++ * The SOC model and revision are not validated, they are only displayed for ++ * informational purposes. ++ * ++ * 'calc_size' is the calculated size, in bytes, of the firmware structure and ++ * all of the microcode structures, minus the CRC. ++ * ++ * 'length' is the size that the structure says it is, including the CRC. ++ */ ++int qe_upload_firmware(const struct qe_firmware *firmware) ++{ ++ unsigned int i; ++ unsigned int j; ++ u32 crc; ++ size_t calc_size = sizeof(struct qe_firmware); ++ size_t length; ++ const struct qe_header *hdr; ++ ++ if (!firmware) { ++ printk(KERN_ERR "qe-firmware: invalid pointer\n"); ++ return -EINVAL; ++ } ++ ++ hdr = &firmware->header; ++ length = be32_to_cpu(hdr->length); ++ ++ /* Check the magic */ ++ if ((hdr->magic[0] != 'Q') || (hdr->magic[1] != 'E') || ++ (hdr->magic[2] != 'F')) { ++ printk(KERN_ERR "qe-firmware: not a microcode\n"); ++ return -EPERM; ++ } ++ ++ /* Check the version */ ++ if (hdr->version != 1) { ++ printk(KERN_ERR "qe-firmware: unsupported version\n"); ++ return -EPERM; ++ } ++ ++ /* Validate some of the fields */ ++ if ((firmware->count < 1) || (firmware->count >= MAX_QE_RISC)) { ++ printk(KERN_ERR "qe-firmware: invalid data\n"); ++ return -EINVAL; ++ } ++ ++ /* Validate the length and check if there's a CRC */ ++ calc_size += (firmware->count - 1) * sizeof(struct qe_microcode); ++ ++ for (i = 0; i < firmware->count; i++) ++ /* ++ * For situations where the second RISC uses the same microcode ++ * as the first, the 'code_offset' and 'count' fields will be ++ * zero, so it's okay to add those. ++ */ ++ calc_size += sizeof(__be32) * ++ be32_to_cpu(firmware->microcode[i].count); ++ ++ /* Validate the length */ ++ if (length != calc_size + sizeof(__be32)) { ++ printk(KERN_ERR "qe-firmware: invalid length\n"); ++ return -EPERM; ++ } ++ ++ /* Validate the CRC */ ++ crc = be32_to_cpu(*(__be32 *)((void *)firmware + calc_size)); ++ if (crc != crc32(0, firmware, calc_size)) { ++ printk(KERN_ERR "qe-firmware: firmware CRC is invalid\n"); ++ return -EIO; ++ } ++ ++ /* ++ * If the microcode calls for it, split the I-RAM. ++ */ ++ if (!firmware->split) ++ setbits16(&qe_immr->cp.cercr, QE_CP_CERCR_CIR); ++ ++ if (firmware->soc.model) ++ printk(KERN_INFO ++ "qe-firmware: firmware '%s' for %u V%u.%u\n", ++ firmware->id, be16_to_cpu(firmware->soc.model), ++ firmware->soc.major, firmware->soc.minor); ++ else ++ printk(KERN_INFO "qe-firmware: firmware '%s'\n", ++ firmware->id); ++ ++ /* ++ * The QE only supports one microcode per RISC, so clear out all the ++ * saved microcode information and put in the new. ++ */ ++ memset(&qe_firmware_info, 0, sizeof(qe_firmware_info)); ++ strcpy(qe_firmware_info.id, firmware->id); ++ qe_firmware_info.extended_modes = firmware->extended_modes; ++ memcpy(qe_firmware_info.vtraps, firmware->vtraps, ++ sizeof(firmware->vtraps)); ++ ++ /* Loop through each microcode. */ ++ for (i = 0; i < firmware->count; i++) { ++ const struct qe_microcode *ucode = &firmware->microcode[i]; ++ ++ /* Upload a microcode if it's present */ ++ if (ucode->code_offset) ++ qe_upload_microcode(firmware, ucode); ++ ++ /* Program the traps for this processor */ ++ for (j = 0; j < 16; j++) { ++ u32 trap = be32_to_cpu(ucode->traps[j]); ++ ++ if (trap) ++ out_be32(&qe_immr->rsp[i].tibcr[j], trap); ++ } ++ ++ /* Enable traps */ ++ out_be32(&qe_immr->rsp[i].eccr, be32_to_cpu(ucode->eccr)); ++ } ++ ++ qe_firmware_uploaded = 1; ++ ++ return 0; ++} ++EXPORT_SYMBOL(qe_upload_firmware); ++ ++/* ++ * Get info on the currently-loaded firmware ++ * ++ * This function also checks the device tree to see if the boot loader has ++ * uploaded a firmware already. ++ */ ++struct qe_firmware_info *qe_get_firmware_info(void) ++{ ++ static int initialized; ++ struct property *prop; ++ struct device_node *qe; ++ struct device_node *fw = NULL; ++ const char *sprop; ++ unsigned int i; ++ ++ /* ++ * If we haven't checked yet, and a driver hasn't uploaded a firmware ++ * yet, then check the device tree for information. ++ */ ++ if (initialized || qe_firmware_uploaded) ++ return NULL; ++ ++ initialized = 1; ++ ++ /* ++ * Newer device trees have an "fsl,qe" compatible property for the QE ++ * node, but we still need to support older device trees. ++ */ ++ qe = of_find_compatible_node(NULL, NULL, "fsl,qe"); ++ if (!qe) { ++ qe = of_find_node_by_type(NULL, "qe"); ++ if (!qe) ++ return NULL; ++ } ++ ++ /* Find the 'firmware' child node */ ++ for_each_child_of_node(qe, fw) { ++ if (strcmp(fw->name, "firmware") == 0) ++ break; ++ } ++ ++ of_node_put(qe); ++ ++ /* Did we find the 'firmware' node? */ ++ if (!fw) ++ return NULL; ++ ++ qe_firmware_uploaded = 1; ++ ++ /* Copy the data into qe_firmware_info*/ ++ sprop = of_get_property(fw, "id", NULL); ++ if (sprop) ++ strncpy(qe_firmware_info.id, sprop, ++ sizeof(qe_firmware_info.id) - 1); ++ ++ prop = of_find_property(fw, "extended-modes", NULL); ++ if (prop && (prop->length == sizeof(u64))) { ++ const u64 *iprop = prop->value; ++ ++ qe_firmware_info.extended_modes = *iprop; ++ } ++ ++ prop = of_find_property(fw, "virtual-traps", NULL); ++ if (prop && (prop->length == 32)) { ++ const u32 *iprop = prop->value; ++ ++ for (i = 0; i < ARRAY_SIZE(qe_firmware_info.vtraps); i++) ++ qe_firmware_info.vtraps[i] = iprop[i]; ++ } ++ ++ of_node_put(fw); ++ ++ return &qe_firmware_info; ++} ++EXPORT_SYMBOL(qe_get_firmware_info); ++ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/qe_lib/ucc_slow.c powerpc.git/arch/powerpc/sysdev/qe_lib/ucc_slow.c +--- linux-2.6.24/arch/powerpc/sysdev/qe_lib/ucc_slow.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/qe_lib/ucc_slow.c 2008-01-28 20:25:49.000000000 +0100 +@@ -19,6 +19,7 @@ + #include <linux/stddef.h> + #include <linux/interrupt.h> + #include <linux/err.h> ++#include <linux/module.h> + + #include <asm/io.h> + #include <asm/immap_qe.h> +@@ -41,6 +42,7 @@ + default: return QE_CR_SUBBLOCK_INVALID; + } + } ++EXPORT_SYMBOL(ucc_slow_get_qe_cr_subblock); + + void ucc_slow_poll_transmitter_now(struct ucc_slow_private * uccs) + { +@@ -56,6 +58,7 @@ + qe_issue_cmd(QE_GRACEFUL_STOP_TX, id, + QE_CR_PROTOCOL_UNSPECIFIED, 0); + } ++EXPORT_SYMBOL(ucc_slow_graceful_stop_tx); + + void ucc_slow_stop_tx(struct ucc_slow_private * uccs) + { +@@ -65,6 +68,7 @@ + id = ucc_slow_get_qe_cr_subblock(us_info->ucc_num); + qe_issue_cmd(QE_STOP_TX, id, QE_CR_PROTOCOL_UNSPECIFIED, 0); + } ++EXPORT_SYMBOL(ucc_slow_stop_tx); + + void ucc_slow_restart_tx(struct ucc_slow_private * uccs) + { +@@ -74,6 +78,7 @@ + id = ucc_slow_get_qe_cr_subblock(us_info->ucc_num); + qe_issue_cmd(QE_RESTART_TX, id, QE_CR_PROTOCOL_UNSPECIFIED, 0); + } ++EXPORT_SYMBOL(ucc_slow_restart_tx); + + void ucc_slow_enable(struct ucc_slow_private * uccs, enum comm_dir mode) + { +@@ -94,6 +99,7 @@ + } + out_be32(&us_regs->gumr_l, gumr_l); + } ++EXPORT_SYMBOL(ucc_slow_enable); + + void ucc_slow_disable(struct ucc_slow_private * uccs, enum comm_dir mode) + { +@@ -114,6 +120,7 @@ + } + out_be32(&us_regs->gumr_l, gumr_l); + } ++EXPORT_SYMBOL(ucc_slow_disable); + + /* Initialize the UCC for Slow operations + * +@@ -347,6 +354,7 @@ + *uccs_ret = uccs; + return 0; + } ++EXPORT_SYMBOL(ucc_slow_init); + + void ucc_slow_free(struct ucc_slow_private * uccs) + { +@@ -366,5 +374,5 @@ + + kfree(uccs); + } +- ++EXPORT_SYMBOL(ucc_slow_free); + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/tsi108_dev.c powerpc.git/arch/powerpc/sysdev/tsi108_dev.c +--- linux-2.6.24/arch/powerpc/sysdev/tsi108_dev.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/tsi108_dev.c 2008-01-28 20:25:49.000000000 +0100 +@@ -66,14 +66,12 @@ + static int __init tsi108_eth_of_init(void) + { + struct device_node *np; +- unsigned int i; ++ unsigned int i = 0; + struct platform_device *tsi_eth_dev; + struct resource res; + int ret; + +- for (np = NULL, i = 0; +- (np = of_find_compatible_node(np, "network", "tsi108-ethernet")) != NULL; +- i++) { ++ for_each_compatible_node(np, "network", "tsi108-ethernet") { + struct resource r[2]; + struct device_node *phy, *mdio; + hw_info tsi_eth_data; +@@ -98,7 +96,7 @@ + __FUNCTION__,r[1].name, r[1].start, r[1].end); + + tsi_eth_dev = +- platform_device_register_simple("tsi-ethernet", i, &r[0], ++ platform_device_register_simple("tsi-ethernet", i++, &r[0], + 1); + + if (IS_ERR(tsi_eth_dev)) { +@@ -154,6 +152,7 @@ + unreg: + platform_device_unregister(tsi_eth_dev); + err: ++ of_node_put(np); + return ret; + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/uic.c powerpc.git/arch/powerpc/sysdev/uic.c +--- linux-2.6.24/arch/powerpc/sysdev/uic.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/uic.c 2008-01-28 20:25:49.000000000 +0100 +@@ -53,21 +53,23 @@ + + /* The remapper for this UIC */ + struct irq_host *irqhost; +- +- /* For secondary UICs, the cascade interrupt's irqaction */ +- struct irqaction cascade; + }; + + static void uic_unmask_irq(unsigned int virq) + { ++ struct irq_desc *desc = get_irq_desc(virq); + struct uic *uic = get_irq_chip_data(virq); + unsigned int src = uic_irq_to_hw(virq); + unsigned long flags; +- u32 er; ++ u32 er, sr; + ++ sr = 1 << (31-src); + spin_lock_irqsave(&uic->lock, flags); ++ /* ack level-triggered interrupts here */ ++ if (desc->status & IRQ_LEVEL) ++ mtdcr(uic->dcrbase + UIC_SR, sr); + er = mfdcr(uic->dcrbase + UIC_ER); +- er |= 1 << (31 - src); ++ er |= sr; + mtdcr(uic->dcrbase + UIC_ER, er); + spin_unlock_irqrestore(&uic->lock, flags); + } +@@ -99,6 +101,7 @@ + + static void uic_mask_ack_irq(unsigned int virq) + { ++ struct irq_desc *desc = get_irq_desc(virq); + struct uic *uic = get_irq_chip_data(virq); + unsigned int src = uic_irq_to_hw(virq); + unsigned long flags; +@@ -109,7 +112,16 @@ + er = mfdcr(uic->dcrbase + UIC_ER); + er &= ~sr; + mtdcr(uic->dcrbase + UIC_ER, er); +- mtdcr(uic->dcrbase + UIC_SR, sr); ++ /* On the UIC, acking (i.e. clearing the SR bit) ++ * a level irq will have no effect if the interrupt ++ * is still asserted by the device, even if ++ * the interrupt is already masked. Therefore ++ * we only ack the egde interrupts here, while ++ * level interrupts are ack'ed after the actual ++ * isr call in the uic_unmask_irq() ++ */ ++ if (!(desc->status & IRQ_LEVEL)) ++ mtdcr(uic->dcrbase + UIC_SR, sr); + spin_unlock_irqrestore(&uic->lock, flags); + } + +@@ -173,64 +185,6 @@ + .set_type = uic_set_irq_type, + }; + +-/** +- * handle_uic_irq - irq flow handler for UIC +- * @irq: the interrupt number +- * @desc: the interrupt description structure for this irq +- * +- * This is modified version of the generic handle_level_irq() suitable +- * for the UIC. On the UIC, acking (i.e. clearing the SR bit) a level +- * irq will have no effect if the interrupt is still asserted by the +- * device, even if the interrupt is already masked. Therefore, unlike +- * the standard handle_level_irq(), we must ack the interrupt *after* +- * invoking the ISR (which should have de-asserted the interrupt in +- * the external source). For edge interrupts we ack at the beginning +- * instead of the end, to keep the window in which we can miss an +- * interrupt as small as possible. +- */ +-void fastcall handle_uic_irq(unsigned int irq, struct irq_desc *desc) +-{ +- unsigned int cpu = smp_processor_id(); +- struct irqaction *action; +- irqreturn_t action_ret; +- +- spin_lock(&desc->lock); +- if (desc->status & IRQ_LEVEL) +- desc->chip->mask(irq); +- else +- desc->chip->mask_ack(irq); +- +- if (unlikely(desc->status & IRQ_INPROGRESS)) +- goto out_unlock; +- desc->status &= ~(IRQ_REPLAY | IRQ_WAITING); +- kstat_cpu(cpu).irqs[irq]++; +- +- /* +- * If its disabled or no action available +- * keep it masked and get out of here +- */ +- action = desc->action; +- if (unlikely(!action || (desc->status & IRQ_DISABLED))) { +- desc->status |= IRQ_PENDING; +- goto out_unlock; +- } +- +- desc->status |= IRQ_INPROGRESS; +- desc->status &= ~IRQ_PENDING; +- spin_unlock(&desc->lock); +- +- action_ret = handle_IRQ_event(irq, action); +- +- spin_lock(&desc->lock); +- desc->status &= ~IRQ_INPROGRESS; +- if (desc->status & IRQ_LEVEL) +- desc->chip->ack(irq); +- if (!(desc->status & IRQ_DISABLED) && desc->chip->unmask) +- desc->chip->unmask(irq); +-out_unlock: +- spin_unlock(&desc->lock); +-} +- + static int uic_host_map(struct irq_host *h, unsigned int virq, + irq_hw_number_t hw) + { +@@ -239,7 +193,7 @@ + set_irq_chip_data(virq, uic); + /* Despite the name, handle_level_irq() works for both level + * and edge irqs on UIC. FIXME: check this is correct */ +- set_irq_chip_and_handler(virq, &uic_irq_chip, handle_uic_irq); ++ set_irq_chip_and_handler(virq, &uic_irq_chip, handle_level_irq); + + /* Set default irq type */ + set_irq_type(virq, IRQ_TYPE_NONE); +@@ -264,23 +218,36 @@ + .xlate = uic_host_xlate, + }; + +-irqreturn_t uic_cascade(int virq, void *data) ++void uic_irq_cascade(unsigned int virq, struct irq_desc *desc) + { +- struct uic *uic = data; ++ struct uic *uic = get_irq_data(virq); + u32 msr; + int src; + int subvirq; + ++ spin_lock(&desc->lock); ++ if (desc->status & IRQ_LEVEL) ++ desc->chip->mask(virq); ++ else ++ desc->chip->mask_ack(virq); ++ spin_unlock(&desc->lock); ++ + msr = mfdcr(uic->dcrbase + UIC_MSR); + if (!msr) /* spurious interrupt */ +- return IRQ_HANDLED; ++ goto uic_irq_ret; + + src = 32 - ffs(msr); + + subvirq = irq_linear_revmap(uic->irqhost, src); + generic_handle_irq(subvirq); + +- return IRQ_HANDLED; ++uic_irq_ret: ++ spin_lock(&desc->lock); ++ if (desc->status & IRQ_LEVEL) ++ desc->chip->ack(virq); ++ if (!(desc->status & IRQ_DISABLED) && desc->chip->unmask) ++ desc->chip->unmask(virq); ++ spin_unlock(&desc->lock); + } + + static struct uic * __init uic_init_one(struct device_node *node) +@@ -342,33 +309,27 @@ + const u32 *interrupts; + + /* First locate and initialize the top-level UIC */ +- +- np = of_find_compatible_node(NULL, NULL, "ibm,uic"); +- while (np) { ++ for_each_compatible_node(np, NULL, "ibm,uic") { + interrupts = of_get_property(np, "interrupts", NULL); +- if (! interrupts) ++ if (!interrupts) + break; +- +- np = of_find_compatible_node(np, NULL, "ibm,uic"); + } + + BUG_ON(!np); /* uic_init_tree() assumes there's a UIC as the + * top-level interrupt controller */ + primary_uic = uic_init_one(np); +- if (! primary_uic) ++ if (!primary_uic) + panic("Unable to initialize primary UIC %s\n", np->full_name); + + irq_set_default_host(primary_uic->irqhost); + of_node_put(np); + + /* The scan again for cascaded UICs */ +- np = of_find_compatible_node(NULL, NULL, "ibm,uic"); +- while (np) { ++ for_each_compatible_node(np, NULL, "ibm,uic") { + interrupts = of_get_property(np, "interrupts", NULL); + if (interrupts) { + /* Secondary UIC */ + int cascade_virq; +- int ret; + + uic = uic_init_one(np); + if (! uic) +@@ -377,20 +338,11 @@ + + cascade_virq = irq_of_parse_and_map(np, 0); + +- uic->cascade.handler = uic_cascade; +- uic->cascade.name = "UIC cascade"; +- uic->cascade.dev_id = uic; +- +- ret = setup_irq(cascade_virq, &uic->cascade); +- if (ret) +- printk(KERN_ERR "Failed to setup_irq(%d) for " +- "UIC%d cascade\n", cascade_virq, +- uic->index); ++ set_irq_data(cascade_virq, uic); ++ set_irq_chained_handler(cascade_virq, uic_irq_cascade); + + /* FIXME: setup critical cascade?? */ + } +- +- np = of_find_compatible_node(np, NULL, "ibm,uic"); + } + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/sysdev/xilinx_intc.c powerpc.git/arch/powerpc/sysdev/xilinx_intc.c +--- linux-2.6.24/arch/powerpc/sysdev/xilinx_intc.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/sysdev/xilinx_intc.c 2008-01-28 20:25:49.000000000 +0100 +@@ -135,10 +135,16 @@ + struct device_node *np; + + /* find top level interrupt controller */ +- for_each_compatible_node(np, NULL, "xilinx,intc") { ++ for_each_compatible_node(np, NULL, "xlnx,opb-intc-1.00.c") { + if (!of_get_property(np, "interrupts", NULL)) + break; + } ++ if (!np) { ++ for_each_compatible_node(np, NULL, "xlnx,xps-intc-1.00.a") { ++ if (!of_get_property(np, "interrupts", NULL)) ++ break; ++ } ++ } + + /* xilinx interrupt controller needs to be top level */ + BUG_ON(!np); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/xmon/setjmp.S powerpc.git/arch/powerpc/xmon/setjmp.S +--- linux-2.6.24/arch/powerpc/xmon/setjmp.S 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/xmon/setjmp.S 2008-01-28 20:25:49.000000000 +0100 +@@ -12,67 +12,6 @@ + #include <asm/ppc_asm.h> + #include <asm/asm-offsets.h> + +-_GLOBAL(xmon_setjmp) +- mflr r0 +- PPC_STL r0,0(r3) +- PPC_STL r1,SZL(r3) +- PPC_STL r2,2*SZL(r3) +- mfcr r0 +- PPC_STL r0,3*SZL(r3) +- PPC_STL r13,4*SZL(r3) +- PPC_STL r14,5*SZL(r3) +- PPC_STL r15,6*SZL(r3) +- PPC_STL r16,7*SZL(r3) +- PPC_STL r17,8*SZL(r3) +- PPC_STL r18,9*SZL(r3) +- PPC_STL r19,10*SZL(r3) +- PPC_STL r20,11*SZL(r3) +- PPC_STL r21,12*SZL(r3) +- PPC_STL r22,13*SZL(r3) +- PPC_STL r23,14*SZL(r3) +- PPC_STL r24,15*SZL(r3) +- PPC_STL r25,16*SZL(r3) +- PPC_STL r26,17*SZL(r3) +- PPC_STL r27,18*SZL(r3) +- PPC_STL r28,19*SZL(r3) +- PPC_STL r29,20*SZL(r3) +- PPC_STL r30,21*SZL(r3) +- PPC_STL r31,22*SZL(r3) +- li r3,0 +- blr +- +-_GLOBAL(xmon_longjmp) +- PPC_LCMPI r4,0 +- bne 1f +- li r4,1 +-1: PPC_LL r13,4*SZL(r3) +- PPC_LL r14,5*SZL(r3) +- PPC_LL r15,6*SZL(r3) +- PPC_LL r16,7*SZL(r3) +- PPC_LL r17,8*SZL(r3) +- PPC_LL r18,9*SZL(r3) +- PPC_LL r19,10*SZL(r3) +- PPC_LL r20,11*SZL(r3) +- PPC_LL r21,12*SZL(r3) +- PPC_LL r22,13*SZL(r3) +- PPC_LL r23,14*SZL(r3) +- PPC_LL r24,15*SZL(r3) +- PPC_LL r25,16*SZL(r3) +- PPC_LL r26,17*SZL(r3) +- PPC_LL r27,18*SZL(r3) +- PPC_LL r28,19*SZL(r3) +- PPC_LL r29,20*SZL(r3) +- PPC_LL r30,21*SZL(r3) +- PPC_LL r31,22*SZL(r3) +- PPC_LL r0,3*SZL(r3) +- mtcrf 0x38,r0 +- PPC_LL r0,0(r3) +- PPC_LL r1,SZL(r3) +- PPC_LL r2,2*SZL(r3) +- mtlr r0 +- mr r3,r4 +- blr +- + /* + * Grab the register values as they are now. + * This won't do a particularily good job because we really +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/powerpc/xmon/xmon.c powerpc.git/arch/powerpc/xmon/xmon.c +--- linux-2.6.24/arch/powerpc/xmon/xmon.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/powerpc/xmon/xmon.c 2008-01-28 20:25:49.000000000 +0100 +@@ -40,6 +40,7 @@ + #include <asm/spu.h> + #include <asm/spu_priv1.h> + #include <asm/firmware.h> ++#include <asm/setjmp.h> + + #ifdef CONFIG_PPC64 + #include <asm/hvcall.h> +@@ -71,12 +72,9 @@ + static int termch; + static char tmpstr[128]; + +-#define JMP_BUF_LEN 23 + static long bus_error_jmp[JMP_BUF_LEN]; + static int catch_memory_errors; + static long *xmon_fault_jmp[NR_CPUS]; +-#define setjmp xmon_setjmp +-#define longjmp xmon_longjmp + + /* Breakpoint stuff */ + struct bpt { +@@ -153,13 +151,15 @@ + + static int do_spu_cmd(void); + ++#ifdef CONFIG_44x ++static void dump_tlb_44x(void); ++#endif ++ + int xmon_no_auto_backtrace; + + extern void xmon_enter(void); + extern void xmon_leave(void); + +-extern long setjmp(long *); +-extern void longjmp(long *, long); + extern void xmon_save_regs(struct pt_regs *); + + #ifdef CONFIG_PPC64 +@@ -231,6 +231,9 @@ + #ifdef CONFIG_PPC_STD_MMU_32 + " u dump segment registers\n" + #endif ++#ifdef CONFIG_44x ++" u dump TLB\n" ++#endif + " ? help\n" + " zr reboot\n\ + zh halt\n" +@@ -856,6 +859,11 @@ + dump_segments(); + break; + #endif ++#ifdef CONFIG_4xx ++ case 'u': ++ dump_tlb_44x(); ++ break; ++#endif + default: + printf("Unrecognized command: "); + do { +@@ -2527,16 +2535,33 @@ + static void dump_slb(void) + { + int i; +- unsigned long tmp; ++ unsigned long esid,vsid,valid; ++ unsigned long llp; + + printf("SLB contents of cpu %x\n", smp_processor_id()); + +- for (i = 0; i < SLB_NUM_ENTRIES; i++) { +- asm volatile("slbmfee %0,%1" : "=r" (tmp) : "r" (i)); +- printf("%02d %016lx ", i, tmp); +- +- asm volatile("slbmfev %0,%1" : "=r" (tmp) : "r" (i)); +- printf("%016lx\n", tmp); ++ for (i = 0; i < mmu_slb_size; i++) { ++ asm volatile("slbmfee %0,%1" : "=r" (esid) : "r" (i)); ++ asm volatile("slbmfev %0,%1" : "=r" (vsid) : "r" (i)); ++ valid = (esid & SLB_ESID_V); ++ if (valid | esid | vsid) { ++ printf("%02d %016lx %016lx", i, esid, vsid); ++ if (valid) { ++ llp = vsid & SLB_VSID_LLP; ++ if (vsid & SLB_VSID_B_1T) { ++ printf(" 1T ESID=%9lx VSID=%13lx LLP:%3lx \n", ++ GET_ESID_1T(esid), ++ (vsid & ~SLB_VSID_B) >> SLB_VSID_SHIFT_1T, ++ llp); ++ } else { ++ printf(" 256M ESID=%9lx VSID=%13lx LLP:%3lx \n", ++ GET_ESID(esid), ++ (vsid & ~SLB_VSID_B) >> SLB_VSID_SHIFT, ++ llp); ++ } ++ } else ++ printf("\n"); ++ } + } + } + +@@ -2581,6 +2606,32 @@ + } + #endif + ++#ifdef CONFIG_44x ++static void dump_tlb_44x(void) ++{ ++ int i; ++ ++ for (i = 0; i < PPC44x_TLB_SIZE; i++) { ++ unsigned long w0,w1,w2; ++ asm volatile("tlbre %0,%1,0" : "=r" (w0) : "r" (i)); ++ asm volatile("tlbre %0,%1,1" : "=r" (w1) : "r" (i)); ++ asm volatile("tlbre %0,%1,2" : "=r" (w2) : "r" (i)); ++ printf("[%02x] %08x %08x %08x ", i, w0, w1, w2); ++ if (w0 & PPC44x_TLB_VALID) { ++ printf("V %08x -> %01x%08x %c%c%c%c%c", ++ w0 & PPC44x_TLB_EPN_MASK, ++ w1 & PPC44x_TLB_ERPN_MASK, ++ w1 & PPC44x_TLB_RPN_MASK, ++ (w2 & PPC44x_TLB_W) ? 'W' : 'w', ++ (w2 & PPC44x_TLB_I) ? 'I' : 'i', ++ (w2 & PPC44x_TLB_M) ? 'M' : 'm', ++ (w2 & PPC44x_TLB_G) ? 'G' : 'g', ++ (w2 & PPC44x_TLB_E) ? 'E' : 'e'); ++ } ++ printf("\n"); ++ } ++} ++#endif /* CONFIG_44x */ + void xmon_init(int enable) + { + #ifdef CONFIG_PPC_ISERIES +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/kernel/Makefile powerpc.git/arch/ppc/kernel/Makefile +--- linux-2.6.24/arch/ppc/kernel/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/kernel/Makefile 2008-01-28 20:25:50.000000000 +0100 +@@ -13,7 +13,6 @@ + ppc_htab.o + obj-$(CONFIG_MODULES) += ppc_ksyms.o + obj-$(CONFIG_PCI) += pci.o +-obj-$(CONFIG_RAPIDIO) += rio.o + obj-$(CONFIG_KGDB) += ppc-stub.o + obj-$(CONFIG_SMP) += smp.o smp-tbsync.o + obj-$(CONFIG_KEXEC) += machine_kexec.o relocate_kernel.o +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/kernel/head_44x.S powerpc.git/arch/ppc/kernel/head_44x.S +--- linux-2.6.24/arch/ppc/kernel/head_44x.S 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/kernel/head_44x.S 2008-01-28 20:25:50.000000000 +0100 +@@ -195,7 +195,7 @@ + li r5,0 + ori r5,r5,(PPC44x_TLB_SW | PPC44x_TLB_SR | PPC44x_TLB_I | PPC44x_TLB_G) + +- li r0,0 /* TLB slot 0 */ ++ li r0,62 /* TLB slot 62 */ + + tlbwe r3,r0,PPC44x_TLB_PAGEID /* Load the pageid fields */ + tlbwe r4,r0,PPC44x_TLB_XLAT /* Load the translation fields */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/kernel/ppc_htab.c powerpc.git/arch/ppc/kernel/ppc_htab.c +--- linux-2.6.24/arch/ppc/kernel/ppc_htab.c 2008-01-28 20:50:10.000000000 +0100 ++++ powerpc.git/arch/ppc/kernel/ppc_htab.c 2008-01-28 20:25:50.000000000 +0100 +@@ -436,6 +436,7 @@ + */ + static ctl_table htab_ctl_table[]={ + { ++ .ctl_name = KERN_PPC_L2CR, + .procname = "l2cr", + .mode = 0644, + .proc_handler = &proc_dol2crvec, +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/kernel/rio.c powerpc.git/arch/ppc/kernel/rio.c +--- linux-2.6.24/arch/ppc/kernel/rio.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/kernel/rio.c 1970-01-01 01:00:00.000000000 +0100 +@@ -1,52 +0,0 @@ +-/* +- * RapidIO PPC32 support +- * +- * Copyright 2005 MontaVista Software, Inc. +- * Matt Porter <mporter@kernel.crashing.org> +- * +- * This program is free software; you can redistribute it and/or modify it +- * under the terms of the GNU General Public License as published by the +- * Free Software Foundation; either version 2 of the License, or (at your +- * option) any later version. +- */ +- +-#include <linux/init.h> +-#include <linux/kernel.h> +-#include <linux/rio.h> +- +-#include <asm/rio.h> +- +-/** +- * platform_rio_init - Do platform specific RIO init +- * +- * Any platform specific initialization of RapdIO +- * hardware is done here as well as registration +- * of any active master ports in the system. +- */ +-void __attribute__ ((weak)) +- platform_rio_init(void) +-{ +- printk(KERN_WARNING "RIO: No platform_rio_init() present\n"); +-} +- +-/** +- * ppc_rio_init - Do PPC32 RIO init +- * +- * Calls platform-specific RIO init code and then calls +- * rio_init_mports() to initialize any master ports that +- * have been registered with the RIO subsystem. +- */ +-static int __init ppc_rio_init(void) +-{ +- printk(KERN_INFO "RIO: RapidIO init\n"); +- +- /* Platform specific initialization */ +- platform_rio_init(); +- +- /* Enumerate all registered ports */ +- rio_init_mports(); +- +- return 0; +-} +- +-subsys_initcall(ppc_rio_init); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/kernel/setup.c powerpc.git/arch/ppc/kernel/setup.c +--- linux-2.6.24/arch/ppc/kernel/setup.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/kernel/setup.c 2008-01-28 20:25:50.000000000 +0100 +@@ -37,7 +37,6 @@ + #include <asm/nvram.h> + #include <asm/xmon.h> + #include <asm/ocp.h> +-#include <asm/prom.h> + + #define USES_PPC_SYS (defined(CONFIG_85xx) || defined(CONFIG_83xx) || \ + defined(CONFIG_MPC10X_BRIDGE) || defined(CONFIG_8260) || \ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/kernel/traps.c powerpc.git/arch/ppc/kernel/traps.c +--- linux-2.6.24/arch/ppc/kernel/traps.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/kernel/traps.c 2008-01-28 20:25:50.000000000 +0100 +@@ -231,39 +231,25 @@ + { + } + +-void machine_check_exception(struct pt_regs *regs) ++#if defined(CONFIG_4xx) ++int machine_check_4xx(struct pt_regs *regs) + { + unsigned long reason = get_mc_reason(regs); + +- if (user_mode(regs)) { +- regs->msr |= MSR_RI; +- _exception(SIGBUS, regs, BUS_ADRERR, regs->nip); +- return; +- } +- +-#if defined(CONFIG_8xx) && defined(CONFIG_PCI) +- /* the qspan pci read routines can cause machine checks -- Cort */ +- bad_page_fault(regs, regs->dar, SIGBUS); +- return; +-#endif +- +- if (debugger_fault_handler) { +- debugger_fault_handler(regs); +- regs->msr |= MSR_RI; +- return; +- } +- +- if (check_io_access(regs)) +- return; +- +-#if defined(CONFIG_4xx) && !defined(CONFIG_440A) + if (reason & ESR_IMCP) { + printk("Instruction"); + mtspr(SPRN_ESR, reason & ~ESR_IMCP); + } else + printk("Data"); + printk(" machine check in kernel mode.\n"); +-#elif defined(CONFIG_440A) ++ ++ return 0; ++} ++ ++int machine_check_440A(struct pt_regs *regs) ++{ ++ unsigned long reason = get_mc_reason(regs); ++ + printk("Machine check in kernel mode.\n"); + if (reason & ESR_IMCP){ + printk("Instruction Synchronous Machine Check exception\n"); +@@ -293,7 +279,13 @@ + /* Clear MCSR */ + mtspr(SPRN_MCSR, mcsr); + } +-#elif defined (CONFIG_E500) ++ return 0; ++} ++#elif defined(CONFIG_E500) ++int machine_check_e500(struct pt_regs *regs) ++{ ++ unsigned long reason = get_mc_reason(regs); ++ + printk("Machine check in kernel mode.\n"); + printk("Caused by (from MCSR=%lx): ", reason); + +@@ -305,8 +297,6 @@ + printk("Data Cache Push Parity Error\n"); + if (reason & MCSR_DCPERR) + printk("Data Cache Parity Error\n"); +- if (reason & MCSR_GL_CI) +- printk("Guarded Load or Cache-Inhibited stwcx.\n"); + if (reason & MCSR_BUS_IAERR) + printk("Bus - Instruction Address Error\n"); + if (reason & MCSR_BUS_RAERR) +@@ -318,12 +308,19 @@ + if (reason & MCSR_BUS_RBERR) + printk("Bus - Read Data Bus Error\n"); + if (reason & MCSR_BUS_WBERR) +- printk("Bus - Write Data Bus Error\n"); ++ printk("Bus - Read Data Bus Error\n"); + if (reason & MCSR_BUS_IPERR) + printk("Bus - Instruction Parity Error\n"); + if (reason & MCSR_BUS_RPERR) + printk("Bus - Read Parity Error\n"); +-#elif defined (CONFIG_E200) ++ ++ return 0; ++} ++#elif defined(CONFIG_E200) ++int machine_check_e200(struct pt_regs *regs) ++{ ++ unsigned long reason = get_mc_reason(regs); ++ + printk("Machine check in kernel mode.\n"); + printk("Caused by (from MCSR=%lx): ", reason); + +@@ -341,7 +338,14 @@ + printk("Bus - Read Bus Error on data load\n"); + if (reason & MCSR_BUS_WRERR) + printk("Bus - Write Bus Error on buffered store or cache line push\n"); +-#else /* !CONFIG_4xx && !CONFIG_E500 && !CONFIG_E200 */ ++ ++ return 0; ++} ++#else ++int machine_check_generic(struct pt_regs *regs) ++{ ++ unsigned long reason = get_mc_reason(regs); ++ + printk("Machine check in kernel mode.\n"); + printk("Caused by (from SRR1=%lx): ", reason); + switch (reason & 0x601F0000) { +@@ -371,7 +375,39 @@ + default: + printk("Unknown values in msr\n"); + } +-#endif /* CONFIG_4xx */ ++ return 0; ++} ++#endif /* everything else */ ++ ++void machine_check_exception(struct pt_regs *regs) ++{ ++ int recover = 0; ++ ++ if (cur_cpu_spec->machine_check) ++ recover = cur_cpu_spec->machine_check(regs); ++ if (recover > 0) ++ return; ++ ++ if (user_mode(regs)) { ++ regs->msr |= MSR_RI; ++ _exception(SIGBUS, regs, BUS_ADRERR, regs->nip); ++ return; ++ } ++ ++#if defined(CONFIG_8xx) && defined(CONFIG_PCI) ++ /* the qspan pci read routines can cause machine checks -- Cort */ ++ bad_page_fault(regs, regs->dar, SIGBUS); ++ return; ++#endif ++ ++ if (debugger_fault_handler) { ++ debugger_fault_handler(regs); ++ regs->msr |= MSR_RI; ++ return; ++ } ++ ++ if (check_io_access(regs)) ++ return; + + /* + * Optional platform-provided routine to print out +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/mm/44x_mmu.c powerpc.git/arch/ppc/mm/44x_mmu.c +--- linux-2.6.24/arch/ppc/mm/44x_mmu.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/mm/44x_mmu.c 2008-01-28 20:25:51.000000000 +0100 +@@ -60,38 +60,28 @@ + * Just needed it declared someplace. + */ + unsigned int tlb_44x_index = 0; +-unsigned int tlb_44x_hwater = 62; ++unsigned int tlb_44x_hwater = PPC4XX_TLB_SIZE - 1 - PPC44x_EARLY_TLBS; + int icache_44x_need_flush; + + /* + * "Pins" a 256MB TLB entry in AS0 for kernel lowmem + */ +-static void __init +-ppc44x_pin_tlb(int slot, unsigned int virt, unsigned int phys) ++static void __init ppc44x_pin_tlb(unsigned int virt, unsigned int phys) + { +- unsigned long attrib = 0; +- +- __asm__ __volatile__("\ +- clrrwi %2,%2,10\n\ +- ori %2,%2,%4\n\ +- clrrwi %1,%1,10\n\ +- li %0,0\n\ +- ori %0,%0,%5\n\ +- tlbwe %2,%3,%6\n\ +- tlbwe %1,%3,%7\n\ +- tlbwe %0,%3,%8" ++ __asm__ __volatile__( ++ "tlbwe %2,%3,%4\n" ++ "tlbwe %1,%3,%5\n" ++ "tlbwe %0,%3,%6\n" + : +- : "r" (attrib), "r" (phys), "r" (virt), "r" (slot), +- "i" (PPC44x_TLB_VALID | PPC44x_TLB_256M), +- "i" (PPC44x_TLB_SW | PPC44x_TLB_SR | PPC44x_TLB_SX | PPC44x_TLB_G), ++ : "r" (PPC44x_TLB_SW | PPC44x_TLB_SR | PPC44x_TLB_SX | PPC44x_TLB_G), ++ "r" (phys), ++ "r" (virt | PPC44x_TLB_VALID | PPC44x_TLB_256M), ++ "r" (tlb_44x_hwater--), /* slot for this TLB entry */ + "i" (PPC44x_TLB_PAGEID), + "i" (PPC44x_TLB_XLAT), + "i" (PPC44x_TLB_ATTRIB)); + } + +-/* +- * MMU_init_hw does the chip-specific initialization of the MMU hardware. +- */ + void __init MMU_init_hw(void) + { + flush_instruction_cache(); +@@ -99,22 +89,13 @@ + + unsigned long __init mmu_mapin_ram(void) + { +- unsigned int pinned_tlbs = 1; +- int i; +- +- /* Determine number of entries necessary to cover lowmem */ +- pinned_tlbs = (unsigned int) +- (_ALIGN(total_lowmem, PPC_PIN_SIZE) >> PPC44x_PIN_SHIFT); +- +- /* Write upper watermark to save location */ +- tlb_44x_hwater = PPC44x_LOW_SLOT - pinned_tlbs; ++ unsigned long addr; + +- /* If necessary, set additional pinned TLBs */ +- if (pinned_tlbs > 1) +- for (i = (PPC44x_LOW_SLOT-(pinned_tlbs-1)); i < PPC44x_LOW_SLOT; i++) { +- unsigned int phys_addr = (PPC44x_LOW_SLOT-i) * PPC_PIN_SIZE; +- ppc44x_pin_tlb(i, phys_addr+PAGE_OFFSET, phys_addr); +- } ++ /* Pin in enough TLBs to cover any lowmem not covered by the ++ * initial 256M mapping established in head_44x.S */ ++ for (addr = PPC_PIN_SIZE; addr < total_lowmem; ++ addr += PPC_PIN_SIZE) ++ ppc44x_pin_tlb(addr + PAGE_OFFSET, addr); + + return total_lowmem; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/platforms/85xx/mpc85xx_ads_common.c powerpc.git/arch/ppc/platforms/85xx/mpc85xx_ads_common.c +--- linux-2.6.24/arch/ppc/platforms/85xx/mpc85xx_ads_common.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/platforms/85xx/mpc85xx_ads_common.c 2008-01-28 20:25:51.000000000 +0100 +@@ -42,8 +42,6 @@ + + #include <mm/mmu_decl.h> + +-#include <syslib/ppc85xx_rio.h> +- + #include <platforms/85xx/mpc85xx_ads_common.h> + + #ifndef CONFIG_PCI +@@ -190,6 +188,7 @@ + #endif /* CONFIG_PCI */ + + #ifdef CONFIG_RAPIDIO ++extern void mpc85xx_rio_setup(int law_start, int law_size); + void platform_rio_init(void) + { + /* 512MB RIO LAW at 0xc0000000 */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/platforms/85xx/stx_gp3.c powerpc.git/arch/ppc/platforms/85xx/stx_gp3.c +--- linux-2.6.24/arch/ppc/platforms/85xx/stx_gp3.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/platforms/85xx/stx_gp3.c 2008-01-28 20:25:51.000000000 +0100 +@@ -50,12 +50,10 @@ + #include <asm/irq.h> + #include <asm/immap_85xx.h> + #include <asm/cpm2.h> +-#include <asm/mpc85xx.h> + #include <asm/ppc_sys.h> + + #include <syslib/cpm2_pic.h> + #include <syslib/ppc85xx_common.h> +-#include <syslib/ppc85xx_rio.h> + + + unsigned char __res[sizeof(bd_t)]; +@@ -271,6 +269,7 @@ + #endif /* CONFIG_PCI */ + + #ifdef CONFIG_RAPIDIO ++extern void mpc85xx_rio_setup(int law_start, int law_size); + void + platform_rio_init(void) + { +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/platforms/85xx/tqm85xx.c powerpc.git/arch/ppc/platforms/85xx/tqm85xx.c +--- linux-2.6.24/arch/ppc/platforms/85xx/tqm85xx.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/platforms/85xx/tqm85xx.c 2008-01-28 20:25:51.000000000 +0100 +@@ -54,7 +54,6 @@ + #include <syslib/ppc85xx_setup.h> + #include <syslib/cpm2_pic.h> + #include <syslib/ppc85xx_common.h> +-#include <syslib/ppc85xx_rio.h> + + #ifndef CONFIG_PCI + unsigned long isa_io_base = 0; +@@ -309,6 +308,7 @@ + #endif /* CONFIG_PCI */ + + #ifdef CONFIG_RAPIDIO ++extern void mpc85xx_rio_setup(int law_start, int law_size); + void platform_rio_init(void) + { + /* 512MB RIO LAW at 0xc0000000 */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/platforms/ev64260.c powerpc.git/arch/ppc/platforms/ev64260.c +--- linux-2.6.24/arch/ppc/platforms/ev64260.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/platforms/ev64260.c 2008-01-28 20:25:51.000000000 +0100 +@@ -336,7 +336,7 @@ + #endif + + if (early_serial_setup(&port) != 0) +- printk(KERN_WARNING "Early serial init of port 0" ++ printk(KERN_WARNING "Early serial init of port 0 " + "failed\n"); + + first_time = 0; +@@ -388,7 +388,7 @@ + ev64260_early_serial_map(); + #endif + +- printk(KERN_INFO "%s %s port (C) 2001 MontaVista Software, Inc." ++ printk(KERN_INFO "%s %s port (C) 2001 MontaVista Software, Inc. " + "(source@mvista.com)\n", BOARD_VENDOR, BOARD_MACHINE); + + if (ppc_md.progress) +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/platforms/prep_pci.c powerpc.git/arch/ppc/platforms/prep_pci.c +--- linux-2.6.24/arch/ppc/platforms/prep_pci.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/platforms/prep_pci.c 2008-01-28 20:25:52.000000000 +0100 +@@ -1099,7 +1099,6 @@ + pci_write_config_byte(dev, 0x43, reg); + } + } +- pci_dev_put(dev); + } + + if ((dev = pci_get_device(PCI_VENDOR_ID_WINBOND, +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/syslib/Makefile powerpc.git/arch/ppc/syslib/Makefile +--- linux-2.6.24/arch/ppc/syslib/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/syslib/Makefile 2008-01-28 20:25:52.000000000 +0100 +@@ -93,7 +93,6 @@ + ifeq ($(CONFIG_85xx),y) + obj-$(CONFIG_PCI) += pci_auto.o + endif +-obj-$(CONFIG_RAPIDIO) += ppc85xx_rio.o + obj-$(CONFIG_83xx) += ppc83xx_setup.o ppc_sys.o \ + mpc83xx_sys.o mpc83xx_devices.o ipic.o + ifeq ($(CONFIG_83xx),y) +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/syslib/gt64260_pic.c powerpc.git/arch/ppc/syslib/gt64260_pic.c +--- linux-2.6.24/arch/ppc/syslib/gt64260_pic.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/syslib/gt64260_pic.c 2008-01-28 20:25:52.000000000 +0100 +@@ -35,7 +35,6 @@ + #include <linux/interrupt.h> + #include <linux/sched.h> + #include <linux/signal.h> +-#include <linux/stddef.h> + #include <linux/delay.h> + #include <linux/irq.h> + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/syslib/mpc52xx_pic.c powerpc.git/arch/ppc/syslib/mpc52xx_pic.c +--- linux-2.6.24/arch/ppc/syslib/mpc52xx_pic.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/syslib/mpc52xx_pic.c 2008-01-28 20:25:52.000000000 +0100 +@@ -20,7 +20,6 @@ + #include <linux/init.h> + #include <linux/sched.h> + #include <linux/signal.h> +-#include <linux/stddef.h> + #include <linux/delay.h> + #include <linux/irq.h> + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/syslib/mv64360_pic.c powerpc.git/arch/ppc/syslib/mv64360_pic.c +--- linux-2.6.24/arch/ppc/syslib/mv64360_pic.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/syslib/mv64360_pic.c 2008-01-28 20:25:52.000000000 +0100 +@@ -36,7 +36,6 @@ + #include <linux/init.h> + #include <linux/sched.h> + #include <linux/signal.h> +-#include <linux/stddef.h> + #include <linux/delay.h> + #include <linux/irq.h> + #include <linux/interrupt.h> +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/syslib/ocp.c powerpc.git/arch/ppc/syslib/ocp.c +--- linux-2.6.24/arch/ppc/syslib/ocp.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/syslib/ocp.c 2008-01-28 20:25:52.000000000 +0100 +@@ -376,7 +376,7 @@ + + down_write(&ocp_devices_sem); + dev = __ocp_find_device(vendor, function, index); +- list_del((struct list_head *)dev); ++ list_del(&dev->link); + up_write(&ocp_devices_sem); + + DBG(("ocp: ocp_remove_one_device(vendor: %x, function: %x, index: %d)... done.\n", vendor, function, index)); +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/syslib/ppc83xx_setup.c powerpc.git/arch/ppc/syslib/ppc83xx_setup.c +--- linux-2.6.24/arch/ppc/syslib/ppc83xx_setup.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/syslib/ppc83xx_setup.c 2008-01-28 20:25:52.000000000 +0100 +@@ -41,7 +41,6 @@ + + #include <syslib/ppc83xx_setup.h> + #if defined(CONFIG_PCI) +-#include <asm/delay.h> + #include <syslib/ppc83xx_pci.h> + #endif + +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/syslib/ppc85xx_rio.c powerpc.git/arch/ppc/syslib/ppc85xx_rio.c +--- linux-2.6.24/arch/ppc/syslib/ppc85xx_rio.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/syslib/ppc85xx_rio.c 1970-01-01 01:00:00.000000000 +0100 +@@ -1,932 +0,0 @@ +-/* +- * MPC85xx RapidIO support +- * +- * Copyright 2005 MontaVista Software, Inc. +- * Matt Porter <mporter@kernel.crashing.org> +- * +- * This program is free software; you can redistribute it and/or modify it +- * under the terms of the GNU General Public License as published by the +- * Free Software Foundation; either version 2 of the License, or (at your +- * option) any later version. +- */ +- +-#include <linux/init.h> +-#include <linux/module.h> +-#include <linux/types.h> +-#include <linux/dma-mapping.h> +-#include <linux/interrupt.h> +-#include <linux/rio.h> +-#include <linux/rio_drv.h> +- +-#include <asm/io.h> +- +-#define RIO_REGS_BASE (CCSRBAR + 0xc0000) +-#define RIO_ATMU_REGS_OFFSET 0x10c00 +-#define RIO_MSG_REGS_OFFSET 0x11000 +-#define RIO_MAINT_WIN_SIZE 0x400000 +-#define RIO_DBELL_WIN_SIZE 0x1000 +- +-#define RIO_MSG_OMR_MUI 0x00000002 +-#define RIO_MSG_OSR_TE 0x00000080 +-#define RIO_MSG_OSR_QOI 0x00000020 +-#define RIO_MSG_OSR_QFI 0x00000010 +-#define RIO_MSG_OSR_MUB 0x00000004 +-#define RIO_MSG_OSR_EOMI 0x00000002 +-#define RIO_MSG_OSR_QEI 0x00000001 +- +-#define RIO_MSG_IMR_MI 0x00000002 +-#define RIO_MSG_ISR_TE 0x00000080 +-#define RIO_MSG_ISR_QFI 0x00000010 +-#define RIO_MSG_ISR_DIQI 0x00000001 +- +-#define RIO_MSG_DESC_SIZE 32 +-#define RIO_MSG_BUFFER_SIZE 4096 +-#define RIO_MIN_TX_RING_SIZE 2 +-#define RIO_MAX_TX_RING_SIZE 2048 +-#define RIO_MIN_RX_RING_SIZE 2 +-#define RIO_MAX_RX_RING_SIZE 2048 +- +-#define DOORBELL_DMR_DI 0x00000002 +-#define DOORBELL_DSR_TE 0x00000080 +-#define DOORBELL_DSR_QFI 0x00000010 +-#define DOORBELL_DSR_DIQI 0x00000001 +-#define DOORBELL_TID_OFFSET 0x03 +-#define DOORBELL_SID_OFFSET 0x05 +-#define DOORBELL_INFO_OFFSET 0x06 +- +-#define DOORBELL_MESSAGE_SIZE 0x08 +-#define DBELL_SID(x) (*(u8 *)(x + DOORBELL_SID_OFFSET)) +-#define DBELL_TID(x) (*(u8 *)(x + DOORBELL_TID_OFFSET)) +-#define DBELL_INF(x) (*(u16 *)(x + DOORBELL_INFO_OFFSET)) +- +-struct rio_atmu_regs { +- u32 rowtar; +- u32 pad1; +- u32 rowbar; +- u32 pad2; +- u32 rowar; +- u32 pad3[3]; +-}; +- +-struct rio_msg_regs { +- u32 omr; +- u32 osr; +- u32 pad1; +- u32 odqdpar; +- u32 pad2; +- u32 osar; +- u32 odpr; +- u32 odatr; +- u32 odcr; +- u32 pad3; +- u32 odqepar; +- u32 pad4[13]; +- u32 imr; +- u32 isr; +- u32 pad5; +- u32 ifqdpar; +- u32 pad6; +- u32 ifqepar; +- u32 pad7[250]; +- u32 dmr; +- u32 dsr; +- u32 pad8; +- u32 dqdpar; +- u32 pad9; +- u32 dqepar; +- u32 pad10[26]; +- u32 pwmr; +- u32 pwsr; +- u32 pad11; +- u32 pwqbar; +-}; +- +-struct rio_tx_desc { +- u32 res1; +- u32 saddr; +- u32 dport; +- u32 dattr; +- u32 res2; +- u32 res3; +- u32 dwcnt; +- u32 res4; +-}; +- +-static u32 regs_win; +-static struct rio_atmu_regs *atmu_regs; +-static struct rio_atmu_regs *maint_atmu_regs; +-static struct rio_atmu_regs *dbell_atmu_regs; +-static u32 dbell_win; +-static u32 maint_win; +-static struct rio_msg_regs *msg_regs; +- +-static struct rio_dbell_ring { +- void *virt; +- dma_addr_t phys; +-} dbell_ring; +- +-static struct rio_msg_tx_ring { +- void *virt; +- dma_addr_t phys; +- void *virt_buffer[RIO_MAX_TX_RING_SIZE]; +- dma_addr_t phys_buffer[RIO_MAX_TX_RING_SIZE]; +- int tx_slot; +- int size; +- void *dev_id; +-} msg_tx_ring; +- +-static struct rio_msg_rx_ring { +- void *virt; +- dma_addr_t phys; +- void *virt_buffer[RIO_MAX_RX_RING_SIZE]; +- int rx_slot; +- int size; +- void *dev_id; +-} msg_rx_ring; +- +-/** +- * mpc85xx_rio_doorbell_send - Send a MPC85xx doorbell message +- * @index: ID of RapidIO interface +- * @destid: Destination ID of target device +- * @data: 16-bit info field of RapidIO doorbell message +- * +- * Sends a MPC85xx doorbell message. Returns %0 on success or +- * %-EINVAL on failure. +- */ +-static int mpc85xx_rio_doorbell_send(int index, u16 destid, u16 data) +-{ +- pr_debug("mpc85xx_doorbell_send: index %d destid %4.4x data %4.4x\n", +- index, destid, data); +- out_be32((void *)&dbell_atmu_regs->rowtar, destid << 22); +- out_be16((void *)(dbell_win), data); +- +- return 0; +-} +- +-/** +- * mpc85xx_local_config_read - Generate a MPC85xx local config space read +- * @index: ID of RapdiIO interface +- * @offset: Offset into configuration space +- * @len: Length (in bytes) of the maintenance transaction +- * @data: Value to be read into +- * +- * Generates a MPC85xx local configuration space read. Returns %0 on +- * success or %-EINVAL on failure. +- */ +-static int mpc85xx_local_config_read(int index, u32 offset, int len, u32 * data) +-{ +- pr_debug("mpc85xx_local_config_read: index %d offset %8.8x\n", index, +- offset); +- *data = in_be32((void *)(regs_win + offset)); +- +- return 0; +-} +- +-/** +- * mpc85xx_local_config_write - Generate a MPC85xx local config space write +- * @index: ID of RapdiIO interface +- * @offset: Offset into configuration space +- * @len: Length (in bytes) of the maintenance transaction +- * @data: Value to be written +- * +- * Generates a MPC85xx local configuration space write. Returns %0 on +- * success or %-EINVAL on failure. +- */ +-static int mpc85xx_local_config_write(int index, u32 offset, int len, u32 data) +-{ +- pr_debug +- ("mpc85xx_local_config_write: index %d offset %8.8x data %8.8x\n", +- index, offset, data); +- out_be32((void *)(regs_win + offset), data); +- +- return 0; +-} +- +-/** +- * mpc85xx_rio_config_read - Generate a MPC85xx read maintenance transaction +- * @index: ID of RapdiIO interface +- * @destid: Destination ID of transaction +- * @hopcount: Number of hops to target device +- * @offset: Offset into configuration space +- * @len: Length (in bytes) of the maintenance transaction +- * @val: Location to be read into +- * +- * Generates a MPC85xx read maintenance transaction. Returns %0 on +- * success or %-EINVAL on failure. +- */ +-static int +-mpc85xx_rio_config_read(int index, u16 destid, u8 hopcount, u32 offset, int len, +- u32 * val) +-{ +- u8 *data; +- +- pr_debug +- ("mpc85xx_rio_config_read: index %d destid %d hopcount %d offset %8.8x len %d\n", +- index, destid, hopcount, offset, len); +- out_be32((void *)&maint_atmu_regs->rowtar, +- (destid << 22) | (hopcount << 12) | ((offset & ~0x3) >> 9)); +- +- data = (u8 *) maint_win + offset; +- switch (len) { +- case 1: +- *val = in_8((u8 *) data); +- break; +- case 2: +- *val = in_be16((u16 *) data); +- break; +- default: +- *val = in_be32((u32 *) data); +- break; +- } +- +- return 0; +-} +- +-/** +- * mpc85xx_rio_config_write - Generate a MPC85xx write maintenance transaction +- * @index: ID of RapdiIO interface +- * @destid: Destination ID of transaction +- * @hopcount: Number of hops to target device +- * @offset: Offset into configuration space +- * @len: Length (in bytes) of the maintenance transaction +- * @val: Value to be written +- * +- * Generates an MPC85xx write maintenance transaction. Returns %0 on +- * success or %-EINVAL on failure. +- */ +-static int +-mpc85xx_rio_config_write(int index, u16 destid, u8 hopcount, u32 offset, +- int len, u32 val) +-{ +- u8 *data; +- pr_debug +- ("mpc85xx_rio_config_write: index %d destid %d hopcount %d offset %8.8x len %d val %8.8x\n", +- index, destid, hopcount, offset, len, val); +- out_be32((void *)&maint_atmu_regs->rowtar, +- (destid << 22) | (hopcount << 12) | ((offset & ~0x3) >> 9)); +- +- data = (u8 *) maint_win + offset; +- switch (len) { +- case 1: +- out_8((u8 *) data, val); +- break; +- case 2: +- out_be16((u16 *) data, val); +- break; +- default: +- out_be32((u32 *) data, val); +- break; +- } +- +- return 0; +-} +- +-/** +- * rio_hw_add_outb_message - Add message to the MPC85xx outbound message queue +- * @mport: Master port with outbound message queue +- * @rdev: Target of outbound message +- * @mbox: Outbound mailbox +- * @buffer: Message to add to outbound queue +- * @len: Length of message +- * +- * Adds the @buffer message to the MPC85xx outbound message queue. Returns +- * %0 on success or %-EINVAL on failure. +- */ +-int +-rio_hw_add_outb_message(struct rio_mport *mport, struct rio_dev *rdev, int mbox, +- void *buffer, size_t len) +-{ +- u32 omr; +- struct rio_tx_desc *desc = +- (struct rio_tx_desc *)msg_tx_ring.virt + msg_tx_ring.tx_slot; +- int ret = 0; +- +- pr_debug +- ("RIO: rio_hw_add_outb_message(): destid %4.4x mbox %d buffer %8.8x len %8.8x\n", +- rdev->destid, mbox, (int)buffer, len); +- +- if ((len < 8) || (len > RIO_MAX_MSG_SIZE)) { +- ret = -EINVAL; +- goto out; +- } +- +- /* Copy and clear rest of buffer */ +- memcpy(msg_tx_ring.virt_buffer[msg_tx_ring.tx_slot], buffer, len); +- if (len < (RIO_MAX_MSG_SIZE - 4)) +- memset((void *)((u32) msg_tx_ring. +- virt_buffer[msg_tx_ring.tx_slot] + len), 0, +- RIO_MAX_MSG_SIZE - len); +- +- /* Set mbox field for message */ +- desc->dport = mbox & 0x3; +- +- /* Enable EOMI interrupt, set priority, and set destid */ +- desc->dattr = 0x28000000 | (rdev->destid << 2); +- +- /* Set transfer size aligned to next power of 2 (in double words) */ +- desc->dwcnt = is_power_of_2(len) ? len : 1 << get_bitmask_order(len); +- +- /* Set snooping and source buffer address */ +- desc->saddr = 0x00000004 | msg_tx_ring.phys_buffer[msg_tx_ring.tx_slot]; +- +- /* Increment enqueue pointer */ +- omr = in_be32((void *)&msg_regs->omr); +- out_be32((void *)&msg_regs->omr, omr | RIO_MSG_OMR_MUI); +- +- /* Go to next descriptor */ +- if (++msg_tx_ring.tx_slot == msg_tx_ring.size) +- msg_tx_ring.tx_slot = 0; +- +- out: +- return ret; +-} +- +-EXPORT_SYMBOL_GPL(rio_hw_add_outb_message); +- +-/** +- * mpc85xx_rio_tx_handler - MPC85xx outbound message interrupt handler +- * @irq: Linux interrupt number +- * @dev_instance: Pointer to interrupt-specific data +- * +- * Handles outbound message interrupts. Executes a register outbound +- * mailbox event handler and acks the interrupt occurrence. +- */ +-static irqreturn_t +-mpc85xx_rio_tx_handler(int irq, void *dev_instance) +-{ +- int osr; +- struct rio_mport *port = (struct rio_mport *)dev_instance; +- +- osr = in_be32((void *)&msg_regs->osr); +- +- if (osr & RIO_MSG_OSR_TE) { +- pr_info("RIO: outbound message transmission error\n"); +- out_be32((void *)&msg_regs->osr, RIO_MSG_OSR_TE); +- goto out; +- } +- +- if (osr & RIO_MSG_OSR_QOI) { +- pr_info("RIO: outbound message queue overflow\n"); +- out_be32((void *)&msg_regs->osr, RIO_MSG_OSR_QOI); +- goto out; +- } +- +- if (osr & RIO_MSG_OSR_EOMI) { +- u32 dqp = in_be32((void *)&msg_regs->odqdpar); +- int slot = (dqp - msg_tx_ring.phys) >> 5; +- port->outb_msg[0].mcback(port, msg_tx_ring.dev_id, -1, slot); +- +- /* Ack the end-of-message interrupt */ +- out_be32((void *)&msg_regs->osr, RIO_MSG_OSR_EOMI); +- } +- +- out: +- return IRQ_HANDLED; +-} +- +-/** +- * rio_open_outb_mbox - Initialize MPC85xx outbound mailbox +- * @mport: Master port implementing the outbound message unit +- * @dev_id: Device specific pointer to pass on event +- * @mbox: Mailbox to open +- * @entries: Number of entries in the outbound mailbox ring +- * +- * Initializes buffer ring, request the outbound message interrupt, +- * and enables the outbound message unit. Returns %0 on success and +- * %-EINVAL or %-ENOMEM on failure. +- */ +-int rio_open_outb_mbox(struct rio_mport *mport, void *dev_id, int mbox, int entries) +-{ +- int i, j, rc = 0; +- +- if ((entries < RIO_MIN_TX_RING_SIZE) || +- (entries > RIO_MAX_TX_RING_SIZE) || (!is_power_of_2(entries))) { +- rc = -EINVAL; +- goto out; +- } +- +- /* Initialize shadow copy ring */ +- msg_tx_ring.dev_id = dev_id; +- msg_tx_ring.size = entries; +- +- for (i = 0; i < msg_tx_ring.size; i++) { +- if (! +- (msg_tx_ring.virt_buffer[i] = +- dma_alloc_coherent(NULL, RIO_MSG_BUFFER_SIZE, +- &msg_tx_ring.phys_buffer[i], +- GFP_KERNEL))) { +- rc = -ENOMEM; +- for (j = 0; j < msg_tx_ring.size; j++) +- if (msg_tx_ring.virt_buffer[j]) +- dma_free_coherent(NULL, +- RIO_MSG_BUFFER_SIZE, +- msg_tx_ring. +- virt_buffer[j], +- msg_tx_ring. +- phys_buffer[j]); +- goto out; +- } +- } +- +- /* Initialize outbound message descriptor ring */ +- if (!(msg_tx_ring.virt = dma_alloc_coherent(NULL, +- msg_tx_ring.size * +- RIO_MSG_DESC_SIZE, +- &msg_tx_ring.phys, +- GFP_KERNEL))) { +- rc = -ENOMEM; +- goto out_dma; +- } +- memset(msg_tx_ring.virt, 0, msg_tx_ring.size * RIO_MSG_DESC_SIZE); +- msg_tx_ring.tx_slot = 0; +- +- /* Point dequeue/enqueue pointers at first entry in ring */ +- out_be32((void *)&msg_regs->odqdpar, msg_tx_ring.phys); +- out_be32((void *)&msg_regs->odqepar, msg_tx_ring.phys); +- +- /* Configure for snooping */ +- out_be32((void *)&msg_regs->osar, 0x00000004); +- +- /* Clear interrupt status */ +- out_be32((void *)&msg_regs->osr, 0x000000b3); +- +- /* Hook up outbound message handler */ +- if ((rc = +- request_irq(MPC85xx_IRQ_RIO_TX, mpc85xx_rio_tx_handler, 0, +- "msg_tx", (void *)mport)) < 0) +- goto out_irq; +- +- /* +- * Configure outbound message unit +- * Snooping +- * Interrupts (all enabled, except QEIE) +- * Chaining mode +- * Disable +- */ +- out_be32((void *)&msg_regs->omr, 0x00100220); +- +- /* Set number of entries */ +- out_be32((void *)&msg_regs->omr, +- in_be32((void *)&msg_regs->omr) | +- ((get_bitmask_order(entries) - 2) << 12)); +- +- /* Now enable the unit */ +- out_be32((void *)&msg_regs->omr, in_be32((void *)&msg_regs->omr) | 0x1); +- +- out: +- return rc; +- +- out_irq: +- dma_free_coherent(NULL, msg_tx_ring.size * RIO_MSG_DESC_SIZE, +- msg_tx_ring.virt, msg_tx_ring.phys); +- +- out_dma: +- for (i = 0; i < msg_tx_ring.size; i++) +- dma_free_coherent(NULL, RIO_MSG_BUFFER_SIZE, +- msg_tx_ring.virt_buffer[i], +- msg_tx_ring.phys_buffer[i]); +- +- return rc; +-} +- +-/** +- * rio_close_outb_mbox - Shut down MPC85xx outbound mailbox +- * @mport: Master port implementing the outbound message unit +- * @mbox: Mailbox to close +- * +- * Disables the outbound message unit, free all buffers, and +- * frees the outbound message interrupt. +- */ +-void rio_close_outb_mbox(struct rio_mport *mport, int mbox) +-{ +- /* Disable inbound message unit */ +- out_be32((void *)&msg_regs->omr, 0); +- +- /* Free ring */ +- dma_free_coherent(NULL, msg_tx_ring.size * RIO_MSG_DESC_SIZE, +- msg_tx_ring.virt, msg_tx_ring.phys); +- +- /* Free interrupt */ +- free_irq(MPC85xx_IRQ_RIO_TX, (void *)mport); +-} +- +-/** +- * mpc85xx_rio_rx_handler - MPC85xx inbound message interrupt handler +- * @irq: Linux interrupt number +- * @dev_instance: Pointer to interrupt-specific data +- * +- * Handles inbound message interrupts. Executes a registered inbound +- * mailbox event handler and acks the interrupt occurrence. +- */ +-static irqreturn_t +-mpc85xx_rio_rx_handler(int irq, void *dev_instance) +-{ +- int isr; +- struct rio_mport *port = (struct rio_mport *)dev_instance; +- +- isr = in_be32((void *)&msg_regs->isr); +- +- if (isr & RIO_MSG_ISR_TE) { +- pr_info("RIO: inbound message reception error\n"); +- out_be32((void *)&msg_regs->isr, RIO_MSG_ISR_TE); +- goto out; +- } +- +- /* XXX Need to check/dispatch until queue empty */ +- if (isr & RIO_MSG_ISR_DIQI) { +- /* +- * We implement *only* mailbox 0, but can receive messages +- * for any mailbox/letter to that mailbox destination. So, +- * make the callback with an unknown/invalid mailbox number +- * argument. +- */ +- port->inb_msg[0].mcback(port, msg_rx_ring.dev_id, -1, -1); +- +- /* Ack the queueing interrupt */ +- out_be32((void *)&msg_regs->isr, RIO_MSG_ISR_DIQI); +- } +- +- out: +- return IRQ_HANDLED; +-} +- +-/** +- * rio_open_inb_mbox - Initialize MPC85xx inbound mailbox +- * @mport: Master port implementing the inbound message unit +- * @dev_id: Device specific pointer to pass on event +- * @mbox: Mailbox to open +- * @entries: Number of entries in the inbound mailbox ring +- * +- * Initializes buffer ring, request the inbound message interrupt, +- * and enables the inbound message unit. Returns %0 on success +- * and %-EINVAL or %-ENOMEM on failure. +- */ +-int rio_open_inb_mbox(struct rio_mport *mport, void *dev_id, int mbox, int entries) +-{ +- int i, rc = 0; +- +- if ((entries < RIO_MIN_RX_RING_SIZE) || +- (entries > RIO_MAX_RX_RING_SIZE) || (!is_power_of_2(entries))) { +- rc = -EINVAL; +- goto out; +- } +- +- /* Initialize client buffer ring */ +- msg_rx_ring.dev_id = dev_id; +- msg_rx_ring.size = entries; +- msg_rx_ring.rx_slot = 0; +- for (i = 0; i < msg_rx_ring.size; i++) +- msg_rx_ring.virt_buffer[i] = NULL; +- +- /* Initialize inbound message ring */ +- if (!(msg_rx_ring.virt = dma_alloc_coherent(NULL, +- msg_rx_ring.size * +- RIO_MAX_MSG_SIZE, +- &msg_rx_ring.phys, +- GFP_KERNEL))) { +- rc = -ENOMEM; +- goto out; +- } +- +- /* Point dequeue/enqueue pointers at first entry in ring */ +- out_be32((void *)&msg_regs->ifqdpar, (u32) msg_rx_ring.phys); +- out_be32((void *)&msg_regs->ifqepar, (u32) msg_rx_ring.phys); +- +- /* Clear interrupt status */ +- out_be32((void *)&msg_regs->isr, 0x00000091); +- +- /* Hook up inbound message handler */ +- if ((rc = +- request_irq(MPC85xx_IRQ_RIO_RX, mpc85xx_rio_rx_handler, 0, +- "msg_rx", (void *)mport)) < 0) { +- dma_free_coherent(NULL, RIO_MSG_BUFFER_SIZE, +- msg_tx_ring.virt_buffer[i], +- msg_tx_ring.phys_buffer[i]); +- goto out; +- } +- +- /* +- * Configure inbound message unit: +- * Snooping +- * 4KB max message size +- * Unmask all interrupt sources +- * Disable +- */ +- out_be32((void *)&msg_regs->imr, 0x001b0060); +- +- /* Set number of queue entries */ +- out_be32((void *)&msg_regs->imr, +- in_be32((void *)&msg_regs->imr) | +- ((get_bitmask_order(entries) - 2) << 12)); +- +- /* Now enable the unit */ +- out_be32((void *)&msg_regs->imr, in_be32((void *)&msg_regs->imr) | 0x1); +- +- out: +- return rc; +-} +- +-/** +- * rio_close_inb_mbox - Shut down MPC85xx inbound mailbox +- * @mport: Master port implementing the inbound message unit +- * @mbox: Mailbox to close +- * +- * Disables the inbound message unit, free all buffers, and +- * frees the inbound message interrupt. +- */ +-void rio_close_inb_mbox(struct rio_mport *mport, int mbox) +-{ +- /* Disable inbound message unit */ +- out_be32((void *)&msg_regs->imr, 0); +- +- /* Free ring */ +- dma_free_coherent(NULL, msg_rx_ring.size * RIO_MAX_MSG_SIZE, +- msg_rx_ring.virt, msg_rx_ring.phys); +- +- /* Free interrupt */ +- free_irq(MPC85xx_IRQ_RIO_RX, (void *)mport); +-} +- +-/** +- * rio_hw_add_inb_buffer - Add buffer to the MPC85xx inbound message queue +- * @mport: Master port implementing the inbound message unit +- * @mbox: Inbound mailbox number +- * @buf: Buffer to add to inbound queue +- * +- * Adds the @buf buffer to the MPC85xx inbound message queue. Returns +- * %0 on success or %-EINVAL on failure. +- */ +-int rio_hw_add_inb_buffer(struct rio_mport *mport, int mbox, void *buf) +-{ +- int rc = 0; +- +- pr_debug("RIO: rio_hw_add_inb_buffer(), msg_rx_ring.rx_slot %d\n", +- msg_rx_ring.rx_slot); +- +- if (msg_rx_ring.virt_buffer[msg_rx_ring.rx_slot]) { +- printk(KERN_ERR +- "RIO: error adding inbound buffer %d, buffer exists\n", +- msg_rx_ring.rx_slot); +- rc = -EINVAL; +- goto out; +- } +- +- msg_rx_ring.virt_buffer[msg_rx_ring.rx_slot] = buf; +- if (++msg_rx_ring.rx_slot == msg_rx_ring.size) +- msg_rx_ring.rx_slot = 0; +- +- out: +- return rc; +-} +- +-EXPORT_SYMBOL_GPL(rio_hw_add_inb_buffer); +- +-/** +- * rio_hw_get_inb_message - Fetch inbound message from the MPC85xx message unit +- * @mport: Master port implementing the inbound message unit +- * @mbox: Inbound mailbox number +- * +- * Gets the next available inbound message from the inbound message queue. +- * A pointer to the message is returned on success or NULL on failure. +- */ +-void *rio_hw_get_inb_message(struct rio_mport *mport, int mbox) +-{ +- u32 imr; +- u32 phys_buf, virt_buf; +- void *buf = NULL; +- int buf_idx; +- +- phys_buf = in_be32((void *)&msg_regs->ifqdpar); +- +- /* If no more messages, then bail out */ +- if (phys_buf == in_be32((void *)&msg_regs->ifqepar)) +- goto out2; +- +- virt_buf = (u32) msg_rx_ring.virt + (phys_buf - msg_rx_ring.phys); +- buf_idx = (phys_buf - msg_rx_ring.phys) / RIO_MAX_MSG_SIZE; +- buf = msg_rx_ring.virt_buffer[buf_idx]; +- +- if (!buf) { +- printk(KERN_ERR +- "RIO: inbound message copy failed, no buffers\n"); +- goto out1; +- } +- +- /* Copy max message size, caller is expected to allocate that big */ +- memcpy(buf, (void *)virt_buf, RIO_MAX_MSG_SIZE); +- +- /* Clear the available buffer */ +- msg_rx_ring.virt_buffer[buf_idx] = NULL; +- +- out1: +- imr = in_be32((void *)&msg_regs->imr); +- out_be32((void *)&msg_regs->imr, imr | RIO_MSG_IMR_MI); +- +- out2: +- return buf; +-} +- +-EXPORT_SYMBOL_GPL(rio_hw_get_inb_message); +- +-/** +- * mpc85xx_rio_dbell_handler - MPC85xx doorbell interrupt handler +- * @irq: Linux interrupt number +- * @dev_instance: Pointer to interrupt-specific data +- * +- * Handles doorbell interrupts. Parses a list of registered +- * doorbell event handlers and executes a matching event handler. +- */ +-static irqreturn_t +-mpc85xx_rio_dbell_handler(int irq, void *dev_instance) +-{ +- int dsr; +- struct rio_mport *port = (struct rio_mport *)dev_instance; +- +- dsr = in_be32((void *)&msg_regs->dsr); +- +- if (dsr & DOORBELL_DSR_TE) { +- pr_info("RIO: doorbell reception error\n"); +- out_be32((void *)&msg_regs->dsr, DOORBELL_DSR_TE); +- goto out; +- } +- +- if (dsr & DOORBELL_DSR_QFI) { +- pr_info("RIO: doorbell queue full\n"); +- out_be32((void *)&msg_regs->dsr, DOORBELL_DSR_QFI); +- goto out; +- } +- +- /* XXX Need to check/dispatch until queue empty */ +- if (dsr & DOORBELL_DSR_DIQI) { +- u32 dmsg = +- (u32) dbell_ring.virt + +- (in_be32((void *)&msg_regs->dqdpar) & 0xfff); +- u32 dmr; +- struct rio_dbell *dbell; +- int found = 0; +- +- pr_debug +- ("RIO: processing doorbell, sid %2.2x tid %2.2x info %4.4x\n", +- DBELL_SID(dmsg), DBELL_TID(dmsg), DBELL_INF(dmsg)); +- +- list_for_each_entry(dbell, &port->dbells, node) { +- if ((dbell->res->start <= DBELL_INF(dmsg)) && +- (dbell->res->end >= DBELL_INF(dmsg))) { +- found = 1; +- break; +- } +- } +- if (found) { +- dbell->dinb(port, dbell->dev_id, DBELL_SID(dmsg), DBELL_TID(dmsg), +- DBELL_INF(dmsg)); +- } else { +- pr_debug +- ("RIO: spurious doorbell, sid %2.2x tid %2.2x info %4.4x\n", +- DBELL_SID(dmsg), DBELL_TID(dmsg), DBELL_INF(dmsg)); +- } +- dmr = in_be32((void *)&msg_regs->dmr); +- out_be32((void *)&msg_regs->dmr, dmr | DOORBELL_DMR_DI); +- out_be32((void *)&msg_regs->dsr, DOORBELL_DSR_DIQI); +- } +- +- out: +- return IRQ_HANDLED; +-} +- +-/** +- * mpc85xx_rio_doorbell_init - MPC85xx doorbell interface init +- * @mport: Master port implementing the inbound doorbell unit +- * +- * Initializes doorbell unit hardware and inbound DMA buffer +- * ring. Called from mpc85xx_rio_setup(). Returns %0 on success +- * or %-ENOMEM on failure. +- */ +-static int mpc85xx_rio_doorbell_init(struct rio_mport *mport) +-{ +- int rc = 0; +- +- /* Map outbound doorbell window immediately after maintenance window */ +- if (!(dbell_win = +- (u32) ioremap(mport->iores.start + RIO_MAINT_WIN_SIZE, +- RIO_DBELL_WIN_SIZE))) { +- printk(KERN_ERR +- "RIO: unable to map outbound doorbell window\n"); +- rc = -ENOMEM; +- goto out; +- } +- +- /* Initialize inbound doorbells */ +- if (!(dbell_ring.virt = dma_alloc_coherent(NULL, +- 512 * DOORBELL_MESSAGE_SIZE, +- &dbell_ring.phys, +- GFP_KERNEL))) { +- printk(KERN_ERR "RIO: unable allocate inbound doorbell ring\n"); +- rc = -ENOMEM; +- iounmap((void *)dbell_win); +- goto out; +- } +- +- /* Point dequeue/enqueue pointers at first entry in ring */ +- out_be32((void *)&msg_regs->dqdpar, (u32) dbell_ring.phys); +- out_be32((void *)&msg_regs->dqepar, (u32) dbell_ring.phys); +- +- /* Clear interrupt status */ +- out_be32((void *)&msg_regs->dsr, 0x00000091); +- +- /* Hook up doorbell handler */ +- if ((rc = +- request_irq(MPC85xx_IRQ_RIO_BELL, mpc85xx_rio_dbell_handler, 0, +- "dbell_rx", (void *)mport) < 0)) { +- iounmap((void *)dbell_win); +- dma_free_coherent(NULL, 512 * DOORBELL_MESSAGE_SIZE, +- dbell_ring.virt, dbell_ring.phys); +- printk(KERN_ERR +- "MPC85xx RIO: unable to request inbound doorbell irq"); +- goto out; +- } +- +- /* Configure doorbells for snooping, 512 entries, and enable */ +- out_be32((void *)&msg_regs->dmr, 0x00108161); +- +- out: +- return rc; +-} +- +-static char *cmdline = NULL; +- +-static int mpc85xx_rio_get_hdid(int index) +-{ +- /* XXX Need to parse multiple entries in some format */ +- if (!cmdline) +- return -1; +- +- return simple_strtol(cmdline, NULL, 0); +-} +- +-static int mpc85xx_rio_get_cmdline(char *s) +-{ +- if (!s) +- return 0; +- +- cmdline = s; +- return 1; +-} +- +-__setup("riohdid=", mpc85xx_rio_get_cmdline); +- +-/** +- * mpc85xx_rio_setup - Setup MPC85xx RapidIO interface +- * @law_start: Starting physical address of RapidIO LAW +- * @law_size: Size of RapidIO LAW +- * +- * Initializes MPC85xx RapidIO hardware interface, configures +- * master port with system-specific info, and registers the +- * master port with the RapidIO subsystem. +- */ +-void mpc85xx_rio_setup(int law_start, int law_size) +-{ +- struct rio_ops *ops; +- struct rio_mport *port; +- +- ops = kmalloc(sizeof(struct rio_ops), GFP_KERNEL); +- ops->lcread = mpc85xx_local_config_read; +- ops->lcwrite = mpc85xx_local_config_write; +- ops->cread = mpc85xx_rio_config_read; +- ops->cwrite = mpc85xx_rio_config_write; +- ops->dsend = mpc85xx_rio_doorbell_send; +- +- port = kmalloc(sizeof(struct rio_mport), GFP_KERNEL); +- port->id = 0; +- port->index = 0; +- INIT_LIST_HEAD(&port->dbells); +- port->iores.start = law_start; +- port->iores.end = law_start + law_size; +- port->iores.flags = IORESOURCE_MEM; +- +- rio_init_dbell_res(&port->riores[RIO_DOORBELL_RESOURCE], 0, 0xffff); +- rio_init_mbox_res(&port->riores[RIO_INB_MBOX_RESOURCE], 0, 0); +- rio_init_mbox_res(&port->riores[RIO_OUTB_MBOX_RESOURCE], 0, 0); +- strcpy(port->name, "RIO0 mport"); +- +- port->ops = ops; +- port->host_deviceid = mpc85xx_rio_get_hdid(port->id); +- +- rio_register_mport(port); +- +- regs_win = (u32) ioremap(RIO_REGS_BASE, 0x20000); +- atmu_regs = (struct rio_atmu_regs *)(regs_win + RIO_ATMU_REGS_OFFSET); +- maint_atmu_regs = atmu_regs + 1; +- dbell_atmu_regs = atmu_regs + 2; +- msg_regs = (struct rio_msg_regs *)(regs_win + RIO_MSG_REGS_OFFSET); +- +- /* Configure maintenance transaction window */ +- out_be32((void *)&maint_atmu_regs->rowbar, 0x000c0000); +- out_be32((void *)&maint_atmu_regs->rowar, 0x80077015); +- +- maint_win = (u32) ioremap(law_start, RIO_MAINT_WIN_SIZE); +- +- /* Configure outbound doorbell window */ +- out_be32((void *)&dbell_atmu_regs->rowbar, 0x000c0400); +- out_be32((void *)&dbell_atmu_regs->rowar, 0x8004200b); +- mpc85xx_rio_doorbell_init(port); +-} +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/syslib/ppc85xx_rio.h powerpc.git/arch/ppc/syslib/ppc85xx_rio.h +--- linux-2.6.24/arch/ppc/syslib/ppc85xx_rio.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/syslib/ppc85xx_rio.h 1970-01-01 01:00:00.000000000 +0100 +@@ -1,20 +0,0 @@ +-/* +- * MPC85xx RapidIO definitions +- * +- * Copyright 2005 MontaVista Software, Inc. +- * Matt Porter <mporter@kernel.crashing.org> +- * +- * This program is free software; you can redistribute it and/or modify it +- * under the terms of the GNU General Public License as published by the +- * Free Software Foundation; either version 2 of the License, or (at your +- * option) any later version. +- */ +- +-#ifndef __PPC_SYSLIB_PPC85XX_RIO_H +-#define __PPC_SYSLIB_PPC85XX_RIO_H +- +-#include <linux/init.h> +- +-extern void mpc85xx_rio_setup(int law_start, int law_size); +- +-#endif /* __PPC_SYSLIB_PPC85XX_RIO_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/syslib/ppc8xx_pic.c powerpc.git/arch/ppc/syslib/ppc8xx_pic.c +--- linux-2.6.24/arch/ppc/syslib/ppc8xx_pic.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/syslib/ppc8xx_pic.c 2008-01-28 20:25:52.000000000 +0100 +@@ -16,7 +16,7 @@ + * the only interrupt controller. Some boards, like the MBX and + * Sandpoint have the 8259 as a secondary controller. Depending + * upon the processor type, the internal controller can have as +- * few as 16 interrups or as many as 64. We could use the ++ * few as 16 interrupts or as many as 64. We could use the + * "clear_bit()" and "set_bit()" functions like other platforms, + * but they are overkill for us. + */ +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/syslib/ppc_sys.c powerpc.git/arch/ppc/syslib/ppc_sys.c +--- linux-2.6.24/arch/ppc/syslib/ppc_sys.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/syslib/ppc_sys.c 2008-01-28 20:25:52.000000000 +0100 +@@ -185,7 +185,7 @@ + */ + + /* +- Here we'll replace .name pointers with fixed-lenght strings ++ Here we'll replace .name pointers with fixed-length strings + Hereby, this should be called *before* any func stuff triggeded. + */ + void ppc_sys_device_initfunc(void) +diff -x .git -x .gitignore -Nur linux-2.6.24/arch/ppc/xmon/start.c powerpc.git/arch/ppc/xmon/start.c +--- linux-2.6.24/arch/ppc/xmon/start.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/arch/ppc/xmon/start.c 2008-01-28 20:25:52.000000000 +0100 +@@ -10,7 +10,6 @@ + #include <linux/sysrq.h> + #include <linux/bitops.h> + #include <asm/xmon.h> +-#include <asm/machdep.h> + #include <asm/errno.h> + #include <asm/processor.h> + #include <asm/delay.h> +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/ata/Kconfig powerpc.git/drivers/ata/Kconfig +--- linux-2.6.24/drivers/ata/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/ata/Kconfig 2008-01-28 20:25:59.000000000 +0100 +@@ -607,13 +607,23 @@ + + config PATA_PLATFORM + tristate "Generic platform device PATA support" +- depends on EMBEDDED || ARCH_RPC ++ depends on EMBEDDED || ARCH_RPC || PPC + help + This option enables support for generic directly connected ATA + devices commonly found on embedded systems. + + If unsure, say N. + ++config PATA_OF_PLATFORM ++ tristate "OpenFirmware platform device PATA support" ++ depends on PATA_PLATFORM && PPC_OF ++ help ++ This option enables support for generic directly connected ATA ++ devices commonly found on embedded systems with OpenFirmware ++ bindings. ++ ++ If unsure, say N. ++ + config PATA_ICSIDE + tristate "Acorn ICS PATA support" + depends on ARM && ARCH_ACORN +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/ata/Makefile powerpc.git/drivers/ata/Makefile +--- linux-2.6.24/drivers/ata/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/ata/Makefile 2008-01-28 20:25:59.000000000 +0100 +@@ -67,6 +67,7 @@ + obj-$(CONFIG_PATA_SCC) += pata_scc.o + obj-$(CONFIG_PATA_BF54X) += pata_bf54x.o + obj-$(CONFIG_PATA_PLATFORM) += pata_platform.o ++obj-$(CONFIG_PATA_OF_PLATFORM) += pata_of_platform.o + obj-$(CONFIG_PATA_ICSIDE) += pata_icside.o + # Should be last but two libata driver + obj-$(CONFIG_PATA_ACPI) += pata_acpi.o +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/ata/pata_of_platform.c powerpc.git/drivers/ata/pata_of_platform.c +--- linux-2.6.24/drivers/ata/pata_of_platform.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/drivers/ata/pata_of_platform.c 2008-01-28 20:25:59.000000000 +0100 +@@ -0,0 +1,114 @@ ++/* ++ * OF-platform PATA driver ++ * ++ * Copyright (c) 2007 MontaVista Software, Inc. ++ * Anton Vorontsov <avorontsov@ru.mvista.com> ++ * ++ * This program is free software; you can redistribute it and/or modify ++ * it under the terms of the GNU General Public License (Version 2) as ++ * published by the Free Software Foundation. ++ */ ++ ++#include <linux/kernel.h> ++#include <linux/module.h> ++#include <linux/of_platform.h> ++#include <linux/pata_platform.h> ++ ++static int __devinit pata_of_platform_probe(struct of_device *ofdev, ++ const struct of_device_id *match) ++{ ++ int ret; ++ struct device_node *dn = ofdev->node; ++ struct resource io_res; ++ struct resource ctl_res; ++ struct resource irq_res; ++ unsigned int reg_shift = 0; ++ int pio_mode = 0; ++ int pio_mask; ++ const u32 *prop; ++ ++ ret = of_address_to_resource(dn, 0, &io_res); ++ if (ret) { ++ dev_err(&ofdev->dev, "can't get IO address from " ++ "device tree\n"); ++ return -EINVAL; ++ } ++ ++ if (of_device_is_compatible(dn, "electra-ide")) { ++ /* Altstatus is really at offset 0x3f6 from the primary window ++ * on electra-ide. Adjust ctl_res and io_res accordingly. ++ */ ++ ctl_res = io_res; ++ ctl_res.start = ctl_res.start+0x3f6; ++ io_res.end = ctl_res.start-1; ++ } else { ++ ret = of_address_to_resource(dn, 1, &ctl_res); ++ if (ret) { ++ dev_err(&ofdev->dev, "can't get CTL address from " ++ "device tree\n"); ++ return -EINVAL; ++ } ++ } ++ ++ ret = of_irq_to_resource(dn, 0, &irq_res); ++ if (ret == NO_IRQ) ++ irq_res.start = irq_res.end = -1; ++ else ++ irq_res.flags = 0; ++ ++ prop = of_get_property(dn, "reg-shift", NULL); ++ if (prop) ++ reg_shift = *prop; ++ ++ prop = of_get_property(dn, "pio-mode", NULL); ++ if (prop) { ++ pio_mode = *prop; ++ if (pio_mode > 6) { ++ dev_err(&ofdev->dev, "invalid pio-mode\n"); ++ return -EINVAL; ++ } ++ } else { ++ dev_info(&ofdev->dev, "pio-mode unspecified, assuming PIO0\n"); ++ } ++ ++ pio_mask = 1 << pio_mode; ++ pio_mask |= (1 << pio_mode) - 1; ++ ++ return __pata_platform_probe(&ofdev->dev, &io_res, &ctl_res, &irq_res, ++ reg_shift, pio_mask); ++} ++ ++static int __devexit pata_of_platform_remove(struct of_device *ofdev) ++{ ++ return __pata_platform_remove(&ofdev->dev); ++} ++ ++static struct of_device_id pata_of_platform_match[] = { ++ { .compatible = "ata-generic", }, ++ { .compatible = "electra-ide", }, ++ {}, ++}; ++MODULE_DEVICE_TABLE(of, pata_of_platform_match); ++ ++static struct of_platform_driver pata_of_platform_driver = { ++ .name = "pata_of_platform", ++ .match_table = pata_of_platform_match, ++ .probe = pata_of_platform_probe, ++ .remove = __devexit_p(pata_of_platform_remove), ++}; ++ ++static int __init pata_of_platform_init(void) ++{ ++ return of_register_platform_driver(&pata_of_platform_driver); ++} ++module_init(pata_of_platform_init); ++ ++static void __exit pata_of_platform_exit(void) ++{ ++ of_unregister_platform_driver(&pata_of_platform_driver); ++} ++module_exit(pata_of_platform_exit); ++ ++MODULE_DESCRIPTION("OF-platform PATA driver"); ++MODULE_AUTHOR("Anton Vorontsov <avorontsov@ru.mvista.com>"); ++MODULE_LICENSE("GPL"); +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/ata/pata_platform.c powerpc.git/drivers/ata/pata_platform.c +--- linux-2.6.24/drivers/ata/pata_platform.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/ata/pata_platform.c 2008-01-28 20:25:59.000000000 +0100 +@@ -93,14 +93,9 @@ + }; + + static void pata_platform_setup_port(struct ata_ioports *ioaddr, +- struct pata_platform_info *info) ++ unsigned int shift) + { +- unsigned int shift = 0; +- + /* Fixup the port shift for platforms that need it */ +- if (info && info->ioport_shift) +- shift = info->ioport_shift; +- + ioaddr->data_addr = ioaddr->cmd_addr + (ATA_REG_DATA << shift); + ioaddr->error_addr = ioaddr->cmd_addr + (ATA_REG_ERR << shift); + ioaddr->feature_addr = ioaddr->cmd_addr + (ATA_REG_FEATURE << shift); +@@ -114,8 +109,13 @@ + } + + /** +- * pata_platform_probe - attach a platform interface +- * @pdev: platform device ++ * __pata_platform_probe - attach a platform interface ++ * @dev: device ++ * @io_res: Resource representing I/O base ++ * @ctl_res: Resource representing CTL base ++ * @irq_res: Resource representing IRQ and its flags ++ * @ioport_shift: I/O port shift ++ * @__pio_mask: PIO mask + * + * Register a platform bus IDE interface. Such interfaces are PIO and we + * assume do not support IRQ sharing. +@@ -135,42 +135,18 @@ + * + * If no IRQ resource is present, PIO polling mode is used instead. + */ +-static int __devinit pata_platform_probe(struct platform_device *pdev) ++int __devinit __pata_platform_probe(struct device *dev, ++ struct resource *io_res, ++ struct resource *ctl_res, ++ struct resource *irq_res, ++ unsigned int ioport_shift, ++ int __pio_mask) + { +- struct resource *io_res, *ctl_res; + struct ata_host *host; + struct ata_port *ap; +- struct pata_platform_info *pp_info; + unsigned int mmio; +- int irq; +- +- /* +- * Simple resource validation .. +- */ +- if ((pdev->num_resources != 3) && (pdev->num_resources != 2)) { +- dev_err(&pdev->dev, "invalid number of resources\n"); +- return -EINVAL; +- } +- +- /* +- * Get the I/O base first +- */ +- io_res = platform_get_resource(pdev, IORESOURCE_IO, 0); +- if (io_res == NULL) { +- io_res = platform_get_resource(pdev, IORESOURCE_MEM, 0); +- if (unlikely(io_res == NULL)) +- return -EINVAL; +- } +- +- /* +- * Then the CTL base +- */ +- ctl_res = platform_get_resource(pdev, IORESOURCE_IO, 1); +- if (ctl_res == NULL) { +- ctl_res = platform_get_resource(pdev, IORESOURCE_MEM, 1); +- if (unlikely(ctl_res == NULL)) +- return -EINVAL; +- } ++ int irq = 0; ++ int irq_flags = 0; + + /* + * Check for MMIO +@@ -181,20 +157,21 @@ + /* + * And the IRQ + */ +- irq = platform_get_irq(pdev, 0); +- if (irq < 0) +- irq = 0; /* no irq */ ++ if (irq_res && irq_res->start > 0) { ++ irq = irq_res->start; ++ irq_flags = irq_res->flags; ++ } + + /* + * Now that that's out of the way, wire up the port.. + */ +- host = ata_host_alloc(&pdev->dev, 1); ++ host = ata_host_alloc(dev, 1); + if (!host) + return -ENOMEM; + ap = host->ports[0]; + + ap->ops = &pata_platform_port_ops; +- ap->pio_mask = pio_mask; ++ ap->pio_mask = __pio_mask; + ap->flags |= ATA_FLAG_SLAVE_POSS; + + /* +@@ -209,25 +186,24 @@ + * Handle the MMIO case + */ + if (mmio) { +- ap->ioaddr.cmd_addr = devm_ioremap(&pdev->dev, io_res->start, ++ ap->ioaddr.cmd_addr = devm_ioremap(dev, io_res->start, + io_res->end - io_res->start + 1); +- ap->ioaddr.ctl_addr = devm_ioremap(&pdev->dev, ctl_res->start, ++ ap->ioaddr.ctl_addr = devm_ioremap(dev, ctl_res->start, + ctl_res->end - ctl_res->start + 1); + } else { +- ap->ioaddr.cmd_addr = devm_ioport_map(&pdev->dev, io_res->start, ++ ap->ioaddr.cmd_addr = devm_ioport_map(dev, io_res->start, + io_res->end - io_res->start + 1); +- ap->ioaddr.ctl_addr = devm_ioport_map(&pdev->dev, ctl_res->start, ++ ap->ioaddr.ctl_addr = devm_ioport_map(dev, ctl_res->start, + ctl_res->end - ctl_res->start + 1); + } + if (!ap->ioaddr.cmd_addr || !ap->ioaddr.ctl_addr) { +- dev_err(&pdev->dev, "failed to map IO/CTL base\n"); ++ dev_err(dev, "failed to map IO/CTL base\n"); + return -ENOMEM; + } + + ap->ioaddr.altstatus_addr = ap->ioaddr.ctl_addr; + +- pp_info = pdev->dev.platform_data; +- pata_platform_setup_port(&ap->ioaddr, pp_info); ++ pata_platform_setup_port(&ap->ioaddr, ioport_shift); + + ata_port_desc(ap, "%s cmd 0x%llx ctl 0x%llx", mmio ? "mmio" : "ioport", + (unsigned long long)io_res->start, +@@ -235,26 +211,78 @@ + + /* activate */ + return ata_host_activate(host, irq, irq ? ata_interrupt : NULL, +- pp_info ? pp_info->irq_flags : 0, +- &pata_platform_sht); ++ irq_flags, &pata_platform_sht); + } ++EXPORT_SYMBOL_GPL(__pata_platform_probe); + + /** +- * pata_platform_remove - unplug a platform interface +- * @pdev: platform device ++ * __pata_platform_remove - unplug a platform interface ++ * @dev: device + * + * A platform bus ATA device has been unplugged. Perform the needed + * cleanup. Also called on module unload for any active devices. + */ +-static int __devexit pata_platform_remove(struct platform_device *pdev) ++int __devexit __pata_platform_remove(struct device *dev) + { +- struct device *dev = &pdev->dev; + struct ata_host *host = dev_get_drvdata(dev); + + ata_host_detach(host); + + return 0; + } ++EXPORT_SYMBOL_GPL(__pata_platform_remove); ++ ++static int __devinit pata_platform_probe(struct platform_device *pdev) ++{ ++ struct resource *io_res; ++ struct resource *ctl_res; ++ struct resource *irq_res; ++ struct pata_platform_info *pp_info = pdev->dev.platform_data; ++ ++ /* ++ * Simple resource validation .. ++ */ ++ if ((pdev->num_resources != 3) && (pdev->num_resources != 2)) { ++ dev_err(&pdev->dev, "invalid number of resources\n"); ++ return -EINVAL; ++ } ++ ++ /* ++ * Get the I/O base first ++ */ ++ io_res = platform_get_resource(pdev, IORESOURCE_IO, 0); ++ if (io_res == NULL) { ++ io_res = platform_get_resource(pdev, IORESOURCE_MEM, 0); ++ if (unlikely(io_res == NULL)) ++ return -EINVAL; ++ } ++ ++ /* ++ * Then the CTL base ++ */ ++ ctl_res = platform_get_resource(pdev, IORESOURCE_IO, 1); ++ if (ctl_res == NULL) { ++ ctl_res = platform_get_resource(pdev, IORESOURCE_MEM, 1); ++ if (unlikely(ctl_res == NULL)) ++ return -EINVAL; ++ } ++ ++ /* ++ * And the IRQ ++ */ ++ irq_res = platform_get_resource(pdev, IORESOURCE_IRQ, 0); ++ if (irq_res) ++ irq_res->flags = pp_info ? pp_info->irq_flags : 0; ++ ++ return __pata_platform_probe(&pdev->dev, io_res, ctl_res, irq_res, ++ pp_info ? pp_info->ioport_shift : 0, ++ pio_mask); ++} ++ ++static int __devexit pata_platform_remove(struct platform_device *pdev) ++{ ++ return __pata_platform_remove(&pdev->dev); ++} + + static struct platform_driver pata_platform_driver = { + .probe = pata_platform_probe, +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/char/hw_random/Kconfig powerpc.git/drivers/char/hw_random/Kconfig +--- linux-2.6.24/drivers/char/hw_random/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/char/hw_random/Kconfig 2008-01-28 20:25:59.000000000 +0100 +@@ -98,7 +98,7 @@ + default HW_RANDOM + ---help--- + This driver provides kernel-side support for the Random Number +- Generator hardware found on PA6T-1682M processor. ++ Generator hardware found on PA Semi PWRficient SoCs. + + To compile this driver as a module, choose M here: the + module will be called pasemi-rng. +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/char/hw_random/pasemi-rng.c powerpc.git/drivers/char/hw_random/pasemi-rng.c +--- linux-2.6.24/drivers/char/hw_random/pasemi-rng.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/char/hw_random/pasemi-rng.c 2008-01-28 20:25:59.000000000 +0100 +@@ -126,10 +126,9 @@ + } + + static struct of_device_id rng_match[] = { +- { +- .compatible = "1682m-rng", +- }, +- {}, ++ { .compatible = "1682m-rng", }, ++ { .compatible = "pasemi,pwrficient-rng", }, ++ { }, + }; + + static struct of_platform_driver rng_driver = { +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/edac/pasemi_edac.c powerpc.git/drivers/edac/pasemi_edac.c +--- linux-2.6.24/drivers/edac/pasemi_edac.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/edac/pasemi_edac.c 2008-01-28 20:26:00.000000000 +0100 +@@ -225,7 +225,7 @@ + EDAC_FLAG_NONE; + mci->mod_name = MODULE_NAME; + mci->dev_name = pci_name(pdev); +- mci->ctl_name = "pasemi,1682m-mc"; ++ mci->ctl_name = "pasemi,pwrficient-mc"; + mci->edac_check = pasemi_edac_check; + mci->ctl_page_to_phys = NULL; + pci_read_config_dword(pdev, MCCFG_SCRUB, &scrub); +@@ -297,4 +297,4 @@ + + MODULE_LICENSE("GPL"); + MODULE_AUTHOR("Egor Martovetsky <egor@pasemi.com>"); +-MODULE_DESCRIPTION("MC support for PA Semi PA6T-1682M memory controller"); ++MODULE_DESCRIPTION("MC support for PA Semi PWRficient memory controller"); +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/macintosh/adb.c powerpc.git/drivers/macintosh/adb.c +--- linux-2.6.24/drivers/macintosh/adb.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/macintosh/adb.c 2008-01-28 20:26:08.000000000 +0100 +@@ -35,6 +35,7 @@ + #include <linux/spinlock.h> + #include <linux/completion.h> + #include <linux/device.h> ++#include <linux/kthread.h> + + #include <asm/uaccess.h> + #include <asm/semaphore.h> +@@ -82,21 +83,11 @@ + BLOCKING_NOTIFIER_HEAD(adb_client_list); + static int adb_got_sleep; + static int adb_inited; +-static pid_t adb_probe_task_pid; + static DECLARE_MUTEX(adb_probe_mutex); +-static struct completion adb_probe_task_comp; + static int sleepy_trackpad; + static int autopoll_devs; + int __adb_probe_sync; + +-#ifdef CONFIG_PM_SLEEP +-static void adb_notify_sleep(struct pmu_sleep_notifier *self, int when); +-static struct pmu_sleep_notifier adb_sleep_notifier = { +- adb_notify_sleep, +- SLEEP_LEVEL_ADB, +-}; +-#endif +- + static int adb_scan_bus(void); + static int do_adb_reset_bus(void); + static void adbdev_init(void); +@@ -134,16 +125,6 @@ + } + #endif + +- +-static __inline__ void adb_wait_ms(unsigned int ms) +-{ +- if (current->pid && adb_probe_task_pid && +- adb_probe_task_pid == current->pid) +- msleep(ms); +- else +- mdelay(ms); +-} +- + static int adb_scan_bus(void) + { + int i, highFree=0, noMovement; +@@ -248,13 +229,10 @@ + static int + adb_probe_task(void *x) + { +- strcpy(current->comm, "kadbprobe"); +- + printk(KERN_INFO "adb: starting probe task...\n"); + do_adb_reset_bus(); + printk(KERN_INFO "adb: finished probe task...\n"); + +- adb_probe_task_pid = 0; + up(&adb_probe_mutex); + + return 0; +@@ -263,7 +241,7 @@ + static void + __adb_probe_task(struct work_struct *bullshit) + { +- adb_probe_task_pid = kernel_thread(adb_probe_task, NULL, SIGCHLD | CLONE_KERNEL); ++ kthread_run(adb_probe_task, NULL, "kadbprobe"); + } + + static DECLARE_WORK(adb_reset_work, __adb_probe_task); +@@ -281,6 +259,36 @@ + return 0; + } + ++#ifdef CONFIG_PM ++/* ++ * notify clients before sleep ++ */ ++static int adb_suspend(struct platform_device *dev, pm_message_t state) ++{ ++ adb_got_sleep = 1; ++ /* We need to get a lock on the probe thread */ ++ down(&adb_probe_mutex); ++ /* Stop autopoll */ ++ if (adb_controller->autopoll) ++ adb_controller->autopoll(0); ++ blocking_notifier_call_chain(&adb_client_list, ADB_MSG_POWERDOWN, NULL); ++ ++ return 0; ++} ++ ++/* ++ * reset bus after sleep ++ */ ++static int adb_resume(struct platform_device *dev) ++{ ++ adb_got_sleep = 0; ++ up(&adb_probe_mutex); ++ adb_reset_bus(); ++ ++ return 0; ++} ++#endif /* CONFIG_PM */ ++ + int __init adb_init(void) + { + struct adb_driver *driver; +@@ -313,15 +321,12 @@ + printk(KERN_WARNING "Warning: no ADB interface detected\n"); + adb_controller = NULL; + } else { +-#ifdef CONFIG_PM_SLEEP +- pmu_register_sleep_notifier(&adb_sleep_notifier); +-#endif /* CONFIG_PM */ + #ifdef CONFIG_PPC + if (machine_is_compatible("AAPL,PowerBook1998") || + machine_is_compatible("PowerBook1,1")) + sleepy_trackpad = 1; + #endif /* CONFIG_PPC */ +- init_completion(&adb_probe_task_comp); ++ + adbdev_init(); + adb_reset_bus(); + } +@@ -330,33 +335,6 @@ + + __initcall(adb_init); + +-#ifdef CONFIG_PM +-/* +- * notify clients before sleep and reset bus afterwards +- */ +-void +-adb_notify_sleep(struct pmu_sleep_notifier *self, int when) +-{ +- switch (when) { +- case PBOOK_SLEEP_REQUEST: +- adb_got_sleep = 1; +- /* We need to get a lock on the probe thread */ +- down(&adb_probe_mutex); +- /* Stop autopoll */ +- if (adb_controller->autopoll) +- adb_controller->autopoll(0); +- blocking_notifier_call_chain(&adb_client_list, +- ADB_MSG_POWERDOWN, NULL); +- break; +- case PBOOK_WAKE: +- adb_got_sleep = 0; +- up(&adb_probe_mutex); +- adb_reset_bus(); +- break; +- } +-} +-#endif /* CONFIG_PM */ +- + static int + do_adb_reset_bus(void) + { +@@ -373,7 +351,7 @@ + + if (sleepy_trackpad) { + /* Let the trackpad settle down */ +- adb_wait_ms(500); ++ msleep(500); + } + + down(&adb_handler_sem); +@@ -389,7 +367,7 @@ + + if (sleepy_trackpad) { + /* Let the trackpad settle down */ +- adb_wait_ms(1500); ++ msleep(1500); + } + + if (!ret) { +@@ -413,41 +391,27 @@ + adb_controller->poll(); + } + +-static void +-adb_probe_wakeup(struct adb_request *req) ++static void adb_sync_req_done(struct adb_request *req) + { +- complete(&adb_probe_task_comp); +-} ++ struct completion *comp = req->arg; + +-/* Static request used during probe */ +-static struct adb_request adb_sreq; +-static unsigned long adb_sreq_lock; // Use semaphore ! */ ++ complete(comp); ++} + + int + adb_request(struct adb_request *req, void (*done)(struct adb_request *), + int flags, int nbytes, ...) + { + va_list list; +- int i, use_sreq; ++ int i; + int rc; ++ struct completion comp; + + if ((adb_controller == NULL) || (adb_controller->send_request == NULL)) + return -ENXIO; + if (nbytes < 1) + return -EINVAL; +- if (req == NULL && (flags & ADBREQ_NOSEND)) +- return -EINVAL; +- +- if (req == NULL) { +- if (test_and_set_bit(0,&adb_sreq_lock)) { +- printk("adb.c: Warning: contention on static request !\n"); +- return -EPERM; +- } +- req = &adb_sreq; +- flags |= ADBREQ_SYNC; +- use_sreq = 1; +- } else +- use_sreq = 0; ++ + req->nbytes = nbytes+1; + req->done = done; + req->reply_expected = flags & ADBREQ_REPLY; +@@ -460,25 +424,18 @@ + if (flags & ADBREQ_NOSEND) + return 0; + +- /* Synchronous requests send from the probe thread cause it to +- * block. Beware that the "done" callback will be overriden ! +- */ +- if ((flags & ADBREQ_SYNC) && +- (current->pid && adb_probe_task_pid && +- adb_probe_task_pid == current->pid)) { +- req->done = adb_probe_wakeup; +- rc = adb_controller->send_request(req, 0); +- if (rc || req->complete) +- goto bail; +- wait_for_completion(&adb_probe_task_comp); +- rc = 0; +- goto bail; +- } +- +- rc = adb_controller->send_request(req, flags & ADBREQ_SYNC); +-bail: +- if (use_sreq) +- clear_bit(0, &adb_sreq_lock); ++ /* Synchronous requests block using an on-stack completion */ ++ if (flags & ADBREQ_SYNC) { ++ WARN_ON(done); ++ req->done = adb_sync_req_done; ++ req->arg = ∁ ++ init_completion(&comp); ++ } ++ ++ rc = adb_controller->send_request(req, 0); ++ ++ if ((flags & ADBREQ_SYNC) && !rc && !req->complete) ++ wait_for_completion(&comp); + + return rc; + } +@@ -864,7 +821,29 @@ + .release = adb_release, + }; + +-static void ++static struct platform_driver adb_pfdrv = { ++ .driver = { ++ .name = "adb", ++ }, ++#ifdef CONFIG_PM ++ .suspend = adb_suspend, ++ .resume = adb_resume, ++#endif ++}; ++ ++static struct platform_device adb_pfdev = { ++ .name = "adb", ++}; ++ ++static int __init ++adb_dummy_probe(struct platform_device *dev) ++{ ++ if (dev == &adb_pfdev) ++ return 0; ++ return -ENODEV; ++} ++ ++static void __init + adbdev_init(void) + { + if (register_chrdev(ADB_MAJOR, "adb", &adb_fops)) { +@@ -876,4 +855,7 @@ + if (IS_ERR(adb_dev_class)) + return; + class_device_create(adb_dev_class, NULL, MKDEV(ADB_MAJOR, 0), NULL, "adb"); ++ ++ platform_device_register(&adb_pfdev); ++ platform_driver_probe(&adb_pfdrv, adb_dummy_probe); + } +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/macintosh/mediabay.c powerpc.git/drivers/macintosh/mediabay.c +--- linux-2.6.24/drivers/macintosh/mediabay.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/macintosh/mediabay.c 2008-01-28 20:26:08.000000000 +0100 +@@ -20,6 +20,7 @@ + #include <linux/stddef.h> + #include <linux/init.h> + #include <linux/ide.h> ++#include <linux/kthread.h> + #include <asm/prom.h> + #include <asm/pgtable.h> + #include <asm/io.h> +@@ -35,7 +36,6 @@ + + + #define MB_DEBUG +-#define MB_IGNORE_SIGNALS + + #ifdef MB_DEBUG + #define MBDBG(fmt, arg...) printk(KERN_INFO fmt , ## arg) +@@ -622,12 +622,7 @@ + { + int i; + +- strcpy(current->comm, "media-bay"); +-#ifdef MB_IGNORE_SIGNALS +- sigfillset(¤t->blocked); +-#endif +- +- for (;;) { ++ while (!kthread_should_stop()) { + for (i = 0; i < media_bay_count; ++i) { + down(&media_bays[i].lock); + if (!media_bays[i].sleeping) +@@ -636,9 +631,8 @@ + } + + msleep_interruptible(MB_POLL_DELAY); +- if (signal_pending(current)) +- return 0; + } ++ return 0; + } + + static int __devinit media_bay_attach(struct macio_dev *mdev, const struct of_device_id *match) +@@ -699,7 +693,7 @@ + + /* Startup kernel thread */ + if (i == 0) +- kernel_thread(media_bay_task, NULL, CLONE_KERNEL); ++ kthread_run(media_bay_task, NULL, "media-bay"); + + return 0; + +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/macintosh/therm_adt746x.c powerpc.git/drivers/macintosh/therm_adt746x.c +--- linux-2.6.24/drivers/macintosh/therm_adt746x.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/macintosh/therm_adt746x.c 2008-01-28 20:26:08.000000000 +0100 +@@ -553,6 +553,7 @@ + struct device_node* np; + const u32 *prop; + int i = 0, offset = 0; ++ int err; + + np = of_find_node_by_name(NULL, "fan"); + if (!np) +@@ -612,17 +613,20 @@ + return -ENODEV; + } + +- device_create_file(&of_dev->dev, &dev_attr_sensor1_temperature); +- device_create_file(&of_dev->dev, &dev_attr_sensor2_temperature); +- device_create_file(&of_dev->dev, &dev_attr_sensor1_limit); +- device_create_file(&of_dev->dev, &dev_attr_sensor2_limit); +- device_create_file(&of_dev->dev, &dev_attr_sensor1_location); +- device_create_file(&of_dev->dev, &dev_attr_sensor2_location); +- device_create_file(&of_dev->dev, &dev_attr_limit_adjust); +- device_create_file(&of_dev->dev, &dev_attr_specified_fan_speed); +- device_create_file(&of_dev->dev, &dev_attr_sensor1_fan_speed); ++ err = device_create_file(&of_dev->dev, &dev_attr_sensor1_temperature); ++ err |= device_create_file(&of_dev->dev, &dev_attr_sensor2_temperature); ++ err |= device_create_file(&of_dev->dev, &dev_attr_sensor1_limit); ++ err |= device_create_file(&of_dev->dev, &dev_attr_sensor2_limit); ++ err |= device_create_file(&of_dev->dev, &dev_attr_sensor1_location); ++ err |= device_create_file(&of_dev->dev, &dev_attr_sensor2_location); ++ err |= device_create_file(&of_dev->dev, &dev_attr_limit_adjust); ++ err |= device_create_file(&of_dev->dev, &dev_attr_specified_fan_speed); ++ err |= device_create_file(&of_dev->dev, &dev_attr_sensor1_fan_speed); + if(therm_type == ADT7460) +- device_create_file(&of_dev->dev, &dev_attr_sensor2_fan_speed); ++ err |= device_create_file(&of_dev->dev, &dev_attr_sensor2_fan_speed); ++ if (err) ++ printk(KERN_WARNING ++ "Failed to create tempertaure attribute file(s).\n"); + + #ifndef CONFIG_I2C_POWERMAC + request_module("i2c-powermac"); +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/macintosh/therm_pm72.c powerpc.git/drivers/macintosh/therm_pm72.c +--- linux-2.6.24/drivers/macintosh/therm_pm72.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/macintosh/therm_pm72.c 2008-01-28 20:26:08.000000000 +0100 +@@ -121,6 +121,7 @@ + #include <linux/reboot.h> + #include <linux/kmod.h> + #include <linux/i2c.h> ++#include <linux/kthread.h> + #include <asm/prom.h> + #include <asm/machdep.h> + #include <asm/io.h> +@@ -161,7 +162,7 @@ + static int state; + static int cpu_count; + static int cpu_pid_type; +-static pid_t ctrl_task; ++static struct task_struct *ctrl_task; + static struct completion ctrl_complete; + static int critical_state; + static int rackmac; +@@ -1156,6 +1157,8 @@ + */ + static int init_cpu_state(struct cpu_pid_state *state, int index) + { ++ int err; ++ + state->index = index; + state->first = 1; + state->rpm = (cpu_pid_type == CPU_PID_TYPE_RACKMAC) ? 4000 : 1000; +@@ -1181,18 +1184,21 @@ + DBG("CPU %d Using %d power history entries\n", index, state->count_power); + + if (index == 0) { +- device_create_file(&of_dev->dev, &dev_attr_cpu0_temperature); +- device_create_file(&of_dev->dev, &dev_attr_cpu0_voltage); +- device_create_file(&of_dev->dev, &dev_attr_cpu0_current); +- device_create_file(&of_dev->dev, &dev_attr_cpu0_exhaust_fan_rpm); +- device_create_file(&of_dev->dev, &dev_attr_cpu0_intake_fan_rpm); ++ err = device_create_file(&of_dev->dev, &dev_attr_cpu0_temperature); ++ err |= device_create_file(&of_dev->dev, &dev_attr_cpu0_voltage); ++ err |= device_create_file(&of_dev->dev, &dev_attr_cpu0_current); ++ err |= device_create_file(&of_dev->dev, &dev_attr_cpu0_exhaust_fan_rpm); ++ err |= device_create_file(&of_dev->dev, &dev_attr_cpu0_intake_fan_rpm); + } else { +- device_create_file(&of_dev->dev, &dev_attr_cpu1_temperature); +- device_create_file(&of_dev->dev, &dev_attr_cpu1_voltage); +- device_create_file(&of_dev->dev, &dev_attr_cpu1_current); +- device_create_file(&of_dev->dev, &dev_attr_cpu1_exhaust_fan_rpm); +- device_create_file(&of_dev->dev, &dev_attr_cpu1_intake_fan_rpm); +- } ++ err = device_create_file(&of_dev->dev, &dev_attr_cpu1_temperature); ++ err |= device_create_file(&of_dev->dev, &dev_attr_cpu1_voltage); ++ err |= device_create_file(&of_dev->dev, &dev_attr_cpu1_current); ++ err |= device_create_file(&of_dev->dev, &dev_attr_cpu1_exhaust_fan_rpm); ++ err |= device_create_file(&of_dev->dev, &dev_attr_cpu1_intake_fan_rpm); ++ } ++ if (err) ++ printk(KERN_WARNING "Failed to create some of the atribute" ++ "files for CPU %d\n", index); + + return 0; + fail: +@@ -1328,6 +1334,7 @@ + { + struct device_node *u3; + int u3h = 1; /* conservative by default */ ++ int err; + + /* + * There are different PID params for machines with U3 and machines +@@ -1379,8 +1386,11 @@ + if (state->monitor == NULL) + return -ENODEV; + +- device_create_file(&of_dev->dev, &dev_attr_backside_temperature); +- device_create_file(&of_dev->dev, &dev_attr_backside_fan_pwm); ++ err = device_create_file(&of_dev->dev, &dev_attr_backside_temperature); ++ err |= device_create_file(&of_dev->dev, &dev_attr_backside_fan_pwm); ++ if (err) ++ printk(KERN_WARNING "Failed to create attribute file(s)" ++ " for backside fan\n"); + + return 0; + } +@@ -1491,6 +1501,8 @@ + */ + static int init_drives_state(struct drives_pid_state *state) + { ++ int err; ++ + state->ticks = 1; + state->first = 1; + state->rpm = 1000; +@@ -1499,8 +1511,11 @@ + if (state->monitor == NULL) + return -ENODEV; + +- device_create_file(&of_dev->dev, &dev_attr_drives_temperature); +- device_create_file(&of_dev->dev, &dev_attr_drives_fan_rpm); ++ err = device_create_file(&of_dev->dev, &dev_attr_drives_temperature); ++ err |= device_create_file(&of_dev->dev, &dev_attr_drives_fan_rpm); ++ if (err) ++ printk(KERN_WARNING "Failed to create attribute file(s)" ++ " for drives bay fan\n"); + + return 0; + } +@@ -1621,7 +1636,9 @@ + if (state->monitor == NULL) + return -ENODEV; + +- device_create_file(&of_dev->dev, &dev_attr_dimms_temperature); ++ if (device_create_file(&of_dev->dev, &dev_attr_dimms_temperature)) ++ printk(KERN_WARNING "Failed to create attribute file" ++ " for DIMM temperature\n"); + + return 0; + } +@@ -1731,6 +1748,8 @@ + */ + static int init_slots_state(struct slots_pid_state *state) + { ++ int err; ++ + state->ticks = 1; + state->first = 1; + state->pwm = 50; +@@ -1739,8 +1758,11 @@ + if (state->monitor == NULL) + return -ENODEV; + +- device_create_file(&of_dev->dev, &dev_attr_slots_temperature); +- device_create_file(&of_dev->dev, &dev_attr_slots_fan_pwm); ++ err = device_create_file(&of_dev->dev, &dev_attr_slots_temperature); ++ err |= device_create_file(&of_dev->dev, &dev_attr_slots_fan_pwm); ++ if (err) ++ printk(KERN_WARNING "Failed to create attribute file(s)" ++ " for slots bay fan\n"); + + return 0; + } +@@ -1779,8 +1801,6 @@ + */ + static int main_control_loop(void *x) + { +- daemonize("kfand"); +- + DBG("main_control_loop started\n"); + + down(&driver_lock); +@@ -1956,7 +1976,7 @@ + { + init_completion(&ctrl_complete); + +- ctrl_task = kernel_thread(main_control_loop, NULL, SIGCHLD | CLONE_KERNEL); ++ ctrl_task = kthread_run(main_control_loop, NULL, "kfand"); + } + + /* +@@ -1964,7 +1984,7 @@ + */ + static void stop_control_loops(void) + { +- if (ctrl_task != 0) ++ if (ctrl_task) + wait_for_completion(&ctrl_complete); + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/macintosh/therm_windtunnel.c powerpc.git/drivers/macintosh/therm_windtunnel.c +--- linux-2.6.24/drivers/macintosh/therm_windtunnel.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/macintosh/therm_windtunnel.c 2008-01-28 20:26:08.000000000 +0100 +@@ -36,6 +36,7 @@ + #include <linux/i2c.h> + #include <linux/slab.h> + #include <linux/init.h> ++#include <linux/kthread.h> + + #include <asm/prom.h> + #include <asm/machdep.h> +@@ -61,8 +62,7 @@ + + static struct { + volatile int running; +- struct completion completion; +- pid_t poll_task; ++ struct task_struct *poll_task; + + struct semaphore lock; + struct of_device *of_dev; +@@ -223,6 +223,7 @@ + setup_hardware( void ) + { + int val; ++ int err; + + /* save registers (if we unload the module) */ + x.r0 = read_reg( x.fan, 0x00, 1 ); +@@ -265,8 +266,11 @@ + x.upind = -1; + /* tune_fan( fan_up_table[x.upind].fan_setting ); */ + +- device_create_file( &x.of_dev->dev, &dev_attr_cpu_temperature ); +- device_create_file( &x.of_dev->dev, &dev_attr_case_temperature ); ++ err = device_create_file( &x.of_dev->dev, &dev_attr_cpu_temperature ); ++ err |= device_create_file( &x.of_dev->dev, &dev_attr_case_temperature ); ++ if (err) ++ printk(KERN_WARNING ++ "Failed to create temperature attribute file(s).\n"); + } + + static void +@@ -282,27 +286,27 @@ + write_reg( x.fan, 0x00, x.r0, 1 ); + } + +-static int +-control_loop( void *dummy ) ++static int control_loop(void *dummy) + { +- daemonize("g4fand"); +- +- down( &x.lock ); ++ down(&x.lock); + setup_hardware(); ++ up(&x.lock); + +- while( x.running ) { +- up( &x.lock ); +- ++ for (;;) { + msleep_interruptible(8000); +- +- down( &x.lock ); ++ if (kthread_should_stop()) ++ break; ++ ++ down(&x.lock); + poll_temp(); ++ up(&x.lock); + } + ++ down(&x.lock); + restore_regs(); +- up( &x.lock ); ++ up(&x.lock); + +- complete_and_exit( &x.completion, 0 ); ++ return 0; + } + + +@@ -322,8 +326,7 @@ + ret = i2c_probe( adapter, &addr_data, &do_probe ); + if( x.thermostat && x.fan ) { + x.running = 1; +- init_completion( &x.completion ); +- x.poll_task = kernel_thread( control_loop, NULL, SIGCHLD | CLONE_KERNEL ); ++ x.poll_task = kthread_run(control_loop, NULL, "g4fand"); + } + } + return ret; +@@ -339,7 +342,8 @@ + else { + if( x.running ) { + x.running = 0; +- wait_for_completion( &x.completion ); ++ kthread_stop(x.poll_task); ++ x.poll_task = NULL; + } + if( client == x.thermostat ) + x.thermostat = NULL; +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/macintosh/via-pmu-backlight.c powerpc.git/drivers/macintosh/via-pmu-backlight.c +--- linux-2.6.24/drivers/macintosh/via-pmu-backlight.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/macintosh/via-pmu-backlight.c 2008-01-28 20:26:08.000000000 +0100 +@@ -22,7 +22,7 @@ + + static void pmu_backlight_init_curve(u8 off, u8 min, u8 max) + { +- unsigned int i, flat, count, range = (max - min); ++ int i, flat, count, range = (max - min); + + bl_curve[0] = off; + +@@ -68,17 +68,11 @@ + return pmulevel; + } + +-static int pmu_backlight_update_status(struct backlight_device *bd) ++static int __pmu_backlight_update_status(struct backlight_device *bd) + { + struct adb_request req; +- unsigned long flags; + int level = bd->props.brightness; + +- spin_lock_irqsave(&pmu_backlight_lock, flags); +- +- /* Don't update brightness when sleeping */ +- if (sleeping) +- goto out; + + if (bd->props.power != FB_BLANK_UNBLANK || + bd->props.fb_blank != FB_BLANK_UNBLANK) +@@ -99,12 +93,23 @@ + pmu_wait_complete(&req); + } + +-out: +- spin_unlock_irqrestore(&pmu_backlight_lock, flags); +- + return 0; + } + ++static int pmu_backlight_update_status(struct backlight_device *bd) ++{ ++ unsigned long flags; ++ int rc = 0; ++ ++ spin_lock_irqsave(&pmu_backlight_lock, flags); ++ /* Don't update brightness when sleeping */ ++ if (!sleeping) ++ rc = __pmu_backlight_update_status(bd); ++ spin_unlock_irqrestore(&pmu_backlight_lock, flags); ++ return rc; ++} ++ ++ + static int pmu_backlight_get_brightness(struct backlight_device *bd) + { + return bd->props.brightness; +@@ -123,6 +128,16 @@ + + spin_lock_irqsave(&pmu_backlight_lock, flags); + sleeping = sleep; ++ if (pmac_backlight) { ++ if (sleep) { ++ struct adb_request req; ++ ++ pmu_request(&req, NULL, 2, PMU_POWER_CTRL, ++ PMU_POW_BACKLIGHT | PMU_POW_OFF); ++ pmu_wait_complete(&req); ++ } else ++ __pmu_backlight_update_status(pmac_backlight); ++ } + spin_unlock_irqrestore(&pmu_backlight_lock, flags); + } + #endif /* CONFIG_PM */ +@@ -148,8 +163,8 @@ + + bd = backlight_device_register(name, NULL, NULL, &pmu_backlight_data); + if (IS_ERR(bd)) { +- printk("pmubl: Backlight registration failed\n"); +- goto error; ++ printk(KERN_ERR "PMU Backlight registration failed\n"); ++ return; + } + bd->props.max_brightness = FB_BACKLIGHT_LEVELS - 1; + pmu_backlight_init_curve(0x7F, 0x46, 0x0E); +@@ -171,10 +186,5 @@ + bd->props.power = FB_BLANK_UNBLANK; + backlight_update_status(bd); + +- printk("pmubl: Backlight initialized (%s)\n", name); +- +- return; +- +-error: +- return; ++ printk(KERN_INFO "PMU Backlight initialized (%s)\n", name); + } +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/macintosh/via-pmu.c powerpc.git/drivers/macintosh/via-pmu.c +--- linux-2.6.24/drivers/macintosh/via-pmu.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/macintosh/via-pmu.c 2008-01-28 20:26:08.000000000 +0100 +@@ -10,13 +10,11 @@ + * + * Copyright (C) 1998 Paul Mackerras and Fabio Riccardi. + * Copyright (C) 2001-2002 Benjamin Herrenschmidt ++ * Copyright (C) 2006-2007 Johannes Berg + * + * THIS DRIVER IS BECOMING A TOTAL MESS ! + * - Cleanup atomically disabling reply to PMU events after + * a sleep or a freq. switch +- * - Move sleep code out of here to pmac_pm, merge into new +- * common PM infrastructure +- * - Save/Restore PCI space properly + * + */ + #include <stdarg.h> +@@ -33,7 +31,6 @@ + #include <linux/adb.h> + #include <linux/pmu.h> + #include <linux/cuda.h> +-#include <linux/smp_lock.h> + #include <linux/module.h> + #include <linux/spinlock.h> + #include <linux/pm.h> +@@ -65,9 +62,7 @@ + #include "via-pmu-event.h" + + /* Some compile options */ +-#undef SUSPEND_USES_PMU +-#define DEBUG_SLEEP +-#undef HACKED_PCI_SAVE ++#undef DEBUG_SLEEP + + /* Misc minor number allocated for /dev/pmu */ + #define PMU_MINOR 154 +@@ -152,12 +147,9 @@ + static u8 pmu_intr_mask; + static int pmu_version; + static int drop_interrupts; +-#if defined(CONFIG_PM_SLEEP) && defined(CONFIG_PPC32) ++#if defined(CONFIG_SUSPEND) && defined(CONFIG_PPC32) + static int option_lid_wakeup = 1; +-#endif /* CONFIG_PM_SLEEP && CONFIG_PPC32 */ +-#if (defined(CONFIG_PM_SLEEP)&&defined(CONFIG_PPC32))||defined(CONFIG_PMAC_BACKLIGHT_LEGACY) +-static int sleep_in_progress; +-#endif ++#endif /* CONFIG_SUSPEND && CONFIG_PPC32 */ + static unsigned long async_req_locks; + static unsigned int pmu_irq_stats[11]; + +@@ -177,7 +169,6 @@ + + int __fake_sleep; + int asleep; +-BLOCKING_NOTIFIER_HEAD(sleep_notifier_list); + + #ifdef CONFIG_ADB + static int adb_dev_map; +@@ -224,7 +215,7 @@ + + #ifdef DEBUG_SLEEP + int pmu_polled_request(struct adb_request *req); +-int pmu_wink(struct adb_request *req); ++void pmu_blink(int n); + #endif + + /* +@@ -875,7 +866,7 @@ + { + char *p = page; + +-#if defined(CONFIG_PM_SLEEP) && defined(CONFIG_PPC32) ++#if defined(CONFIG_SUSPEND) && defined(CONFIG_PPC32) + if (pmu_kind == PMU_KEYLARGO_BASED && + pmac_call_feature(PMAC_FTR_SLEEP_STATE,NULL,0,-1) >= 0) + p += sprintf(p, "lid_wakeup=%d\n", option_lid_wakeup); +@@ -916,7 +907,7 @@ + *(val++) = 0; + while(*val == ' ') + val++; +-#if defined(CONFIG_PM_SLEEP) && defined(CONFIG_PPC32) ++#if defined(CONFIG_SUSPEND) && defined(CONFIG_PPC32) + if (pmu_kind == PMU_KEYLARGO_BASED && + pmac_call_feature(PMAC_FTR_SLEEP_STATE,NULL,0,-1) >= 0) + if (!strcmp(label, "lid_wakeup")) +@@ -1256,9 +1247,7 @@ + pmu_suspend(void) + { + unsigned long flags; +-#ifdef SUSPEND_USES_PMU +- struct adb_request *req; +-#endif ++ + if (!via) + return; + +@@ -1276,17 +1265,10 @@ + via_pmu_interrupt(0, NULL); + spin_lock_irqsave(&pmu_lock, flags); + if (!adb_int_pending && pmu_state == idle && !req_awaiting_reply) { +-#ifdef SUSPEND_USES_PMU +- pmu_request(&req, NULL, 2, PMU_SET_INTR_MASK, 0); +- spin_unlock_irqrestore(&pmu_lock, flags); +- while(!req.complete) +- pmu_poll(); +-#else /* SUSPEND_USES_PMU */ + if (gpio_irq >= 0) + disable_irq_nosync(gpio_irq); + out_8(&via[IER], CB1_INT | IER_CLR); + spin_unlock_irqrestore(&pmu_lock, flags); +-#endif /* SUSPEND_USES_PMU */ + break; + } + } while (1); +@@ -1307,18 +1289,11 @@ + return; + } + adb_int_pending = 1; +-#ifdef SUSPEND_USES_PMU +- pmu_request(&req, NULL, 2, PMU_SET_INTR_MASK, pmu_intr_mask); +- spin_unlock_irqrestore(&pmu_lock, flags); +- while(!req.complete) +- pmu_poll(); +-#else /* SUSPEND_USES_PMU */ + if (gpio_irq >= 0) + enable_irq(gpio_irq); + out_8(&via[IER], CB1_INT | IER_SET); + spin_unlock_irqrestore(&pmu_lock, flags); + pmu_poll(); +-#endif /* SUSPEND_USES_PMU */ + } + + /* Interrupt data could be the result data from an ADB cmd */ +@@ -1738,228 +1713,7 @@ + return via != 0; + } + +-#ifdef CONFIG_PM_SLEEP +- +-static LIST_HEAD(sleep_notifiers); +- +-int +-pmu_register_sleep_notifier(struct pmu_sleep_notifier *n) +-{ +- struct list_head *list; +- struct pmu_sleep_notifier *notifier; +- +- for (list = sleep_notifiers.next; list != &sleep_notifiers; +- list = list->next) { +- notifier = list_entry(list, struct pmu_sleep_notifier, list); +- if (n->priority > notifier->priority) +- break; +- } +- __list_add(&n->list, list->prev, list); +- return 0; +-} +-EXPORT_SYMBOL(pmu_register_sleep_notifier); +- +-int +-pmu_unregister_sleep_notifier(struct pmu_sleep_notifier* n) +-{ +- if (n->list.next == 0) +- return -ENOENT; +- list_del(&n->list); +- n->list.next = NULL; +- return 0; +-} +-EXPORT_SYMBOL(pmu_unregister_sleep_notifier); +-#endif /* CONFIG_PM_SLEEP */ +- +-#if defined(CONFIG_PM_SLEEP) && defined(CONFIG_PPC32) +- +-/* Sleep is broadcast last-to-first */ +-static void broadcast_sleep(int when) +-{ +- struct list_head *list; +- struct pmu_sleep_notifier *notifier; +- +- for (list = sleep_notifiers.prev; list != &sleep_notifiers; +- list = list->prev) { +- notifier = list_entry(list, struct pmu_sleep_notifier, list); +- notifier->notifier_call(notifier, when); +- } +-} +- +-/* Wake is broadcast first-to-last */ +-static void broadcast_wake(void) +-{ +- struct list_head *list; +- struct pmu_sleep_notifier *notifier; +- +- for (list = sleep_notifiers.next; list != &sleep_notifiers; +- list = list->next) { +- notifier = list_entry(list, struct pmu_sleep_notifier, list); +- notifier->notifier_call(notifier, PBOOK_WAKE); +- } +-} +- +-/* +- * This struct is used to store config register values for +- * PCI devices which may get powered off when we sleep. +- */ +-static struct pci_save { +-#ifndef HACKED_PCI_SAVE +- u16 command; +- u16 cache_lat; +- u16 intr; +- u32 rom_address; +-#else +- u32 config[16]; +-#endif +-} *pbook_pci_saves; +-static int pbook_npci_saves; +- +-static void +-pbook_alloc_pci_save(void) +-{ +- int npci; +- struct pci_dev *pd = NULL; +- +- npci = 0; +- while ((pd = pci_get_device(PCI_ANY_ID, PCI_ANY_ID, pd)) != NULL) { +- ++npci; +- } +- if (npci == 0) +- return; +- pbook_pci_saves = (struct pci_save *) +- kmalloc(npci * sizeof(struct pci_save), GFP_KERNEL); +- pbook_npci_saves = npci; +-} +- +-static void +-pbook_free_pci_save(void) +-{ +- if (pbook_pci_saves == NULL) +- return; +- kfree(pbook_pci_saves); +- pbook_pci_saves = NULL; +- pbook_npci_saves = 0; +-} +- +-static void +-pbook_pci_save(void) +-{ +- struct pci_save *ps = pbook_pci_saves; +- struct pci_dev *pd = NULL; +- int npci = pbook_npci_saves; +- +- if (ps == NULL) +- return; +- +- while ((pd = pci_get_device(PCI_ANY_ID, PCI_ANY_ID, pd)) != NULL) { +- if (npci-- == 0) { +- pci_dev_put(pd); +- return; +- } +-#ifndef HACKED_PCI_SAVE +- pci_read_config_word(pd, PCI_COMMAND, &ps->command); +- pci_read_config_word(pd, PCI_CACHE_LINE_SIZE, &ps->cache_lat); +- pci_read_config_word(pd, PCI_INTERRUPT_LINE, &ps->intr); +- pci_read_config_dword(pd, PCI_ROM_ADDRESS, &ps->rom_address); +-#else +- int i; +- for (i=1;i<16;i++) +- pci_read_config_dword(pd, i<<4, &ps->config[i]); +-#endif +- ++ps; +- } +-} +- +-/* For this to work, we must take care of a few things: If gmac was enabled +- * during boot, it will be in the pci dev list. If it's disabled at this point +- * (and it will probably be), then you can't access it's config space. +- */ +-static void +-pbook_pci_restore(void) +-{ +- u16 cmd; +- struct pci_save *ps = pbook_pci_saves - 1; +- struct pci_dev *pd = NULL; +- int npci = pbook_npci_saves; +- int j; +- +- while ((pd = pci_get_device(PCI_ANY_ID, PCI_ANY_ID, pd)) != NULL) { +-#ifdef HACKED_PCI_SAVE +- int i; +- if (npci-- == 0) { +- pci_dev_put(pd); +- return; +- } +- ps++; +- for (i=2;i<16;i++) +- pci_write_config_dword(pd, i<<4, ps->config[i]); +- pci_write_config_dword(pd, 4, ps->config[1]); +-#else +- if (npci-- == 0) +- return; +- ps++; +- if (ps->command == 0) +- continue; +- pci_read_config_word(pd, PCI_COMMAND, &cmd); +- if ((ps->command & ~cmd) == 0) +- continue; +- switch (pd->hdr_type) { +- case PCI_HEADER_TYPE_NORMAL: +- for (j = 0; j < 6; ++j) +- pci_write_config_dword(pd, +- PCI_BASE_ADDRESS_0 + j*4, +- pd->resource[j].start); +- pci_write_config_dword(pd, PCI_ROM_ADDRESS, +- ps->rom_address); +- pci_write_config_word(pd, PCI_CACHE_LINE_SIZE, +- ps->cache_lat); +- pci_write_config_word(pd, PCI_INTERRUPT_LINE, +- ps->intr); +- pci_write_config_word(pd, PCI_COMMAND, ps->command); +- break; +- } +-#endif +- } +-} +- +-#ifdef DEBUG_SLEEP +-/* N.B. This doesn't work on the 3400 */ +-void +-pmu_blink(int n) +-{ +- struct adb_request req; +- +- memset(&req, 0, sizeof(req)); +- +- for (; n > 0; --n) { +- req.nbytes = 4; +- req.done = NULL; +- req.data[0] = 0xee; +- req.data[1] = 4; +- req.data[2] = 0; +- req.data[3] = 1; +- req.reply[0] = ADB_RET_OK; +- req.reply_len = 1; +- req.reply_expected = 0; +- pmu_polled_request(&req); +- mdelay(50); +- req.nbytes = 4; +- req.done = NULL; +- req.data[0] = 0xee; +- req.data[1] = 4; +- req.data[2] = 0; +- req.data[3] = 0; +- req.reply[0] = ADB_RET_OK; +- req.reply_len = 1; +- req.reply_expected = 0; +- pmu_polled_request(&req); +- mdelay(50); +- } +- mdelay(50); +-} +-#endif +- ++#if defined(CONFIG_SUSPEND) && defined(CONFIG_PPC32) + /* + * Put the powerbook to sleep. + */ +@@ -1994,134 +1748,6 @@ + out_8(&via[IER], IER_SET | SR_INT | CB1_INT); + } + +-extern void pmu_backlight_set_sleep(int sleep); +- +-static int +-pmac_suspend_devices(void) +-{ +- int ret; +- +- pm_prepare_console(); +- +- /* Notify old-style device drivers */ +- broadcast_sleep(PBOOK_SLEEP_REQUEST); +- +- /* Sync the disks. */ +- /* XXX It would be nice to have some way to ensure that +- * nobody is dirtying any new buffers while we wait. That +- * could be achieved using the refrigerator for processes +- * that swsusp uses +- */ +- sys_sync(); +- +- broadcast_sleep(PBOOK_SLEEP_NOW); +- +- /* Send suspend call to devices, hold the device core's dpm_sem */ +- ret = device_suspend(PMSG_SUSPEND); +- if (ret) { +- broadcast_wake(); +- printk(KERN_ERR "Driver sleep failed\n"); +- return -EBUSY; +- } +- +-#ifdef CONFIG_PMAC_BACKLIGHT +- /* Tell backlight code not to muck around with the chip anymore */ +- pmu_backlight_set_sleep(1); +-#endif +- +- /* Call platform functions marked "on sleep" */ +- pmac_pfunc_i2c_suspend(); +- pmac_pfunc_base_suspend(); +- +- /* Stop preemption */ +- preempt_disable(); +- +- /* Make sure the decrementer won't interrupt us */ +- asm volatile("mtdec %0" : : "r" (0x7fffffff)); +- /* Make sure any pending DEC interrupt occurring while we did +- * the above didn't re-enable the DEC */ +- mb(); +- asm volatile("mtdec %0" : : "r" (0x7fffffff)); +- +- /* We can now disable MSR_EE. This code of course works properly only +- * on UP machines... For SMP, if we ever implement sleep, we'll have to +- * stop the "other" CPUs way before we do all that stuff. +- */ +- local_irq_disable(); +- +- /* Broadcast power down irq +- * This isn't that useful in most cases (only directly wired devices can +- * use this but still... This will take care of sysdev's as well, so +- * we exit from here with local irqs disabled and PIC off. +- */ +- ret = device_power_down(PMSG_SUSPEND); +- if (ret) { +- wakeup_decrementer(); +- local_irq_enable(); +- preempt_enable(); +- device_resume(); +- broadcast_wake(); +- printk(KERN_ERR "Driver powerdown failed\n"); +- return -EBUSY; +- } +- +- /* Wait for completion of async requests */ +- while (!batt_req.complete) +- pmu_poll(); +- +- /* Giveup the lazy FPU & vec so we don't have to back them +- * up from the low level code +- */ +- enable_kernel_fp(); +- +-#ifdef CONFIG_ALTIVEC +- if (cpu_has_feature(CPU_FTR_ALTIVEC)) +- enable_kernel_altivec(); +-#endif /* CONFIG_ALTIVEC */ +- +- return 0; +-} +- +-static int +-pmac_wakeup_devices(void) +-{ +- mdelay(100); +- +-#ifdef CONFIG_PMAC_BACKLIGHT +- /* Tell backlight code it can use the chip again */ +- pmu_backlight_set_sleep(0); +-#endif +- +- /* Power back up system devices (including the PIC) */ +- device_power_up(); +- +- /* Force a poll of ADB interrupts */ +- adb_int_pending = 1; +- via_pmu_interrupt(0, NULL); +- +- /* Restart jiffies & scheduling */ +- wakeup_decrementer(); +- +- /* Re-enable local CPU interrupts */ +- local_irq_enable(); +- mdelay(10); +- preempt_enable(); +- +- /* Call platform functions marked "on wake" */ +- pmac_pfunc_base_resume(); +- pmac_pfunc_i2c_resume(); +- +- /* Resume devices */ +- device_resume(); +- +- /* Notify old style drivers */ +- broadcast_wake(); +- +- pm_restore_console(); +- +- return 0; +-} +- + #define GRACKLE_PM (1<<7) + #define GRACKLE_DOZE (1<<5) + #define GRACKLE_NAP (1<<4) +@@ -2132,19 +1758,12 @@ + unsigned long save_l2cr; + unsigned short pmcr1; + struct adb_request req; +- int ret; + struct pci_dev *grackle; + + grackle = pci_get_bus_and_slot(0, 0); + if (!grackle) + return -ENODEV; + +- ret = pmac_suspend_devices(); +- if (ret) { +- printk(KERN_ERR "Sleep rejected by devices\n"); +- return ret; +- } +- + /* Turn off various things. Darwin does some retry tests here... */ + pmu_request(&req, NULL, 2, PMU_POWER_CTRL0, PMU_POW0_OFF|PMU_POW0_HARD_DRIVE); + pmu_wait_complete(&req); +@@ -2207,8 +1826,6 @@ + PMU_POW_ON|PMU_POW_BACKLIGHT|PMU_POW_CHARGER|PMU_POW_IRLED|PMU_POW_MEDIABAY); + pmu_wait_complete(&req); + +- pmac_wakeup_devices(); +- + return 0; + } + +@@ -2218,7 +1835,6 @@ + unsigned long save_l2cr; + unsigned long save_l3cr; + struct adb_request req; +- int ret; + + if (pmac_call_feature(PMAC_FTR_SLEEP_STATE,NULL,0,-1) < 0) { + printk(KERN_ERR "Sleep mode not supported on this machine\n"); +@@ -2228,12 +1844,6 @@ + if (num_online_cpus() > 1 || cpu_is_offline(0)) + return -EAGAIN; + +- ret = pmac_suspend_devices(); +- if (ret) { +- printk(KERN_ERR "Sleep rejected by devices\n"); +- return ret; +- } +- + /* Stop environment and ADB interrupts */ + pmu_request(&req, NULL, 2, PMU_SET_INTR_MASK, 0); + pmu_wait_complete(&req); +@@ -2304,45 +1914,33 @@ + /* Restore LPJ, cpufreq will adjust the cpu frequency */ + loops_per_jiffy /= 2; + +- pmac_wakeup_devices(); +- + return 0; + } + + #define PB3400_MEM_CTRL 0xf8000000 + #define PB3400_MEM_CTRL_SLEEP 0x70 + +-static int +-powerbook_sleep_3400(void) ++static void __iomem *pb3400_mem_ctrl; ++ ++static void powerbook_sleep_init_3400(void) + { +- int ret, i, x; ++ /* map in the memory controller registers */ ++ pb3400_mem_ctrl = ioremap(PB3400_MEM_CTRL, 0x100); ++ if (pb3400_mem_ctrl == NULL) ++ printk(KERN_WARNING "ioremap failed: sleep won't be possible"); ++} ++ ++static int powerbook_sleep_3400(void) ++{ ++ int i, x; + unsigned int hid0; +- unsigned long p; ++ unsigned long msr; + struct adb_request sleep_req; +- void __iomem *mem_ctrl; + unsigned int __iomem *mem_ctrl_sleep; + +- /* first map in the memory controller registers */ +- mem_ctrl = ioremap(PB3400_MEM_CTRL, 0x100); +- if (mem_ctrl == NULL) { +- printk("powerbook_sleep_3400: ioremap failed\n"); ++ if (pb3400_mem_ctrl == NULL) + return -ENOMEM; +- } +- mem_ctrl_sleep = mem_ctrl + PB3400_MEM_CTRL_SLEEP; +- +- /* Allocate room for PCI save */ +- pbook_alloc_pci_save(); +- +- ret = pmac_suspend_devices(); +- if (ret) { +- pbook_free_pci_save(); +- iounmap(mem_ctrl); +- printk(KERN_ERR "Sleep rejected by devices\n"); +- return ret; +- } +- +- /* Save the state of PCI config space for some slots */ +- pbook_pci_save(); ++ mem_ctrl_sleep = pb3400_mem_ctrl + PB3400_MEM_CTRL_SLEEP; + + /* Set the memory controller to keep the memory refreshed + while we're asleep */ +@@ -2357,41 +1955,34 @@ + + /* Ask the PMU to put us to sleep */ + pmu_request(&sleep_req, NULL, 5, PMU_SLEEP, 'M', 'A', 'T', 'T'); +- while (!sleep_req.complete) +- mb(); ++ pmu_wait_complete(&sleep_req); ++ pmu_unlock(); + +- pmac_call_feature(PMAC_FTR_SLEEP_STATE,NULL,0,1); ++ pmac_call_feature(PMAC_FTR_SLEEP_STATE, NULL, 0, 1); + +- /* displacement-flush the L2 cache - necessary? */ +- for (p = KERNELBASE; p < KERNELBASE + 0x100000; p += 0x1000) +- i = *(volatile int *)p; + asleep = 1; + + /* Put the CPU into sleep mode */ + hid0 = mfspr(SPRN_HID0); + hid0 = (hid0 & ~(HID0_NAP | HID0_DOZE)) | HID0_SLEEP; + mtspr(SPRN_HID0, hid0); +- mtmsr(mfmsr() | MSR_POW | MSR_EE); +- udelay(10); ++ local_irq_enable(); ++ msr = mfmsr() | MSR_POW; ++ while (asleep) { ++ mb(); ++ mtmsr(msr); ++ isync(); ++ } ++ local_irq_disable(); + + /* OK, we're awake again, start restoring things */ + out_be32(mem_ctrl_sleep, 0x3f); +- pmac_call_feature(PMAC_FTR_SLEEP_STATE,NULL,0,0); +- pbook_pci_restore(); +- pmu_unlock(); +- +- /* wait for the PMU interrupt sequence to complete */ +- while (asleep) +- mb(); +- +- pmac_wakeup_devices(); +- pbook_free_pci_save(); +- iounmap(mem_ctrl); ++ pmac_call_feature(PMAC_FTR_SLEEP_STATE, NULL, 0, 0); + + return 0; + } + +-#endif /* CONFIG_PM_SLEEP && CONFIG_PPC32 */ ++#endif /* CONFIG_SUSPEND && CONFIG_PPC32 */ + + /* + * Support for /dev/pmu device +@@ -2548,7 +2139,6 @@ + struct pmu_private *pp = file->private_data; + unsigned long flags; + +- lock_kernel(); + if (pp != 0) { + file->private_data = NULL; + spin_lock_irqsave(&all_pvt_lock, flags); +@@ -2562,10 +2152,96 @@ + + kfree(pp); + } +- unlock_kernel(); + return 0; + } + ++#if defined(CONFIG_SUSPEND) && defined(CONFIG_PPC32) ++static void pmac_suspend_disable_irqs(void) ++{ ++ /* Call platform functions marked "on sleep" */ ++ pmac_pfunc_i2c_suspend(); ++ pmac_pfunc_base_suspend(); ++} ++ ++static int powerbook_sleep(suspend_state_t state) ++{ ++ int error = 0; ++ ++ /* Wait for completion of async requests */ ++ while (!batt_req.complete) ++ pmu_poll(); ++ ++ /* Giveup the lazy FPU & vec so we don't have to back them ++ * up from the low level code ++ */ ++ enable_kernel_fp(); ++ ++#ifdef CONFIG_ALTIVEC ++ if (cpu_has_feature(CPU_FTR_ALTIVEC)) ++ enable_kernel_altivec(); ++#endif /* CONFIG_ALTIVEC */ ++ ++ switch (pmu_kind) { ++ case PMU_OHARE_BASED: ++ error = powerbook_sleep_3400(); ++ break; ++ case PMU_HEATHROW_BASED: ++ case PMU_PADDINGTON_BASED: ++ error = powerbook_sleep_grackle(); ++ break; ++ case PMU_KEYLARGO_BASED: ++ error = powerbook_sleep_Core99(); ++ break; ++ default: ++ return -ENOSYS; ++ } ++ ++ if (error) ++ return error; ++ ++ mdelay(100); ++ ++ return 0; ++} ++ ++static void pmac_suspend_enable_irqs(void) ++{ ++ /* Force a poll of ADB interrupts */ ++ adb_int_pending = 1; ++ via_pmu_interrupt(0, NULL); ++ ++ mdelay(10); ++ ++ /* Call platform functions marked "on wake" */ ++ pmac_pfunc_base_resume(); ++ pmac_pfunc_i2c_resume(); ++} ++ ++static int pmu_sleep_valid(suspend_state_t state) ++{ ++ return state == PM_SUSPEND_MEM ++ && (pmac_call_feature(PMAC_FTR_SLEEP_STATE, NULL, 0, -1) >= 0); ++} ++ ++static struct platform_suspend_ops pmu_pm_ops = { ++ .enter = powerbook_sleep, ++ .valid = pmu_sleep_valid, ++}; ++ ++static int register_pmu_pm_ops(void) ++{ ++ if (pmu_kind == PMU_OHARE_BASED) ++ powerbook_sleep_init_3400(); ++ ppc_md.suspend_disable_irqs = pmac_suspend_disable_irqs; ++ ppc_md.suspend_enable_irqs = pmac_suspend_enable_irqs; ++ suspend_set_ops(&pmu_pm_ops); ++ ++ return 0; ++} ++ ++device_initcall(register_pmu_pm_ops); ++#endif ++ + static int + pmu_ioctl(struct inode * inode, struct file *filp, + u_int cmd, u_long arg) +@@ -2574,35 +2250,15 @@ + int error = -EINVAL; + + switch (cmd) { +-#if defined(CONFIG_PM_SLEEP) && defined(CONFIG_PPC32) + case PMU_IOC_SLEEP: + if (!capable(CAP_SYS_ADMIN)) + return -EACCES; +- if (sleep_in_progress) +- return -EBUSY; +- sleep_in_progress = 1; +- switch (pmu_kind) { +- case PMU_OHARE_BASED: +- error = powerbook_sleep_3400(); +- break; +- case PMU_HEATHROW_BASED: +- case PMU_PADDINGTON_BASED: +- error = powerbook_sleep_grackle(); +- break; +- case PMU_KEYLARGO_BASED: +- error = powerbook_sleep_Core99(); +- break; +- default: +- error = -ENOSYS; +- } +- sleep_in_progress = 0; +- break; ++ return pm_suspend(PM_SUSPEND_MEM); + case PMU_IOC_CAN_SLEEP: +- if (pmac_call_feature(PMAC_FTR_SLEEP_STATE,NULL,0,-1) < 0) ++ if (pmac_call_feature(PMAC_FTR_SLEEP_STATE, NULL, 0, -1) < 0) + return put_user(0, argp); + else + return put_user(1, argp); +-#endif /* CONFIG_PM_SLEEP && CONFIG_PPC32 */ + + #ifdef CONFIG_PMAC_BACKLIGHT_LEGACY + /* Compatibility ioctl's for backlight */ +@@ -2610,9 +2266,6 @@ + { + int brightness; + +- if (sleep_in_progress) +- return -EBUSY; +- + brightness = pmac_backlight_get_legacy_brightness(); + if (brightness < 0) + return brightness; +@@ -2624,9 +2277,6 @@ + { + int brightness; + +- if (sleep_in_progress) +- return -EBUSY; +- + error = get_user(brightness, argp); + if (error) + return error; +@@ -2751,15 +2401,43 @@ + local_irq_restore(flags); + return 0; + } +-#endif /* DEBUG_SLEEP */ + ++/* N.B. This doesn't work on the 3400 */ ++void pmu_blink(int n) ++{ ++ struct adb_request req; + +-/* FIXME: This is a temporary set of callbacks to enable us +- * to do suspend-to-disk. +- */ ++ memset(&req, 0, sizeof(req)); + +-#if defined(CONFIG_PM_SLEEP) && defined(CONFIG_PPC32) ++ for (; n > 0; --n) { ++ req.nbytes = 4; ++ req.done = NULL; ++ req.data[0] = 0xee; ++ req.data[1] = 4; ++ req.data[2] = 0; ++ req.data[3] = 1; ++ req.reply[0] = ADB_RET_OK; ++ req.reply_len = 1; ++ req.reply_expected = 0; ++ pmu_polled_request(&req); ++ mdelay(50); ++ req.nbytes = 4; ++ req.done = NULL; ++ req.data[0] = 0xee; ++ req.data[1] = 4; ++ req.data[2] = 0; ++ req.data[3] = 0; ++ req.reply[0] = ADB_RET_OK; ++ req.reply_len = 1; ++ req.reply_expected = 0; ++ pmu_polled_request(&req); ++ mdelay(50); ++ } ++ mdelay(50); ++} ++#endif /* DEBUG_SLEEP */ + ++#if defined(CONFIG_SUSPEND) && defined(CONFIG_PPC32) + int pmu_sys_suspended; + + static int pmu_sys_suspend(struct sys_device *sysdev, pm_message_t state) +@@ -2767,10 +2445,15 @@ + if (state.event != PM_EVENT_SUSPEND || pmu_sys_suspended) + return 0; + +- /* Suspend PMU event interrupts */ ++ /* Suspend PMU event interrupts */\ + pmu_suspend(); +- + pmu_sys_suspended = 1; ++ ++#ifdef CONFIG_PMAC_BACKLIGHT ++ /* Tell backlight code not to muck around with the chip anymore */ ++ pmu_backlight_set_sleep(1); ++#endif ++ + return 0; + } + +@@ -2785,15 +2468,18 @@ + pmu_request(&req, NULL, 2, PMU_SYSTEM_READY, 2); + pmu_wait_complete(&req); + ++#ifdef CONFIG_PMAC_BACKLIGHT ++ /* Tell backlight code it can use the chip again */ ++ pmu_backlight_set_sleep(0); ++#endif + /* Resume PMU event interrupts */ + pmu_resume(); +- + pmu_sys_suspended = 0; + + return 0; + } + +-#endif /* CONFIG_PM_SLEEP && CONFIG_PPC32 */ ++#endif /* CONFIG_SUSPEND && CONFIG_PPC32 */ + + static struct sysdev_class pmu_sysclass = { + set_kset_name("pmu"), +@@ -2804,10 +2490,10 @@ + }; + + static struct sysdev_driver driver_pmu = { +-#if defined(CONFIG_PM_SLEEP) && defined(CONFIG_PPC32) ++#if defined(CONFIG_SUSPEND) && defined(CONFIG_PPC32) + .suspend = &pmu_sys_suspend, + .resume = &pmu_sys_resume, +-#endif /* CONFIG_PM_SLEEP && CONFIG_PPC32 */ ++#endif /* CONFIG_SUSPEND && CONFIG_PPC32 */ + }; + + static int __init init_pmu_sysfs(void) +@@ -2842,10 +2528,10 @@ + EXPORT_SYMBOL(pmu_suspend); + EXPORT_SYMBOL(pmu_resume); + EXPORT_SYMBOL(pmu_unlock); +-#if defined(CONFIG_PM_SLEEP) && defined(CONFIG_PPC32) ++#if defined(CONFIG_SUSPEND) && defined(CONFIG_PPC32) + EXPORT_SYMBOL(pmu_enable_irled); + EXPORT_SYMBOL(pmu_battery_count); + EXPORT_SYMBOL(pmu_batteries); + EXPORT_SYMBOL(pmu_power_flags); +-#endif /* CONFIG_PM_SLEEP && CONFIG_PPC32 */ ++#endif /* CONFIG_SUSPEND && CONFIG_PPC32 */ + +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/net/fs_enet/fs_enet-main.c powerpc.git/drivers/net/fs_enet/fs_enet-main.c +--- linux-2.6.24/drivers/net/fs_enet/fs_enet-main.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/net/fs_enet/fs_enet-main.c 2008-01-28 20:26:12.000000000 +0100 +@@ -1178,8 +1178,15 @@ + struct device_node *phynode, *mdionode; + struct resource res; + int ret = 0, len; ++ const u32 *data; ++ ++ data = of_get_property(np, "fixed-link", NULL); ++ if (data) { ++ snprintf(fpi->bus_id, 16, PHY_ID_FMT, 0, *data); ++ return 0; ++ } + +- const u32 *data = of_get_property(np, "phy-handle", &len); ++ data = of_get_property(np, "phy-handle", &len); + if (!data || len != 4) + return -EINVAL; + +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/net/fs_enet/mac-fcc.c powerpc.git/drivers/net/fs_enet/mac-fcc.c +--- linux-2.6.24/drivers/net/fs_enet/mac-fcc.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/net/fs_enet/mac-fcc.c 2008-01-28 20:26:12.000000000 +0100 +@@ -81,16 +81,8 @@ + static inline int fcc_cr_cmd(struct fs_enet_private *fep, u32 op) + { + const struct fs_platform_info *fpi = fep->fpi; +- int i; + +- W32(cpmp, cp_cpcr, fpi->cp_command | op | CPM_CR_FLG); +- for (i = 0; i < MAX_CR_CMD_LOOPS; i++) +- if ((R32(cpmp, cp_cpcr) & CPM_CR_FLG) == 0) +- return 0; +- +- printk(KERN_ERR "%s(): Not able to issue CPM command\n", +- __FUNCTION__); +- return 1; ++ return cpm_command(fpi->cp_command, op); + } + + static int do_pd_setup(struct fs_enet_private *fep) +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/net/fs_enet/mac-scc.c powerpc.git/drivers/net/fs_enet/mac-scc.c +--- linux-2.6.24/drivers/net/fs_enet/mac-scc.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/net/fs_enet/mac-scc.c 2008-01-28 20:26:12.000000000 +0100 +@@ -89,21 +89,12 @@ + * Delay to wait for SCC reset command to complete (in us) + */ + #define SCC_RESET_DELAY 50 +-#define MAX_CR_CMD_LOOPS 10000 + + static inline int scc_cr_cmd(struct fs_enet_private *fep, u32 op) + { + const struct fs_platform_info *fpi = fep->fpi; +- int i; + +- W16(cpmp, cp_cpcr, fpi->cp_command | CPM_CR_FLG | (op << 8)); +- for (i = 0; i < MAX_CR_CMD_LOOPS; i++) +- if ((R16(cpmp, cp_cpcr) & CPM_CR_FLG) == 0) +- return 0; +- +- printk(KERN_ERR "%s(): Not able to issue CPM command\n", +- __FUNCTION__); +- return 1; ++ return cpm_command(fpi->cp_command, op); + } + + static int do_pd_setup(struct fs_enet_private *fep) +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/net/ibm_newemac/core.c powerpc.git/drivers/net/ibm_newemac/core.c +--- linux-2.6.24/drivers/net/ibm_newemac/core.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/net/ibm_newemac/core.c 2008-01-28 20:26:12.000000000 +0100 +@@ -37,6 +37,7 @@ + #include <linux/mii.h> + #include <linux/bitops.h> + #include <linux/workqueue.h> ++#include <linux/of.h> + + #include <asm/processor.h> + #include <asm/io.h> +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/net/phy/Kconfig powerpc.git/drivers/net/phy/Kconfig +--- linux-2.6.24/drivers/net/phy/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/net/phy/Kconfig 2008-01-28 20:26:14.000000000 +0100 +@@ -61,34 +61,12 @@ + Currently supports the IP175C PHY. + + config FIXED_PHY +- tristate "Drivers for PHY emulation on fixed speed/link" ++ bool "Driver for MDIO Bus/PHY emulation with fixed speed/link PHYs" + ---help--- +- Adds the driver to PHY layer to cover the boards that do not have any PHY bound, +- but with the ability to manipulate the speed/link in software. The relevant MII +- speed/duplex parameters could be effectively handled in a user-specified function. +- Currently tested with mpc866ads. ++ Adds the platform "fixed" MDIO Bus to cover the boards that use ++ PHYs that are not connected to the real MDIO bus. + +-config FIXED_MII_10_FDX +- bool "Emulation for 10M Fdx fixed PHY behavior" +- depends on FIXED_PHY +- +-config FIXED_MII_100_FDX +- bool "Emulation for 100M Fdx fixed PHY behavior" +- depends on FIXED_PHY +- +-config FIXED_MII_1000_FDX +- bool "Emulation for 1000M Fdx fixed PHY behavior" +- depends on FIXED_PHY +- +-config FIXED_MII_AMNT +- int "Number of emulated PHYs to allocate " +- depends on FIXED_PHY +- default "1" +- ---help--- +- Sometimes it is required to have several independent emulated +- PHYs on the bus (in case of multi-eth but phy-less HW for instance). +- This control will have specified number allocated for each fixed +- PHY type enabled. ++ Currently tested with mpc866ads and mpc8349e-mitx. + + config MDIO_BITBANG + tristate "Support for bitbanged MDIO buses" +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/net/phy/fixed.c powerpc.git/drivers/net/phy/fixed.c +--- linux-2.6.24/drivers/net/phy/fixed.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/net/phy/fixed.c 2008-01-28 20:26:14.000000000 +0100 +@@ -1,362 +1,253 @@ + /* +- * drivers/net/phy/fixed.c ++ * Fixed MDIO bus (MDIO bus emulation with fixed PHYs) + * +- * Driver for fixed PHYs, when transceiver is able to operate in one fixed mode. ++ * Author: Vitaly Bordug <vbordug@ru.mvista.com> ++ * Anton Vorontsov <avorontsov@ru.mvista.com> + * +- * Author: Vitaly Bordug +- * +- * Copyright (c) 2006 MontaVista Software, Inc. ++ * Copyright (c) 2006-2007 MontaVista Software, Inc. + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the + * Free Software Foundation; either version 2 of the License, or (at your + * option) any later version. +- * + */ ++ + #include <linux/kernel.h> +-#include <linux/string.h> +-#include <linux/errno.h> +-#include <linux/unistd.h> +-#include <linux/slab.h> +-#include <linux/interrupt.h> +-#include <linux/init.h> +-#include <linux/delay.h> +-#include <linux/netdevice.h> +-#include <linux/etherdevice.h> +-#include <linux/skbuff.h> +-#include <linux/spinlock.h> +-#include <linux/mm.h> + #include <linux/module.h> ++#include <linux/platform_device.h> ++#include <linux/list.h> + #include <linux/mii.h> +-#include <linux/ethtool.h> + #include <linux/phy.h> + #include <linux/phy_fixed.h> + +-#include <asm/io.h> +-#include <asm/irq.h> +-#include <asm/uaccess.h> +- +-/* we need to track the allocated pointers in order to free them on exit */ +-static struct fixed_info *fixed_phy_ptrs[CONFIG_FIXED_MII_AMNT*MAX_PHY_AMNT]; +- +-/*----------------------------------------------------------------------------- +- * If something weird is required to be done with link/speed, +- * network driver is able to assign a function to implement this. +- * May be useful for PHY's that need to be software-driven. +- *-----------------------------------------------------------------------------*/ +-int fixed_mdio_set_link_update(struct phy_device *phydev, +- int (*link_update) (struct net_device *, +- struct fixed_phy_status *)) +-{ +- struct fixed_info *fixed; +- +- if (link_update == NULL) +- return -EINVAL; ++#define MII_REGS_NUM 29 + +- if (phydev) { +- if (phydev->bus) { +- fixed = phydev->bus->priv; +- fixed->link_update = link_update; +- return 0; +- } +- } +- return -EINVAL; +-} +- +-EXPORT_SYMBOL(fixed_mdio_set_link_update); ++struct fixed_mdio_bus { ++ int irqs[PHY_MAX_ADDR]; ++ struct mii_bus mii_bus; ++ struct list_head phys; ++}; + +-struct fixed_info *fixed_mdio_get_phydev (int phydev_ind) +-{ +- if (phydev_ind >= MAX_PHY_AMNT) +- return NULL; +- return fixed_phy_ptrs[phydev_ind]; +-} ++struct fixed_phy { ++ int id; ++ u16 regs[MII_REGS_NUM]; ++ struct phy_device *phydev; ++ struct fixed_phy_status status; ++ int (*link_update)(struct net_device *, struct fixed_phy_status *); ++ struct list_head node; ++}; + +-EXPORT_SYMBOL(fixed_mdio_get_phydev); ++static struct platform_device *pdev; ++static struct fixed_mdio_bus platform_fmb = { ++ .phys = LIST_HEAD_INIT(platform_fmb.phys), ++}; + +-/*----------------------------------------------------------------------------- +- * This is used for updating internal mii regs from the status +- *-----------------------------------------------------------------------------*/ +-#if defined(CONFIG_FIXED_MII_100_FDX) || defined(CONFIG_FIXED_MII_10_FDX) || defined(CONFIG_FIXED_MII_1000_FDX) +-static int fixed_mdio_update_regs(struct fixed_info *fixed) ++static int fixed_phy_update_regs(struct fixed_phy *fp) + { +- u16 *regs = fixed->regs; +- u16 bmsr = 0; ++ u16 bmsr = BMSR_ANEGCAPABLE; + u16 bmcr = 0; ++ u16 lpagb = 0; ++ u16 lpa = 0; + +- if (!regs) { +- printk(KERN_ERR "%s: regs not set up", __FUNCTION__); +- return -EINVAL; +- } +- +- if (fixed->phy_status.link) +- bmsr |= BMSR_LSTATUS; +- +- if (fixed->phy_status.duplex) { ++ if (fp->status.duplex) { + bmcr |= BMCR_FULLDPLX; + +- switch (fixed->phy_status.speed) { ++ switch (fp->status.speed) { ++ case 1000: ++ bmsr |= BMSR_ESTATEN; ++ bmcr |= BMCR_SPEED1000; ++ lpagb |= LPA_1000FULL; ++ break; + case 100: + bmsr |= BMSR_100FULL; + bmcr |= BMCR_SPEED100; ++ lpa |= LPA_100FULL; + break; +- + case 10: + bmsr |= BMSR_10FULL; ++ lpa |= LPA_10FULL; + break; ++ default: ++ printk(KERN_WARNING "fixed phy: unknown speed\n"); ++ return -EINVAL; + } + } else { +- switch (fixed->phy_status.speed) { ++ switch (fp->status.speed) { ++ case 1000: ++ bmsr |= BMSR_ESTATEN; ++ bmcr |= BMCR_SPEED1000; ++ lpagb |= LPA_1000HALF; ++ break; + case 100: + bmsr |= BMSR_100HALF; + bmcr |= BMCR_SPEED100; ++ lpa |= LPA_100HALF; + break; +- + case 10: +- bmsr |= BMSR_100HALF; ++ bmsr |= BMSR_10HALF; ++ lpa |= LPA_10HALF; + break; ++ default: ++ printk(KERN_WARNING "fixed phy: unknown speed\n"); ++ return -EINVAL; + } + } + +- regs[MII_BMCR] = bmcr; +- regs[MII_BMSR] = bmsr | 0x800; /*we are always capable of 10 hdx */ ++ if (fp->status.link) ++ bmsr |= BMSR_LSTATUS | BMSR_ANEGCOMPLETE; ++ ++ if (fp->status.pause) ++ lpa |= LPA_PAUSE_CAP; ++ ++ if (fp->status.asym_pause) ++ lpa |= LPA_PAUSE_ASYM; ++ ++ fp->regs[MII_PHYSID1] = fp->id >> 16; ++ fp->regs[MII_PHYSID2] = fp->id; ++ ++ fp->regs[MII_BMSR] = bmsr; ++ fp->regs[MII_BMCR] = bmcr; ++ fp->regs[MII_LPA] = lpa; ++ fp->regs[MII_STAT1000] = lpagb; + + return 0; + } + +-static int fixed_mii_read(struct mii_bus *bus, int phy_id, int location) ++static int fixed_mdio_read(struct mii_bus *bus, int phy_id, int reg_num) + { +- struct fixed_info *fixed = bus->priv; ++ struct fixed_mdio_bus *fmb = container_of(bus, struct fixed_mdio_bus, ++ mii_bus); ++ struct fixed_phy *fp; + +- /* if user has registered link update callback, use it */ +- if (fixed->phydev) +- if (fixed->phydev->attached_dev) { +- if (fixed->link_update) { +- fixed->link_update(fixed->phydev->attached_dev, +- &fixed->phy_status); +- fixed_mdio_update_regs(fixed); ++ if (reg_num >= MII_REGS_NUM) ++ return -1; ++ ++ list_for_each_entry(fp, &fmb->phys, node) { ++ if (fp->id == phy_id) { ++ /* Issue callback if user registered it. */ ++ if (fp->link_update) { ++ fp->link_update(fp->phydev->attached_dev, ++ &fp->status); ++ fixed_phy_update_regs(fp); + } ++ return fp->regs[reg_num]; + } ++ } + +- if ((unsigned int)location >= fixed->regs_num) +- return -1; +- return fixed->regs[location]; ++ return 0xFFFF; + } + +-static int fixed_mii_write(struct mii_bus *bus, int phy_id, int location, +- u16 val) ++static int fixed_mdio_write(struct mii_bus *bus, int phy_id, int reg_num, ++ u16 val) + { +- /* do nothing for now */ + return 0; + } + +-static int fixed_mii_reset(struct mii_bus *bus) ++/* ++ * If something weird is required to be done with link/speed, ++ * network driver is able to assign a function to implement this. ++ * May be useful for PHY's that need to be software-driven. ++ */ ++int fixed_phy_set_link_update(struct phy_device *phydev, ++ int (*link_update)(struct net_device *, ++ struct fixed_phy_status *)) + { +- /*nothing here - no way/need to reset it */ +- return 0; +-} +-#endif ++ struct fixed_mdio_bus *fmb = &platform_fmb; ++ struct fixed_phy *fp; + +-static int fixed_config_aneg(struct phy_device *phydev) +-{ +- /* :TODO:03/13/2006 09:45:37 PM:: +- The full autoneg funcionality can be emulated, +- but no need to have anything here for now +- */ +- return 0; +-} ++ if (!link_update || !phydev || !phydev->bus) ++ return -EINVAL; + +-/*----------------------------------------------------------------------------- +- * the manual bind will do the magic - with phy_id_mask == 0 +- * match will never return true... +- *-----------------------------------------------------------------------------*/ +-static struct phy_driver fixed_mdio_driver = { +- .name = "Fixed PHY", +-#ifdef CONFIG_FIXED_MII_1000_FDX +- .features = PHY_GBIT_FEATURES, +-#else +- .features = PHY_BASIC_FEATURES, +-#endif +- .config_aneg = fixed_config_aneg, +- .read_status = genphy_read_status, +- .driver = { .owner = THIS_MODULE, }, +-}; ++ list_for_each_entry(fp, &fmb->phys, node) { ++ if (fp->id == phydev->phy_id) { ++ fp->link_update = link_update; ++ fp->phydev = phydev; ++ return 0; ++ } ++ } + +-static void fixed_mdio_release(struct device *dev) +-{ +- struct phy_device *phydev = container_of(dev, struct phy_device, dev); +- struct mii_bus *bus = phydev->bus; +- struct fixed_info *fixed = bus->priv; +- +- kfree(phydev); +- kfree(bus->dev); +- kfree(bus); +- kfree(fixed->regs); +- kfree(fixed); ++ return -ENOENT; + } ++EXPORT_SYMBOL_GPL(fixed_phy_set_link_update); + +-/*----------------------------------------------------------------------------- +- * This func is used to create all the necessary stuff, bind +- * the fixed phy driver and register all it on the mdio_bus_type. +- * speed is either 10 or 100 or 1000, duplex is boolean. +- * number is used to create multiple fixed PHYs, so that several devices can +- * utilize them simultaneously. +- * +- * The device on mdio bus will look like [bus_id]:[phy_id], +- * bus_id = number +- * phy_id = speed+duplex. +- *-----------------------------------------------------------------------------*/ +-#if defined(CONFIG_FIXED_MII_100_FDX) || defined(CONFIG_FIXED_MII_10_FDX) || defined(CONFIG_FIXED_MII_1000_FDX) +-struct fixed_info *fixed_mdio_register_device( +- int bus_id, int speed, int duplex, u8 phy_id) ++int fixed_phy_add(unsigned int irq, int phy_id, ++ struct fixed_phy_status *status) + { +- struct mii_bus *new_bus; +- struct fixed_info *fixed; +- struct phy_device *phydev; +- int err; ++ int ret; ++ struct fixed_mdio_bus *fmb = &platform_fmb; ++ struct fixed_phy *fp; + +- struct device *dev = kzalloc(sizeof(struct device), GFP_KERNEL); ++ fp = kzalloc(sizeof(*fp), GFP_KERNEL); ++ if (!fp) ++ return -ENOMEM; + +- if (dev == NULL) +- goto err_dev_alloc; ++ memset(fp->regs, 0xFF, sizeof(fp->regs[0]) * MII_REGS_NUM); + +- new_bus = kzalloc(sizeof(struct mii_bus), GFP_KERNEL); ++ fmb->irqs[phy_id] = irq; + +- if (new_bus == NULL) +- goto err_bus_alloc; +- +- fixed = kzalloc(sizeof(struct fixed_info), GFP_KERNEL); +- +- if (fixed == NULL) +- goto err_fixed_alloc; +- +- fixed->regs = kzalloc(MII_REGS_NUM * sizeof(int), GFP_KERNEL); +- if (NULL == fixed->regs) +- goto err_fixed_regs_alloc; +- +- fixed->regs_num = MII_REGS_NUM; +- fixed->phy_status.speed = speed; +- fixed->phy_status.duplex = duplex; +- fixed->phy_status.link = 1; +- +- new_bus->name = "Fixed MII Bus"; +- new_bus->read = &fixed_mii_read; +- new_bus->write = &fixed_mii_write; +- new_bus->reset = &fixed_mii_reset; +- /*set up workspace */ +- fixed_mdio_update_regs(fixed); +- new_bus->priv = fixed; +- +- new_bus->dev = dev; +- dev_set_drvdata(dev, new_bus); +- +- /* create phy_device and register it on the mdio bus */ +- phydev = phy_device_create(new_bus, 0, 0); +- if (phydev == NULL) +- goto err_phy_dev_create; +- +- /* +- * Put the phydev pointer into the fixed pack so that bus read/write +- * code could be able to access for instance attached netdev. Well it +- * doesn't have to do so, only in case of utilizing user-specified +- * link-update... +- */ +- +- fixed->phydev = phydev; +- phydev->speed = speed; +- phydev->duplex = duplex; +- +- phydev->irq = PHY_IGNORE_INTERRUPT; +- phydev->dev.bus = &mdio_bus_type; +- +- snprintf(phydev->dev.bus_id, BUS_ID_SIZE, +- PHY_ID_FMT, bus_id, phy_id); +- +- phydev->bus = new_bus; +- +- phydev->dev.driver = &fixed_mdio_driver.driver; +- phydev->dev.release = fixed_mdio_release; +- err = phydev->dev.driver->probe(&phydev->dev); +- if (err < 0) { +- printk(KERN_ERR "Phy %s: problems with fixed driver\n", +- phydev->dev.bus_id); +- goto err_out; +- } +- err = device_register(&phydev->dev); +- if (err) { +- printk(KERN_ERR "Phy %s failed to register\n", +- phydev->dev.bus_id); +- goto err_out; +- } +- //phydev->state = PHY_RUNNING; /* make phy go up quick, but in 10Mbit/HDX +- return fixed; ++ fp->id = phy_id; ++ fp->status = *status; + +-err_out: +- kfree(phydev); +-err_phy_dev_create: +- kfree(fixed->regs); +-err_fixed_regs_alloc: +- kfree(fixed); +-err_fixed_alloc: +- kfree(new_bus); +-err_bus_alloc: +- kfree(dev); +-err_dev_alloc: ++ ret = fixed_phy_update_regs(fp); ++ if (ret) ++ goto err_regs; + +- return NULL; ++ list_add_tail(&fp->node, &fmb->phys); + +-} +-#endif ++ return 0; + +-MODULE_DESCRIPTION("Fixed PHY device & driver for PAL"); +-MODULE_AUTHOR("Vitaly Bordug"); +-MODULE_LICENSE("GPL"); ++err_regs: ++ kfree(fp); ++ return ret; ++} ++EXPORT_SYMBOL_GPL(fixed_phy_add); + +-static int __init fixed_init(void) ++static int __init fixed_mdio_bus_init(void) + { +- int cnt = 0; +- int i; +-/* register on the bus... Not expected to be matched +- * with anything there... +- * +- */ +- phy_driver_register(&fixed_mdio_driver); ++ struct fixed_mdio_bus *fmb = &platform_fmb; ++ int ret; + +-/* We will create several mdio devices here, and will bound the upper +- * driver to them. +- * +- * Then the external software can lookup the phy bus by searching +- * for 0:101, to be connected to the virtual 100M Fdx phy. +- * +- * In case several virtual PHYs required, the bus_id will be in form +- * [num]:[duplex]+[speed], which make it able even to define +- * driver-specific link control callback, if for instance PHY is +- * completely SW-driven. +- */ +- for (i=1; i <= CONFIG_FIXED_MII_AMNT; i++) { +-#ifdef CONFIG_FIXED_MII_1000_FDX +- fixed_phy_ptrs[cnt++] = fixed_mdio_register_device(0, 1000, 1, i); +-#endif +-#ifdef CONFIG_FIXED_MII_100_FDX +- fixed_phy_ptrs[cnt++] = fixed_mdio_register_device(1, 100, 1, i); +-#endif +-#ifdef CONFIG_FIXED_MII_10_FDX +- fixed_phy_ptrs[cnt++] = fixed_mdio_register_device(2, 10, 1, i); +-#endif ++ pdev = platform_device_register_simple("Fixed MDIO bus", 0, NULL, 0); ++ if (!pdev) { ++ ret = -ENOMEM; ++ goto err_pdev; + } + ++ fmb->mii_bus.id = 0; ++ fmb->mii_bus.name = "Fixed MDIO Bus"; ++ fmb->mii_bus.dev = &pdev->dev; ++ fmb->mii_bus.read = &fixed_mdio_read; ++ fmb->mii_bus.write = &fixed_mdio_write; ++ fmb->mii_bus.irq = fmb->irqs; ++ ++ ret = mdiobus_register(&fmb->mii_bus); ++ if (ret) ++ goto err_mdiobus_reg; ++ + return 0; ++ ++err_mdiobus_reg: ++ platform_device_unregister(pdev); ++err_pdev: ++ return ret; + } ++module_init(fixed_mdio_bus_init); + +-static void __exit fixed_exit(void) ++static void __exit fixed_mdio_bus_exit(void) + { +- int i; ++ struct fixed_mdio_bus *fmb = &platform_fmb; ++ struct fixed_phy *fp; + +- phy_driver_unregister(&fixed_mdio_driver); +- for (i=0; i < MAX_PHY_AMNT; i++) +- if ( fixed_phy_ptrs[i] ) +- device_unregister(&fixed_phy_ptrs[i]->phydev->dev); ++ mdiobus_unregister(&fmb->mii_bus); ++ platform_device_unregister(pdev); ++ ++ list_for_each_entry(fp, &fmb->phys, node) { ++ list_del(&fp->node); ++ kfree(fp); ++ } + } ++module_exit(fixed_mdio_bus_exit); + +-module_init(fixed_init); +-module_exit(fixed_exit); ++MODULE_DESCRIPTION("Fixed MDIO bus (MDIO bus emulation with fixed PHYs)"); ++MODULE_AUTHOR("Vitaly Bordug"); ++MODULE_LICENSE("GPL"); +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/net/ps3_gelic_net.c powerpc.git/drivers/net/ps3_gelic_net.c +--- linux-2.6.24/drivers/net/ps3_gelic_net.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/net/ps3_gelic_net.c 2008-01-28 20:26:14.000000000 +0100 +@@ -58,11 +58,11 @@ + { + return &card->dev->core; + } +-static inline unsigned int bus_id(struct gelic_net_card *card) ++static inline u64 bus_id(struct gelic_net_card *card) + { + return card->dev->bus_id; + } +-static inline unsigned int dev_id(struct gelic_net_card *card) ++static inline u64 dev_id(struct gelic_net_card *card) + { + return card->dev->dev_id; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/net/ucc_geth.c powerpc.git/drivers/net/ucc_geth.c +--- linux-2.6.24/drivers/net/ucc_geth.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/net/ucc_geth.c 2008-01-28 20:26:14.000000000 +0100 +@@ -3822,6 +3822,7 @@ + int err, ucc_num, max_speed = 0; + const phandle *ph; + const unsigned int *prop; ++ const char *sprop; + const void *mac_addr; + phy_interface_t phy_interface; + static const int enet_to_speed[] = { +@@ -3854,10 +3855,56 @@ + + ug_info->uf_info.ucc_num = ucc_num; + +- prop = of_get_property(np, "rx-clock", NULL); +- ug_info->uf_info.rx_clock = *prop; +- prop = of_get_property(np, "tx-clock", NULL); +- ug_info->uf_info.tx_clock = *prop; ++ sprop = of_get_property(np, "rx-clock-name", NULL); ++ if (sprop) { ++ ug_info->uf_info.rx_clock = qe_clock_source(sprop); ++ if ((ug_info->uf_info.rx_clock < QE_CLK_NONE) || ++ (ug_info->uf_info.rx_clock > QE_CLK24)) { ++ printk(KERN_ERR ++ "ucc_geth: invalid rx-clock-name property\n"); ++ return -EINVAL; ++ } ++ } else { ++ prop = of_get_property(np, "rx-clock", NULL); ++ if (!prop) { ++ /* If both rx-clock-name and rx-clock are missing, ++ we want to tell people to use rx-clock-name. */ ++ printk(KERN_ERR ++ "ucc_geth: missing rx-clock-name property\n"); ++ return -EINVAL; ++ } ++ if ((*prop < QE_CLK_NONE) || (*prop > QE_CLK24)) { ++ printk(KERN_ERR ++ "ucc_geth: invalid rx-clock propperty\n"); ++ return -EINVAL; ++ } ++ ug_info->uf_info.rx_clock = *prop; ++ } ++ ++ sprop = of_get_property(np, "tx-clock-name", NULL); ++ if (sprop) { ++ ug_info->uf_info.tx_clock = qe_clock_source(sprop); ++ if ((ug_info->uf_info.tx_clock < QE_CLK_NONE) || ++ (ug_info->uf_info.tx_clock > QE_CLK24)) { ++ printk(KERN_ERR ++ "ucc_geth: invalid tx-clock-name property\n"); ++ return -EINVAL; ++ } ++ } else { ++ prop = of_get_property(np, "rx-clock", NULL); ++ if (!prop) { ++ printk(KERN_ERR ++ "ucc_geth: mising tx-clock-name property\n"); ++ return -EINVAL; ++ } ++ if ((*prop < QE_CLK_NONE) || (*prop > QE_CLK24)) { ++ printk(KERN_ERR ++ "ucc_geth: invalid tx-clock property\n"); ++ return -EINVAL; ++ } ++ ug_info->uf_info.tx_clock = *prop; ++ } ++ + err = of_address_to_resource(np, 0, &res); + if (err) + return -EINVAL; +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/of/base.c powerpc.git/drivers/of/base.c +--- linux-2.6.24/drivers/of/base.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/of/base.c 2008-01-28 20:26:17.000000000 +0100 +@@ -273,3 +273,61 @@ + return np; + } + EXPORT_SYMBOL(of_find_compatible_node); ++ ++/** ++ * of_match_node - Tell if an device_node has a matching of_match structure ++ * @matches: array of of device match structures to search in ++ * @node: the of device structure to match against ++ * ++ * Low level utility function used by device matching. ++ */ ++const struct of_device_id *of_match_node(const struct of_device_id *matches, ++ const struct device_node *node) ++{ ++ while (matches->name[0] || matches->type[0] || matches->compatible[0]) { ++ int match = 1; ++ if (matches->name[0]) ++ match &= node->name ++ && !strcmp(matches->name, node->name); ++ if (matches->type[0]) ++ match &= node->type ++ && !strcmp(matches->type, node->type); ++ if (matches->compatible[0]) ++ match &= of_device_is_compatible(node, ++ matches->compatible); ++ if (match) ++ return matches; ++ matches++; ++ } ++ return NULL; ++} ++EXPORT_SYMBOL(of_match_node); ++ ++/** ++ * of_find_matching_node - Find a node based on an of_device_id match ++ * table. ++ * @from: The node to start searching from or NULL, the node ++ * you pass will not be searched, only the next one ++ * will; typically, you pass what the previous call ++ * returned. of_node_put() will be called on it ++ * @matches: array of of device match structures to search in ++ * ++ * Returns a node pointer with refcount incremented, use ++ * of_node_put() on it when done. ++ */ ++struct device_node *of_find_matching_node(struct device_node *from, ++ const struct of_device_id *matches) ++{ ++ struct device_node *np; ++ ++ read_lock(&devtree_lock); ++ np = from ? from->allnext : allnodes; ++ for (; np; np = np->allnext) { ++ if (of_match_node(matches, np) && of_node_get(np)) ++ break; ++ } ++ of_node_put(from); ++ read_unlock(&devtree_lock); ++ return np; ++} ++EXPORT_SYMBOL(of_find_matching_node); +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/of/device.c powerpc.git/drivers/of/device.c +--- linux-2.6.24/drivers/of/device.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/of/device.c 2008-01-28 20:26:17.000000000 +0100 +@@ -10,35 +10,6 @@ + #include <asm/errno.h> + + /** +- * of_match_node - Tell if an device_node has a matching of_match structure +- * @ids: array of of device match structures to search in +- * @node: the of device structure to match against +- * +- * Low level utility function used by device matching. +- */ +-const struct of_device_id *of_match_node(const struct of_device_id *matches, +- const struct device_node *node) +-{ +- while (matches->name[0] || matches->type[0] || matches->compatible[0]) { +- int match = 1; +- if (matches->name[0]) +- match &= node->name +- && !strcmp(matches->name, node->name); +- if (matches->type[0]) +- match &= node->type +- && !strcmp(matches->type, node->type); +- if (matches->compatible[0]) +- match &= of_device_is_compatible(node, +- matches->compatible); +- if (match) +- return matches; +- matches++; +- } +- return NULL; +-} +-EXPORT_SYMBOL(of_match_node); +- +-/** + * of_match_device - Tell if an of_device structure has a matching + * of_match structure + * @ids: array of of device match structures to search in +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/ps3/Makefile powerpc.git/drivers/ps3/Makefile +--- linux-2.6.24/drivers/ps3/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/ps3/Makefile 2008-01-28 20:26:18.000000000 +0100 +@@ -4,3 +4,4 @@ + obj-$(CONFIG_PPC_PS3) += sys-manager-core.o + obj-$(CONFIG_PS3_SYS_MANAGER) += ps3-sys-manager.o + obj-$(CONFIG_PS3_STORAGE) += ps3stor_lib.o ++obj-$(CONFIG_PS3_LPM) += ps3-lpm.o +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/ps3/ps3-lpm.c powerpc.git/drivers/ps3/ps3-lpm.c +--- linux-2.6.24/drivers/ps3/ps3-lpm.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/drivers/ps3/ps3-lpm.c 2008-01-28 20:26:18.000000000 +0100 +@@ -0,0 +1,1248 @@ ++/* ++ * PS3 Logical Performance Monitor. ++ * ++ * Copyright (C) 2007 Sony Computer Entertainment Inc. ++ * Copyright 2007 Sony Corp. ++ * ++ * This program is free software; you can redistribute it and/or modify ++ * it under the terms of the GNU General Public License as published by ++ * the Free Software Foundation; version 2 of the License. ++ * ++ * This program is distributed in the hope that it will be useful, ++ * but WITHOUT ANY WARRANTY; without even the implied warranty of ++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ++ * GNU General Public License for more details. ++ * ++ * You should have received a copy of the GNU General Public License ++ * along with this program; if not, write to the Free Software ++ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ++ */ ++ ++#include <linux/kernel.h> ++#include <linux/module.h> ++#include <linux/interrupt.h> ++#include <linux/uaccess.h> ++#include <asm/ps3.h> ++#include <asm/lv1call.h> ++#include <asm/cell-pmu.h> ++ ++ ++/* BOOKMARK tag macros */ ++#define PS3_PM_BOOKMARK_START 0x8000000000000000ULL ++#define PS3_PM_BOOKMARK_STOP 0x4000000000000000ULL ++#define PS3_PM_BOOKMARK_TAG_KERNEL 0x1000000000000000ULL ++#define PS3_PM_BOOKMARK_TAG_USER 0x3000000000000000ULL ++#define PS3_PM_BOOKMARK_TAG_MASK_HI 0xF000000000000000ULL ++#define PS3_PM_BOOKMARK_TAG_MASK_LO 0x0F00000000000000ULL ++ ++/* CBE PM CONTROL register macros */ ++#define PS3_PM_CONTROL_PPU_TH0_BOOKMARK 0x00001000 ++#define PS3_PM_CONTROL_PPU_TH1_BOOKMARK 0x00000800 ++#define PS3_PM_CONTROL_PPU_COUNT_MODE_MASK 0x000C0000 ++#define PS3_PM_CONTROL_PPU_COUNT_MODE_PROBLEM 0x00080000 ++#define PS3_WRITE_PM_MASK 0xFFFFFFFFFFFFFFFFULL ++ ++/* CBE PM START STOP register macros */ ++#define PS3_PM_START_STOP_PPU_TH0_BOOKMARK_START 0x02000000 ++#define PS3_PM_START_STOP_PPU_TH1_BOOKMARK_START 0x01000000 ++#define PS3_PM_START_STOP_PPU_TH0_BOOKMARK_STOP 0x00020000 ++#define PS3_PM_START_STOP_PPU_TH1_BOOKMARK_STOP 0x00010000 ++#define PS3_PM_START_STOP_START_MASK 0xFF000000 ++#define PS3_PM_START_STOP_STOP_MASK 0x00FF0000 ++ ++/* CBE PM COUNTER register macres */ ++#define PS3_PM_COUNTER_MASK_HI 0xFFFFFFFF00000000ULL ++#define PS3_PM_COUNTER_MASK_LO 0x00000000FFFFFFFFULL ++ ++/* BASE SIGNAL GROUP NUMBER macros */ ++#define PM_ISLAND2_BASE_SIGNAL_GROUP_NUMBER 0 ++#define PM_ISLAND2_SIGNAL_GROUP_NUMBER1 6 ++#define PM_ISLAND2_SIGNAL_GROUP_NUMBER2 7 ++#define PM_ISLAND3_BASE_SIGNAL_GROUP_NUMBER 7 ++#define PM_ISLAND4_BASE_SIGNAL_GROUP_NUMBER 15 ++#define PM_SPU_TRIGGER_SIGNAL_GROUP_NUMBER 17 ++#define PM_SPU_EVENT_SIGNAL_GROUP_NUMBER 18 ++#define PM_ISLAND5_BASE_SIGNAL_GROUP_NUMBER 18 ++#define PM_ISLAND6_BASE_SIGNAL_GROUP_NUMBER 24 ++#define PM_ISLAND7_BASE_SIGNAL_GROUP_NUMBER 49 ++#define PM_ISLAND8_BASE_SIGNAL_GROUP_NUMBER 52 ++#define PM_SIG_GROUP_SPU 41 ++#define PM_SIG_GROUP_SPU_TRIGGER 42 ++#define PM_SIG_GROUP_SPU_EVENT 43 ++#define PM_SIG_GROUP_MFC_MAX 60 ++ ++/** ++ * struct ps3_lpm_shadow_regs - Performance monitor shadow registers. ++ * ++ * @pm_control: Shadow of the processor's pm_control register. ++ * @pm_start_stop: Shadow of the processor's pm_start_stop register. ++ * @pm_interval: Shadow of the processor's pm_interval register. ++ * @group_control: Shadow of the processor's group_control register. ++ * @debug_bus_control: Shadow of the processor's debug_bus_control register. ++ * ++ * The logical performance monitor provides a write-only interface to ++ * these processor registers. These shadow variables cache the processor ++ * register values for reading. ++ * ++ * The initial value of the shadow registers at lpm creation is ++ * PS3_LPM_SHADOW_REG_INIT. ++ */ ++ ++struct ps3_lpm_shadow_regs { ++ u64 pm_control; ++ u64 pm_start_stop; ++ u64 pm_interval; ++ u64 group_control; ++ u64 debug_bus_control; ++}; ++ ++#define PS3_LPM_SHADOW_REG_INIT 0xFFFFFFFF00000000ULL ++ ++/** ++ * struct ps3_lpm_priv - Private lpm device data. ++ * ++ * @open: An atomic variable indicating the lpm driver has been opened. ++ * @rights: The lpm rigths granted by the system policy module. A logical ++ * OR of enum ps3_lpm_rights. ++ * @node_id: The node id of a BE prosessor whose performance monitor this ++ * lpar has the right to use. ++ * @pu_id: The lv1 id of the logical PU. ++ * @lpm_id: The lv1 id of this lpm instance. ++ * @outlet_id: The outlet created by lv1 for this lpm instance. ++ * @tb_count: The number of bytes of data held in the lv1 trace buffer. ++ * @tb_cache: Kernel buffer to receive the data from the lv1 trace buffer. ++ * Must be 128 byte aligned. ++ * @tb_cache_size: Size of the kernel @tb_cache buffer. Must be 128 byte ++ * aligned. ++ * @tb_cache_internal: An unaligned buffer allocated by this driver to be ++ * used for the trace buffer cache when ps3_lpm_open() is called with a ++ * NULL tb_cache argument. Otherwise unused. ++ * @shadow: Processor register shadow of type struct ps3_lpm_shadow_regs. ++ * @sbd: The struct ps3_system_bus_device attached to this driver. ++ * ++ * The trace buffer is a buffer allocated and used internally to the lv1 ++ * hypervisor to collect trace data. The trace buffer cache is a guest ++ * buffer that accepts the trace data from the trace buffer. ++ */ ++ ++struct ps3_lpm_priv { ++ atomic_t open; ++ u64 rights; ++ u64 node_id; ++ u64 pu_id; ++ u64 lpm_id; ++ u64 outlet_id; ++ u64 tb_count; ++ void *tb_cache; ++ u64 tb_cache_size; ++ void *tb_cache_internal; ++ struct ps3_lpm_shadow_regs shadow; ++ struct ps3_system_bus_device *sbd; ++}; ++ ++enum { ++ PS3_LPM_DEFAULT_TB_CACHE_SIZE = 0x4000, ++}; ++ ++/** ++ * lpm_priv - Static instance of the lpm data. ++ * ++ * Since the exported routines don't support the notion of a device ++ * instance we need to hold the instance in this static variable ++ * and then only allow at most one instance at a time to be created. ++ */ ++ ++static struct ps3_lpm_priv *lpm_priv; ++ ++static struct device *sbd_core(void) ++{ ++ BUG_ON(!lpm_priv || !lpm_priv->sbd); ++ return &lpm_priv->sbd->core; ++} ++ ++/** ++ * use_start_stop_bookmark - Enable the PPU bookmark trace. ++ * ++ * And it enables PPU bookmark triggers ONLY if the other triggers are not set. ++ * The start/stop bookmarks are inserted at ps3_enable_pm() and ps3_disable_pm() ++ * to start/stop LPM. ++ * ++ * Used to get good quality of the performance counter. ++ */ ++ ++enum {use_start_stop_bookmark = 1,}; ++ ++void ps3_set_bookmark(u64 bookmark) ++{ ++ /* ++ * As per the PPE book IV, to avoid bookmark loss there must ++ * not be a traced branch within 10 cycles of setting the ++ * SPRN_BKMK register. The actual text is unclear if 'within' ++ * includes cycles before the call. ++ */ ++ ++ asm volatile("or 29, 29, 29;"); /* db10cyc */ ++ mtspr(SPRN_BKMK, bookmark); ++ asm volatile("or 29, 29, 29;"); /* db10cyc */ ++} ++EXPORT_SYMBOL_GPL(ps3_set_bookmark); ++ ++void ps3_set_pm_bookmark(u64 tag, u64 incident, u64 th_id) ++{ ++ u64 bookmark; ++ ++ bookmark = (get_tb() & 0x00000000FFFFFFFFULL) | ++ PS3_PM_BOOKMARK_TAG_KERNEL; ++ bookmark = ((tag << 56) & PS3_PM_BOOKMARK_TAG_MASK_LO) | ++ (incident << 48) | (th_id << 32) | bookmark; ++ ps3_set_bookmark(bookmark); ++} ++EXPORT_SYMBOL_GPL(ps3_set_pm_bookmark); ++ ++/** ++ * ps3_read_phys_ctr - Read physical counter registers. ++ * ++ * Each physical counter can act as one 32 bit counter or as two 16 bit ++ * counters. ++ */ ++ ++u32 ps3_read_phys_ctr(u32 cpu, u32 phys_ctr) ++{ ++ int result; ++ u64 counter0415; ++ u64 counter2637; ++ ++ if (phys_ctr >= NR_PHYS_CTRS) { ++ dev_dbg(sbd_core(), "%s:%u: phys_ctr too big: %u\n", __func__, ++ __LINE__, phys_ctr); ++ return 0; ++ } ++ ++ result = lv1_set_lpm_counter(lpm_priv->lpm_id, 0, 0, 0, 0, &counter0415, ++ &counter2637); ++ if (result) { ++ dev_err(sbd_core(), "%s:%u: lv1_set_lpm_counter failed: " ++ "phys_ctr %u, %s\n", __func__, __LINE__, phys_ctr, ++ ps3_result(result)); ++ return 0; ++ } ++ ++ switch (phys_ctr) { ++ case 0: ++ return counter0415 >> 32; ++ case 1: ++ return counter0415 & PS3_PM_COUNTER_MASK_LO; ++ case 2: ++ return counter2637 >> 32; ++ case 3: ++ return counter2637 & PS3_PM_COUNTER_MASK_LO; ++ default: ++ BUG(); ++ } ++ return 0; ++} ++EXPORT_SYMBOL_GPL(ps3_read_phys_ctr); ++ ++/** ++ * ps3_write_phys_ctr - Write physical counter registers. ++ * ++ * Each physical counter can act as one 32 bit counter or as two 16 bit ++ * counters. ++ */ ++ ++void ps3_write_phys_ctr(u32 cpu, u32 phys_ctr, u32 val) ++{ ++ u64 counter0415; ++ u64 counter0415_mask; ++ u64 counter2637; ++ u64 counter2637_mask; ++ int result; ++ ++ if (phys_ctr >= NR_PHYS_CTRS) { ++ dev_dbg(sbd_core(), "%s:%u: phys_ctr too big: %u\n", __func__, ++ __LINE__, phys_ctr); ++ return; ++ } ++ ++ switch (phys_ctr) { ++ case 0: ++ counter0415 = (u64)val << 32; ++ counter0415_mask = PS3_PM_COUNTER_MASK_HI; ++ counter2637 = 0x0; ++ counter2637_mask = 0x0; ++ break; ++ case 1: ++ counter0415 = (u64)val; ++ counter0415_mask = PS3_PM_COUNTER_MASK_LO; ++ counter2637 = 0x0; ++ counter2637_mask = 0x0; ++ break; ++ case 2: ++ counter0415 = 0x0; ++ counter0415_mask = 0x0; ++ counter2637 = (u64)val << 32; ++ counter2637_mask = PS3_PM_COUNTER_MASK_HI; ++ break; ++ case 3: ++ counter0415 = 0x0; ++ counter0415_mask = 0x0; ++ counter2637 = (u64)val; ++ counter2637_mask = PS3_PM_COUNTER_MASK_LO; ++ break; ++ default: ++ BUG(); ++ } ++ ++ result = lv1_set_lpm_counter(lpm_priv->lpm_id, ++ counter0415, counter0415_mask, ++ counter2637, counter2637_mask, ++ &counter0415, &counter2637); ++ if (result) ++ dev_err(sbd_core(), "%s:%u: lv1_set_lpm_counter failed: " ++ "phys_ctr %u, val %u, %s\n", __func__, __LINE__, ++ phys_ctr, val, ps3_result(result)); ++} ++EXPORT_SYMBOL_GPL(ps3_write_phys_ctr); ++ ++/** ++ * ps3_read_ctr - Read counter. ++ * ++ * Read 16 or 32 bits depending on the current size of the counter. ++ * Counters 4, 5, 6 & 7 are always 16 bit. ++ */ ++ ++u32 ps3_read_ctr(u32 cpu, u32 ctr) ++{ ++ u32 val; ++ u32 phys_ctr = ctr & (NR_PHYS_CTRS - 1); ++ ++ val = ps3_read_phys_ctr(cpu, phys_ctr); ++ ++ if (ps3_get_ctr_size(cpu, phys_ctr) == 16) ++ val = (ctr < NR_PHYS_CTRS) ? (val >> 16) : (val & 0xffff); ++ ++ return val; ++} ++EXPORT_SYMBOL_GPL(ps3_read_ctr); ++ ++/** ++ * ps3_write_ctr - Write counter. ++ * ++ * Write 16 or 32 bits depending on the current size of the counter. ++ * Counters 4, 5, 6 & 7 are always 16 bit. ++ */ ++ ++void ps3_write_ctr(u32 cpu, u32 ctr, u32 val) ++{ ++ u32 phys_ctr; ++ u32 phys_val; ++ ++ phys_ctr = ctr & (NR_PHYS_CTRS - 1); ++ ++ if (ps3_get_ctr_size(cpu, phys_ctr) == 16) { ++ phys_val = ps3_read_phys_ctr(cpu, phys_ctr); ++ ++ if (ctr < NR_PHYS_CTRS) ++ val = (val << 16) | (phys_val & 0xffff); ++ else ++ val = (val & 0xffff) | (phys_val & 0xffff0000); ++ } ++ ++ ps3_write_phys_ctr(cpu, phys_ctr, val); ++} ++EXPORT_SYMBOL_GPL(ps3_write_ctr); ++ ++/** ++ * ps3_read_pm07_control - Read counter control registers. ++ * ++ * Each logical counter has a corresponding control register. ++ */ ++ ++u32 ps3_read_pm07_control(u32 cpu, u32 ctr) ++{ ++ return 0; ++} ++EXPORT_SYMBOL_GPL(ps3_read_pm07_control); ++ ++/** ++ * ps3_write_pm07_control - Write counter control registers. ++ * ++ * Each logical counter has a corresponding control register. ++ */ ++ ++void ps3_write_pm07_control(u32 cpu, u32 ctr, u32 val) ++{ ++ int result; ++ static const u64 mask = 0xFFFFFFFFFFFFFFFFULL; ++ u64 old_value; ++ ++ if (ctr >= NR_CTRS) { ++ dev_dbg(sbd_core(), "%s:%u: ctr too big: %u\n", __func__, ++ __LINE__, ctr); ++ return; ++ } ++ ++ result = lv1_set_lpm_counter_control(lpm_priv->lpm_id, ctr, val, mask, ++ &old_value); ++ if (result) ++ dev_err(sbd_core(), "%s:%u: lv1_set_lpm_counter_control " ++ "failed: ctr %u, %s\n", __func__, __LINE__, ctr, ++ ps3_result(result)); ++} ++EXPORT_SYMBOL_GPL(ps3_write_pm07_control); ++ ++/** ++ * ps3_read_pm - Read Other LPM control registers. ++ */ ++ ++u32 ps3_read_pm(u32 cpu, enum pm_reg_name reg) ++{ ++ int result = 0; ++ u64 val = 0; ++ ++ switch (reg) { ++ case pm_control: ++ return lpm_priv->shadow.pm_control; ++ case trace_address: ++ return CBE_PM_TRACE_BUF_EMPTY; ++ case pm_start_stop: ++ return lpm_priv->shadow.pm_start_stop; ++ case pm_interval: ++ return lpm_priv->shadow.pm_interval; ++ case group_control: ++ return lpm_priv->shadow.group_control; ++ case debug_bus_control: ++ return lpm_priv->shadow.debug_bus_control; ++ case pm_status: ++ result = lv1_get_lpm_interrupt_status(lpm_priv->lpm_id, ++ &val); ++ if (result) { ++ val = 0; ++ dev_dbg(sbd_core(), "%s:%u: lv1 get_lpm_status failed: " ++ "reg %u, %s\n", __func__, __LINE__, reg, ++ ps3_result(result)); ++ } ++ return (u32)val; ++ case ext_tr_timer: ++ return 0; ++ default: ++ dev_dbg(sbd_core(), "%s:%u: unknown reg: %d\n", __func__, ++ __LINE__, reg); ++ BUG(); ++ break; ++ } ++ ++ return 0; ++} ++EXPORT_SYMBOL_GPL(ps3_read_pm); ++ ++/** ++ * ps3_write_pm - Write Other LPM control registers. ++ */ ++ ++void ps3_write_pm(u32 cpu, enum pm_reg_name reg, u32 val) ++{ ++ int result = 0; ++ u64 dummy; ++ ++ switch (reg) { ++ case group_control: ++ if (val != lpm_priv->shadow.group_control) ++ result = lv1_set_lpm_group_control(lpm_priv->lpm_id, ++ val, ++ PS3_WRITE_PM_MASK, ++ &dummy); ++ lpm_priv->shadow.group_control = val; ++ break; ++ case debug_bus_control: ++ if (val != lpm_priv->shadow.debug_bus_control) ++ result = lv1_set_lpm_debug_bus_control(lpm_priv->lpm_id, ++ val, ++ PS3_WRITE_PM_MASK, ++ &dummy); ++ lpm_priv->shadow.debug_bus_control = val; ++ break; ++ case pm_control: ++ if (use_start_stop_bookmark) ++ val |= (PS3_PM_CONTROL_PPU_TH0_BOOKMARK | ++ PS3_PM_CONTROL_PPU_TH1_BOOKMARK); ++ if (val != lpm_priv->shadow.pm_control) ++ result = lv1_set_lpm_general_control(lpm_priv->lpm_id, ++ val, ++ PS3_WRITE_PM_MASK, ++ 0, 0, &dummy, ++ &dummy); ++ lpm_priv->shadow.pm_control = val; ++ break; ++ case pm_interval: ++ if (val != lpm_priv->shadow.pm_interval) ++ result = lv1_set_lpm_interval(lpm_priv->lpm_id, val, ++ PS3_WRITE_PM_MASK, &dummy); ++ lpm_priv->shadow.pm_interval = val; ++ break; ++ case pm_start_stop: ++ if (val != lpm_priv->shadow.pm_start_stop) ++ result = lv1_set_lpm_trigger_control(lpm_priv->lpm_id, ++ val, ++ PS3_WRITE_PM_MASK, ++ &dummy); ++ lpm_priv->shadow.pm_start_stop = val; ++ break; ++ case trace_address: ++ case ext_tr_timer: ++ case pm_status: ++ break; ++ default: ++ dev_dbg(sbd_core(), "%s:%u: unknown reg: %d\n", __func__, ++ __LINE__, reg); ++ BUG(); ++ break; ++ } ++ ++ if (result) ++ dev_err(sbd_core(), "%s:%u: lv1 set_control failed: " ++ "reg %u, %s\n", __func__, __LINE__, reg, ++ ps3_result(result)); ++} ++EXPORT_SYMBOL_GPL(ps3_write_pm); ++ ++/** ++ * ps3_get_ctr_size - Get the size of a physical counter. ++ * ++ * Returns either 16 or 32. ++ */ ++ ++u32 ps3_get_ctr_size(u32 cpu, u32 phys_ctr) ++{ ++ u32 pm_ctrl; ++ ++ if (phys_ctr >= NR_PHYS_CTRS) { ++ dev_dbg(sbd_core(), "%s:%u: phys_ctr too big: %u\n", __func__, ++ __LINE__, phys_ctr); ++ return 0; ++ } ++ ++ pm_ctrl = ps3_read_pm(cpu, pm_control); ++ return (pm_ctrl & CBE_PM_16BIT_CTR(phys_ctr)) ? 16 : 32; ++} ++EXPORT_SYMBOL_GPL(ps3_get_ctr_size); ++ ++/** ++ * ps3_set_ctr_size - Set the size of a physical counter to 16 or 32 bits. ++ */ ++ ++void ps3_set_ctr_size(u32 cpu, u32 phys_ctr, u32 ctr_size) ++{ ++ u32 pm_ctrl; ++ ++ if (phys_ctr >= NR_PHYS_CTRS) { ++ dev_dbg(sbd_core(), "%s:%u: phys_ctr too big: %u\n", __func__, ++ __LINE__, phys_ctr); ++ return; ++ } ++ ++ pm_ctrl = ps3_read_pm(cpu, pm_control); ++ ++ switch (ctr_size) { ++ case 16: ++ pm_ctrl |= CBE_PM_16BIT_CTR(phys_ctr); ++ ps3_write_pm(cpu, pm_control, pm_ctrl); ++ break; ++ ++ case 32: ++ pm_ctrl &= ~CBE_PM_16BIT_CTR(phys_ctr); ++ ps3_write_pm(cpu, pm_control, pm_ctrl); ++ break; ++ default: ++ BUG(); ++ } ++} ++EXPORT_SYMBOL_GPL(ps3_set_ctr_size); ++ ++static u64 pm_translate_signal_group_number_on_island2(u64 subgroup) ++{ ++ ++ if (subgroup == 2) ++ subgroup = 3; ++ ++ if (subgroup <= 6) ++ return PM_ISLAND2_BASE_SIGNAL_GROUP_NUMBER + subgroup; ++ else if (subgroup == 7) ++ return PM_ISLAND2_SIGNAL_GROUP_NUMBER1; ++ else ++ return PM_ISLAND2_SIGNAL_GROUP_NUMBER2; ++} ++ ++static u64 pm_translate_signal_group_number_on_island3(u64 subgroup) ++{ ++ ++ switch (subgroup) { ++ case 2: ++ case 3: ++ case 4: ++ subgroup += 2; ++ break; ++ case 5: ++ subgroup = 8; ++ break; ++ default: ++ break; ++ } ++ return PM_ISLAND3_BASE_SIGNAL_GROUP_NUMBER + subgroup; ++} ++ ++static u64 pm_translate_signal_group_number_on_island4(u64 subgroup) ++{ ++ return PM_ISLAND4_BASE_SIGNAL_GROUP_NUMBER + subgroup; ++} ++ ++static u64 pm_translate_signal_group_number_on_island5(u64 subgroup) ++{ ++ ++ switch (subgroup) { ++ case 3: ++ subgroup = 4; ++ break; ++ case 4: ++ subgroup = 6; ++ break; ++ default: ++ break; ++ } ++ return PM_ISLAND5_BASE_SIGNAL_GROUP_NUMBER + subgroup; ++} ++ ++static u64 pm_translate_signal_group_number_on_island6(u64 subgroup, ++ u64 subsubgroup) ++{ ++ switch (subgroup) { ++ case 3: ++ case 4: ++ case 5: ++ subgroup += 1; ++ break; ++ default: ++ break; ++ } ++ ++ switch (subsubgroup) { ++ case 4: ++ case 5: ++ case 6: ++ subsubgroup += 2; ++ break; ++ case 7: ++ case 8: ++ case 9: ++ case 10: ++ subsubgroup += 4; ++ break; ++ case 11: ++ case 12: ++ case 13: ++ subsubgroup += 5; ++ break; ++ default: ++ break; ++ } ++ ++ if (subgroup <= 5) ++ return (PM_ISLAND6_BASE_SIGNAL_GROUP_NUMBER + subgroup); ++ else ++ return (PM_ISLAND6_BASE_SIGNAL_GROUP_NUMBER + subgroup ++ + subsubgroup - 1); ++} ++ ++static u64 pm_translate_signal_group_number_on_island7(u64 subgroup) ++{ ++ return PM_ISLAND7_BASE_SIGNAL_GROUP_NUMBER + subgroup; ++} ++ ++static u64 pm_translate_signal_group_number_on_island8(u64 subgroup) ++{ ++ return PM_ISLAND8_BASE_SIGNAL_GROUP_NUMBER + subgroup; ++} ++ ++static u64 pm_signal_group_to_ps3_lv1_signal_group(u64 group) ++{ ++ u64 island; ++ u64 subgroup; ++ u64 subsubgroup; ++ ++ subgroup = 0; ++ subsubgroup = 0; ++ island = 0; ++ if (group < 1000) { ++ if (group < 100) { ++ if (20 <= group && group < 30) { ++ island = 2; ++ subgroup = group - 20; ++ } else if (30 <= group && group < 40) { ++ island = 3; ++ subgroup = group - 30; ++ } else if (40 <= group && group < 50) { ++ island = 4; ++ subgroup = group - 40; ++ } else if (50 <= group && group < 60) { ++ island = 5; ++ subgroup = group - 50; ++ } else if (60 <= group && group < 70) { ++ island = 6; ++ subgroup = group - 60; ++ } else if (70 <= group && group < 80) { ++ island = 7; ++ subgroup = group - 70; ++ } else if (80 <= group && group < 90) { ++ island = 8; ++ subgroup = group - 80; ++ } ++ } else if (200 <= group && group < 300) { ++ island = 2; ++ subgroup = group - 200; ++ } else if (600 <= group && group < 700) { ++ island = 6; ++ subgroup = 5; ++ subsubgroup = group - 650; ++ } ++ } else if (6000 <= group && group < 7000) { ++ island = 6; ++ subgroup = 5; ++ subsubgroup = group - 6500; ++ } ++ ++ switch (island) { ++ case 2: ++ return pm_translate_signal_group_number_on_island2(subgroup); ++ case 3: ++ return pm_translate_signal_group_number_on_island3(subgroup); ++ case 4: ++ return pm_translate_signal_group_number_on_island4(subgroup); ++ case 5: ++ return pm_translate_signal_group_number_on_island5(subgroup); ++ case 6: ++ return pm_translate_signal_group_number_on_island6(subgroup, ++ subsubgroup); ++ case 7: ++ return pm_translate_signal_group_number_on_island7(subgroup); ++ case 8: ++ return pm_translate_signal_group_number_on_island8(subgroup); ++ default: ++ dev_dbg(sbd_core(), "%s:%u: island not found: %lu\n", __func__, ++ __LINE__, group); ++ BUG(); ++ break; ++ } ++ return 0; ++} ++ ++static u64 pm_bus_word_to_ps3_lv1_bus_word(u8 word) ++{ ++ ++ switch (word) { ++ case 1: ++ return 0xF000; ++ case 2: ++ return 0x0F00; ++ case 4: ++ return 0x00F0; ++ case 8: ++ default: ++ return 0x000F; ++ } ++} ++ ++static int __ps3_set_signal(u64 lv1_signal_group, u64 bus_select, ++ u64 signal_select, u64 attr1, u64 attr2, u64 attr3) ++{ ++ int ret; ++ ++ ret = lv1_set_lpm_signal(lpm_priv->lpm_id, lv1_signal_group, bus_select, ++ signal_select, attr1, attr2, attr3); ++ if (ret) ++ dev_err(sbd_core(), ++ "%s:%u: error:%d 0x%lx 0x%lx 0x%lx 0x%lx 0x%lx 0x%lx\n", ++ __func__, __LINE__, ret, lv1_signal_group, bus_select, ++ signal_select, attr1, attr2, attr3); ++ ++ return ret; ++} ++ ++int ps3_set_signal(u64 signal_group, u8 signal_bit, u16 sub_unit, ++ u8 bus_word) ++{ ++ int ret; ++ u64 lv1_signal_group; ++ u64 bus_select; ++ u64 signal_select; ++ u64 attr1, attr2, attr3; ++ ++ if (signal_group == 0) ++ return __ps3_set_signal(0, 0, 0, 0, 0, 0); ++ ++ lv1_signal_group = ++ pm_signal_group_to_ps3_lv1_signal_group(signal_group); ++ bus_select = pm_bus_word_to_ps3_lv1_bus_word(bus_word); ++ ++ switch (signal_group) { ++ case PM_SIG_GROUP_SPU_TRIGGER: ++ signal_select = 1; ++ signal_select = signal_select << (63 - signal_bit); ++ break; ++ case PM_SIG_GROUP_SPU_EVENT: ++ signal_select = 1; ++ signal_select = (signal_select << (63 - signal_bit)) | 0x3; ++ break; ++ default: ++ signal_select = 0; ++ break; ++ } ++ ++ /* ++ * 0: physical object. ++ * 1: logical object. ++ * This parameter is only used for the PPE and SPE signals. ++ */ ++ attr1 = 1; ++ ++ /* ++ * This parameter is used to specify the target physical/logical ++ * PPE/SPE object. ++ */ ++ if (PM_SIG_GROUP_SPU <= signal_group && ++ signal_group < PM_SIG_GROUP_MFC_MAX) ++ attr2 = sub_unit; ++ else ++ attr2 = lpm_priv->pu_id; ++ ++ /* ++ * This parameter is only used for setting the SPE signal. ++ */ ++ attr3 = 0; ++ ++ ret = __ps3_set_signal(lv1_signal_group, bus_select, signal_select, ++ attr1, attr2, attr3); ++ if (ret) ++ dev_err(sbd_core(), "%s:%u: __ps3_set_signal failed: %d\n", ++ __func__, __LINE__, ret); ++ ++ return ret; ++} ++EXPORT_SYMBOL_GPL(ps3_set_signal); ++ ++u32 ps3_get_hw_thread_id(int cpu) ++{ ++ return get_hard_smp_processor_id(cpu); ++} ++EXPORT_SYMBOL_GPL(ps3_get_hw_thread_id); ++ ++/** ++ * ps3_enable_pm - Enable the entire performance monitoring unit. ++ * ++ * When we enable the LPM, all pending writes to counters get committed. ++ */ ++ ++void ps3_enable_pm(u32 cpu) ++{ ++ int result; ++ u64 tmp; ++ int insert_bookmark = 0; ++ ++ lpm_priv->tb_count = 0; ++ ++ if (use_start_stop_bookmark) { ++ if (!(lpm_priv->shadow.pm_start_stop & ++ (PS3_PM_START_STOP_START_MASK ++ | PS3_PM_START_STOP_STOP_MASK))) { ++ result = lv1_set_lpm_trigger_control(lpm_priv->lpm_id, ++ (PS3_PM_START_STOP_PPU_TH0_BOOKMARK_START | ++ PS3_PM_START_STOP_PPU_TH1_BOOKMARK_START | ++ PS3_PM_START_STOP_PPU_TH0_BOOKMARK_STOP | ++ PS3_PM_START_STOP_PPU_TH1_BOOKMARK_STOP), ++ 0xFFFFFFFFFFFFFFFFULL, &tmp); ++ ++ if (result) ++ dev_err(sbd_core(), "%s:%u: " ++ "lv1_set_lpm_trigger_control failed: " ++ "%s\n", __func__, __LINE__, ++ ps3_result(result)); ++ ++ insert_bookmark = !result; ++ } ++ } ++ ++ result = lv1_start_lpm(lpm_priv->lpm_id); ++ ++ if (result) ++ dev_err(sbd_core(), "%s:%u: lv1_start_lpm failed: %s\n", ++ __func__, __LINE__, ps3_result(result)); ++ ++ if (use_start_stop_bookmark && !result && insert_bookmark) ++ ps3_set_bookmark(get_tb() | PS3_PM_BOOKMARK_START); ++} ++EXPORT_SYMBOL_GPL(ps3_enable_pm); ++ ++/** ++ * ps3_disable_pm - Disable the entire performance monitoring unit. ++ */ ++ ++void ps3_disable_pm(u32 cpu) ++{ ++ int result; ++ u64 tmp; ++ ++ ps3_set_bookmark(get_tb() | PS3_PM_BOOKMARK_STOP); ++ ++ result = lv1_stop_lpm(lpm_priv->lpm_id, &tmp); ++ ++ if (result) { ++ if(result != LV1_WRONG_STATE) ++ dev_err(sbd_core(), "%s:%u: lv1_stop_lpm failed: %s\n", ++ __func__, __LINE__, ps3_result(result)); ++ return; ++ } ++ ++ lpm_priv->tb_count = tmp; ++ ++ dev_dbg(sbd_core(), "%s:%u: tb_count %lu (%lxh)\n", __func__, __LINE__, ++ lpm_priv->tb_count, lpm_priv->tb_count); ++} ++EXPORT_SYMBOL_GPL(ps3_disable_pm); ++ ++/** ++ * ps3_lpm_copy_tb - Copy data from the trace buffer to a kernel buffer. ++ * @offset: Offset in bytes from the start of the trace buffer. ++ * @buf: Copy destination. ++ * @count: Maximum count of bytes to copy. ++ * @bytes_copied: Pointer to a variable that will recieve the number of ++ * bytes copied to @buf. ++ * ++ * On error @buf will contain any successfully copied trace buffer data ++ * and bytes_copied will be set to the number of bytes successfully copied. ++ */ ++ ++int ps3_lpm_copy_tb(unsigned long offset, void *buf, unsigned long count, ++ unsigned long *bytes_copied) ++{ ++ int result; ++ ++ *bytes_copied = 0; ++ ++ if (!lpm_priv->tb_cache) ++ return -EPERM; ++ ++ if (offset >= lpm_priv->tb_count) ++ return 0; ++ ++ count = min(count, lpm_priv->tb_count - offset); ++ ++ while (*bytes_copied < count) { ++ const unsigned long request = count - *bytes_copied; ++ u64 tmp; ++ ++ result = lv1_copy_lpm_trace_buffer(lpm_priv->lpm_id, offset, ++ request, &tmp); ++ if (result) { ++ dev_dbg(sbd_core(), "%s:%u: 0x%lx bytes at 0x%lx\n", ++ __func__, __LINE__, request, offset); ++ ++ dev_err(sbd_core(), "%s:%u: lv1_copy_lpm_trace_buffer " ++ "failed: %s\n", __func__, __LINE__, ++ ps3_result(result)); ++ return result == LV1_WRONG_STATE ? -EBUSY : -EINVAL; ++ } ++ ++ memcpy(buf, lpm_priv->tb_cache, tmp); ++ buf += tmp; ++ *bytes_copied += tmp; ++ offset += tmp; ++ } ++ dev_dbg(sbd_core(), "%s:%u: copied %lxh bytes\n", __func__, __LINE__, ++ *bytes_copied); ++ ++ return 0; ++} ++EXPORT_SYMBOL_GPL(ps3_lpm_copy_tb); ++ ++/** ++ * ps3_lpm_copy_tb_to_user - Copy data from the trace buffer to a user buffer. ++ * @offset: Offset in bytes from the start of the trace buffer. ++ * @buf: A __user copy destination. ++ * @count: Maximum count of bytes to copy. ++ * @bytes_copied: Pointer to a variable that will recieve the number of ++ * bytes copied to @buf. ++ * ++ * On error @buf will contain any successfully copied trace buffer data ++ * and bytes_copied will be set to the number of bytes successfully copied. ++ */ ++ ++int ps3_lpm_copy_tb_to_user(unsigned long offset, void __user *buf, ++ unsigned long count, unsigned long *bytes_copied) ++{ ++ int result; ++ ++ *bytes_copied = 0; ++ ++ if (!lpm_priv->tb_cache) ++ return -EPERM; ++ ++ if (offset >= lpm_priv->tb_count) ++ return 0; ++ ++ count = min(count, lpm_priv->tb_count - offset); ++ ++ while (*bytes_copied < count) { ++ const unsigned long request = count - *bytes_copied; ++ u64 tmp; ++ ++ result = lv1_copy_lpm_trace_buffer(lpm_priv->lpm_id, offset, ++ request, &tmp); ++ if (result) { ++ dev_dbg(sbd_core(), "%s:%u: 0x%lx bytes at 0x%lx\n", ++ __func__, __LINE__, request, offset); ++ dev_err(sbd_core(), "%s:%u: lv1_copy_lpm_trace_buffer " ++ "failed: %s\n", __func__, __LINE__, ++ ps3_result(result)); ++ return result == LV1_WRONG_STATE ? -EBUSY : -EINVAL; ++ } ++ ++ result = copy_to_user(buf, lpm_priv->tb_cache, tmp); ++ ++ if (result) { ++ dev_dbg(sbd_core(), "%s:%u: 0x%lx bytes at 0x%p\n", ++ __func__, __LINE__, tmp, buf); ++ dev_err(sbd_core(), "%s:%u: copy_to_user failed: %d\n", ++ __func__, __LINE__, result); ++ return -EFAULT; ++ } ++ ++ buf += tmp; ++ *bytes_copied += tmp; ++ offset += tmp; ++ } ++ dev_dbg(sbd_core(), "%s:%u: copied %lxh bytes\n", __func__, __LINE__, ++ *bytes_copied); ++ ++ return 0; ++} ++EXPORT_SYMBOL_GPL(ps3_lpm_copy_tb_to_user); ++ ++/** ++ * ps3_get_and_clear_pm_interrupts - ++ * ++ * Clearing interrupts for the entire performance monitoring unit. ++ * Reading pm_status clears the interrupt bits. ++ */ ++ ++u32 ps3_get_and_clear_pm_interrupts(u32 cpu) ++{ ++ return ps3_read_pm(cpu, pm_status); ++} ++EXPORT_SYMBOL_GPL(ps3_get_and_clear_pm_interrupts); ++ ++/** ++ * ps3_enable_pm_interrupts - ++ * ++ * Enabling interrupts for the entire performance monitoring unit. ++ * Enables the interrupt bits in the pm_status register. ++ */ ++ ++void ps3_enable_pm_interrupts(u32 cpu, u32 thread, u32 mask) ++{ ++ if (mask) ++ ps3_write_pm(cpu, pm_status, mask); ++} ++EXPORT_SYMBOL_GPL(ps3_enable_pm_interrupts); ++ ++/** ++ * ps3_enable_pm_interrupts - ++ * ++ * Disabling interrupts for the entire performance monitoring unit. ++ */ ++ ++void ps3_disable_pm_interrupts(u32 cpu) ++{ ++ ps3_get_and_clear_pm_interrupts(cpu); ++ ps3_write_pm(cpu, pm_status, 0); ++} ++EXPORT_SYMBOL_GPL(ps3_disable_pm_interrupts); ++ ++/** ++ * ps3_lpm_open - Open the logical performance monitor device. ++ * @tb_type: Specifies the type of trace buffer lv1 sould use for this lpm ++ * instance, specified by one of enum ps3_lpm_tb_type. ++ * @tb_cache: Optional user supplied buffer to use as the trace buffer cache. ++ * If NULL, the driver will allocate and manage an internal buffer. ++ * Unused when when @tb_type is PS3_LPM_TB_TYPE_NONE. ++ * @tb_cache_size: The size in bytes of the user supplied @tb_cache buffer. ++ * Unused when @tb_cache is NULL or @tb_type is PS3_LPM_TB_TYPE_NONE. ++ */ ++ ++int ps3_lpm_open(enum ps3_lpm_tb_type tb_type, void *tb_cache, ++ u64 tb_cache_size) ++{ ++ int result; ++ u64 tb_size; ++ ++ BUG_ON(!lpm_priv); ++ BUG_ON(tb_type != PS3_LPM_TB_TYPE_NONE ++ && tb_type != PS3_LPM_TB_TYPE_INTERNAL); ++ ++ if (tb_type == PS3_LPM_TB_TYPE_NONE && tb_cache) ++ dev_dbg(sbd_core(), "%s:%u: bad in vals\n", __func__, __LINE__); ++ ++ if (!atomic_add_unless(&lpm_priv->open, 1, 1)) { ++ dev_dbg(sbd_core(), "%s:%u: busy\n", __func__, __LINE__); ++ return -EBUSY; ++ } ++ ++ /* Note tb_cache needs 128 byte alignment. */ ++ ++ if (tb_type == PS3_LPM_TB_TYPE_NONE) { ++ lpm_priv->tb_cache_size = 0; ++ lpm_priv->tb_cache_internal = NULL; ++ lpm_priv->tb_cache = NULL; ++ } else if (tb_cache) { ++ if (tb_cache != (void *)_ALIGN_UP((unsigned long)tb_cache, 128) ++ || tb_cache_size != _ALIGN_UP(tb_cache_size, 128)) { ++ dev_err(sbd_core(), "%s:%u: unaligned tb_cache\n", ++ __func__, __LINE__); ++ result = -EINVAL; ++ goto fail_align; ++ } ++ lpm_priv->tb_cache_size = tb_cache_size; ++ lpm_priv->tb_cache_internal = NULL; ++ lpm_priv->tb_cache = tb_cache; ++ } else { ++ lpm_priv->tb_cache_size = PS3_LPM_DEFAULT_TB_CACHE_SIZE; ++ lpm_priv->tb_cache_internal = kzalloc( ++ lpm_priv->tb_cache_size + 127, GFP_KERNEL); ++ if (!lpm_priv->tb_cache_internal) { ++ dev_err(sbd_core(), "%s:%u: alloc internal tb_cache " ++ "failed\n", __func__, __LINE__); ++ result = -ENOMEM; ++ goto fail_malloc; ++ } ++ lpm_priv->tb_cache = (void *)_ALIGN_UP( ++ (unsigned long)lpm_priv->tb_cache_internal, 128); ++ } ++ ++ result = lv1_construct_lpm(lpm_priv->node_id, tb_type, 0, 0, ++ ps3_mm_phys_to_lpar(__pa(lpm_priv->tb_cache)), ++ lpm_priv->tb_cache_size, &lpm_priv->lpm_id, ++ &lpm_priv->outlet_id, &tb_size); ++ ++ if (result) { ++ dev_err(sbd_core(), "%s:%u: lv1_construct_lpm failed: %s\n", ++ __func__, __LINE__, ps3_result(result)); ++ result = -EINVAL; ++ goto fail_construct; ++ } ++ ++ lpm_priv->shadow.pm_control = PS3_LPM_SHADOW_REG_INIT; ++ lpm_priv->shadow.pm_start_stop = PS3_LPM_SHADOW_REG_INIT; ++ lpm_priv->shadow.pm_interval = PS3_LPM_SHADOW_REG_INIT; ++ lpm_priv->shadow.group_control = PS3_LPM_SHADOW_REG_INIT; ++ lpm_priv->shadow.debug_bus_control = PS3_LPM_SHADOW_REG_INIT; ++ ++ dev_dbg(sbd_core(), "%s:%u: lpm_id 0x%lx, outlet_id 0x%lx, " ++ "tb_size 0x%lx\n", __func__, __LINE__, lpm_priv->lpm_id, ++ lpm_priv->outlet_id, tb_size); ++ ++ return 0; ++ ++fail_construct: ++ kfree(lpm_priv->tb_cache_internal); ++ lpm_priv->tb_cache_internal = NULL; ++fail_malloc: ++fail_align: ++ atomic_dec(&lpm_priv->open); ++ return result; ++} ++EXPORT_SYMBOL_GPL(ps3_lpm_open); ++ ++/** ++ * ps3_lpm_close - Close the lpm device. ++ * ++ */ ++ ++int ps3_lpm_close(void) ++{ ++ dev_dbg(sbd_core(), "%s:%u\n", __func__, __LINE__); ++ ++ lv1_destruct_lpm(lpm_priv->lpm_id); ++ lpm_priv->lpm_id = 0; ++ ++ kfree(lpm_priv->tb_cache_internal); ++ lpm_priv->tb_cache_internal = NULL; ++ ++ atomic_dec(&lpm_priv->open); ++ return 0; ++} ++EXPORT_SYMBOL_GPL(ps3_lpm_close); ++ ++static int __devinit ps3_lpm_probe(struct ps3_system_bus_device *dev) ++{ ++ dev_dbg(&dev->core, " -> %s:%u\n", __func__, __LINE__); ++ ++ if (lpm_priv) { ++ dev_info(&dev->core, "%s:%u: called twice\n", ++ __func__, __LINE__); ++ return -EBUSY; ++ } ++ ++ lpm_priv = kzalloc(sizeof(*lpm_priv), GFP_KERNEL); ++ ++ if (!lpm_priv) ++ return -ENOMEM; ++ ++ lpm_priv->sbd = dev; ++ lpm_priv->node_id = dev->lpm.node_id; ++ lpm_priv->pu_id = dev->lpm.pu_id; ++ lpm_priv->rights = dev->lpm.rights; ++ ++ dev_info(&dev->core, " <- %s:%u:\n", __func__, __LINE__); ++ ++ return 0; ++} ++ ++static int ps3_lpm_remove(struct ps3_system_bus_device *dev) ++{ ++ dev_dbg(&dev->core, " -> %s:%u:\n", __func__, __LINE__); ++ ++ ps3_lpm_close(); ++ ++ kfree(lpm_priv); ++ lpm_priv = NULL; ++ ++ dev_info(&dev->core, " <- %s:%u:\n", __func__, __LINE__); ++ return 0; ++} ++ ++static struct ps3_system_bus_driver ps3_lpm_driver = { ++ .match_id = PS3_MATCH_ID_LPM, ++ .core.name = "ps3-lpm", ++ .core.owner = THIS_MODULE, ++ .probe = ps3_lpm_probe, ++ .remove = ps3_lpm_remove, ++ .shutdown = ps3_lpm_remove, ++}; ++ ++static int __init ps3_lpm_init(void) ++{ ++ pr_debug("%s:%d:\n", __func__, __LINE__); ++ return ps3_system_bus_driver_register(&ps3_lpm_driver); ++} ++ ++static void __exit ps3_lpm_exit(void) ++{ ++ pr_debug("%s:%d:\n", __func__, __LINE__); ++ ps3_system_bus_driver_unregister(&ps3_lpm_driver); ++} ++ ++module_init(ps3_lpm_init); ++module_exit(ps3_lpm_exit); ++ ++MODULE_LICENSE("GPL v2"); ++MODULE_DESCRIPTION("PS3 Logical Performance Monitor Driver"); ++MODULE_AUTHOR("Sony Corporation"); ++MODULE_ALIAS(PS3_MODULE_ALIAS_LPM); +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/ps3/ps3-sys-manager.c powerpc.git/drivers/ps3/ps3-sys-manager.c +--- linux-2.6.24/drivers/ps3/ps3-sys-manager.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/ps3/ps3-sys-manager.c 2008-01-28 20:26:18.000000000 +0100 +@@ -452,7 +452,7 @@ + case PS3_SM_EVENT_THERMAL_ALERT: + dev_dbg(&dev->core, "%s:%d: THERMAL_ALERT (zone %u)\n", + __func__, __LINE__, event.value); +- printk(KERN_INFO "PS3 Thermal Alert Zone %u\n", event.value); ++ pr_info("PS3 Thermal Alert Zone %u\n", event.value); + break; + case PS3_SM_EVENT_THERMAL_CLEARED: + dev_dbg(&dev->core, "%s:%d: THERMAL_CLEARED (zone %u)\n", +@@ -488,7 +488,7 @@ + result = ps3_vuart_read(dev, &cmd, sizeof(cmd)); + BUG_ON(result && "need to retry here"); + +- if(result) ++ if (result) + return result; + + if (cmd.version != 1) { +@@ -521,7 +521,7 @@ + result = ps3_vuart_read(dev, &header, + sizeof(struct ps3_sys_manager_header)); + +- if(result) ++ if (result) + return result; + + if (header.version != 1) { +@@ -589,9 +589,9 @@ + PS3_SM_WAKE_DEFAULT); + ps3_sys_manager_send_request_shutdown(dev); + +- printk(KERN_EMERG "System Halted, OK to turn off power\n"); ++ pr_emerg("System Halted, OK to turn off power\n"); + +- while(1) ++ while (1) + ps3_sys_manager_handle_msg(dev); + } + +@@ -626,9 +626,9 @@ + PS3_SM_WAKE_DEFAULT); + ps3_sys_manager_send_request_shutdown(dev); + +- printk(KERN_EMERG "System Halted, OK to turn off power\n"); ++ pr_emerg("System Halted, OK to turn off power\n"); + +- while(1) ++ while (1) + ps3_sys_manager_handle_msg(dev); + } + +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/ps3/ps3-vuart.c powerpc.git/drivers/ps3/ps3-vuart.c +--- linux-2.6.24/drivers/ps3/ps3-vuart.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/ps3/ps3-vuart.c 2008-01-28 20:26:18.000000000 +0100 +@@ -108,18 +108,18 @@ + struct ports_bmp { + u64 status; + u64 unused[3]; +-} __attribute__ ((aligned (32))); ++} __attribute__((aligned(32))); + + #define dump_ports_bmp(_b) _dump_ports_bmp(_b, __func__, __LINE__) + static void __maybe_unused _dump_ports_bmp( +- const struct ports_bmp* bmp, const char* func, int line) ++ const struct ports_bmp *bmp, const char *func, int line) + { + pr_debug("%s:%d: ports_bmp: %016lxh\n", func, line, bmp->status); + } + + #define dump_port_params(_b) _dump_port_params(_b, __func__, __LINE__) + static void __maybe_unused _dump_port_params(unsigned int port_number, +- const char* func, int line) ++ const char *func, int line) + { + #if defined(DEBUG) + static const char *strings[] = { +@@ -363,7 +363,7 @@ + */ + + static int ps3_vuart_raw_write(struct ps3_system_bus_device *dev, +- const void* buf, unsigned int bytes, unsigned long *bytes_written) ++ const void *buf, unsigned int bytes, unsigned long *bytes_written) + { + int result; + struct ps3_vuart_port_priv *priv = to_port_priv(dev); +@@ -431,7 +431,7 @@ + int result; + struct ps3_vuart_port_priv *priv = to_port_priv(dev); + u64 bytes_waiting; +- void* tmp; ++ void *tmp; + + result = ps3_vuart_get_rx_bytes_waiting(dev, &bytes_waiting); + +@@ -526,9 +526,8 @@ + + lb = kmalloc(sizeof(struct list_buffer) + bytes, GFP_KERNEL); + +- if (!lb) { ++ if (!lb) + return -ENOMEM; +- } + + memcpy(lb->data, buf, bytes); + lb->head = lb->data; +@@ -878,7 +877,7 @@ + struct vuart_bus_priv { + struct ports_bmp *bmp; + unsigned int virq; +- struct semaphore probe_mutex; ++ struct mutex probe_mutex; + int use_count; + struct ps3_system_bus_device *devices[PORT_COUNT]; + } static vuart_bus_priv; +@@ -926,9 +925,8 @@ + + BUG_ON(vuart_bus_priv.use_count > 2); + +- if (vuart_bus_priv.use_count != 1) { ++ if (vuart_bus_priv.use_count != 1) + return 0; +- } + + BUG_ON(vuart_bus_priv.bmp); + +@@ -1017,7 +1015,7 @@ + return -EINVAL; + } + +- down(&vuart_bus_priv.probe_mutex); ++ mutex_lock(&vuart_bus_priv.probe_mutex); + + result = ps3_vuart_bus_interrupt_get(); + +@@ -1077,7 +1075,7 @@ + goto fail_probe; + } + +- up(&vuart_bus_priv.probe_mutex); ++ mutex_unlock(&vuart_bus_priv.probe_mutex); + + return result; + +@@ -1090,7 +1088,7 @@ + fail_busy: + ps3_vuart_bus_interrupt_put(); + fail_setup_interrupt: +- up(&vuart_bus_priv.probe_mutex); ++ mutex_unlock(&vuart_bus_priv.probe_mutex); + dev_dbg(&dev->core, "%s:%d: failed\n", __func__, __LINE__); + return result; + } +@@ -1129,7 +1127,7 @@ + + BUG_ON(!dev); + +- down(&vuart_bus_priv.probe_mutex); ++ mutex_lock(&vuart_bus_priv.probe_mutex); + + dev_dbg(&dev->core, " -> %s:%d: match_id %d\n", __func__, __LINE__, + dev->match_id); +@@ -1137,7 +1135,7 @@ + if (!dev->core.driver) { + dev_dbg(&dev->core, "%s:%d: no driver bound\n", __func__, + __LINE__); +- up(&vuart_bus_priv.probe_mutex); ++ mutex_unlock(&vuart_bus_priv.probe_mutex); + return 0; + } + +@@ -1160,7 +1158,7 @@ + priv = NULL; + + dev_dbg(&dev->core, " <- %s:%d\n", __func__, __LINE__); +- up(&vuart_bus_priv.probe_mutex); ++ mutex_unlock(&vuart_bus_priv.probe_mutex); + return 0; + } + +@@ -1180,7 +1178,7 @@ + + BUG_ON(!dev); + +- down(&vuart_bus_priv.probe_mutex); ++ mutex_lock(&vuart_bus_priv.probe_mutex); + + dev_dbg(&dev->core, " -> %s:%d: match_id %d\n", __func__, __LINE__, + dev->match_id); +@@ -1188,7 +1186,7 @@ + if (!dev->core.driver) { + dev_dbg(&dev->core, "%s:%d: no driver bound\n", __func__, + __LINE__); +- up(&vuart_bus_priv.probe_mutex); ++ mutex_unlock(&vuart_bus_priv.probe_mutex); + return 0; + } + +@@ -1212,7 +1210,7 @@ + + dev_dbg(&dev->core, " <- %s:%d\n", __func__, __LINE__); + +- up(&vuart_bus_priv.probe_mutex); ++ mutex_unlock(&vuart_bus_priv.probe_mutex); + return 0; + } + +@@ -1223,7 +1221,7 @@ + if (!firmware_has_feature(FW_FEATURE_PS3_LV1)) + return -ENODEV; + +- init_MUTEX(&vuart_bus_priv.probe_mutex); ++ mutex_init(&vuart_bus_priv.probe_mutex); + + return 0; + } +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/serial/Kconfig powerpc.git/drivers/serial/Kconfig +--- linux-2.6.24/drivers/serial/Kconfig 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/serial/Kconfig 2008-01-28 20:26:19.000000000 +0100 +@@ -1284,4 +1284,14 @@ + Currently, only 8250 compatible ports are supported, but + others can easily be added. + ++config SERIAL_QE ++ tristate "Freescale QUICC Engine serial port support" ++ depends on QUICC_ENGINE ++ select SERIAL_CORE ++ select FW_LOADER ++ default n ++ help ++ This driver supports the QE serial ports on Freescale embedded ++ PowerPC that contain a QUICC Engine. ++ + endmenu +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/serial/Makefile powerpc.git/drivers/serial/Makefile +--- linux-2.6.24/drivers/serial/Makefile 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/serial/Makefile 2008-01-28 20:26:19.000000000 +0100 +@@ -64,3 +64,4 @@ + obj-$(CONFIG_SERIAL_NETX) += netx-serial.o + obj-$(CONFIG_SERIAL_OF_PLATFORM) += of_serial.o + obj-$(CONFIG_SERIAL_KS8695) += serial_ks8695.o ++obj-$(CONFIG_SERIAL_QE) += ucc_uart.o +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/serial/cpm_uart/cpm_uart_cpm1.c powerpc.git/drivers/serial/cpm_uart/cpm_uart_cpm1.c +--- linux-2.6.24/drivers/serial/cpm_uart/cpm_uart_cpm1.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/serial/cpm_uart/cpm_uart_cpm1.c 2008-01-28 20:26:19.000000000 +0100 +@@ -52,11 +52,7 @@ + #ifdef CONFIG_PPC_CPM_NEW_BINDING + void cpm_line_cr_cmd(struct uart_cpm_port *port, int cmd) + { +- u16 __iomem *cpcr = &cpmp->cp_cpcr; +- +- out_be16(cpcr, port->command | (cmd << 8) | CPM_CR_FLG); +- while (in_be16(cpcr) & CPM_CR_FLG) +- ; ++ cpm_command(port->command, cmd); + } + #else + void cpm_line_cr_cmd(struct uart_cpm_port *port, int cmd) +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/serial/cpm_uart/cpm_uart_cpm2.c powerpc.git/drivers/serial/cpm_uart/cpm_uart_cpm2.c +--- linux-2.6.24/drivers/serial/cpm_uart/cpm_uart_cpm2.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/serial/cpm_uart/cpm_uart_cpm2.c 2008-01-28 20:26:19.000000000 +0100 +@@ -52,13 +52,7 @@ + #ifdef CONFIG_PPC_CPM_NEW_BINDING + void cpm_line_cr_cmd(struct uart_cpm_port *port, int cmd) + { +- cpm_cpm2_t __iomem *cp = cpm2_map(im_cpm); +- +- out_be32(&cp->cp_cpcr, port->command | cmd | CPM_CR_FLG); +- while (in_be32(&cp->cp_cpcr) & CPM_CR_FLG) +- ; +- +- cpm2_unmap(cp); ++ cpm_command(port->command, cmd); + } + #else + void cpm_line_cr_cmd(struct uart_cpm_port *port, int cmd) +@@ -171,9 +165,9 @@ + * really has to get out of the driver so boards can + * be supported in a sane fashion. + */ ++ volatile cpmux_t *cpmux = cpm2_map(im_cpmux); + #ifndef CONFIG_STX_GP3 + volatile iop_cpm2_t *io = cpm2_map(im_ioport); +- volatile cpmux_t *cpmux = cpm2_map(im_cpmux); + + io->iop_pparb |= 0x008b0000; + io->iop_pdirb |= 0x00880000; +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/serial/mpc52xx_uart.c powerpc.git/drivers/serial/mpc52xx_uart.c +--- linux-2.6.24/drivers/serial/mpc52xx_uart.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/serial/mpc52xx_uart.c 2008-01-28 20:26:19.000000000 +0100 +@@ -36,7 +36,7 @@ + * DCD. However, the pin multiplexing aren't changed and should be set either + * by the bootloader or in the platform init code. + * +- * The idx field must be equal to the PSC index ( e.g. 0 for PSC1, 1 for PSC2, ++ * The idx field must be equal to the PSC index (e.g. 0 for PSC1, 1 for PSC2, + * and so on). So the PSC1 is mapped to /dev/ttyPSC0, PSC2 to /dev/ttyPSC1 and + * so on. But be warned, it's an ABSOLUTE REQUIREMENT ! This is needed mainly + * fpr the console code : without this 1:1 mapping, at early boot time, when we +@@ -68,11 +68,12 @@ + #include <linux/sysrq.h> + #include <linux/console.h> + +-#include <asm/delay.h> +-#include <asm/io.h> ++#include <linux/delay.h> ++#include <linux/io.h> + + #if defined(CONFIG_PPC_MERGE) +-#include <asm/of_platform.h> ++#include <linux/of.h> ++#include <linux/of_platform.h> + #else + #include <linux/platform_device.h> + #endif +@@ -111,16 +112,18 @@ + #endif + + #define PSC(port) ((struct mpc52xx_psc __iomem *)((port)->membase)) ++#define FIFO(port) ((struct mpc52xx_psc_fifo __iomem *)(PSC(port)+1)) + + + /* Forward declaration of the interruption handling routine */ +-static irqreturn_t mpc52xx_uart_int(int irq,void *dev_id); ++static irqreturn_t mpc52xx_uart_int(int irq, void *dev_id); + + + /* Simple macro to test if a port is console or not. This one is taken + * for serial_core.c and maybe should be moved to serial_core.h ? */ + #ifdef CONFIG_SERIAL_CORE_CONSOLE +-#define uart_console(port) ((port)->cons && (port)->cons->index == (port)->line) ++#define uart_console(port) \ ++ ((port)->cons && (port)->cons->index == (port)->line) + #else + #define uart_console(port) (0) + #endif +@@ -162,7 +165,7 @@ + { + /* port->lock taken by caller */ + port->read_status_mask &= ~MPC52xx_PSC_IMR_TXRDY; +- out_be16(&PSC(port)->mpc52xx_psc_imr,port->read_status_mask); ++ out_be16(&PSC(port)->mpc52xx_psc_imr, port->read_status_mask); + } + + static void +@@ -170,7 +173,7 @@ + { + /* port->lock taken by caller */ + port->read_status_mask |= MPC52xx_PSC_IMR_TXRDY; +- out_be16(&PSC(port)->mpc52xx_psc_imr,port->read_status_mask); ++ out_be16(&PSC(port)->mpc52xx_psc_imr, port->read_status_mask); + } + + static void +@@ -184,7 +187,7 @@ + /* Make sure tx interrupts are on */ + /* Truly necessary ??? They should be anyway */ + port->read_status_mask |= MPC52xx_PSC_IMR_TXRDY; +- out_be16(&PSC(port)->mpc52xx_psc_imr,port->read_status_mask); ++ out_be16(&PSC(port)->mpc52xx_psc_imr, port->read_status_mask); + } + + spin_unlock_irqrestore(&port->lock, flags); +@@ -195,7 +198,7 @@ + { + /* port->lock taken by caller */ + port->read_status_mask &= ~MPC52xx_PSC_IMR_RXRDY; +- out_be16(&PSC(port)->mpc52xx_psc_imr,port->read_status_mask); ++ out_be16(&PSC(port)->mpc52xx_psc_imr, port->read_status_mask); + } + + static void +@@ -210,10 +213,10 @@ + unsigned long flags; + spin_lock_irqsave(&port->lock, flags); + +- if ( ctl == -1 ) +- out_8(&PSC(port)->command,MPC52xx_PSC_START_BRK); ++ if (ctl == -1) ++ out_8(&PSC(port)->command, MPC52xx_PSC_START_BRK); + else +- out_8(&PSC(port)->command,MPC52xx_PSC_STOP_BRK); ++ out_8(&PSC(port)->command, MPC52xx_PSC_STOP_BRK); + + spin_unlock_irqrestore(&port->lock, flags); + } +@@ -222,6 +225,7 @@ + mpc52xx_uart_startup(struct uart_port *port) + { + struct mpc52xx_psc __iomem *psc = PSC(port); ++ struct mpc52xx_psc_fifo __iomem *fifo = FIFO(port); + int ret; + + /* Request IRQ */ +@@ -231,23 +235,23 @@ + return ret; + + /* Reset/activate the port, clear and enable interrupts */ +- out_8(&psc->command,MPC52xx_PSC_RST_RX); +- out_8(&psc->command,MPC52xx_PSC_RST_TX); ++ out_8(&psc->command, MPC52xx_PSC_RST_RX); ++ out_8(&psc->command, MPC52xx_PSC_RST_TX); + +- out_be32(&psc->sicr,0); /* UART mode DCD ignored */ ++ out_be32(&psc->sicr, 0); /* UART mode DCD ignored */ + + out_be16(&psc->mpc52xx_psc_clock_select, 0xdd00); /* /16 prescaler on */ + +- out_8(&psc->rfcntl, 0x00); +- out_be16(&psc->rfalarm, 0x1ff); +- out_8(&psc->tfcntl, 0x07); +- out_be16(&psc->tfalarm, 0x80); ++ out_8(&fifo->rfcntl, 0x00); ++ out_be16(&fifo->rfalarm, 0x1ff); ++ out_8(&fifo->tfcntl, 0x07); ++ out_be16(&fifo->tfalarm, 0x80); + + port->read_status_mask |= MPC52xx_PSC_IMR_RXRDY | MPC52xx_PSC_IMR_TXRDY; +- out_be16(&psc->mpc52xx_psc_imr,port->read_status_mask); ++ out_be16(&psc->mpc52xx_psc_imr, port->read_status_mask); + +- out_8(&psc->command,MPC52xx_PSC_TX_ENABLE); +- out_8(&psc->command,MPC52xx_PSC_RX_ENABLE); ++ out_8(&psc->command, MPC52xx_PSC_TX_ENABLE); ++ out_8(&psc->command, MPC52xx_PSC_RX_ENABLE); + + return 0; + } +@@ -258,12 +262,12 @@ + struct mpc52xx_psc __iomem *psc = PSC(port); + + /* Shut down the port. Leave TX active if on a console port */ +- out_8(&psc->command,MPC52xx_PSC_RST_RX); ++ out_8(&psc->command, MPC52xx_PSC_RST_RX); + if (!uart_console(port)) +- out_8(&psc->command,MPC52xx_PSC_RST_TX); ++ out_8(&psc->command, MPC52xx_PSC_RST_TX); + + port->read_status_mask = 0; +- out_be16(&psc->mpc52xx_psc_imr,port->read_status_mask); ++ out_be16(&psc->mpc52xx_psc_imr, port->read_status_mask); + + /* Release interrupt */ + free_irq(port->irq, port); +@@ -271,7 +275,7 @@ + + static void + mpc52xx_uart_set_termios(struct uart_port *port, struct ktermios *new, +- struct ktermios *old) ++ struct ktermios *old) + { + struct mpc52xx_psc __iomem *psc = PSC(port); + unsigned long flags; +@@ -283,14 +287,14 @@ + mr1 = 0; + + switch (new->c_cflag & CSIZE) { +- case CS5: mr1 |= MPC52xx_PSC_MODE_5_BITS; +- break; +- case CS6: mr1 |= MPC52xx_PSC_MODE_6_BITS; +- break; +- case CS7: mr1 |= MPC52xx_PSC_MODE_7_BITS; +- break; +- case CS8: +- default: mr1 |= MPC52xx_PSC_MODE_8_BITS; ++ case CS5: mr1 |= MPC52xx_PSC_MODE_5_BITS; ++ break; ++ case CS6: mr1 |= MPC52xx_PSC_MODE_6_BITS; ++ break; ++ case CS7: mr1 |= MPC52xx_PSC_MODE_7_BITS; ++ break; ++ case CS8: ++ default: mr1 |= MPC52xx_PSC_MODE_8_BITS; + } + + if (new->c_cflag & PARENB) { +@@ -332,24 +336,24 @@ + udelay(1); + + if (!j) +- printk( KERN_ERR "mpc52xx_uart.c: " ++ printk(KERN_ERR "mpc52xx_uart.c: " + "Unable to flush RX & TX fifos in-time in set_termios." +- "Some chars may have been lost.\n" ); ++ "Some chars may have been lost.\n"); + + /* Reset the TX & RX */ +- out_8(&psc->command,MPC52xx_PSC_RST_RX); +- out_8(&psc->command,MPC52xx_PSC_RST_TX); ++ out_8(&psc->command, MPC52xx_PSC_RST_RX); ++ out_8(&psc->command, MPC52xx_PSC_RST_TX); + + /* Send new mode settings */ +- out_8(&psc->command,MPC52xx_PSC_SEL_MODE_REG_1); +- out_8(&psc->mode,mr1); +- out_8(&psc->mode,mr2); +- out_8(&psc->ctur,ctr >> 8); +- out_8(&psc->ctlr,ctr & 0xff); ++ out_8(&psc->command, MPC52xx_PSC_SEL_MODE_REG_1); ++ out_8(&psc->mode, mr1); ++ out_8(&psc->mode, mr2); ++ out_8(&psc->ctur, ctr >> 8); ++ out_8(&psc->ctlr, ctr & 0xff); + + /* Reenable TX & RX */ +- out_8(&psc->command,MPC52xx_PSC_TX_ENABLE); +- out_8(&psc->command,MPC52xx_PSC_RX_ENABLE); ++ out_8(&psc->command, MPC52xx_PSC_TX_ENABLE); ++ out_8(&psc->command, MPC52xx_PSC_RX_ENABLE); + + /* We're all set, release the lock */ + spin_unlock_irqrestore(&port->lock, flags); +@@ -364,7 +368,8 @@ + static void + mpc52xx_uart_release_port(struct uart_port *port) + { +- if (port->flags & UPF_IOREMAP) { /* remapped by us ? */ ++ /* remapped by us ? */ ++ if (port->flags & UPF_IOREMAP) { + iounmap(port->membase); + port->membase = NULL; + } +@@ -379,7 +384,7 @@ + + if (port->flags & UPF_IOREMAP) /* Need to remap ? */ + port->membase = ioremap(port->mapbase, +- sizeof(struct mpc52xx_psc)); ++ sizeof(struct mpc52xx_psc)); + + if (!port->membase) + return -EINVAL; +@@ -398,22 +403,22 @@ + static void + mpc52xx_uart_config_port(struct uart_port *port, int flags) + { +- if ( (flags & UART_CONFIG_TYPE) && +- (mpc52xx_uart_request_port(port) == 0) ) +- port->type = PORT_MPC52xx; ++ if ((flags & UART_CONFIG_TYPE) ++ && (mpc52xx_uart_request_port(port) == 0)) ++ port->type = PORT_MPC52xx; + } + + static int + mpc52xx_uart_verify_port(struct uart_port *port, struct serial_struct *ser) + { +- if ( ser->type != PORT_UNKNOWN && ser->type != PORT_MPC52xx ) ++ if (ser->type != PORT_UNKNOWN && ser->type != PORT_MPC52xx) + return -EINVAL; + +- if ( (ser->irq != port->irq) || +- (ser->io_type != SERIAL_IO_MEM) || +- (ser->baud_base != port->uartclk) || +- (ser->iomem_base != (void*)port->mapbase) || +- (ser->hub6 != 0 ) ) ++ if ((ser->irq != port->irq) || ++ (ser->io_type != SERIAL_IO_MEM) || ++ (ser->baud_base != port->uartclk) || ++ (ser->iomem_base != (void *)port->mapbase) || ++ (ser->hub6 != 0)) + return -EINVAL; + + return 0; +@@ -455,8 +460,8 @@ + unsigned short status; + + /* While we can read, do so ! */ +- while ( (status = in_be16(&PSC(port)->mpc52xx_psc_status)) & +- MPC52xx_PSC_SR_RXRDY) { ++ while ((status = in_be16(&PSC(port)->mpc52xx_psc_status)) & ++ MPC52xx_PSC_SR_RXRDY) { + + /* Get the char */ + ch = in_8(&PSC(port)->mpc52xx_psc_buffer_8); +@@ -474,9 +479,9 @@ + flag = TTY_NORMAL; + port->icount.rx++; + +- if ( status & (MPC52xx_PSC_SR_PE | +- MPC52xx_PSC_SR_FE | +- MPC52xx_PSC_SR_RB) ) { ++ if (status & (MPC52xx_PSC_SR_PE | ++ MPC52xx_PSC_SR_FE | ++ MPC52xx_PSC_SR_RB)) { + + if (status & MPC52xx_PSC_SR_RB) { + flag = TTY_BREAK; +@@ -487,7 +492,7 @@ + flag = TTY_FRAME; + + /* Clear error condition */ +- out_8(&PSC(port)->command,MPC52xx_PSC_RST_ERR_STAT); ++ out_8(&PSC(port)->command, MPC52xx_PSC_RST_ERR_STAT); + + } + tty_insert_flip_char(tty, ch, flag); +@@ -568,16 +573,16 @@ + + /* Do we need to receive chars ? */ + /* For this RX interrupts must be on and some chars waiting */ +- if ( status & MPC52xx_PSC_IMR_RXRDY ) ++ if (status & MPC52xx_PSC_IMR_RXRDY) + keepgoing |= mpc52xx_uart_int_rx_chars(port); + + /* Do we need to send chars ? */ + /* For this, TX must be ready and TX interrupt enabled */ +- if ( status & MPC52xx_PSC_IMR_TXRDY ) ++ if (status & MPC52xx_PSC_IMR_TXRDY) + keepgoing |= mpc52xx_uart_int_tx_chars(port); + + /* Limit number of iteration */ +- if ( !(--pass) ) ++ if (!(--pass)) + keepgoing = 0; + + } while (keepgoing); +@@ -596,7 +601,7 @@ + + static void __init + mpc52xx_console_get_options(struct uart_port *port, +- int *baud, int *parity, int *bits, int *flow) ++ int *baud, int *parity, int *bits, int *flow) + { + struct mpc52xx_psc __iomem *psc = PSC(port); + unsigned char mr1; +@@ -604,7 +609,7 @@ + pr_debug("mpc52xx_console_get_options(port=%p)\n", port); + + /* Read the mode registers */ +- out_8(&psc->command,MPC52xx_PSC_SEL_MODE_REG_1); ++ out_8(&psc->command, MPC52xx_PSC_SEL_MODE_REG_1); + mr1 = in_8(&psc->mode); + + /* CT{U,L}R are write-only ! */ +@@ -616,11 +621,18 @@ + + /* Parse them */ + switch (mr1 & MPC52xx_PSC_MODE_BITS_MASK) { +- case MPC52xx_PSC_MODE_5_BITS: *bits = 5; break; +- case MPC52xx_PSC_MODE_6_BITS: *bits = 6; break; +- case MPC52xx_PSC_MODE_7_BITS: *bits = 7; break; +- case MPC52xx_PSC_MODE_8_BITS: +- default: *bits = 8; ++ case MPC52xx_PSC_MODE_5_BITS: ++ *bits = 5; ++ break; ++ case MPC52xx_PSC_MODE_6_BITS: ++ *bits = 6; ++ break; ++ case MPC52xx_PSC_MODE_7_BITS: ++ *bits = 7; ++ break; ++ case MPC52xx_PSC_MODE_8_BITS: ++ default: ++ *bits = 8; + } + + if (mr1 & MPC52xx_PSC_MODE_PARNONE) +@@ -657,7 +669,7 @@ + /* Wait the TX buffer to be empty */ + j = 20000; /* Maximum wait */ + while (!(in_be16(&psc->mpc52xx_psc_status) & +- MPC52xx_PSC_SR_TXEMP) && --j) ++ MPC52xx_PSC_SR_TXEMP) && --j) + udelay(1); + } + +@@ -730,16 +742,18 @@ + } + + pr_debug("Console on ttyPSC%x is %s\n", +- co->index, mpc52xx_uart_nodes[co->index]->full_name); ++ co->index, mpc52xx_uart_nodes[co->index]->full_name); + + /* Fetch register locations */ +- if ((ret = of_address_to_resource(np, 0, &res)) != 0) { ++ ret = of_address_to_resource(np, 0, &res); ++ if (ret) { + pr_debug("Could not get resources for PSC%x\n", co->index); + return ret; + } + + /* Search for bus-frequency property in this node or a parent */ +- if ((ipb_freq = mpc52xx_find_ipb_freq(np)) == 0) { ++ ipb_freq = mpc52xx_find_ipb_freq(np); ++ if (ipb_freq == 0) { + pr_debug("Could not find IPB bus frequency!\n"); + return -EINVAL; + } +@@ -757,7 +771,8 @@ + return -EINVAL; + + pr_debug("mpc52xx-psc uart at %p, mapped to %p, irq=%x, freq=%i\n", +- (void*)port->mapbase, port->membase, port->irq, port->uartclk); ++ (void *)port->mapbase, port->membase, ++ port->irq, port->uartclk); + + /* Setup the port parameters accoding to options */ + if (options) +@@ -766,7 +781,7 @@ + mpc52xx_console_get_options(port, &baud, &parity, &bits, &flow); + + pr_debug("Setting console parameters: %i %i%c1 flow=%c\n", +- baud, bits, parity, flow); ++ baud, bits, parity, flow); + + return uart_set_options(port, co, baud, parity, bits, flow); + } +@@ -781,7 +796,7 @@ + .device = uart_console_device, + .setup = mpc52xx_console_setup, + .flags = CON_PRINTBUFFER, +- .index = -1, /* Specified on the cmdline (e.g. console=ttyPSC0 ) */ ++ .index = -1, /* Specified on the cmdline (e.g. console=ttyPSC0) */ + .data = &mpc52xx_uart_driver, + }; + +@@ -809,7 +824,6 @@ + /* ======================================================================== */ + + static struct uart_driver mpc52xx_uart_driver = { +- .owner = THIS_MODULE, + .driver_name = "mpc52xx_psc_uart", + .dev_name = "ttyPSC", + .major = SERIAL_PSC_MAJOR, +@@ -837,7 +851,7 @@ + if (idx < 0 || idx >= MPC52xx_PSC_MAXNUM) + return -EINVAL; + +- if (!mpc52xx_match_psc_function(idx,"uart")) ++ if (!mpc52xx_match_psc_function(idx, "uart")) + return -ENODEV; + + /* Init the port structure */ +@@ -848,13 +862,13 @@ + port->fifosize = 512; + port->iotype = UPIO_MEM; + port->flags = UPF_BOOT_AUTOCONF | +- ( uart_console(port) ? 0 : UPF_IOREMAP ); ++ (uart_console(port) ? 0 : UPF_IOREMAP); + port->line = idx; + port->ops = &mpc52xx_uart_ops; + port->dev = &dev->dev; + + /* Search for IRQ and mapbase */ +- for (i=0 ; i<dev->num_resources ; i++, res++) { ++ for (i = 0 ; i < dev->num_resources ; i++, res++) { + if (res->flags & IORESOURCE_MEM) + port->mapbase = res->start; + else if (res->flags & IORESOURCE_IRQ) +@@ -866,7 +880,7 @@ + /* Add the port to the uart sub-system */ + ret = uart_add_one_port(&mpc52xx_uart_driver, port); + if (!ret) +- platform_set_drvdata(dev, (void*)port); ++ platform_set_drvdata(dev, (void *)port); + + return ret; + } +@@ -917,6 +931,7 @@ + .resume = mpc52xx_uart_resume, + #endif + .driver = { ++ .owner = THIS_MODULE, + .name = "mpc52xx-psc", + }, + }; +@@ -946,10 +961,11 @@ + if (idx >= MPC52xx_PSC_MAXNUM) + return -EINVAL; + pr_debug("Found %s assigned to ttyPSC%x\n", +- mpc52xx_uart_nodes[idx]->full_name, idx); ++ mpc52xx_uart_nodes[idx]->full_name, idx); + + /* Search for bus-frequency property in this node or a parent */ +- if ((ipb_freq = mpc52xx_find_ipb_freq(op->node)) == 0) { ++ ipb_freq = mpc52xx_find_ipb_freq(op->node); ++ if (ipb_freq == 0) { + dev_dbg(&op->dev, "Could not find IPB bus frequency!\n"); + return -EINVAL; + } +@@ -962,22 +978,23 @@ + port->fifosize = 512; + port->iotype = UPIO_MEM; + port->flags = UPF_BOOT_AUTOCONF | +- ( uart_console(port) ? 0 : UPF_IOREMAP ); ++ (uart_console(port) ? 0 : UPF_IOREMAP); + port->line = idx; + port->ops = &mpc52xx_uart_ops; + port->dev = &op->dev; + + /* Search for IRQ and mapbase */ +- if ((ret = of_address_to_resource(op->node, 0, &res)) != 0) ++ ret = of_address_to_resource(op->node, 0, &res); ++ if (ret) + return ret; + + port->mapbase = res.start; + port->irq = irq_of_parse_and_map(op->node, 0); + + dev_dbg(&op->dev, "mpc52xx-psc uart at %p, irq=%x, freq=%i\n", +- (void*)port->mapbase, port->irq, port->uartclk); ++ (void *)port->mapbase, port->irq, port->uartclk); + +- if ((port->irq==NO_IRQ) || !port->mapbase) { ++ if ((port->irq == NO_IRQ) || !port->mapbase) { + printk(KERN_ERR "Could not allocate resources for PSC\n"); + return -EINVAL; + } +@@ -985,7 +1002,7 @@ + /* Add the port to the uart sub-system */ + ret = uart_add_one_port(&mpc52xx_uart_driver, port); + if (!ret) +- dev_set_drvdata(&op->dev, (void*)port); ++ dev_set_drvdata(&op->dev, (void *)port); + + return ret; + } +@@ -1048,6 +1065,7 @@ + if (idx < 0) + return; /* No free slot; abort */ + ++ of_node_get(np); + /* If the slot is already occupied, then swap slots */ + if (mpc52xx_uart_nodes[idx] && (free_idx != -1)) + mpc52xx_uart_nodes[free_idx] = mpc52xx_uart_nodes[idx]; +@@ -1057,7 +1075,7 @@ + static void + mpc52xx_uart_of_enumerate(void) + { +- static int enum_done = 0; ++ static int enum_done; + struct device_node *np; + const unsigned int *devno; + int i; +@@ -1071,7 +1089,7 @@ + + /* Is a particular device number requested? */ + devno = of_get_property(np, "port-number", NULL); +- mpc52xx_uart_of_assign(of_node_get(np), devno ? *devno : -1); ++ mpc52xx_uart_of_assign(np, devno ? *devno : -1); + } + + enum_done = 1; +@@ -1079,15 +1097,13 @@ + for (i = 0; i < MPC52xx_PSC_MAXNUM; i++) { + if (mpc52xx_uart_nodes[i]) + pr_debug("%s assigned to ttyPSC%x\n", +- mpc52xx_uart_nodes[i]->full_name, i); ++ mpc52xx_uart_nodes[i]->full_name, i); + } + } + + MODULE_DEVICE_TABLE(of, mpc52xx_uart_of_match); + + static struct of_platform_driver mpc52xx_uart_of_driver = { +- .owner = THIS_MODULE, +- .name = "mpc52xx-psc-uart", + .match_table = mpc52xx_uart_of_match, + .probe = mpc52xx_uart_of_probe, + .remove = mpc52xx_uart_of_remove, +@@ -1113,7 +1129,8 @@ + + printk(KERN_INFO "Serial: MPC52xx PSC UART driver\n"); + +- if ((ret = uart_register_driver(&mpc52xx_uart_driver)) != 0) { ++ ret = uart_register_driver(&mpc52xx_uart_driver); ++ if (ret) { + printk(KERN_ERR "%s: uart_register_driver failed (%i)\n", + __FILE__, ret); + return ret; +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/serial/uartlite.c powerpc.git/drivers/serial/uartlite.c +--- linux-2.6.24/drivers/serial/uartlite.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/serial/uartlite.c 2008-01-28 20:26:19.000000000 +0100 +@@ -539,7 +539,7 @@ + * + * @dev: pointer to device structure + */ +-static int __devinit ulite_release(struct device *dev) ++static int __devexit ulite_release(struct device *dev) + { + struct uart_port *port = dev_get_drvdata(dev); + int rc = 0; +@@ -572,14 +572,14 @@ + return ulite_assign(&pdev->dev, pdev->id, res->start, res2->start); + } + +-static int ulite_remove(struct platform_device *pdev) ++static int __devexit ulite_remove(struct platform_device *pdev) + { + return ulite_release(&pdev->dev); + } + + static struct platform_driver ulite_platform_driver = { + .probe = ulite_probe, +- .remove = ulite_remove, ++ .remove = __devexit_p(ulite_remove), + .driver = { + .owner = THIS_MODULE, + .name = "uartlite", +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/serial/ucc_uart.c powerpc.git/drivers/serial/ucc_uart.c +--- linux-2.6.24/drivers/serial/ucc_uart.c 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/drivers/serial/ucc_uart.c 2008-01-28 20:26:20.000000000 +0100 +@@ -0,0 +1,1514 @@ ++/* ++ * Freescale QUICC Engine UART device driver ++ * ++ * Author: Timur Tabi <timur@freescale.com> ++ * ++ * Copyright 2007 Freescale Semiconductor, Inc. This file is licensed under ++ * the terms of the GNU General Public License version 2. This program ++ * is licensed "as is" without any warranty of any kind, whether express ++ * or implied. ++ * ++ * This driver adds support for UART devices via Freescale's QUICC Engine ++ * found on some Freescale SOCs. ++ * ++ * If Soft-UART support is needed but not already present, then this driver ++ * will request and upload the "Soft-UART" microcode upon probe. The ++ * filename of the microcode should be fsl_qe_ucode_uart_X_YZ.bin, where "X" ++ * is the name of the SOC (e.g. 8323), and YZ is the revision of the SOC, ++ * (e.g. "11" for 1.1). ++ */ ++ ++#include <linux/module.h> ++#include <linux/serial.h> ++#include <linux/serial_core.h> ++#include <linux/io.h> ++#include <linux/of_platform.h> ++#include <linux/dma-mapping.h> ++ ++#include <linux/fs_uart_pd.h> ++#include <asm/ucc_slow.h> ++ ++#include <linux/firmware.h> ++#include <asm/reg.h> ++ ++/* ++ * The GUMR flag for Soft UART. This would normally be defined in qe.h, ++ * but Soft-UART is a hack and we want to keep everything related to it in ++ * this file. ++ */ ++#define UCC_SLOW_GUMR_H_SUART 0x00004000 /* Soft-UART */ ++ ++/* ++ * soft_uart is 1 if we need to use Soft-UART mode ++ */ ++static int soft_uart; ++/* ++ * firmware_loaded is 1 if the firmware has been loaded, 0 otherwise. ++ */ ++static int firmware_loaded; ++ ++/* Enable this macro to configure all serial ports in internal loopback ++ mode */ ++/* #define LOOPBACK */ ++ ++/* The major and minor device numbers are defined in ++ * http://www.lanana.org/docs/device-list/devices-2.6+.txt. For the QE ++ * UART, we have major number 204 and minor numbers 46 - 49, which are the ++ * same as for the CPM2. This decision was made because no Freescale part ++ * has both a CPM and a QE. ++ */ ++#define SERIAL_QE_MAJOR 204 ++#define SERIAL_QE_MINOR 46 ++ ++/* Since we only have minor numbers 46 - 49, there is a hard limit of 4 ports */ ++#define UCC_MAX_UART 4 ++ ++/* The number of buffer descriptors for receiving characters. */ ++#define RX_NUM_FIFO 4 ++ ++/* The number of buffer descriptors for transmitting characters. */ ++#define TX_NUM_FIFO 4 ++ ++/* The maximum size of the character buffer for a single RX BD. */ ++#define RX_BUF_SIZE 32 ++ ++/* The maximum size of the character buffer for a single TX BD. */ ++#define TX_BUF_SIZE 32 ++ ++/* ++ * The number of jiffies to wait after receiving a close command before the ++ * device is actually closed. This allows the last few characters to be ++ * sent over the wire. ++ */ ++#define UCC_WAIT_CLOSING 100 ++ ++struct ucc_uart_pram { ++ struct ucc_slow_pram common; ++ u8 res1[8]; /* reserved */ ++ __be16 maxidl; /* Maximum idle chars */ ++ __be16 idlc; /* temp idle counter */ ++ __be16 brkcr; /* Break count register */ ++ __be16 parec; /* receive parity error counter */ ++ __be16 frmec; /* receive framing error counter */ ++ __be16 nosec; /* receive noise counter */ ++ __be16 brkec; /* receive break condition counter */ ++ __be16 brkln; /* last received break length */ ++ __be16 uaddr[2]; /* UART address character 1 & 2 */ ++ __be16 rtemp; /* Temp storage */ ++ __be16 toseq; /* Transmit out of sequence char */ ++ __be16 cchars[8]; /* control characters 1-8 */ ++ __be16 rccm; /* receive control character mask */ ++ __be16 rccr; /* receive control character register */ ++ __be16 rlbc; /* receive last break character */ ++ __be16 res2; /* reserved */ ++ __be32 res3; /* reserved, should be cleared */ ++ u8 res4; /* reserved, should be cleared */ ++ u8 res5[3]; /* reserved, should be cleared */ ++ __be32 res6; /* reserved, should be cleared */ ++ __be32 res7; /* reserved, should be cleared */ ++ __be32 res8; /* reserved, should be cleared */ ++ __be32 res9; /* reserved, should be cleared */ ++ __be32 res10; /* reserved, should be cleared */ ++ __be32 res11; /* reserved, should be cleared */ ++ __be32 res12; /* reserved, should be cleared */ ++ __be32 res13; /* reserved, should be cleared */ ++/* The rest is for Soft-UART only */ ++ __be16 supsmr; /* 0x90, Shadow UPSMR */ ++ __be16 res92; /* 0x92, reserved, initialize to 0 */ ++ __be32 rx_state; /* 0x94, RX state, initialize to 0 */ ++ __be32 rx_cnt; /* 0x98, RX count, initialize to 0 */ ++ u8 rx_length; /* 0x9C, Char length, set to 1+CL+PEN+1+SL */ ++ u8 rx_bitmark; /* 0x9D, reserved, initialize to 0 */ ++ u8 rx_temp_dlst_qe; /* 0x9E, reserved, initialize to 0 */ ++ u8 res14[0xBC - 0x9F]; /* reserved */ ++ __be32 dump_ptr; /* 0xBC, Dump pointer */ ++ __be32 rx_frame_rem; /* 0xC0, reserved, initialize to 0 */ ++ u8 rx_frame_rem_size; /* 0xC4, reserved, initialize to 0 */ ++ u8 tx_mode; /* 0xC5, mode, 0=AHDLC, 1=UART */ ++ __be16 tx_state; /* 0xC6, TX state */ ++ u8 res15[0xD0 - 0xC8]; /* reserved */ ++ __be32 resD0; /* 0xD0, reserved, initialize to 0 */ ++ u8 resD4; /* 0xD4, reserved, initialize to 0 */ ++ __be16 resD5; /* 0xD5, reserved, initialize to 0 */ ++} __attribute__ ((packed)); ++ ++/* SUPSMR definitions, for Soft-UART only */ ++#define UCC_UART_SUPSMR_SL 0x8000 ++#define UCC_UART_SUPSMR_RPM_MASK 0x6000 ++#define UCC_UART_SUPSMR_RPM_ODD 0x0000 ++#define UCC_UART_SUPSMR_RPM_LOW 0x2000 ++#define UCC_UART_SUPSMR_RPM_EVEN 0x4000 ++#define UCC_UART_SUPSMR_RPM_HIGH 0x6000 ++#define UCC_UART_SUPSMR_PEN 0x1000 ++#define UCC_UART_SUPSMR_TPM_MASK 0x0C00 ++#define UCC_UART_SUPSMR_TPM_ODD 0x0000 ++#define UCC_UART_SUPSMR_TPM_LOW 0x0400 ++#define UCC_UART_SUPSMR_TPM_EVEN 0x0800 ++#define UCC_UART_SUPSMR_TPM_HIGH 0x0C00 ++#define UCC_UART_SUPSMR_FRZ 0x0100 ++#define UCC_UART_SUPSMR_UM_MASK 0x00c0 ++#define UCC_UART_SUPSMR_UM_NORMAL 0x0000 ++#define UCC_UART_SUPSMR_UM_MAN_MULTI 0x0040 ++#define UCC_UART_SUPSMR_UM_AUTO_MULTI 0x00c0 ++#define UCC_UART_SUPSMR_CL_MASK 0x0030 ++#define UCC_UART_SUPSMR_CL_8 0x0030 ++#define UCC_UART_SUPSMR_CL_7 0x0020 ++#define UCC_UART_SUPSMR_CL_6 0x0010 ++#define UCC_UART_SUPSMR_CL_5 0x0000 ++ ++#define UCC_UART_TX_STATE_AHDLC 0x00 ++#define UCC_UART_TX_STATE_UART 0x01 ++#define UCC_UART_TX_STATE_X1 0x00 ++#define UCC_UART_TX_STATE_X16 0x80 ++ ++#define UCC_UART_PRAM_ALIGNMENT 0x100 ++ ++#define UCC_UART_SIZE_OF_BD UCC_SLOW_SIZE_OF_BD ++#define NUM_CONTROL_CHARS 8 ++ ++/* Private per-port data structure */ ++struct uart_qe_port { ++ struct uart_port port; ++ struct ucc_slow __iomem *uccp; ++ struct ucc_uart_pram __iomem *uccup; ++ struct ucc_slow_info us_info; ++ struct ucc_slow_private *us_private; ++ struct device_node *np; ++ unsigned int ucc_num; /* First ucc is 0, not 1 */ ++ ++ u16 rx_nrfifos; ++ u16 rx_fifosize; ++ u16 tx_nrfifos; ++ u16 tx_fifosize; ++ int wait_closing; ++ u32 flags; ++ struct qe_bd *rx_bd_base; ++ struct qe_bd *rx_cur; ++ struct qe_bd *tx_bd_base; ++ struct qe_bd *tx_cur; ++ unsigned char *tx_buf; ++ unsigned char *rx_buf; ++ void *bd_virt; /* virtual address of the BD buffers */ ++ dma_addr_t bd_dma_addr; /* bus address of the BD buffers */ ++ unsigned int bd_size; /* size of BD buffer space */ ++}; ++ ++static struct uart_driver ucc_uart_driver = { ++ .owner = THIS_MODULE, ++ .driver_name = "serial", ++ .dev_name = "ttyQE", ++ .major = SERIAL_QE_MAJOR, ++ .minor = SERIAL_QE_MINOR, ++ .nr = UCC_MAX_UART, ++}; ++ ++/* ++ * Virtual to physical address translation. ++ * ++ * Given the virtual address for a character buffer, this function returns ++ * the physical (DMA) equivalent. ++ */ ++static inline dma_addr_t cpu2qe_addr(void *addr, struct uart_qe_port *qe_port) ++{ ++ if (likely((addr >= qe_port->bd_virt)) && ++ (addr < (qe_port->bd_virt + qe_port->bd_size))) ++ return qe_port->bd_dma_addr + (addr - qe_port->bd_virt); ++ ++ /* something nasty happened */ ++ printk(KERN_ERR "%s: addr=%p\n", __FUNCTION__, addr); ++ BUG(); ++ return 0; ++} ++ ++/* ++ * Physical to virtual address translation. ++ * ++ * Given the physical (DMA) address for a character buffer, this function ++ * returns the virtual equivalent. ++ */ ++static inline void *qe2cpu_addr(dma_addr_t addr, struct uart_qe_port *qe_port) ++{ ++ /* sanity check */ ++ if (likely((addr >= qe_port->bd_dma_addr) && ++ (addr < (qe_port->bd_dma_addr + qe_port->bd_size)))) ++ return qe_port->bd_virt + (addr - qe_port->bd_dma_addr); ++ ++ /* something nasty happened */ ++ printk(KERN_ERR "%s: addr=%x\n", __FUNCTION__, addr); ++ BUG(); ++ return NULL; ++} ++ ++/* ++ * Return 1 if the QE is done transmitting all buffers for this port ++ * ++ * This function scans each BD in sequence. If we find a BD that is not ++ * ready (READY=1), then we return 0 indicating that the QE is still sending ++ * data. If we reach the last BD (WRAP=1), then we know we've scanned ++ * the entire list, and all BDs are done. ++ */ ++static unsigned int qe_uart_tx_empty(struct uart_port *port) ++{ ++ struct uart_qe_port *qe_port = ++ container_of(port, struct uart_qe_port, port); ++ struct qe_bd *bdp = qe_port->tx_bd_base; ++ ++ while (1) { ++ if (in_be16(&bdp->status) & BD_SC_READY) ++ /* This BD is not done, so return "not done" */ ++ return 0; ++ ++ if (in_be16(&bdp->status) & BD_SC_WRAP) ++ /* ++ * This BD is done and it's the last one, so return ++ * "done" ++ */ ++ return 1; ++ ++ bdp++; ++ }; ++} ++ ++/* ++ * Set the modem control lines ++ * ++ * Although the QE can control the modem control lines (e.g. CTS), we ++ * don't need that support. This function must exist, however, otherwise ++ * the kernel will panic. ++ */ ++void qe_uart_set_mctrl(struct uart_port *port, unsigned int mctrl) ++{ ++} ++ ++/* ++ * Get the current modem control line status ++ * ++ * Although the QE can control the modem control lines (e.g. CTS), this ++ * driver currently doesn't support that, so we always return Carrier ++ * Detect, Data Set Ready, and Clear To Send. ++ */ ++static unsigned int qe_uart_get_mctrl(struct uart_port *port) ++{ ++ return TIOCM_CAR | TIOCM_DSR | TIOCM_CTS; ++} ++ ++/* ++ * Disable the transmit interrupt. ++ * ++ * Although this function is called "stop_tx", it does not actually stop ++ * transmission of data. Instead, it tells the QE to not generate an ++ * interrupt when the UCC is finished sending characters. ++ */ ++static void qe_uart_stop_tx(struct uart_port *port) ++{ ++ struct uart_qe_port *qe_port = ++ container_of(port, struct uart_qe_port, port); ++ ++ clrbits16(&qe_port->uccp->uccm, UCC_UART_UCCE_TX); ++} ++ ++/* ++ * Transmit as many characters to the HW as possible. ++ * ++ * This function will attempt to stuff of all the characters from the ++ * kernel's transmit buffer into TX BDs. ++ * ++ * A return value of non-zero indicates that it sucessfully stuffed all ++ * characters from the kernel buffer. ++ * ++ * A return value of zero indicates that there are still characters in the ++ * kernel's buffer that have not been transmitted, but there are no more BDs ++ * available. This function should be called again after a BD has been made ++ * available. ++ */ ++static int qe_uart_tx_pump(struct uart_qe_port *qe_port) ++{ ++ struct qe_bd *bdp; ++ unsigned char *p; ++ unsigned int count; ++ struct uart_port *port = &qe_port->port; ++ struct circ_buf *xmit = &port->info->xmit; ++ ++ bdp = qe_port->rx_cur; ++ ++ /* Handle xon/xoff */ ++ if (port->x_char) { ++ /* Pick next descriptor and fill from buffer */ ++ bdp = qe_port->tx_cur; ++ ++ p = qe2cpu_addr(bdp->buf, qe_port); ++ ++ *p++ = port->x_char; ++ out_be16(&bdp->length, 1); ++ setbits16(&bdp->status, BD_SC_READY); ++ /* Get next BD. */ ++ if (in_be16(&bdp->status) & BD_SC_WRAP) ++ bdp = qe_port->tx_bd_base; ++ else ++ bdp++; ++ qe_port->tx_cur = bdp; ++ ++ port->icount.tx++; ++ port->x_char = 0; ++ return 1; ++ } ++ ++ if (uart_circ_empty(xmit) || uart_tx_stopped(port)) { ++ qe_uart_stop_tx(port); ++ return 0; ++ } ++ ++ /* Pick next descriptor and fill from buffer */ ++ bdp = qe_port->tx_cur; ++ ++ while (!(in_be16(&bdp->status) & BD_SC_READY) && ++ (xmit->tail != xmit->head)) { ++ count = 0; ++ p = qe2cpu_addr(bdp->buf, qe_port); ++ while (count < qe_port->tx_fifosize) { ++ *p++ = xmit->buf[xmit->tail]; ++ xmit->tail = (xmit->tail + 1) & (UART_XMIT_SIZE - 1); ++ port->icount.tx++; ++ count++; ++ if (xmit->head == xmit->tail) ++ break; ++ } ++ ++ out_be16(&bdp->length, count); ++ setbits16(&bdp->status, BD_SC_READY); ++ ++ /* Get next BD. */ ++ if (in_be16(&bdp->status) & BD_SC_WRAP) ++ bdp = qe_port->tx_bd_base; ++ else ++ bdp++; ++ } ++ qe_port->tx_cur = bdp; ++ ++ if (uart_circ_chars_pending(xmit) < WAKEUP_CHARS) ++ uart_write_wakeup(port); ++ ++ if (uart_circ_empty(xmit)) { ++ /* The kernel buffer is empty, so turn off TX interrupts. We ++ don't need to be told when the QE is finished transmitting ++ the data. */ ++ qe_uart_stop_tx(port); ++ return 0; ++ } ++ ++ return 1; ++} ++ ++/* ++ * Start transmitting data ++ * ++ * This function will start transmitting any available data, if the port ++ * isn't already transmitting data. ++ */ ++static void qe_uart_start_tx(struct uart_port *port) ++{ ++ struct uart_qe_port *qe_port = ++ container_of(port, struct uart_qe_port, port); ++ ++ /* If we currently are transmitting, then just return */ ++ if (in_be16(&qe_port->uccp->uccm) & UCC_UART_UCCE_TX) ++ return; ++ ++ /* Otherwise, pump the port and start transmission */ ++ if (qe_uart_tx_pump(qe_port)) ++ setbits16(&qe_port->uccp->uccm, UCC_UART_UCCE_TX); ++} ++ ++/* ++ * Stop transmitting data ++ */ ++static void qe_uart_stop_rx(struct uart_port *port) ++{ ++ struct uart_qe_port *qe_port = ++ container_of(port, struct uart_qe_port, port); ++ ++ clrbits16(&qe_port->uccp->uccm, UCC_UART_UCCE_RX); ++} ++ ++/* ++ * Enable status change interrupts ++ * ++ * We don't support status change interrupts, but we need to define this ++ * function otherwise the kernel will panic. ++ */ ++static void qe_uart_enable_ms(struct uart_port *port) ++{ ++} ++ ++/* Start or stop sending break signal ++ * ++ * This function controls the sending of a break signal. If break_state=1, ++ * then we start sending a break signal. If break_state=0, then we stop ++ * sending the break signal. ++ */ ++static void qe_uart_break_ctl(struct uart_port *port, int break_state) ++{ ++ struct uart_qe_port *qe_port = ++ container_of(port, struct uart_qe_port, port); ++ ++ if (break_state) ++ ucc_slow_stop_tx(qe_port->us_private); ++ else ++ ucc_slow_restart_tx(qe_port->us_private); ++} ++ ++/* ISR helper function for receiving character. ++ * ++ * This function is called by the ISR to handling receiving characters ++ */ ++static void qe_uart_int_rx(struct uart_qe_port *qe_port) ++{ ++ int i; ++ unsigned char ch, *cp; ++ struct uart_port *port = &qe_port->port; ++ struct tty_struct *tty = port->info->tty; ++ struct qe_bd *bdp; ++ u16 status; ++ unsigned int flg; ++ ++ /* Just loop through the closed BDs and copy the characters into ++ * the buffer. ++ */ ++ bdp = qe_port->rx_cur; ++ while (1) { ++ status = in_be16(&bdp->status); ++ ++ /* If this one is empty, then we assume we've read them all */ ++ if (status & BD_SC_EMPTY) ++ break; ++ ++ /* get number of characters, and check space in RX buffer */ ++ i = in_be16(&bdp->length); ++ ++ /* If we don't have enough room in RX buffer for the entire BD, ++ * then we try later, which will be the next RX interrupt. ++ */ ++ if (tty_buffer_request_room(tty, i) < i) { ++ dev_dbg(port->dev, "ucc-uart: no room in RX buffer\n"); ++ return; ++ } ++ ++ /* get pointer */ ++ cp = qe2cpu_addr(bdp->buf, qe_port); ++ ++ /* loop through the buffer */ ++ while (i-- > 0) { ++ ch = *cp++; ++ port->icount.rx++; ++ flg = TTY_NORMAL; ++ ++ if (!i && status & ++ (BD_SC_BR | BD_SC_FR | BD_SC_PR | BD_SC_OV)) ++ goto handle_error; ++ if (uart_handle_sysrq_char(port, ch)) ++ continue; ++ ++error_return: ++ tty_insert_flip_char(tty, ch, flg); ++ ++ } ++ ++ /* This BD is ready to be used again. Clear status. get next */ ++ clrsetbits_be16(&bdp->status, BD_SC_BR | BD_SC_FR | BD_SC_PR | ++ BD_SC_OV | BD_SC_ID, BD_SC_EMPTY); ++ if (in_be16(&bdp->status) & BD_SC_WRAP) ++ bdp = qe_port->rx_bd_base; ++ else ++ bdp++; ++ ++ } ++ ++ /* Write back buffer pointer */ ++ qe_port->rx_cur = bdp; ++ ++ /* Activate BH processing */ ++ tty_flip_buffer_push(tty); ++ ++ return; ++ ++ /* Error processing */ ++ ++handle_error: ++ /* Statistics */ ++ if (status & BD_SC_BR) ++ port->icount.brk++; ++ if (status & BD_SC_PR) ++ port->icount.parity++; ++ if (status & BD_SC_FR) ++ port->icount.frame++; ++ if (status & BD_SC_OV) ++ port->icount.overrun++; ++ ++ /* Mask out ignored conditions */ ++ status &= port->read_status_mask; ++ ++ /* Handle the remaining ones */ ++ if (status & BD_SC_BR) ++ flg = TTY_BREAK; ++ else if (status & BD_SC_PR) ++ flg = TTY_PARITY; ++ else if (status & BD_SC_FR) ++ flg = TTY_FRAME; ++ ++ /* Overrun does not affect the current character ! */ ++ if (status & BD_SC_OV) ++ tty_insert_flip_char(tty, 0, TTY_OVERRUN); ++#ifdef SUPPORT_SYSRQ ++ port->sysrq = 0; ++#endif ++ goto error_return; ++} ++ ++/* Interrupt handler ++ * ++ * This interrupt handler is called after a BD is processed. ++ */ ++static irqreturn_t qe_uart_int(int irq, void *data) ++{ ++ struct uart_qe_port *qe_port = (struct uart_qe_port *) data; ++ struct ucc_slow __iomem *uccp = qe_port->uccp; ++ u16 events; ++ ++ /* Clear the interrupts */ ++ events = in_be16(&uccp->ucce); ++ out_be16(&uccp->ucce, events); ++ ++ if (events & UCC_UART_UCCE_BRKE) ++ uart_handle_break(&qe_port->port); ++ ++ if (events & UCC_UART_UCCE_RX) ++ qe_uart_int_rx(qe_port); ++ ++ if (events & UCC_UART_UCCE_TX) ++ qe_uart_tx_pump(qe_port); ++ ++ return events ? IRQ_HANDLED : IRQ_NONE; ++} ++ ++/* Initialize buffer descriptors ++ * ++ * This function initializes all of the RX and TX buffer descriptors. ++ */ ++static void qe_uart_initbd(struct uart_qe_port *qe_port) ++{ ++ int i; ++ void *bd_virt; ++ struct qe_bd *bdp; ++ ++ /* Set the physical address of the host memory buffers in the buffer ++ * descriptors, and the virtual address for us to work with. ++ */ ++ bd_virt = qe_port->bd_virt; ++ bdp = qe_port->rx_bd_base; ++ qe_port->rx_cur = qe_port->rx_bd_base; ++ for (i = 0; i < (qe_port->rx_nrfifos - 1); i++) { ++ out_be16(&bdp->status, BD_SC_EMPTY | BD_SC_INTRPT); ++ out_be32(&bdp->buf, cpu2qe_addr(bd_virt, qe_port)); ++ out_be16(&bdp->length, 0); ++ bd_virt += qe_port->rx_fifosize; ++ bdp++; ++ } ++ ++ /* */ ++ out_be16(&bdp->status, BD_SC_WRAP | BD_SC_EMPTY | BD_SC_INTRPT); ++ out_be32(&bdp->buf, cpu2qe_addr(bd_virt, qe_port)); ++ out_be16(&bdp->length, 0); ++ ++ /* Set the physical address of the host memory ++ * buffers in the buffer descriptors, and the ++ * virtual address for us to work with. ++ */ ++ bd_virt = qe_port->bd_virt + ++ L1_CACHE_ALIGN(qe_port->rx_nrfifos * qe_port->rx_fifosize); ++ qe_port->tx_cur = qe_port->tx_bd_base; ++ bdp = qe_port->tx_bd_base; ++ for (i = 0; i < (qe_port->tx_nrfifos - 1); i++) { ++ out_be16(&bdp->status, BD_SC_INTRPT); ++ out_be32(&bdp->buf, cpu2qe_addr(bd_virt, qe_port)); ++ out_be16(&bdp->length, 0); ++ bd_virt += qe_port->tx_fifosize; ++ bdp++; ++ } ++ ++ /* Loopback requires the preamble bit to be set on the first TX BD */ ++#ifdef LOOPBACK ++ setbits16(&qe_port->tx_cur->status, BD_SC_P); ++#endif ++ ++ out_be16(&bdp->status, BD_SC_WRAP | BD_SC_INTRPT); ++ out_be32(&bdp->buf, cpu2qe_addr(bd_virt, qe_port)); ++ out_be16(&bdp->length, 0); ++} ++ ++/* ++ * Initialize a UCC for UART. ++ * ++ * This function configures a given UCC to be used as a UART device. Basic ++ * UCC initialization is handled in qe_uart_request_port(). This function ++ * does all the UART-specific stuff. ++ */ ++static void qe_uart_init_ucc(struct uart_qe_port *qe_port) ++{ ++ u32 cecr_subblock; ++ struct ucc_slow __iomem *uccp = qe_port->uccp; ++ struct ucc_uart_pram *uccup = qe_port->uccup; ++ ++ unsigned int i; ++ ++ /* First, disable TX and RX in the UCC */ ++ ucc_slow_disable(qe_port->us_private, COMM_DIR_RX_AND_TX); ++ ++ /* Program the UCC UART parameter RAM */ ++ out_8(&uccup->common.rbmr, UCC_BMR_GBL | UCC_BMR_BO_BE); ++ out_8(&uccup->common.tbmr, UCC_BMR_GBL | UCC_BMR_BO_BE); ++ out_be16(&uccup->common.mrblr, qe_port->rx_fifosize); ++ out_be16(&uccup->maxidl, 0x10); ++ out_be16(&uccup->brkcr, 1); ++ out_be16(&uccup->parec, 0); ++ out_be16(&uccup->frmec, 0); ++ out_be16(&uccup->nosec, 0); ++ out_be16(&uccup->brkec, 0); ++ out_be16(&uccup->uaddr[0], 0); ++ out_be16(&uccup->uaddr[1], 0); ++ out_be16(&uccup->toseq, 0); ++ for (i = 0; i < 8; i++) ++ out_be16(&uccup->cchars[i], 0xC000); ++ out_be16(&uccup->rccm, 0xc0ff); ++ ++ /* Configure the GUMR registers for UART */ ++ if (soft_uart) ++ /* Soft-UART requires a 1X multiplier for TX */ ++ clrsetbits_be32(&uccp->gumr_l, ++ UCC_SLOW_GUMR_L_MODE_MASK | UCC_SLOW_GUMR_L_TDCR_MASK | ++ UCC_SLOW_GUMR_L_RDCR_MASK, ++ UCC_SLOW_GUMR_L_MODE_UART | UCC_SLOW_GUMR_L_TDCR_1 | ++ UCC_SLOW_GUMR_L_RDCR_16); ++ else ++ clrsetbits_be32(&uccp->gumr_l, ++ UCC_SLOW_GUMR_L_MODE_MASK | UCC_SLOW_GUMR_L_TDCR_MASK | ++ UCC_SLOW_GUMR_L_RDCR_MASK, ++ UCC_SLOW_GUMR_L_MODE_UART | UCC_SLOW_GUMR_L_TDCR_16 | ++ UCC_SLOW_GUMR_L_RDCR_16); ++ ++ clrsetbits_be32(&uccp->gumr_h, UCC_SLOW_GUMR_H_RFW, ++ UCC_SLOW_GUMR_H_TRX | UCC_SLOW_GUMR_H_TTX); ++ ++#ifdef LOOPBACK ++ clrsetbits_be32(&uccp->gumr_l, UCC_SLOW_GUMR_L_DIAG_MASK, ++ UCC_SLOW_GUMR_L_DIAG_LOOP); ++ clrsetbits_be32(&uccp->gumr_h, ++ UCC_SLOW_GUMR_H_CTSP | UCC_SLOW_GUMR_H_RSYN, ++ UCC_SLOW_GUMR_H_CDS); ++#endif ++ ++ /* Enable rx interrupts and clear all pending events. */ ++ out_be16(&uccp->uccm, 0); ++ out_be16(&uccp->ucce, 0xffff); ++ out_be16(&uccp->udsr, 0x7e7e); ++ ++ /* Initialize UPSMR */ ++ out_be16(&uccp->upsmr, 0); ++ ++ if (soft_uart) { ++ out_be16(&uccup->supsmr, 0x30); ++ out_be16(&uccup->res92, 0); ++ out_be32(&uccup->rx_state, 0); ++ out_be32(&uccup->rx_cnt, 0); ++ out_8(&uccup->rx_bitmark, 0); ++ out_8(&uccup->rx_length, 10); ++ out_be32(&uccup->dump_ptr, 0x4000); ++ out_8(&uccup->rx_temp_dlst_qe, 0); ++ out_be32(&uccup->rx_frame_rem, 0); ++ out_8(&uccup->rx_frame_rem_size, 0); ++ /* Soft-UART requires TX to be 1X */ ++ out_8(&uccup->tx_mode, ++ UCC_UART_TX_STATE_UART | UCC_UART_TX_STATE_X1); ++ out_be16(&uccup->tx_state, 0); ++ out_8(&uccup->resD4, 0); ++ out_be16(&uccup->resD5, 0); ++ ++ /* Set UART mode. ++ * Enable receive and transmit. ++ */ ++ ++ /* From the microcode errata: ++ * 1.GUMR_L register, set mode=0010 (QMC). ++ * 2.Set GUMR_H[17] bit. (UART/AHDLC mode). ++ * 3.Set GUMR_H[19:20] (Transparent mode) ++ * 4.Clear GUMR_H[26] (RFW) ++ * ... ++ * 6.Receiver must use 16x over sampling ++ */ ++ clrsetbits_be32(&uccp->gumr_l, ++ UCC_SLOW_GUMR_L_MODE_MASK | UCC_SLOW_GUMR_L_TDCR_MASK | ++ UCC_SLOW_GUMR_L_RDCR_MASK, ++ UCC_SLOW_GUMR_L_MODE_QMC | UCC_SLOW_GUMR_L_TDCR_16 | ++ UCC_SLOW_GUMR_L_RDCR_16); ++ ++ clrsetbits_be32(&uccp->gumr_h, ++ UCC_SLOW_GUMR_H_RFW | UCC_SLOW_GUMR_H_RSYN, ++ UCC_SLOW_GUMR_H_SUART | UCC_SLOW_GUMR_H_TRX | ++ UCC_SLOW_GUMR_H_TTX | UCC_SLOW_GUMR_H_TFL); ++ ++#ifdef LOOPBACK ++ clrsetbits_be32(&uccp->gumr_l, UCC_SLOW_GUMR_L_DIAG_MASK, ++ UCC_SLOW_GUMR_L_DIAG_LOOP); ++ clrbits32(&uccp->gumr_h, UCC_SLOW_GUMR_H_CTSP | ++ UCC_SLOW_GUMR_H_CDS); ++#endif ++ ++ cecr_subblock = ucc_slow_get_qe_cr_subblock(qe_port->ucc_num); ++ qe_issue_cmd(QE_INIT_TX_RX, cecr_subblock, ++ QE_CR_PROTOCOL_UNSPECIFIED, 0); ++ } ++} ++ ++/* ++ * Initialize the port. ++ */ ++static int qe_uart_startup(struct uart_port *port) ++{ ++ struct uart_qe_port *qe_port = ++ container_of(port, struct uart_qe_port, port); ++ int ret; ++ ++ /* ++ * If we're using Soft-UART mode, then we need to make sure the ++ * firmware has been uploaded first. ++ */ ++ if (soft_uart && !firmware_loaded) { ++ dev_err(port->dev, "Soft-UART firmware not uploaded\n"); ++ return -ENODEV; ++ } ++ ++ qe_uart_initbd(qe_port); ++ qe_uart_init_ucc(qe_port); ++ ++ /* Install interrupt handler. */ ++ ret = request_irq(port->irq, qe_uart_int, IRQF_SHARED, "ucc-uart", ++ qe_port); ++ if (ret) { ++ dev_err(port->dev, "could not claim IRQ %u\n", port->irq); ++ return ret; ++ } ++ ++ /* Startup rx-int */ ++ setbits16(&qe_port->uccp->uccm, UCC_UART_UCCE_RX); ++ ucc_slow_enable(qe_port->us_private, COMM_DIR_RX_AND_TX); ++ ++ return 0; ++} ++ ++/* ++ * Shutdown the port. ++ */ ++static void qe_uart_shutdown(struct uart_port *port) ++{ ++ struct uart_qe_port *qe_port = ++ container_of(port, struct uart_qe_port, port); ++ struct ucc_slow __iomem *uccp = qe_port->uccp; ++ unsigned int timeout = 20; ++ ++ /* Disable RX and TX */ ++ ++ /* Wait for all the BDs marked sent */ ++ while (!qe_uart_tx_empty(port)) { ++ if (!--timeout) { ++ dev_warn(port->dev, "shutdown timeout\n"); ++ break; ++ } ++ set_current_state(TASK_UNINTERRUPTIBLE); ++ schedule_timeout(2); ++ } ++ ++ if (qe_port->wait_closing) { ++ /* Wait a bit longer */ ++ set_current_state(TASK_UNINTERRUPTIBLE); ++ schedule_timeout(qe_port->wait_closing); ++ } ++ ++ /* Stop uarts */ ++ ucc_slow_disable(qe_port->us_private, COMM_DIR_RX_AND_TX); ++ clrbits16(&uccp->uccm, UCC_UART_UCCE_TX | UCC_UART_UCCE_RX); ++ ++ /* Shut them really down and reinit buffer descriptors */ ++ ucc_slow_graceful_stop_tx(qe_port->us_private); ++ qe_uart_initbd(qe_port); ++ ++ free_irq(port->irq, qe_port); ++} ++ ++/* ++ * Set the serial port parameters. ++ */ ++static void qe_uart_set_termios(struct uart_port *port, ++ struct ktermios *termios, struct ktermios *old) ++{ ++ struct uart_qe_port *qe_port = ++ container_of(port, struct uart_qe_port, port); ++ struct ucc_slow __iomem *uccp = qe_port->uccp; ++ unsigned int baud; ++ unsigned long flags; ++ u16 upsmr = in_be16(&uccp->upsmr); ++ struct ucc_uart_pram __iomem *uccup = qe_port->uccup; ++ u16 supsmr = in_be16(&uccup->supsmr); ++ u8 char_length = 2; /* 1 + CL + PEN + 1 + SL */ ++ ++ /* Character length programmed into the mode register is the ++ * sum of: 1 start bit, number of data bits, 0 or 1 parity bit, ++ * 1 or 2 stop bits, minus 1. ++ * The value 'bits' counts this for us. ++ */ ++ ++ /* byte size */ ++ upsmr &= UCC_UART_UPSMR_CL_MASK; ++ supsmr &= UCC_UART_SUPSMR_CL_MASK; ++ ++ switch (termios->c_cflag & CSIZE) { ++ case CS5: ++ upsmr |= UCC_UART_UPSMR_CL_5; ++ supsmr |= UCC_UART_SUPSMR_CL_5; ++ char_length += 5; ++ break; ++ case CS6: ++ upsmr |= UCC_UART_UPSMR_CL_6; ++ supsmr |= UCC_UART_SUPSMR_CL_6; ++ char_length += 6; ++ break; ++ case CS7: ++ upsmr |= UCC_UART_UPSMR_CL_7; ++ supsmr |= UCC_UART_SUPSMR_CL_7; ++ char_length += 7; ++ break; ++ default: /* case CS8 */ ++ upsmr |= UCC_UART_UPSMR_CL_8; ++ supsmr |= UCC_UART_SUPSMR_CL_8; ++ char_length += 8; ++ break; ++ } ++ ++ /* If CSTOPB is set, we want two stop bits */ ++ if (termios->c_cflag & CSTOPB) { ++ upsmr |= UCC_UART_UPSMR_SL; ++ supsmr |= UCC_UART_SUPSMR_SL; ++ char_length++; /* + SL */ ++ } ++ ++ if (termios->c_cflag & PARENB) { ++ upsmr |= UCC_UART_UPSMR_PEN; ++ supsmr |= UCC_UART_SUPSMR_PEN; ++ char_length++; /* + PEN */ ++ ++ if (!(termios->c_cflag & PARODD)) { ++ upsmr &= ~(UCC_UART_UPSMR_RPM_MASK | ++ UCC_UART_UPSMR_TPM_MASK); ++ upsmr |= UCC_UART_UPSMR_RPM_EVEN | ++ UCC_UART_UPSMR_TPM_EVEN; ++ supsmr &= ~(UCC_UART_SUPSMR_RPM_MASK | ++ UCC_UART_SUPSMR_TPM_MASK); ++ supsmr |= UCC_UART_SUPSMR_RPM_EVEN | ++ UCC_UART_SUPSMR_TPM_EVEN; ++ } ++ } ++ ++ /* ++ * Set up parity check flag ++ */ ++ port->read_status_mask = BD_SC_EMPTY | BD_SC_OV; ++ if (termios->c_iflag & INPCK) ++ port->read_status_mask |= BD_SC_FR | BD_SC_PR; ++ if (termios->c_iflag & (BRKINT | PARMRK)) ++ port->read_status_mask |= BD_SC_BR; ++ ++ /* ++ * Characters to ignore ++ */ ++ port->ignore_status_mask = 0; ++ if (termios->c_iflag & IGNPAR) ++ port->ignore_status_mask |= BD_SC_PR | BD_SC_FR; ++ if (termios->c_iflag & IGNBRK) { ++ port->ignore_status_mask |= BD_SC_BR; ++ /* ++ * If we're ignore parity and break indicators, ignore ++ * overruns too. (For real raw support). ++ */ ++ if (termios->c_iflag & IGNPAR) ++ port->ignore_status_mask |= BD_SC_OV; ++ } ++ /* ++ * !!! ignore all characters if CREAD is not set ++ */ ++ if ((termios->c_cflag & CREAD) == 0) ++ port->read_status_mask &= ~BD_SC_EMPTY; ++ ++ baud = uart_get_baud_rate(port, termios, old, 0, 115200); ++ ++ /* Do we really need a spinlock here? */ ++ spin_lock_irqsave(&port->lock, flags); ++ ++ out_be16(&uccp->upsmr, upsmr); ++ if (soft_uart) { ++ out_be16(&uccup->supsmr, supsmr); ++ out_8(&uccup->rx_length, char_length); ++ ++ /* Soft-UART requires a 1X multiplier for TX */ ++ qe_setbrg(qe_port->us_info.rx_clock, baud, 16); ++ qe_setbrg(qe_port->us_info.tx_clock, baud, 1); ++ } else { ++ qe_setbrg(qe_port->us_info.rx_clock, baud, 16); ++ qe_setbrg(qe_port->us_info.tx_clock, baud, 16); ++ } ++ ++ spin_unlock_irqrestore(&port->lock, flags); ++} ++ ++/* ++ * Return a pointer to a string that describes what kind of port this is. ++ */ ++static const char *qe_uart_type(struct uart_port *port) ++{ ++ return "QE"; ++} ++ ++/* ++ * Allocate any memory and I/O resources required by the port. ++ */ ++static int qe_uart_request_port(struct uart_port *port) ++{ ++ int ret; ++ struct uart_qe_port *qe_port = ++ container_of(port, struct uart_qe_port, port); ++ struct ucc_slow_info *us_info = &qe_port->us_info; ++ struct ucc_slow_private *uccs; ++ unsigned int rx_size, tx_size; ++ void *bd_virt; ++ dma_addr_t bd_dma_addr = 0; ++ ++ ret = ucc_slow_init(us_info, &uccs); ++ if (ret) { ++ dev_err(port->dev, "could not initialize UCC%u\n", ++ qe_port->ucc_num); ++ return ret; ++ } ++ ++ qe_port->us_private = uccs; ++ qe_port->uccp = uccs->us_regs; ++ qe_port->uccup = (struct ucc_uart_pram *) uccs->us_pram; ++ qe_port->rx_bd_base = uccs->rx_bd; ++ qe_port->tx_bd_base = uccs->tx_bd; ++ ++ /* ++ * Allocate the transmit and receive data buffers. ++ */ ++ ++ rx_size = L1_CACHE_ALIGN(qe_port->rx_nrfifos * qe_port->rx_fifosize); ++ tx_size = L1_CACHE_ALIGN(qe_port->tx_nrfifos * qe_port->tx_fifosize); ++ ++ bd_virt = dma_alloc_coherent(NULL, rx_size + tx_size, &bd_dma_addr, ++ GFP_KERNEL); ++ if (!bd_virt) { ++ dev_err(port->dev, "could not allocate buffer descriptors\n"); ++ return -ENOMEM; ++ } ++ ++ qe_port->bd_virt = bd_virt; ++ qe_port->bd_dma_addr = bd_dma_addr; ++ qe_port->bd_size = rx_size + tx_size; ++ ++ qe_port->rx_buf = bd_virt; ++ qe_port->tx_buf = qe_port->rx_buf + rx_size; ++ ++ return 0; ++} ++ ++/* ++ * Configure the port. ++ * ++ * We say we're a CPM-type port because that's mostly true. Once the device ++ * is configured, this driver operates almost identically to the CPM serial ++ * driver. ++ */ ++static void qe_uart_config_port(struct uart_port *port, int flags) ++{ ++ if (flags & UART_CONFIG_TYPE) { ++ port->type = PORT_CPM; ++ qe_uart_request_port(port); ++ } ++} ++ ++/* ++ * Release any memory and I/O resources that were allocated in ++ * qe_uart_request_port(). ++ */ ++static void qe_uart_release_port(struct uart_port *port) ++{ ++ struct uart_qe_port *qe_port = ++ container_of(port, struct uart_qe_port, port); ++ struct ucc_slow_private *uccs = qe_port->us_private; ++ ++ dma_free_coherent(NULL, qe_port->bd_size, qe_port->bd_virt, ++ qe_port->bd_dma_addr); ++ ++ ucc_slow_free(uccs); ++} ++ ++/* ++ * Verify that the data in serial_struct is suitable for this device. ++ */ ++static int qe_uart_verify_port(struct uart_port *port, ++ struct serial_struct *ser) ++{ ++ if (ser->type != PORT_UNKNOWN && ser->type != PORT_CPM) ++ return -EINVAL; ++ ++ if (ser->irq < 0 || ser->irq >= NR_IRQS) ++ return -EINVAL; ++ ++ if (ser->baud_base < 9600) ++ return -EINVAL; ++ ++ return 0; ++} ++/* UART operations ++ * ++ * Details on these functions can be found in Documentation/serial/driver ++ */ ++static struct uart_ops qe_uart_pops = { ++ .tx_empty = qe_uart_tx_empty, ++ .set_mctrl = qe_uart_set_mctrl, ++ .get_mctrl = qe_uart_get_mctrl, ++ .stop_tx = qe_uart_stop_tx, ++ .start_tx = qe_uart_start_tx, ++ .stop_rx = qe_uart_stop_rx, ++ .enable_ms = qe_uart_enable_ms, ++ .break_ctl = qe_uart_break_ctl, ++ .startup = qe_uart_startup, ++ .shutdown = qe_uart_shutdown, ++ .set_termios = qe_uart_set_termios, ++ .type = qe_uart_type, ++ .release_port = qe_uart_release_port, ++ .request_port = qe_uart_request_port, ++ .config_port = qe_uart_config_port, ++ .verify_port = qe_uart_verify_port, ++}; ++ ++/* ++ * Obtain the SOC model number and revision level ++ * ++ * This function parses the device tree to obtain the SOC model. It then ++ * reads the SVR register to the revision. ++ * ++ * The device tree stores the SOC model two different ways. ++ * ++ * The new way is: ++ * ++ * cpu@0 { ++ * compatible = "PowerPC,8323"; ++ * device_type = "cpu"; ++ * ... ++ * ++ * ++ * The old way is: ++ * PowerPC,8323@0 { ++ * device_type = "cpu"; ++ * ... ++ * ++ * This code first checks the new way, and then the old way. ++ */ ++static unsigned int soc_info(unsigned int *rev_h, unsigned int *rev_l) ++{ ++ struct device_node *np; ++ const char *soc_string; ++ unsigned int svr; ++ unsigned int soc; ++ ++ /* Find the CPU node */ ++ np = of_find_node_by_type(NULL, "cpu"); ++ if (!np) ++ return 0; ++ /* Find the compatible property */ ++ soc_string = of_get_property(np, "compatible", NULL); ++ if (!soc_string) ++ /* No compatible property, so try the name. */ ++ soc_string = np->name; ++ ++ /* Extract the SOC number from the "PowerPC," string */ ++ if ((sscanf(soc_string, "PowerPC,%u", &soc) != 1) || !soc) ++ return 0; ++ ++ /* Get the revision from the SVR */ ++ svr = mfspr(SPRN_SVR); ++ *rev_h = (svr >> 4) & 0xf; ++ *rev_l = svr & 0xf; ++ ++ return soc; ++} ++ ++/* ++ * requst_firmware_nowait() callback function ++ * ++ * This function is called by the kernel when a firmware is made available, ++ * or if it times out waiting for the firmware. ++ */ ++static void uart_firmware_cont(const struct firmware *fw, void *context) ++{ ++ struct qe_firmware *firmware; ++ struct device *dev = context; ++ int ret; ++ ++ if (!fw) { ++ dev_err(dev, "firmware not found\n"); ++ return; ++ } ++ ++ firmware = (struct qe_firmware *) fw->data; ++ ++ if (firmware->header.length != fw->size) { ++ dev_err(dev, "invalid firmware\n"); ++ return; ++ } ++ ++ ret = qe_upload_firmware(firmware); ++ if (ret) { ++ dev_err(dev, "could not load firmware\n"); ++ return; ++ } ++ ++ firmware_loaded = 1; ++} ++ ++static int ucc_uart_probe(struct of_device *ofdev, ++ const struct of_device_id *match) ++{ ++ struct device_node *np = ofdev->node; ++ const unsigned int *iprop; /* Integer OF properties */ ++ const char *sprop; /* String OF properties */ ++ struct uart_qe_port *qe_port = NULL; ++ struct resource res; ++ int ret; ++ ++ /* ++ * Determine if we need Soft-UART mode ++ */ ++ if (of_find_property(np, "soft-uart", NULL)) { ++ dev_dbg(&ofdev->dev, "using Soft-UART mode\n"); ++ soft_uart = 1; ++ } ++ ++ /* ++ * If we are using Soft-UART, determine if we need to upload the ++ * firmware, too. ++ */ ++ if (soft_uart) { ++ struct qe_firmware_info *qe_fw_info; ++ ++ qe_fw_info = qe_get_firmware_info(); ++ ++ /* Check if the firmware has been uploaded. */ ++ if (qe_fw_info && strstr(qe_fw_info->id, "Soft-UART")) { ++ firmware_loaded = 1; ++ } else { ++ char filename[32]; ++ unsigned int soc; ++ unsigned int rev_h; ++ unsigned int rev_l; ++ ++ soc = soc_info(&rev_h, &rev_l); ++ if (!soc) { ++ dev_err(&ofdev->dev, "unknown CPU model\n"); ++ return -ENXIO; ++ } ++ sprintf(filename, "fsl_qe_ucode_uart_%u_%u%u.bin", ++ soc, rev_h, rev_l); ++ ++ dev_info(&ofdev->dev, "waiting for firmware %s\n", ++ filename); ++ ++ /* ++ * We call request_firmware_nowait instead of ++ * request_firmware so that the driver can load and ++ * initialize the ports without holding up the rest of ++ * the kernel. If hotplug support is enabled in the ++ * kernel, then we use it. ++ */ ++ ret = request_firmware_nowait(THIS_MODULE, ++ FW_ACTION_HOTPLUG, filename, &ofdev->dev, ++ &ofdev->dev, uart_firmware_cont); ++ if (ret) { ++ dev_err(&ofdev->dev, ++ "could not load firmware %s\n", ++ filename); ++ return ret; ++ } ++ } ++ } ++ ++ qe_port = kzalloc(sizeof(struct uart_qe_port), GFP_KERNEL); ++ if (!qe_port) { ++ dev_err(&ofdev->dev, "can't allocate QE port structure\n"); ++ return -ENOMEM; ++ } ++ ++ /* Search for IRQ and mapbase */ ++ ret = of_address_to_resource(np, 0, &res); ++ if (ret) { ++ dev_err(&ofdev->dev, "missing 'reg' property in device tree\n"); ++ kfree(qe_port); ++ return ret; ++ } ++ if (!res.start) { ++ dev_err(&ofdev->dev, "invalid 'reg' property in device tree\n"); ++ kfree(qe_port); ++ return -EINVAL; ++ } ++ qe_port->port.mapbase = res.start; ++ ++ /* Get the UCC number (device ID) */ ++ /* UCCs are numbered 1-7 */ ++ iprop = of_get_property(np, "device-id", NULL); ++ if (!iprop || (*iprop < 1) || (*iprop > UCC_MAX_NUM)) { ++ dev_err(&ofdev->dev, ++ "missing or invalid UCC specified in device tree\n"); ++ kfree(qe_port); ++ return -ENODEV; ++ } ++ qe_port->ucc_num = *iprop - 1; ++ ++ /* ++ * In the future, we should not require the BRG to be specified in the ++ * device tree. If no clock-source is specified, then just pick a BRG ++ * to use. This requires a new QE library function that manages BRG ++ * assignments. ++ */ ++ ++ sprop = of_get_property(np, "rx-clock-name", NULL); ++ if (!sprop) { ++ dev_err(&ofdev->dev, "missing rx-clock-name in device tree\n"); ++ kfree(qe_port); ++ return -ENODEV; ++ } ++ ++ qe_port->us_info.rx_clock = qe_clock_source(sprop); ++ if ((qe_port->us_info.rx_clock < QE_BRG1) || ++ (qe_port->us_info.rx_clock > QE_BRG16)) { ++ dev_err(&ofdev->dev, "rx-clock-name must be a BRG for UART\n"); ++ kfree(qe_port); ++ return -ENODEV; ++ } ++ ++#ifdef LOOPBACK ++ /* In internal loopback mode, TX and RX must use the same clock */ ++ qe_port->us_info.tx_clock = qe_port->us_info.rx_clock; ++#else ++ sprop = of_get_property(np, "tx-clock-name", NULL); ++ if (!sprop) { ++ dev_err(&ofdev->dev, "missing tx-clock-name in device tree\n"); ++ kfree(qe_port); ++ return -ENODEV; ++ } ++ qe_port->us_info.tx_clock = qe_clock_source(sprop); ++#endif ++ if ((qe_port->us_info.tx_clock < QE_BRG1) || ++ (qe_port->us_info.tx_clock > QE_BRG16)) { ++ dev_err(&ofdev->dev, "tx-clock-name must be a BRG for UART\n"); ++ kfree(qe_port); ++ return -ENODEV; ++ } ++ ++ /* Get the port number, numbered 0-3 */ ++ iprop = of_get_property(np, "port-number", NULL); ++ if (!iprop) { ++ dev_err(&ofdev->dev, "missing port-number in device tree\n"); ++ kfree(qe_port); ++ return -EINVAL; ++ } ++ qe_port->port.line = *iprop; ++ if (qe_port->port.line >= UCC_MAX_UART) { ++ dev_err(&ofdev->dev, "port-number must be 0-%u\n", ++ UCC_MAX_UART - 1); ++ kfree(qe_port); ++ return -EINVAL; ++ } ++ ++ qe_port->port.irq = irq_of_parse_and_map(np, 0); ++ if (qe_port->port.irq == NO_IRQ) { ++ dev_err(&ofdev->dev, "could not map IRQ for UCC%u\n", ++ qe_port->ucc_num + 1); ++ kfree(qe_port); ++ return -EINVAL; ++ } ++ ++ /* ++ * Newer device trees have an "fsl,qe" compatible property for the QE ++ * node, but we still need to support older device trees. ++ */ ++ np = of_find_compatible_node(NULL, NULL, "fsl,qe"); ++ if (!np) { ++ np = of_find_node_by_type(NULL, "qe"); ++ if (!np) { ++ dev_err(&ofdev->dev, "could not find 'qe' node\n"); ++ kfree(qe_port); ++ return -EINVAL; ++ } ++ } ++ ++ iprop = of_get_property(np, "brg-frequency", NULL); ++ if (!iprop) { ++ dev_err(&ofdev->dev, ++ "missing brg-frequency in device tree\n"); ++ kfree(qe_port); ++ return -EINVAL; ++ } ++ ++ if (*iprop) ++ qe_port->port.uartclk = *iprop; ++ else { ++ /* ++ * Older versions of U-Boot do not initialize the brg-frequency ++ * property, so in this case we assume the BRG frequency is ++ * half the QE bus frequency. ++ */ ++ iprop = of_get_property(np, "bus-frequency", NULL); ++ if (!iprop) { ++ dev_err(&ofdev->dev, ++ "missing QE bus-frequency in device tree\n"); ++ kfree(qe_port); ++ return -EINVAL; ++ } ++ if (*iprop) ++ qe_port->port.uartclk = *iprop / 2; ++ else { ++ dev_err(&ofdev->dev, ++ "invalid QE bus-frequency in device tree\n"); ++ kfree(qe_port); ++ return -EINVAL; ++ } ++ } ++ ++ spin_lock_init(&qe_port->port.lock); ++ qe_port->np = np; ++ qe_port->port.dev = &ofdev->dev; ++ qe_port->port.ops = &qe_uart_pops; ++ qe_port->port.iotype = UPIO_MEM; ++ ++ qe_port->tx_nrfifos = TX_NUM_FIFO; ++ qe_port->tx_fifosize = TX_BUF_SIZE; ++ qe_port->rx_nrfifos = RX_NUM_FIFO; ++ qe_port->rx_fifosize = RX_BUF_SIZE; ++ ++ qe_port->wait_closing = UCC_WAIT_CLOSING; ++ qe_port->port.fifosize = 512; ++ qe_port->port.flags = UPF_BOOT_AUTOCONF | UPF_IOREMAP; ++ ++ qe_port->us_info.ucc_num = qe_port->ucc_num; ++ qe_port->us_info.regs = (phys_addr_t) res.start; ++ qe_port->us_info.irq = qe_port->port.irq; ++ ++ qe_port->us_info.rx_bd_ring_len = qe_port->rx_nrfifos; ++ qe_port->us_info.tx_bd_ring_len = qe_port->tx_nrfifos; ++ ++ /* Make sure ucc_slow_init() initializes both TX and RX */ ++ qe_port->us_info.init_tx = 1; ++ qe_port->us_info.init_rx = 1; ++ ++ /* Add the port to the uart sub-system. This will cause ++ * qe_uart_config_port() to be called, so the us_info structure must ++ * be initialized. ++ */ ++ ret = uart_add_one_port(&ucc_uart_driver, &qe_port->port); ++ if (ret) { ++ dev_err(&ofdev->dev, "could not add /dev/ttyQE%u\n", ++ qe_port->port.line); ++ kfree(qe_port); ++ return ret; ++ } ++ ++ dev_set_drvdata(&ofdev->dev, qe_port); ++ ++ dev_info(&ofdev->dev, "UCC%u assigned to /dev/ttyQE%u\n", ++ qe_port->ucc_num + 1, qe_port->port.line); ++ ++ /* Display the mknod command for this device */ ++ dev_dbg(&ofdev->dev, "mknod command is 'mknod /dev/ttyQE%u c %u %u'\n", ++ qe_port->port.line, SERIAL_QE_MAJOR, ++ SERIAL_QE_MINOR + qe_port->port.line); ++ ++ return 0; ++} ++ ++static int ucc_uart_remove(struct of_device *ofdev) ++{ ++ struct uart_qe_port *qe_port = dev_get_drvdata(&ofdev->dev); ++ ++ dev_info(&ofdev->dev, "removing /dev/ttyQE%u\n", qe_port->port.line); ++ ++ uart_remove_one_port(&ucc_uart_driver, &qe_port->port); ++ ++ dev_set_drvdata(&ofdev->dev, NULL); ++ kfree(qe_port); ++ ++ return 0; ++} ++ ++static struct of_device_id ucc_uart_match[] = { ++ { ++ .type = "serial", ++ .compatible = "ucc_uart", ++ }, ++ {}, ++}; ++MODULE_DEVICE_TABLE(of, ucc_uart_match); ++ ++static struct of_platform_driver ucc_uart_of_driver = { ++ .owner = THIS_MODULE, ++ .name = "ucc_uart", ++ .match_table = ucc_uart_match, ++ .probe = ucc_uart_probe, ++ .remove = ucc_uart_remove, ++}; ++ ++static int __init ucc_uart_init(void) ++{ ++ int ret; ++ ++ printk(KERN_INFO "Freescale QUICC Engine UART device driver\n"); ++#ifdef LOOPBACK ++ printk(KERN_INFO "ucc-uart: Using loopback mode\n"); ++#endif ++ ++ ret = uart_register_driver(&ucc_uart_driver); ++ if (ret) { ++ printk(KERN_ERR "ucc-uart: could not register UART driver\n"); ++ return ret; ++ } ++ ++ ret = of_register_platform_driver(&ucc_uart_of_driver); ++ if (ret) ++ printk(KERN_ERR ++ "ucc-uart: could not register platform driver\n"); ++ ++ return ret; ++} ++ ++static void __exit ucc_uart_exit(void) ++{ ++ printk(KERN_INFO ++ "Freescale QUICC Engine UART device driver unloading\n"); ++ ++ of_unregister_platform_driver(&ucc_uart_of_driver); ++ uart_unregister_driver(&ucc_uart_driver); ++} ++ ++module_init(ucc_uart_init); ++module_exit(ucc_uart_exit); ++ ++MODULE_DESCRIPTION("Freescale QUICC Engine (QE) UART"); ++MODULE_AUTHOR("Timur Tabi <timur@freescale.com>"); ++MODULE_LICENSE("GPL v2"); ++MODULE_ALIAS_CHARDEV_MAJOR(SERIAL_QE_MAJOR); ++ +diff -x .git -x .gitignore -Nur linux-2.6.24/drivers/spi/mpc52xx_psc_spi.c powerpc.git/drivers/spi/mpc52xx_psc_spi.c +--- linux-2.6.24/drivers/spi/mpc52xx_psc_spi.c 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/drivers/spi/mpc52xx_psc_spi.c 2008-01-28 20:26:20.000000000 +0100 +@@ -330,6 +330,7 @@ + + static int mpc52xx_psc_spi_port_config(int psc_id, struct mpc52xx_psc_spi *mps) + { ++ struct device_node *np; + struct mpc52xx_cdm __iomem *cdm; + struct mpc52xx_gpio __iomem *gpio; + struct mpc52xx_psc __iomem *psc = mps->psc; +@@ -338,8 +339,12 @@ + int ret = 0; + + #if defined(CONFIG_PPC_MERGE) +- cdm = mpc52xx_find_and_map("mpc5200-cdm"); +- gpio = mpc52xx_find_and_map("mpc5200-gpio"); ++ np = of_find_compatible_node(NULL, NULL, "mpc5200-cdm"); ++ cdm = of_iomap(np, 0); ++ of_node_put(np); ++ np = of_find_compatible_node(NULL, NULL, "mpc5200-gpio"); ++ gpio = of_iomap(np, 0); ++ of_node_put(np); + #else + cdm = ioremap(MPC52xx_PA(MPC52xx_CDM_OFFSET), MPC52xx_CDM_SIZE); + gpio = ioremap(MPC52xx_PA(MPC52xx_GPIO_OFFSET), MPC52xx_GPIO_SIZE); +diff -x .git -x .gitignore -Nur linux-2.6.24/fs/openpromfs/inode.c powerpc.git/fs/openpromfs/inode.c +--- linux-2.6.24/fs/openpromfs/inode.c 2008-01-28 20:50:11.000000000 +0100 ++++ powerpc.git/fs/openpromfs/inode.c 2008-01-28 20:26:31.000000000 +0100 +@@ -131,7 +131,7 @@ + /* Nothing to do */ + } + +-static const struct seq_operations property_op = { ++static struct seq_operations property_op = { + .start = property_start, + .next = property_next, + .stop = property_stop, +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/8xx_immap.h powerpc.git/include/asm-powerpc/8xx_immap.h +--- linux-2.6.24/include/asm-powerpc/8xx_immap.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/8xx_immap.h 2008-01-28 20:26:42.000000000 +0100 +@@ -123,7 +123,7 @@ + #define OR_G5LA 0x00000400 /* Output #GPL5 on #GPL_A5 */ + #define OR_G5LS 0x00000200 /* Drive #GPL high on falling edge of...*/ + #define OR_BI 0x00000100 /* Burst inhibit */ +-#define OR_SCY_MSK 0x000000f0 /* Cycle Lenght in Clocks */ ++#define OR_SCY_MSK 0x000000f0 /* Cycle Length in Clocks */ + #define OR_SCY_0_CLK 0x00000000 /* 0 clock cycles wait states */ + #define OR_SCY_1_CLK 0x00000010 /* 1 clock cycles wait states */ + #define OR_SCY_2_CLK 0x00000020 /* 2 clock cycles wait states */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/commproc.h powerpc.git/include/asm-powerpc/commproc.h +--- linux-2.6.24/include/asm-powerpc/commproc.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/commproc.h 2008-01-28 20:26:42.000000000 +0100 +@@ -693,7 +693,7 @@ + #define CICR_SCC_SCC3 ((uint)0x00200000) /* SCC3 @ SCCc */ + #define CICR_SCB_SCC2 ((uint)0x00040000) /* SCC2 @ SCCb */ + #define CICR_SCA_SCC1 ((uint)0x00000000) /* SCC1 @ SCCa */ +-#define CICR_IRL_MASK ((uint)0x0000e000) /* Core interrrupt */ ++#define CICR_IRL_MASK ((uint)0x0000e000) /* Core interrupt */ + #define CICR_HP_MASK ((uint)0x00001f00) /* Hi-pri int. */ + #define CICR_IEN ((uint)0x00000080) /* Int. enable */ + #define CICR_SPS ((uint)0x00000001) /* SCC Spread */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/cpm.h powerpc.git/include/asm-powerpc/cpm.h +--- linux-2.6.24/include/asm-powerpc/cpm.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/cpm.h 2008-01-28 20:26:42.000000000 +0100 +@@ -10,5 +10,6 @@ + unsigned long cpm_muram_alloc_fixed(unsigned long offset, unsigned long size); + void __iomem *cpm_muram_addr(unsigned long offset); + dma_addr_t cpm_muram_dma(void __iomem *addr); ++int cpm_command(u32 command, u8 opcode); + + #endif +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/cputable.h powerpc.git/include/asm-powerpc/cputable.h +--- linux-2.6.24/include/asm-powerpc/cputable.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/cputable.h 2008-01-28 20:26:42.000000000 +0100 +@@ -57,6 +57,14 @@ + PPC_PMC_PA6T = 2, + }; + ++struct pt_regs; ++ ++extern int machine_check_generic(struct pt_regs *regs); ++extern int machine_check_4xx(struct pt_regs *regs); ++extern int machine_check_440A(struct pt_regs *regs); ++extern int machine_check_e500(struct pt_regs *regs); ++extern int machine_check_e200(struct pt_regs *regs); ++ + /* NOTE WELL: Update identify_cpu() if fields are added or removed! */ + struct cpu_spec { + /* CPU is matched via (PVR & pvr_mask) == pvr_value */ +@@ -97,6 +105,11 @@ + + /* Name of processor class, for the ELF AT_PLATFORM entry */ + char *platform; ++ ++ /* Processor specific machine check handling. Return negative ++ * if the error is fatal, 1 if it was fully recovered and 0 to ++ * pass up (not CPU originated) */ ++ int (*machine_check)(struct pt_regs *regs); + }; + + extern struct cpu_spec *cur_cpu_spec; +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/cputhreads.h powerpc.git/include/asm-powerpc/cputhreads.h +--- linux-2.6.24/include/asm-powerpc/cputhreads.h 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/cputhreads.h 2008-01-28 20:26:42.000000000 +0100 +@@ -0,0 +1,71 @@ ++#ifndef _ASM_POWERPC_CPUTHREADS_H ++#define _ASM_POWERPC_CPUTHREADS_H ++ ++#include <linux/cpumask.h> ++ ++/* ++ * Mapping of threads to cores ++ */ ++ ++#ifdef CONFIG_SMP ++extern int threads_per_core; ++extern int threads_shift; ++extern cpumask_t threads_core_mask; ++#else ++#define threads_per_core 1 ++#define threads_shift 0 ++#define threads_core_mask (CPU_MASK_CPU0) ++#endif ++ ++/* cpu_thread_mask_to_cores - Return a cpumask of one per cores ++ * hit by the argument ++ * ++ * @threads: a cpumask of threads ++ * ++ * This function returns a cpumask which will have one "cpu" (or thread) ++ * bit set for each core that has at least one thread set in the argument. ++ * ++ * This can typically be used for things like IPI for tlb invalidations ++ * since those need to be done only once per core/TLB ++ */ ++static inline cpumask_t cpu_thread_mask_to_cores(cpumask_t threads) ++{ ++ cpumask_t tmp, res; ++ int i; ++ ++ res = CPU_MASK_NONE; ++ for (i = 0; i < NR_CPUS; i += threads_per_core) { ++ cpus_shift_right(tmp, threads_core_mask, i); ++ if (cpus_intersects(threads, tmp)) ++ cpu_set(i, res); ++ } ++ return res; ++} ++ ++static inline int cpu_nr_cores(void) ++{ ++ return NR_CPUS >> threads_shift; ++} ++ ++static inline cpumask_t cpu_online_cores_map(void) ++{ ++ return cpu_thread_mask_to_cores(cpu_online_map); ++} ++ ++static inline int cpu_thread_to_core(int cpu) ++{ ++ return cpu >> threads_shift; ++} ++ ++static inline int cpu_thread_in_core(int cpu) ++{ ++ return cpu & (threads_per_core - 1); ++} ++ ++static inline int cpu_first_thread_in_core(int cpu) ++{ ++ return cpu & ~(threads_per_core - 1); ++} ++ ++#endif /* _ASM_POWERPC_CPUTHREADS_H */ ++ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/dcr-native.h powerpc.git/include/asm-powerpc/dcr-native.h +--- linux-2.6.24/include/asm-powerpc/dcr-native.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/dcr-native.h 2008-01-28 20:26:42.000000000 +0100 +@@ -22,6 +22,8 @@ + #ifdef __KERNEL__ + #ifndef __ASSEMBLY__ + ++#include <linux/spinlock.h> ++ + typedef struct { + unsigned int base; + } dcr_host_t; +@@ -55,20 +57,28 @@ + } while (0) + + /* R/W of indirect DCRs make use of standard naming conventions for DCRs */ +-#define mfdcri(base, reg) \ +-({ \ +- mtdcr(base ## _CFGADDR, base ## _ ## reg); \ +- mfdcr(base ## _CFGDATA); \ ++extern spinlock_t dcr_ind_lock; ++ ++#define mfdcri(base, reg) \ ++({ \ ++ unsigned long flags; \ ++ unsigned int val; \ ++ spin_lock_irqsave(&dcr_ind_lock, flags); \ ++ mtdcr(DCRN_ ## base ## _CONFIG_ADDR, reg); \ ++ val = mfdcr(DCRN_ ## base ## _CONFIG_DATA); \ ++ spin_unlock_irqrestore(&dcr_ind_lock, flags); \ ++ val; \ + }) + +-#define mtdcri(base, reg, data) \ +-do { \ +- mtdcr(base ## _CFGADDR, base ## _ ## reg); \ +- mtdcr(base ## _CFGDATA, data); \ ++#define mtdcri(base, reg, data) \ ++do { \ ++ unsigned long flags; \ ++ spin_lock_irqsave(&dcr_ind_lock, flags); \ ++ mtdcr(DCRN_ ## base ## _CONFIG_ADDR, reg); \ ++ mtdcr(DCRN_ ## base ## _CONFIG_DATA, data); \ ++ spin_unlock_irqrestore(&dcr_ind_lock, flags); \ + } while (0) + + #endif /* __ASSEMBLY__ */ + #endif /* __KERNEL__ */ + #endif /* _ASM_POWERPC_DCR_NATIVE_H */ +- +- +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/dcr-regs.h powerpc.git/include/asm-powerpc/dcr-regs.h +--- linux-2.6.24/include/asm-powerpc/dcr-regs.h 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/dcr-regs.h 2008-01-28 20:26:42.000000000 +0100 +@@ -0,0 +1,71 @@ ++/* ++ * Common DCR / SDR / CPR register definitions used on various IBM/AMCC ++ * 4xx processors ++ * ++ * Copyright 2007 Benjamin Herrenschmidt, IBM Corp ++ * <benh@kernel.crashing.org> ++ * ++ * Mostly lifted from asm-ppc/ibm4xx.h by ++ * ++ * Copyright (c) 1999 Grant Erickson <grant@lcse.umn.edu> ++ * ++ */ ++ ++#ifndef __DCR_REGS_H__ ++#define __DCR_REGS_H__ ++ ++/* ++ * Most DCRs used for controlling devices such as the MAL, DMA engine, ++ * etc... are obtained for the device tree. ++ * ++ * The definitions in this files are fixed DCRs and indirect DCRs that ++ * are commonly used outside of specific drivers or refer to core ++ * common registers that may occasionally have to be tweaked outside ++ * of the driver main register set ++ */ ++ ++/* CPRs (440GX and 440SP/440SPe) */ ++#define DCRN_CPR0_CONFIG_ADDR 0xc ++#define DCRN_CPR0_CONFIG_DATA 0xd ++ ++/* SDRs (440GX and 440SP/440SPe) */ ++#define DCRN_SDR0_CONFIG_ADDR 0xe ++#define DCRN_SDR0_CONFIG_DATA 0xf ++ ++#define SDR0_PFC0 0x4100 ++#define SDR0_PFC1 0x4101 ++#define SDR0_PFC1_EPS 0x1c00000 ++#define SDR0_PFC1_EPS_SHIFT 22 ++#define SDR0_PFC1_RMII 0x02000000 ++#define SDR0_MFR 0x4300 ++#define SDR0_MFR_TAH0 0x80000000 /* TAHOE0 Enable */ ++#define SDR0_MFR_TAH1 0x40000000 /* TAHOE1 Enable */ ++#define SDR0_MFR_PCM 0x10000000 /* PPC440GP irq compat mode */ ++#define SDR0_MFR_ECS 0x08000000 /* EMAC int clk */ ++#define SDR0_MFR_T0TXFL 0x00080000 ++#define SDR0_MFR_T0TXFH 0x00040000 ++#define SDR0_MFR_T1TXFL 0x00020000 ++#define SDR0_MFR_T1TXFH 0x00010000 ++#define SDR0_MFR_E0TXFL 0x00008000 ++#define SDR0_MFR_E0TXFH 0x00004000 ++#define SDR0_MFR_E0RXFL 0x00002000 ++#define SDR0_MFR_E0RXFH 0x00001000 ++#define SDR0_MFR_E1TXFL 0x00000800 ++#define SDR0_MFR_E1TXFH 0x00000400 ++#define SDR0_MFR_E1RXFL 0x00000200 ++#define SDR0_MFR_E1RXFH 0x00000100 ++#define SDR0_MFR_E2TXFL 0x00000080 ++#define SDR0_MFR_E2TXFH 0x00000040 ++#define SDR0_MFR_E2RXFL 0x00000020 ++#define SDR0_MFR_E2RXFH 0x00000010 ++#define SDR0_MFR_E3TXFL 0x00000008 ++#define SDR0_MFR_E3TXFH 0x00000004 ++#define SDR0_MFR_E3RXFL 0x00000002 ++#define SDR0_MFR_E3RXFH 0x00000001 ++#define SDR0_UART0 0x0120 ++#define SDR0_UART1 0x0121 ++#define SDR0_UART2 0x0122 ++#define SDR0_UART3 0x0123 ++#define SDR0_CUST0 0x4000 ++ ++#endif /* __DCR_REGS_H__ */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/dma-mapping.h powerpc.git/include/asm-powerpc/dma-mapping.h +--- linux-2.6.24/include/asm-powerpc/dma-mapping.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/dma-mapping.h 2008-01-28 20:26:42.000000000 +0100 +@@ -87,6 +87,9 @@ + return dma_ops->dma_supported(dev, mask); + } + ++/* We have our own implementation of pci_set_dma_mask() */ ++#define HAVE_ARCH_PCI_SET_DMA_MASK ++ + static inline int dma_set_mask(struct device *dev, u64 dma_mask) + { + struct dma_mapping_ops *dma_ops = get_dma_ops(dev); +@@ -186,8 +189,6 @@ + extern struct dma_mapping_ops dma_iommu_ops; + extern struct dma_mapping_ops dma_direct_ops; + +-extern unsigned long dma_direct_offset; +- + #else /* CONFIG_PPC64 */ + + #define dma_supported(dev, mask) (1) +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/firmware.h powerpc.git/include/asm-powerpc/firmware.h +--- linux-2.6.24/include/asm-powerpc/firmware.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/firmware.h 2008-01-28 20:26:42.000000000 +0100 +@@ -64,7 +64,7 @@ + FW_FEATURE_PS3_POSSIBLE = FW_FEATURE_LPAR | FW_FEATURE_PS3_LV1, + FW_FEATURE_PS3_ALWAYS = FW_FEATURE_LPAR | FW_FEATURE_PS3_LV1, + FW_FEATURE_CELLEB_POSSIBLE = FW_FEATURE_LPAR | FW_FEATURE_BEAT, +- FW_FEATURE_CELLEB_ALWAYS = FW_FEATURE_LPAR | FW_FEATURE_BEAT, ++ FW_FEATURE_CELLEB_ALWAYS = 0, + FW_FEATURE_NATIVE_POSSIBLE = 0, + FW_FEATURE_NATIVE_ALWAYS = 0, + FW_FEATURE_POSSIBLE = +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/immap_86xx.h powerpc.git/include/asm-powerpc/immap_86xx.h +--- linux-2.6.24/include/asm-powerpc/immap_86xx.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/immap_86xx.h 2008-01-28 20:26:42.000000000 +0100 +@@ -89,14 +89,14 @@ + * them. + * + * guts: Pointer to GUTS structure +- * co: The DMA controller (1 or 2) ++ * co: The DMA controller (0 or 1) + * ch: The channel on the DMA controller (0, 1, 2, or 3) + * device: The device to set as the source (CCSR_GUTS_DMACR_DEV_xx) + */ + static inline void guts_set_dmacr(struct ccsr_guts __iomem *guts, + unsigned int co, unsigned int ch, unsigned int device) + { +- unsigned int shift = 16 + (8 * (2 - co) + 2 * (3 - ch)); ++ unsigned int shift = 16 + (8 * (1 - co) + 2 * (3 - ch)); + + clrsetbits_be32(&guts->dmacr, 3 << shift, device << shift); + } +@@ -118,6 +118,27 @@ + #define CCSR_GUTS_PMUXCR_DMA1_0 0x00000002 + #define CCSR_GUTS_PMUXCR_DMA1_3 0x00000001 + ++/* ++ * Set the DMA external control bits in the GUTS ++ * ++ * The DMA external control bits in the PMUXCR are only meaningful for ++ * channels 0 and 3. Any other channels are ignored. ++ * ++ * guts: Pointer to GUTS structure ++ * co: The DMA controller (0 or 1) ++ * ch: The channel on the DMA controller (0, 1, 2, or 3) ++ * value: the new value for the bit (0 or 1) ++ */ ++static inline void guts_set_pmuxcr_dma(struct ccsr_guts __iomem *guts, ++ unsigned int co, unsigned int ch, unsigned int value) ++{ ++ if ((ch == 0) || (ch == 3)) { ++ unsigned int shift = 2 * (co + 1) - (ch & 1) - 1; ++ ++ clrsetbits_be32(&guts->pmuxcr, 1 << shift, value << shift); ++ } ++} ++ + #define CCSR_GUTS_CLKDVDR_PXCKEN 0x80000000 + #define CCSR_GUTS_CLKDVDR_SSICKEN 0x20000000 + #define CCSR_GUTS_CLKDVDR_PXCKINV 0x10000000 +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/immap_qe.h powerpc.git/include/asm-powerpc/immap_qe.h +--- linux-2.6.24/include/asm-powerpc/immap_qe.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/immap_qe.h 2008-01-28 20:26:42.000000000 +0100 +@@ -393,9 +393,39 @@ + u8 res2[0x48]; + } __attribute__ ((packed)); + +-/* RISC Special Registers (Trap and Breakpoint) */ ++/* ++ * RISC Special Registers (Trap and Breakpoint). These are described in ++ * the QE Developer's Handbook. ++ */ + struct rsp { +- u32 reg[0x40]; /* 64 32-bit registers */ ++ __be32 tibcr[16]; /* Trap/instruction breakpoint control regs */ ++ u8 res0[64]; ++ __be32 ibcr0; ++ __be32 ibs0; ++ __be32 ibcnr0; ++ u8 res1[4]; ++ __be32 ibcr1; ++ __be32 ibs1; ++ __be32 ibcnr1; ++ __be32 npcr; ++ __be32 dbcr; ++ __be32 dbar; ++ __be32 dbamr; ++ __be32 dbsr; ++ __be32 dbcnr; ++ u8 res2[12]; ++ __be32 dbdr_h; ++ __be32 dbdr_l; ++ __be32 dbdmr_h; ++ __be32 dbdmr_l; ++ __be32 bsr; ++ __be32 bor; ++ __be32 bior; ++ u8 res3[4]; ++ __be32 iatr[4]; ++ __be32 eccr; /* Exception control configuration register */ ++ __be32 eicr; ++ u8 res4[0x100-0xf8]; + } __attribute__ ((packed)); + + struct qe_immap { +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/io.h powerpc.git/include/asm-powerpc/io.h +--- linux-2.6.24/include/asm-powerpc/io.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/io.h 2008-01-28 20:26:42.000000000 +0100 +@@ -50,15 +50,16 @@ + #define PCI_DRAM_OFFSET pci_dram_offset + #else + #define _IO_BASE pci_io_base +-#define _ISA_MEM_BASE 0 ++#define _ISA_MEM_BASE isa_mem_base + #define PCI_DRAM_OFFSET 0 + #endif + + extern unsigned long isa_io_base; +-extern unsigned long isa_mem_base; + extern unsigned long pci_io_base; + extern unsigned long pci_dram_offset; + ++extern resource_size_t isa_mem_base; ++ + #if defined(CONFIG_PPC32) && defined(CONFIG_PPC_INDIRECT_IO) + #error CONFIG_PPC_INDIRECT_IO is not yet supported on 32 bits + #endif +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/iommu.h powerpc.git/include/asm-powerpc/iommu.h +--- linux-2.6.24/include/asm-powerpc/iommu.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/iommu.h 2008-01-28 20:26:42.000000000 +0100 +@@ -69,10 +69,9 @@ + }; + + struct scatterlist; +-struct device_node; + + /* Frees table for an individual device node */ +-extern void iommu_free_table(struct device_node *dn); ++extern void iommu_free_table(struct iommu_table *tbl, const char *node_name); + + /* Initializes an iommu_table based in values set in the passed-in + * structure +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/ipic.h powerpc.git/include/asm-powerpc/ipic.h +--- linux-2.6.24/include/asm-powerpc/ipic.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/ipic.h 2008-01-28 20:26:42.000000000 +0100 +@@ -20,11 +20,13 @@ + + /* Flags when we init the IPIC */ + #define IPIC_SPREADMODE_GRP_A 0x00000001 +-#define IPIC_SPREADMODE_GRP_D 0x00000002 +-#define IPIC_SPREADMODE_MIX_A 0x00000004 +-#define IPIC_SPREADMODE_MIX_B 0x00000008 +-#define IPIC_DISABLE_MCP_OUT 0x00000010 +-#define IPIC_IRQ0_MCP 0x00000020 ++#define IPIC_SPREADMODE_GRP_B 0x00000002 ++#define IPIC_SPREADMODE_GRP_C 0x00000004 ++#define IPIC_SPREADMODE_GRP_D 0x00000008 ++#define IPIC_SPREADMODE_MIX_A 0x00000010 ++#define IPIC_SPREADMODE_MIX_B 0x00000020 ++#define IPIC_DISABLE_MCP_OUT 0x00000040 ++#define IPIC_IRQ0_MCP 0x00000080 + + /* IPIC registers offsets */ + #define IPIC_SICFR 0x00 /* System Global Interrupt Configuration Register */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/iseries/hv_lp_event.h powerpc.git/include/asm-powerpc/iseries/hv_lp_event.h +--- linux-2.6.24/include/asm-powerpc/iseries/hv_lp_event.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/iseries/hv_lp_event.h 2008-01-28 20:26:42.000000000 +0100 +@@ -78,7 +78,7 @@ + + /* + * Close an Lp Event Path for a type and partition +- * returns 0 on sucess ++ * returns 0 on success + */ + extern int HvLpEvent_closePath(HvLpEvent_Type eventType, HvLpIndex lpIndex); + +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/kexec.h powerpc.git/include/asm-powerpc/kexec.h +--- linux-2.6.24/include/asm-powerpc/kexec.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/kexec.h 2008-01-28 20:26:42.000000000 +0100 +@@ -123,6 +123,9 @@ + extern void default_machine_kexec(struct kimage *image); + extern int default_machine_kexec_prepare(struct kimage *image); + extern void default_machine_crash_shutdown(struct pt_regs *regs); ++typedef void (*crash_shutdown_t)(void); ++extern int crash_shutdown_register(crash_shutdown_t handler); ++extern int crash_shutdown_unregister(crash_shutdown_t handler); + + extern void machine_kexec_simple(struct kimage *image); + extern void crash_kexec_secondary(struct pt_regs *regs); +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/lmb.h powerpc.git/include/asm-powerpc/lmb.h +--- linux-2.6.24/include/asm-powerpc/lmb.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/lmb.h 2008-01-28 20:26:42.000000000 +0100 +@@ -51,6 +51,7 @@ + extern unsigned long __init lmb_phys_mem_size(void); + extern unsigned long __init lmb_end_of_DRAM(void); + extern void __init lmb_enforce_memory_limit(unsigned long memory_limit); ++extern int __init lmb_is_reserved(unsigned long addr); + + extern void lmb_dump_all(void); + +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/machdep.h powerpc.git/include/asm-powerpc/machdep.h +--- linux-2.6.24/include/asm-powerpc/machdep.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/machdep.h 2008-01-28 20:26:42.000000000 +0100 +@@ -204,6 +204,13 @@ + /* + * optional PCI "hooks" + */ ++ /* Called in indirect_* to avoid touching devices */ ++ int (*pci_exclude_device)(struct pci_controller *, unsigned char, unsigned char); ++ ++ /* Called at then very end of pcibios_init() */ ++ void (*pcibios_after_init)(void); ++ ++#endif /* CONFIG_PPC32 */ + + /* Called after PPC generic resource fixup to perform + machine specific fixups */ +@@ -212,18 +219,9 @@ + /* Called for each PCI bus in the system when it's probed */ + void (*pcibios_fixup_bus)(struct pci_bus *); + +- /* Called when pci_enable_device() is called (initial=0) or +- * when a device with no assigned resource is found (initial=1). +- * Returns 0 to allow assignment/enabling of the device. */ +- int (*pcibios_enable_device_hook)(struct pci_dev *, int initial); +- +- /* Called in indirect_* to avoid touching devices */ +- int (*pci_exclude_device)(struct pci_controller *, unsigned char, unsigned char); +- +- /* Called at then very end of pcibios_init() */ +- void (*pcibios_after_init)(void); +- +-#endif /* CONFIG_PPC32 */ ++ /* Called when pci_enable_device() is called. Returns 0 to ++ * allow assignment/enabling of the device. */ ++ int (*pcibios_enable_device_hook)(struct pci_dev *); + + /* Called to shutdown machine specific hardware not already controlled + * by other drivers. +@@ -253,6 +251,16 @@ + */ + void (*machine_kexec)(struct kimage *image); + #endif /* CONFIG_KEXEC */ ++ ++#ifdef CONFIG_SUSPEND ++ /* These are called to disable and enable, respectively, IRQs when ++ * entering a suspend state. If NULL, then the generic versions ++ * will be called. The generic versions disable/enable the ++ * decrementer along with interrupts. ++ */ ++ void (*suspend_disable_irqs)(void); ++ void (*suspend_enable_irqs)(void); ++#endif + }; + + extern void power4_idle(void); +@@ -326,5 +334,31 @@ + ppc_md.log_error(buf, err_type, fatal); + } + ++#define __define_machine_initcall(mach,level,fn,id) \ ++ static int __init __machine_initcall_##mach##_##fn(void) { \ ++ if (machine_is(mach)) return fn(); \ ++ return 0; \ ++ } \ ++ __define_initcall(level,__machine_initcall_##mach##_##fn,id); ++ ++#define machine_core_initcall(mach,fn) __define_machine_initcall(mach,"1",fn,1) ++#define machine_core_initcall_sync(mach,fn) __define_machine_initcall(mach,"1s",fn,1s) ++#define machine_postcore_initcall(mach,fn) __define_machine_initcall(mach,"2",fn,2) ++#define machine_postcore_initcall_sync(mach,fn) __define_machine_initcall(mach,"2s",fn,2s) ++#define machine_arch_initcall(mach,fn) __define_machine_initcall(mach,"3",fn,3) ++#define machine_arch_initcall_sync(mach,fn) __define_machine_initcall(mach,"3s",fn,3s) ++#define machine_subsys_initcall(mach,fn) __define_machine_initcall(mach,"4",fn,4) ++#define machine_subsys_initcall_sync(mach,fn) __define_machine_initcall(mach,"4s",fn,4s) ++#define machine_fs_initcall(mach,fn) __define_machine_initcall(mach,"5",fn,5) ++#define machine_fs_initcall_sync(mach,fn) __define_machine_initcall(mach,"5s",fn,5s) ++#define machine_rootfs_initcall(mach,fn) __define_machine_initcall(mach,"rootfs",fn,rootfs) ++#define machine_device_initcall(mach,fn) __define_machine_initcall(mach,"6",fn,6) ++#define machine_device_initcall_sync(mach,fn) __define_machine_initcall(mach,"6s",fn,6s) ++#define machine_late_initcall(mach,fn) __define_machine_initcall(mach,"7",fn,7) ++#define machine_late_initcall_sync(mach,fn) __define_machine_initcall(mach,"7s",fn,7s) ++ ++void generic_suspend_disable_irqs(void); ++void generic_suspend_enable_irqs(void); ++ + #endif /* __KERNEL__ */ + #endif /* _ASM_POWERPC_MACHDEP_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/mmu-hash64.h powerpc.git/include/asm-powerpc/mmu-hash64.h +--- linux-2.6.24/include/asm-powerpc/mmu-hash64.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/mmu-hash64.h 2008-01-28 21:37:04.000000000 +0100 +@@ -80,7 +80,7 @@ + #define HPTE_V_AVPN_SHIFT 7 + #define HPTE_V_AVPN ASM_CONST(0x3fffffffffffff80) + #define HPTE_V_AVPN_VAL(x) (((x) & HPTE_V_AVPN) >> HPTE_V_AVPN_SHIFT) +-#define HPTE_V_COMPARE(x,y) (!(((x) ^ (y)) & 0xffffffffffffff80)) ++#define HPTE_V_COMPARE(x,y) (!(((x) ^ (y)) & 0xffffffffffffff80UL)) + #define HPTE_V_BOLTED ASM_CONST(0x0000000000000010) + #define HPTE_V_LOCK ASM_CONST(0x0000000000000008) + #define HPTE_V_LARGE ASM_CONST(0x0000000000000004) +@@ -180,6 +180,7 @@ + extern int mmu_io_psize; + extern int mmu_kernel_ssize; + extern int mmu_highuser_ssize; ++extern u16 mmu_slb_size; + + /* + * If the processor supports 64k normal pages but not 64k cache +@@ -277,6 +278,7 @@ + extern int htab_bolt_mapping(unsigned long vstart, unsigned long vend, + unsigned long pstart, unsigned long mode, + int psize, int ssize); ++extern void set_huge_psize(int psize); + + extern void htab_initialize(void); + extern void htab_initialize_secondary(void); +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/mpc52xx.h powerpc.git/include/asm-powerpc/mpc52xx.h +--- linux-2.6.24/include/asm-powerpc/mpc52xx.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/mpc52xx.h 2008-01-28 20:26:42.000000000 +0100 +@@ -248,8 +248,6 @@ + + #ifndef __ASSEMBLY__ + +-extern void __iomem * mpc52xx_find_and_map(const char *); +-extern void __iomem * mpc52xx_find_and_map_path(const char *path); + extern unsigned int mpc52xx_find_ipb_freq(struct device_node *node); + extern void mpc5200_setup_xlb_arbiter(void); + extern void mpc52xx_declare_of_platform_devices(void); +@@ -257,7 +255,12 @@ + extern void mpc52xx_init_irq(void); + extern unsigned int mpc52xx_get_irq(void); + ++#ifdef CONFIG_PCI + extern int __init mpc52xx_add_bridge(struct device_node *node); ++extern void __init mpc52xx_setup_pci(void); ++#else ++static inline void mpc52xx_setup_pci(void) { } ++#endif + + extern void __init mpc52xx_map_wdt(void); + extern void mpc52xx_restart(char *cmd); +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/mpc52xx_psc.h powerpc.git/include/asm-powerpc/mpc52xx_psc.h +--- linux-2.6.24/include/asm-powerpc/mpc52xx_psc.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/mpc52xx_psc.h 2008-01-28 20:26:42.000000000 +0100 +@@ -153,6 +153,9 @@ + u8 reserved16[3]; + u8 irfdr; /* PSC + 0x54 */ + u8 reserved17[3]; ++}; ++ ++struct mpc52xx_psc_fifo { + u16 rfnum; /* PSC + 0x58 */ + u16 reserved18; + u16 tfnum; /* PSC + 0x5c */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/mpc8260.h powerpc.git/include/asm-powerpc/mpc8260.h +--- linux-2.6.24/include/asm-powerpc/mpc8260.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/mpc8260.h 2008-01-28 20:26:42.000000000 +0100 +@@ -8,6 +8,7 @@ + #ifndef __ASM_POWERPC_MPC8260_H__ + #define __ASM_POWERPC_MPC8260_H__ + ++#define MPC82XX_BCR_PLDP 0x00800000 /* Pipeline Maximum Depth */ + + #ifdef CONFIG_8260 + +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/mpic.h powerpc.git/include/asm-powerpc/mpic.h +--- linux-2.6.24/include/asm-powerpc/mpic.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/mpic.h 2008-01-28 20:26:42.000000000 +0100 +@@ -22,7 +22,9 @@ + #define MPIC_GREG_GLOBAL_CONF_0 0x00020 + #define MPIC_GREG_GCONF_RESET 0x80000000 + #define MPIC_GREG_GCONF_8259_PTHROU_DIS 0x20000000 ++#define MPIC_GREG_GCONF_NO_BIAS 0x10000000 + #define MPIC_GREG_GCONF_BASE_MASK 0x000fffff ++#define MPIC_GREG_GCONF_MCK 0x08000000 + #define MPIC_GREG_GLOBAL_CONF_1 0x00030 + #define MPIC_GREG_GLOBAL_CONF_1_SIE 0x08000000 + #define MPIC_GREG_GLOBAL_CONF_1_CLK_RATIO_MASK 0x70000000 +@@ -78,6 +80,7 @@ + #define MPIC_CPU_WHOAMI_MASK 0x0000001f + #define MPIC_CPU_INTACK 0x000a0 + #define MPIC_CPU_EOI 0x000b0 ++#define MPIC_CPU_MCACK 0x000c0 + + /* + * Per-source registers +@@ -141,6 +144,7 @@ + #define TSI108_CPU_WHOAMI 0xffffffff + #define TSI108_CPU_INTACK 0x00004 + #define TSI108_CPU_EOI 0x00008 ++#define TSI108_CPU_MCACK 0x00004 /* Doesn't really exist here */ + + /* + * Per-source registers +@@ -183,6 +187,7 @@ + MPIC_IDX_CPU_WHOAMI, + MPIC_IDX_CPU_INTACK, + MPIC_IDX_CPU_EOI, ++ MPIC_IDX_CPU_MCACK, + + MPIC_IDX_IRQ_BASE, + MPIC_IDX_IRQ_STRIDE, +@@ -344,6 +349,10 @@ + #define MPIC_USES_DCR 0x00000080 + /* MPIC has 11-bit vector fields (or larger) */ + #define MPIC_LARGE_VECTORS 0x00000100 ++/* Enable delivery of prio 15 interrupts as MCK instead of EE */ ++#define MPIC_ENABLE_MCK 0x00000200 ++/* Disable bias among target selection, spread interrupts evenly */ ++#define MPIC_NO_BIAS 0x00000400 + + /* MPIC HW modification ID */ + #define MPIC_REGSET_MASK 0xf0000000 +@@ -447,10 +456,19 @@ + /* Send a message (IPI) to a given target (cpu number or MSG_*) */ + void smp_mpic_message_pass(int target, int msg); + ++/* Unmask a specific virq */ ++extern void mpic_unmask_irq(unsigned int irq); ++/* Mask a specific virq */ ++extern void mpic_mask_irq(unsigned int irq); ++/* EOI a specific virq */ ++extern void mpic_end_irq(unsigned int irq); ++ + /* Fetch interrupt from a given mpic */ + extern unsigned int mpic_get_one_irq(struct mpic *mpic); +-/* This one gets to the primary mpic */ ++/* This one gets from the primary mpic */ + extern unsigned int mpic_get_irq(void); ++/* Fetch Machine Check interrupt from primary mpic */ ++extern unsigned int mpic_get_mcirq(void); + + /* Set the EPIC clock ratio */ + void mpic_set_clk_ratio(struct mpic *mpic, u32 clock_ratio); +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/nvram.h powerpc.git/include/asm-powerpc/nvram.h +--- linux-2.6.24/include/asm-powerpc/nvram.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/nvram.h 2008-01-28 20:26:42.000000000 +0100 +@@ -10,6 +10,8 @@ + #ifndef _ASM_POWERPC_NVRAM_H + #define _ASM_POWERPC_NVRAM_H + ++#include <linux/errno.h> ++ + #define NVRW_CNT 0x20 + #define NVRAM_HEADER_LEN 16 /* sizeof(struct nvram_header) */ + #define NVRAM_BLOCK_LEN 16 +@@ -71,7 +73,16 @@ + extern struct nvram_partition *nvram_find_partition(int sig, const char *name); + + extern int pSeries_nvram_init(void); ++ ++#ifdef CONFIG_MMIO_NVRAM + extern int mmio_nvram_init(void); ++#else ++static inline int mmio_nvram_init(void) ++{ ++ return -ENODEV; ++} ++#endif ++ + #endif /* __KERNEL__ */ + + /* PowerMac specific nvram stuffs */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/of_platform.h powerpc.git/include/asm-powerpc/of_platform.h +--- linux-2.6.24/include/asm-powerpc/of_platform.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/of_platform.h 2008-01-28 20:26:42.000000000 +0100 +@@ -15,8 +15,14 @@ + #include <linux/of_platform.h> + + /* Platform drivers register/unregister */ +-extern int of_register_platform_driver(struct of_platform_driver *drv); +-extern void of_unregister_platform_driver(struct of_platform_driver *drv); ++static inline int of_register_platform_driver(struct of_platform_driver *drv) ++{ ++ return of_register_driver(drv, &of_platform_bus_type); ++} ++static inline void of_unregister_platform_driver(struct of_platform_driver *drv) ++{ ++ of_unregister_driver(drv); ++} + + /* Platform devices and busses creation */ + extern struct of_device *of_platform_device_create(struct device_node *np, +@@ -26,9 +32,11 @@ + #define OF_NO_DEEP_PROBE ((struct of_device_id *)-1) + + extern int of_platform_bus_probe(struct device_node *root, +- struct of_device_id *matches, ++ const struct of_device_id *matches, + struct device *parent); + + extern struct of_device *of_find_device_by_phandle(phandle ph); + ++extern void of_instantiate_rtc(void); ++ + #endif /* _ASM_POWERPC_OF_PLATFORM_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/pci-bridge.h powerpc.git/include/asm-powerpc/pci-bridge.h +--- linux-2.6.24/include/asm-powerpc/pci-bridge.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/pci-bridge.h 2008-01-28 20:26:42.000000000 +0100 +@@ -1,15 +1,42 @@ + #ifndef _ASM_POWERPC_PCI_BRIDGE_H + #define _ASM_POWERPC_PCI_BRIDGE_H + #ifdef __KERNEL__ +- ++/* ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License ++ * as published by the Free Software Foundation; either version ++ * 2 of the License, or (at your option) any later version. ++ */ + #include <linux/pci.h> + #include <linux/list.h> + #include <linux/ioport.h> + +-#ifndef CONFIG_PPC64 +- + struct device_node; +-struct pci_controller; ++ ++extern unsigned int ppc_pci_flags; ++enum { ++ /* Force re-assigning all resources (ignore firmware ++ * setup completely) ++ */ ++ PPC_PCI_REASSIGN_ALL_RSRC = 0x00000001, ++ ++ /* Re-assign all bus numbers */ ++ PPC_PCI_REASSIGN_ALL_BUS = 0x00000002, ++ ++ /* Do not try to assign, just use existing setup */ ++ PPC_PCI_PROBE_ONLY = 0x00000004, ++ ++ /* Don't bother with ISA alignment unless the bridge has ++ * ISA forwarding enabled ++ */ ++ PPC_PCI_CAN_SKIP_ISA_ALIGN = 0x00000008, ++ ++ /* Enable domain numbers in /proc */ ++ PPC_PCI_ENABLE_PROC_DOMAINS = 0x00000010, ++ /* ... except for domain 0 */ ++ PPC_PCI_COMPAT_DOMAIN_0 = 0x00000020, ++}; ++ + + /* + * Structure of a PCI controller (host bridge) +@@ -17,26 +44,41 @@ + struct pci_controller { + struct pci_bus *bus; + char is_dynamic; +- void *arch_data; ++#ifdef CONFIG_PPC64 ++ int node; ++#endif ++ struct device_node *dn; + struct list_head list_node; + struct device *parent; + + int first_busno; + int last_busno; ++#ifndef CONFIG_PPC64 + int self_busno; ++#endif + + void __iomem *io_base_virt; ++#ifdef CONFIG_PPC64 ++ void *io_base_alloc; ++#endif + resource_size_t io_base_phys; ++#ifndef CONFIG_PPC64 ++ resource_size_t pci_io_size; ++#endif + + /* Some machines (PReP) have a non 1:1 mapping of + * the PCI memory space in the CPU bus space + */ + resource_size_t pci_mem_offset; ++#ifdef CONFIG_PPC64 ++ unsigned long pci_io_size; ++#endif + + struct pci_ops *ops; +- volatile unsigned int __iomem *cfg_addr; +- volatile void __iomem *cfg_data; ++ unsigned int __iomem *cfg_addr; ++ void __iomem *cfg_data; + ++#ifndef CONFIG_PPC64 + /* + * Used for variants of PCI indirect handling and possible quirks: + * SET_CFG_TYPE - used on 4xx or any PHB that does explicit type0/1 +@@ -51,21 +93,30 @@ + * set. + * BIG_ENDIAN - cfg_addr is a big endian register + */ +-#define PPC_INDIRECT_TYPE_SET_CFG_TYPE (0x00000001) +-#define PPC_INDIRECT_TYPE_EXT_REG (0x00000002) +-#define PPC_INDIRECT_TYPE_SURPRESS_PRIMARY_BUS (0x00000004) +-#define PPC_INDIRECT_TYPE_NO_PCIE_LINK (0x00000008) +-#define PPC_INDIRECT_TYPE_BIG_ENDIAN (0x00000010) ++#define PPC_INDIRECT_TYPE_SET_CFG_TYPE 0x00000001 ++#define PPC_INDIRECT_TYPE_EXT_REG 0x00000002 ++#define PPC_INDIRECT_TYPE_SURPRESS_PRIMARY_BUS 0x00000004 ++#define PPC_INDIRECT_TYPE_NO_PCIE_LINK 0x00000008 ++#define PPC_INDIRECT_TYPE_BIG_ENDIAN 0x00000010 + u32 indirect_type; +- ++#endif /* !CONFIG_PPC64 */ + /* Currently, we limit ourselves to 1 IO range and 3 mem + * ranges since the common pci_bus structure can't handle more + */ + struct resource io_resource; + struct resource mem_resources[3]; + int global_number; /* PCI domain number */ ++#ifdef CONFIG_PPC64 ++ unsigned long buid; ++ unsigned long dma_window_base_cur; ++ unsigned long dma_window_size; ++ ++ void *private_data; ++#endif /* CONFIG_PPC64 */ + }; + ++#ifndef CONFIG_PPC64 ++ + static inline struct pci_controller *pci_bus_to_host(struct pci_bus *bus) + { + return bus->sysdata; +@@ -81,18 +132,18 @@ + + /* These are used for config access before all the PCI probing + has been done. */ +-int early_read_config_byte(struct pci_controller *hose, int bus, int dev_fn, +- int where, u8 *val); +-int early_read_config_word(struct pci_controller *hose, int bus, int dev_fn, +- int where, u16 *val); +-int early_read_config_dword(struct pci_controller *hose, int bus, int dev_fn, +- int where, u32 *val); +-int early_write_config_byte(struct pci_controller *hose, int bus, int dev_fn, +- int where, u8 val); +-int early_write_config_word(struct pci_controller *hose, int bus, int dev_fn, +- int where, u16 val); +-int early_write_config_dword(struct pci_controller *hose, int bus, int dev_fn, +- int where, u32 val); ++extern int early_read_config_byte(struct pci_controller *hose, int bus, ++ int dev_fn, int where, u8 *val); ++extern int early_read_config_word(struct pci_controller *hose, int bus, ++ int dev_fn, int where, u16 *val); ++extern int early_read_config_dword(struct pci_controller *hose, int bus, ++ int dev_fn, int where, u32 *val); ++extern int early_write_config_byte(struct pci_controller *hose, int bus, ++ int dev_fn, int where, u8 val); ++extern int early_write_config_word(struct pci_controller *hose, int bus, ++ int dev_fn, int where, u16 val); ++extern int early_write_config_dword(struct pci_controller *hose, int bus, ++ int dev_fn, int where, u32 val); + + extern int early_find_capability(struct pci_controller *hose, int bus, + int dev_fn, int cap); +@@ -101,87 +152,33 @@ + resource_size_t cfg_addr, + resource_size_t cfg_data, u32 flags); + extern void setup_grackle(struct pci_controller *hose); +-extern void __init update_bridge_resource(struct pci_dev *dev, +- struct resource *res); +- +-#else +- +- +-/* +- * This program is free software; you can redistribute it and/or +- * modify it under the terms of the GNU General Public License +- * as published by the Free Software Foundation; either version +- * 2 of the License, or (at your option) any later version. +- */ +- +-/* +- * Structure of a PCI controller (host bridge) +- */ +-struct pci_controller { +- struct pci_bus *bus; +- char is_dynamic; +- int node; +- void *arch_data; +- struct list_head list_node; +- struct device *parent; +- +- int first_busno; +- int last_busno; +- +- void __iomem *io_base_virt; +- void *io_base_alloc; +- resource_size_t io_base_phys; +- +- /* Some machines have a non 1:1 mapping of +- * the PCI memory space in the CPU bus space +- */ +- resource_size_t pci_mem_offset; +- unsigned long pci_io_size; +- +- struct pci_ops *ops; +- volatile unsigned int __iomem *cfg_addr; +- volatile void __iomem *cfg_data; +- +- /* Currently, we limit ourselves to 1 IO range and 3 mem +- * ranges since the common pci_bus structure can't handle more +- */ +- struct resource io_resource; +- struct resource mem_resources[3]; +- int global_number; +- unsigned long buid; +- unsigned long dma_window_base_cur; +- unsigned long dma_window_size; +- +- void *private_data; +-}; ++#else /* CONFIG_PPC64 */ + + /* + * PCI stuff, for nodes representing PCI devices, pointed to + * by device_node->data. + */ +-struct pci_controller; + struct iommu_table; + + struct pci_dn { + int busno; /* pci bus number */ +- int bussubno; /* pci subordinate bus number */ + int devfn; /* pci device and function number */ +- int class_code; /* pci device class */ + + struct pci_controller *phb; /* for pci devices */ + struct iommu_table *iommu_table; /* for phb's or bridges */ +- struct pci_dev *pcidev; /* back-pointer to the pci device */ + struct device_node *node; /* back-pointer to the device_node */ + + int pci_ext_config_space; /* for pci devices */ + + #ifdef CONFIG_EEH ++ struct pci_dev *pcidev; /* back-pointer to the pci device */ ++ int class_code; /* pci device class */ + int eeh_mode; /* See eeh.h for possible EEH_MODEs */ + int eeh_config_addr; + int eeh_pe_config_addr; /* new-style partition endpoint address */ +- int eeh_check_count; /* # times driver ignored error */ +- int eeh_freeze_count; /* # times this device froze up. */ +- int eeh_false_positives; /* # times this device reported #ff's */ ++ int eeh_check_count; /* # times driver ignored error */ ++ int eeh_freeze_count; /* # times this device froze up. */ ++ int eeh_false_positives; /* # times this device reported #ff's */ + u32 config_space[16]; /* saved PCI config space */ + #endif + }; +@@ -189,7 +186,7 @@ + /* Get the pointer to a device_node's pci_dn */ + #define PCI_DN(dn) ((struct pci_dn *) (dn)->data) + +-struct device_node *fetch_dev_dn(struct pci_dev *dev); ++extern struct device_node *fetch_dev_dn(struct pci_dev *dev); + + /* Get a device_node from a pci_dev. This code must be fast except + * in the case where the sysdata is incorrect and needs to be fixed +@@ -227,14 +224,14 @@ + } + + /** Find the bus corresponding to the indicated device node */ +-struct pci_bus * pcibios_find_pci_bus(struct device_node *dn); ++extern struct pci_bus *pcibios_find_pci_bus(struct device_node *dn); + + /** Remove all of the PCI devices under this bus */ +-void pcibios_remove_pci_devices(struct pci_bus *bus); ++extern void pcibios_remove_pci_devices(struct pci_bus *bus); + + /** Discover new pci devices under this bus, and add them */ +-void pcibios_add_pci_devices(struct pci_bus * bus); +-void pcibios_fixup_new_pci_devices(struct pci_bus *bus, int fix_bus); ++extern void pcibios_add_pci_devices(struct pci_bus *bus); ++extern void pcibios_fixup_new_pci_devices(struct pci_bus *bus); + + extern int pcibios_remove_root_bus(struct pci_controller *phb); + +@@ -270,20 +267,18 @@ + #define PHB_SET_NODE(PHB, NODE) ((PHB)->node = -1) + #endif + +-#endif /* CONFIG_PPC64 */ ++#endif /* CONFIG_PPC64 */ + + /* Get the PCI host controller for an OF device */ +-extern struct pci_controller* +-pci_find_hose_for_OF_device(struct device_node* node); ++extern struct pci_controller *pci_find_hose_for_OF_device( ++ struct device_node* node); + + /* Fill up host controller resources from the OF node */ +-extern void +-pci_process_bridge_OF_ranges(struct pci_controller *hose, +- struct device_node *dev, int primary); ++extern void pci_process_bridge_OF_ranges(struct pci_controller *hose, ++ struct device_node *dev, int primary); + + /* Allocate & free a PCI host bridge structure */ +-extern struct pci_controller * +-pcibios_alloc_controller(struct device_node *dev); ++extern struct pci_controller *pcibios_alloc_controller(struct device_node *dev); + extern void pcibios_free_controller(struct pci_controller *phb); + + #ifdef CONFIG_PCI +@@ -298,9 +293,7 @@ + { + return 0; + } +-#endif +- ++#endif /* CONFIG_PCI */ + +- +-#endif /* __KERNEL__ */ +-#endif ++#endif /* __KERNEL__ */ ++#endif /* _ASM_POWERPC_PCI_BRIDGE_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/pci.h powerpc.git/include/asm-powerpc/pci.h +--- linux-2.6.24/include/asm-powerpc/pci.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/pci.h 2008-01-28 20:26:42.000000000 +0100 +@@ -36,11 +36,10 @@ + + /* + * Set this to 1 if you want the kernel to re-assign all PCI +- * bus numbers ++ * bus numbers (don't do that on ppc64 yet !) + */ +-extern int pci_assign_all_buses; +-#define pcibios_assign_all_busses() (pci_assign_all_buses) +- ++#define pcibios_assign_all_busses() (ppc_pci_flags & \ ++ PPC_PCI_REASSIGN_ALL_BUS) + #define pcibios_scan_all_fns(a, b) 0 + + static inline void pcibios_set_master(struct pci_dev *dev) +@@ -95,9 +94,6 @@ + #define get_pci_dma_ops() NULL + #endif + +-/* Decide whether to display the domain number in /proc */ +-extern int pci_proc_domain(struct pci_bus *bus); +- + #else /* 32-bit */ + + #ifdef CONFIG_PCI +@@ -109,17 +105,14 @@ + *strategy_parameter = ~0UL; + } + #endif +- +-/* Set the name of the bus as it appears in /proc/bus/pci */ +-static inline int pci_proc_domain(struct pci_bus *bus) +-{ +- return 0; +-} +- + #endif /* CONFIG_PPC64 */ + + extern int pci_domain_nr(struct pci_bus *bus); + ++/* Decide whether to display the domain number in /proc */ ++extern int pci_proc_domain(struct pci_bus *bus); ++ ++ + struct vm_area_struct; + /* Map a range of PCI memory or I/O space for a device into user space */ + int pci_mmap_page_range(struct pci_dev *pdev, struct vm_area_struct *vma, +@@ -199,13 +192,12 @@ + return root; + } + +-extern void pcibios_fixup_device_resources(struct pci_dev *dev, +- struct pci_bus *bus); +- + extern void pcibios_setup_new_device(struct pci_dev *dev); + + extern void pcibios_claim_one_bus(struct pci_bus *b); + ++extern void pcibios_resource_survey(void); ++ + extern struct pci_controller *init_phb_dynamic(struct device_node *dn); + + extern struct pci_dev *of_create_pci_dev(struct device_node *node, +@@ -229,5 +221,8 @@ + const struct resource *rsrc, + resource_size_t *start, resource_size_t *end); + ++extern void pcibios_do_bus_setup(struct pci_bus *bus); ++extern void pcibios_fixup_of_probed_bus(struct pci_bus *bus); ++ + #endif /* __KERNEL__ */ + #endif /* __ASM_POWERPC_PCI_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/ppc-pci.h powerpc.git/include/asm-powerpc/ppc-pci.h +--- linux-2.6.24/include/asm-powerpc/ppc-pci.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/ppc-pci.h 2008-01-28 20:26:42.000000000 +0100 +@@ -22,7 +22,6 @@ + + + extern struct list_head hose_list; +-extern int global_phb_number; + + extern void find_and_init_phbs(void); + +@@ -47,9 +46,6 @@ + extern unsigned long get_phb_buid (struct device_node *); + extern int rtas_setup_phb(struct pci_controller *phb); + +-/* From iSeries PCI */ +-extern void iSeries_pcibios_init(void); +- + extern unsigned long pci_probe_only; + + /* ---- EEH internal-use-only related routines ---- */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/prom.h powerpc.git/include/asm-powerpc/prom.h +--- linux-2.6.24/include/asm-powerpc/prom.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/prom.h 2008-01-28 20:26:42.000000000 +0100 +@@ -202,6 +202,10 @@ + */ + extern u64 of_translate_address(struct device_node *np, const u32 *addr); + ++/* Translate a DMA address from device space to CPU space */ ++extern u64 of_translate_dma_address(struct device_node *dev, ++ const u32 *in_addr); ++ + /* Extract an address from a device, returns the region size and + * the address space flags too. The PCI version uses a BAR number + * instead of an absolute index +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/ps3.h powerpc.git/include/asm-powerpc/ps3.h +--- linux-2.6.24/include/asm-powerpc/ps3.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/ps3.h 2008-01-28 20:26:42.000000000 +0100 +@@ -24,6 +24,7 @@ + #include <linux/init.h> + #include <linux/types.h> + #include <linux/device.h> ++#include "cell-pmu.h" + + union ps3_firmware_version { + u64 raw; +@@ -317,6 +318,7 @@ + PS3_MATCH_ID_STOR_FLASH = 8, + PS3_MATCH_ID_SOUND = 9, + PS3_MATCH_ID_GRAPHICS = 10, ++ PS3_MATCH_ID_LPM = 11, + }; + + #define PS3_MODULE_ALIAS_EHCI "ps3:1" +@@ -329,11 +331,13 @@ + #define PS3_MODULE_ALIAS_STOR_FLASH "ps3:8" + #define PS3_MODULE_ALIAS_SOUND "ps3:9" + #define PS3_MODULE_ALIAS_GRAPHICS "ps3:10" ++#define PS3_MODULE_ALIAS_LPM "ps3:11" + + enum ps3_system_bus_device_type { + PS3_DEVICE_TYPE_IOC0 = 1, + PS3_DEVICE_TYPE_SB, + PS3_DEVICE_TYPE_VUART, ++ PS3_DEVICE_TYPE_LPM, + }; + + /** +@@ -344,12 +348,17 @@ + enum ps3_match_id match_id; + enum ps3_system_bus_device_type dev_type; + +- unsigned int bus_id; /* SB */ +- unsigned int dev_id; /* SB */ ++ u64 bus_id; /* SB */ ++ u64 dev_id; /* SB */ + unsigned int interrupt_id; /* SB */ + struct ps3_dma_region *d_region; /* SB, IOC0 */ + struct ps3_mmio_region *m_region; /* SB, IOC0*/ + unsigned int port_number; /* VUART */ ++ struct { /* LPM */ ++ u64 node_id; ++ u64 pu_id; ++ u64 rights; ++ } lpm; + + /* struct iommu_table *iommu_table; -- waiting for BenH's cleanups */ + struct device core; +@@ -438,5 +447,66 @@ + extern struct ps3_prealloc ps3fb_videomemory; + extern struct ps3_prealloc ps3flash_bounce_buffer; + ++/* logical performance monitor */ ++ ++/** ++ * enum ps3_lpm_rights - Rigths granted by the system policy module. ++ * ++ * @PS3_LPM_RIGHTS_USE_LPM: The right to use the lpm. ++ * @PS3_LPM_RIGHTS_USE_TB: The right to use the internal trace buffer. ++ */ ++ ++enum ps3_lpm_rights { ++ PS3_LPM_RIGHTS_USE_LPM = 0x001, ++ PS3_LPM_RIGHTS_USE_TB = 0x100, ++}; ++ ++/** ++ * enum ps3_lpm_tb_type - Type of trace buffer lv1 should use. ++ * ++ * @PS3_LPM_TB_TYPE_NONE: Do not use a trace buffer. ++ * @PS3_LPM_RIGHTS_USE_TB: Use the lv1 internal trace buffer. Must have ++ * rights @PS3_LPM_RIGHTS_USE_TB. ++ */ ++ ++enum ps3_lpm_tb_type { ++ PS3_LPM_TB_TYPE_NONE = 0, ++ PS3_LPM_TB_TYPE_INTERNAL = 1, ++}; ++ ++int ps3_lpm_open(enum ps3_lpm_tb_type tb_type, void *tb_cache, ++ u64 tb_cache_size); ++int ps3_lpm_close(void); ++int ps3_lpm_copy_tb(unsigned long offset, void *buf, unsigned long count, ++ unsigned long *bytes_copied); ++int ps3_lpm_copy_tb_to_user(unsigned long offset, void __user *buf, ++ unsigned long count, unsigned long *bytes_copied); ++void ps3_set_bookmark(u64 bookmark); ++void ps3_set_pm_bookmark(u64 tag, u64 incident, u64 th_id); ++int ps3_set_signal(u64 rtas_signal_group, u8 signal_bit, u16 sub_unit, ++ u8 bus_word); ++ ++u32 ps3_read_phys_ctr(u32 cpu, u32 phys_ctr); ++void ps3_write_phys_ctr(u32 cpu, u32 phys_ctr, u32 val); ++u32 ps3_read_ctr(u32 cpu, u32 ctr); ++void ps3_write_ctr(u32 cpu, u32 ctr, u32 val); ++ ++u32 ps3_read_pm07_control(u32 cpu, u32 ctr); ++void ps3_write_pm07_control(u32 cpu, u32 ctr, u32 val); ++u32 ps3_read_pm(u32 cpu, enum pm_reg_name reg); ++void ps3_write_pm(u32 cpu, enum pm_reg_name reg, u32 val); ++ ++u32 ps3_get_ctr_size(u32 cpu, u32 phys_ctr); ++void ps3_set_ctr_size(u32 cpu, u32 phys_ctr, u32 ctr_size); ++ ++void ps3_enable_pm(u32 cpu); ++void ps3_disable_pm(u32 cpu); ++void ps3_enable_pm_interrupts(u32 cpu, u32 thread, u32 mask); ++void ps3_disable_pm_interrupts(u32 cpu); ++ ++u32 ps3_get_and_clear_pm_interrupts(u32 cpu); ++void ps3_sync_irq(int node); ++u32 ps3_get_hw_thread_id(int cpu); ++u64 ps3_get_spe_id(void *arg); + + #endif +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/ptrace.h powerpc.git/include/asm-powerpc/ptrace.h +--- linux-2.6.24/include/asm-powerpc/ptrace.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/ptrace.h 2008-01-28 20:26:42.000000000 +0100 +@@ -106,7 +106,8 @@ + */ + #define FULL_REGS(regs) (((regs)->trap & 1) == 0) + #ifndef __powerpc64__ +-#define IS_CRITICAL_EXC(regs) (((regs)->trap & 2) == 0) ++#define IS_CRITICAL_EXC(regs) (((regs)->trap & 2) != 0) ++#define IS_MCHECK_EXC(regs) (((regs)->trap & 4) != 0) + #endif /* ! __powerpc64__ */ + #define TRAP(regs) ((regs)->trap & ~0xF) + #ifdef __powerpc64__ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/qe.h powerpc.git/include/asm-powerpc/qe.h +--- linux-2.6.24/include/asm-powerpc/qe.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/qe.h 2008-01-28 20:26:42.000000000 +0100 +@@ -28,6 +28,52 @@ + #define MEM_PART_SECONDARY 1 + #define MEM_PART_MURAM 2 + ++/* Clocks and BRGs */ ++enum qe_clock { ++ QE_CLK_NONE = 0, ++ QE_BRG1, /* Baud Rate Generator 1 */ ++ QE_BRG2, /* Baud Rate Generator 2 */ ++ QE_BRG3, /* Baud Rate Generator 3 */ ++ QE_BRG4, /* Baud Rate Generator 4 */ ++ QE_BRG5, /* Baud Rate Generator 5 */ ++ QE_BRG6, /* Baud Rate Generator 6 */ ++ QE_BRG7, /* Baud Rate Generator 7 */ ++ QE_BRG8, /* Baud Rate Generator 8 */ ++ QE_BRG9, /* Baud Rate Generator 9 */ ++ QE_BRG10, /* Baud Rate Generator 10 */ ++ QE_BRG11, /* Baud Rate Generator 11 */ ++ QE_BRG12, /* Baud Rate Generator 12 */ ++ QE_BRG13, /* Baud Rate Generator 13 */ ++ QE_BRG14, /* Baud Rate Generator 14 */ ++ QE_BRG15, /* Baud Rate Generator 15 */ ++ QE_BRG16, /* Baud Rate Generator 16 */ ++ QE_CLK1, /* Clock 1 */ ++ QE_CLK2, /* Clock 2 */ ++ QE_CLK3, /* Clock 3 */ ++ QE_CLK4, /* Clock 4 */ ++ QE_CLK5, /* Clock 5 */ ++ QE_CLK6, /* Clock 6 */ ++ QE_CLK7, /* Clock 7 */ ++ QE_CLK8, /* Clock 8 */ ++ QE_CLK9, /* Clock 9 */ ++ QE_CLK10, /* Clock 10 */ ++ QE_CLK11, /* Clock 11 */ ++ QE_CLK12, /* Clock 12 */ ++ QE_CLK13, /* Clock 13 */ ++ QE_CLK14, /* Clock 14 */ ++ QE_CLK15, /* Clock 15 */ ++ QE_CLK16, /* Clock 16 */ ++ QE_CLK17, /* Clock 17 */ ++ QE_CLK18, /* Clock 18 */ ++ QE_CLK19, /* Clock 19 */ ++ QE_CLK20, /* Clock 20 */ ++ QE_CLK21, /* Clock 21 */ ++ QE_CLK22, /* Clock 22 */ ++ QE_CLK23, /* Clock 23 */ ++ QE_CLK24, /* Clock 24 */ ++ QE_CLK_DUMMY ++}; ++ + /* Export QE common operations */ + extern void qe_reset(void); + extern int par_io_init(struct device_node *np); +@@ -38,7 +84,8 @@ + + /* QE internal API */ + int qe_issue_cmd(u32 cmd, u32 device, u8 mcn_protocol, u32 cmd_input); +-void qe_setbrg(unsigned int brg, unsigned int rate, unsigned int multiplier); ++enum qe_clock qe_clock_source(const char *source); ++int qe_setbrg(enum qe_clock brg, unsigned int rate, unsigned int multiplier); + int qe_get_snum(void); + void qe_put_snum(u8 snum); + unsigned long qe_muram_alloc(int size, int align); +@@ -47,6 +94,58 @@ + void qe_muram_dump(void); + void *qe_muram_addr(unsigned long offset); + ++/* Structure that defines QE firmware binary files. ++ * ++ * See Documentation/powerpc/qe-firmware.txt for a description of these ++ * fields. ++ */ ++struct qe_firmware { ++ struct qe_header { ++ __be32 length; /* Length of the entire structure, in bytes */ ++ u8 magic[3]; /* Set to { 'Q', 'E', 'F' } */ ++ u8 version; /* Version of this layout. First ver is '1' */ ++ } header; ++ u8 id[62]; /* Null-terminated identifier string */ ++ u8 split; /* 0 = shared I-RAM, 1 = split I-RAM */ ++ u8 count; /* Number of microcode[] structures */ ++ struct { ++ __be16 model; /* The SOC model */ ++ u8 major; /* The SOC revision major */ ++ u8 minor; /* The SOC revision minor */ ++ } __attribute__ ((packed)) soc; ++ u8 padding[4]; /* Reserved, for alignment */ ++ __be64 extended_modes; /* Extended modes */ ++ __be32 vtraps[8]; /* Virtual trap addresses */ ++ u8 reserved[4]; /* Reserved, for future expansion */ ++ struct qe_microcode { ++ u8 id[32]; /* Null-terminated identifier */ ++ __be32 traps[16]; /* Trap addresses, 0 == ignore */ ++ __be32 eccr; /* The value for the ECCR register */ ++ __be32 iram_offset; /* Offset into I-RAM for the code */ ++ __be32 count; /* Number of 32-bit words of the code */ ++ __be32 code_offset; /* Offset of the actual microcode */ ++ u8 major; /* The microcode version major */ ++ u8 minor; /* The microcode version minor */ ++ u8 revision; /* The microcode version revision */ ++ u8 padding; /* Reserved, for alignment */ ++ u8 reserved[4]; /* Reserved, for future expansion */ ++ } __attribute__ ((packed)) microcode[1]; ++ /* All microcode binaries should be located here */ ++ /* CRC32 should be located here, after the microcode binaries */ ++} __attribute__ ((packed)); ++ ++struct qe_firmware_info { ++ char id[64]; /* Firmware name */ ++ u32 vtraps[8]; /* Virtual trap addresses */ ++ u64 extended_modes; /* Extended modes */ ++}; ++ ++/* Upload a firmware to the QE */ ++int qe_upload_firmware(const struct qe_firmware *firmware); ++ ++/* Obtain information on the uploaded firmware */ ++struct qe_firmware_info *qe_get_firmware_info(void); ++ + /* Buffer descriptors */ + struct qe_bd { + __be16 status; +@@ -129,52 +228,6 @@ + COMM_DIR_RX_AND_TX = 3 + }; + +-/* Clocks and BRGs */ +-enum qe_clock { +- QE_CLK_NONE = 0, +- QE_BRG1, /* Baud Rate Generator 1 */ +- QE_BRG2, /* Baud Rate Generator 2 */ +- QE_BRG3, /* Baud Rate Generator 3 */ +- QE_BRG4, /* Baud Rate Generator 4 */ +- QE_BRG5, /* Baud Rate Generator 5 */ +- QE_BRG6, /* Baud Rate Generator 6 */ +- QE_BRG7, /* Baud Rate Generator 7 */ +- QE_BRG8, /* Baud Rate Generator 8 */ +- QE_BRG9, /* Baud Rate Generator 9 */ +- QE_BRG10, /* Baud Rate Generator 10 */ +- QE_BRG11, /* Baud Rate Generator 11 */ +- QE_BRG12, /* Baud Rate Generator 12 */ +- QE_BRG13, /* Baud Rate Generator 13 */ +- QE_BRG14, /* Baud Rate Generator 14 */ +- QE_BRG15, /* Baud Rate Generator 15 */ +- QE_BRG16, /* Baud Rate Generator 16 */ +- QE_CLK1, /* Clock 1 */ +- QE_CLK2, /* Clock 2 */ +- QE_CLK3, /* Clock 3 */ +- QE_CLK4, /* Clock 4 */ +- QE_CLK5, /* Clock 5 */ +- QE_CLK6, /* Clock 6 */ +- QE_CLK7, /* Clock 7 */ +- QE_CLK8, /* Clock 8 */ +- QE_CLK9, /* Clock 9 */ +- QE_CLK10, /* Clock 10 */ +- QE_CLK11, /* Clock 11 */ +- QE_CLK12, /* Clock 12 */ +- QE_CLK13, /* Clock 13 */ +- QE_CLK14, /* Clock 14 */ +- QE_CLK15, /* Clock 15 */ +- QE_CLK16, /* Clock 16 */ +- QE_CLK17, /* Clock 17 */ +- QE_CLK18, /* Clock 18 */ +- QE_CLK19, /* Clock 19 */ +- QE_CLK20, /* Clock 20 */ +- QE_CLK21, /* Clock 21 */ +- QE_CLK22, /* Clock 22 */ +- QE_CLK23, /* Clock 23 */ +- QE_CLK24, /* Clock 24 */ +- QE_CLK_DUMMY, +-}; +- + /* QE CMXUCR Registers. + * There are two UCCs represented in each of the four CMXUCR registers. + * These values are for the UCC in the LSBs +@@ -328,6 +381,15 @@ + + #define QE_SDEBCR_BA_MASK 0x01FFFFFF + ++/* Communication Processor */ ++#define QE_CP_CERCR_MEE 0x8000 /* Multi-user RAM ECC enable */ ++#define QE_CP_CERCR_IEE 0x4000 /* Instruction RAM ECC enable */ ++#define QE_CP_CERCR_CIR 0x0800 /* Common instruction RAM */ ++ ++/* I-RAM */ ++#define QE_IRAM_IADD_AIE 0x80000000 /* Auto Increment Enable */ ++#define QE_IRAM_IADD_BADDR 0x00080000 /* Base Address */ ++ + /* UPC */ + #define UPGCR_PROTOCOL 0x80000000 /* protocol ul2 or pl2 */ + #define UPGCR_TMS 0x40000000 /* Transmit master/slave mode */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/reg.h powerpc.git/include/asm-powerpc/reg.h +--- linux-2.6.24/include/asm-powerpc/reg.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/reg.h 2008-01-28 20:26:42.000000000 +0100 +@@ -553,6 +553,7 @@ + #define SPRN_PA6T_BTCR 978 /* Breakpoint and Tagging Control Register */ + #define SPRN_PA6T_IMAAT 979 /* Instruction Match Array Action Table */ + #define SPRN_PA6T_PCCR 1019 /* Power Counter Control Register */ ++#define SPRN_BKMK 1020 /* Cell Bookmark Register */ + #define SPRN_PA6T_RPCCR 1021 /* Retire PC Trace Control Register */ + + +@@ -691,12 +692,6 @@ + #define PV_BE 0x0070 + #define PV_PA6T 0x0090 + +-/* +- * Number of entries in the SLB. If this ever changes we should handle +- * it with a use a cpu feature fixup. +- */ +-#define SLB_NUM_ENTRIES 64 +- + /* Macros for setting and retrieving special purpose registers */ + #ifndef __ASSEMBLY__ + #define mfmsr() ({unsigned long rval; \ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/reg_booke.h powerpc.git/include/asm-powerpc/reg_booke.h +--- linux-2.6.24/include/asm-powerpc/reg_booke.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/reg_booke.h 2008-01-28 20:26:42.000000000 +0100 +@@ -123,16 +123,23 @@ + #define SPRN_SPEFSCR 0x200 /* SPE & Embedded FP Status & Control */ + #define SPRN_BBEAR 0x201 /* Branch Buffer Entry Address Register */ + #define SPRN_BBTAR 0x202 /* Branch Buffer Target Address Register */ ++#define SPRN_ATB 0x20E /* Alternate Time Base */ ++#define SPRN_ATBL 0x20E /* Alternate Time Base Lower */ ++#define SPRN_ATBU 0x20F /* Alternate Time Base Upper */ + #define SPRN_IVOR32 0x210 /* Interrupt Vector Offset Register 32 */ + #define SPRN_IVOR33 0x211 /* Interrupt Vector Offset Register 33 */ + #define SPRN_IVOR34 0x212 /* Interrupt Vector Offset Register 34 */ + #define SPRN_IVOR35 0x213 /* Interrupt Vector Offset Register 35 */ ++#define SPRN_IVOR36 0x214 /* Interrupt Vector Offset Register 36 */ ++#define SPRN_IVOR37 0x215 /* Interrupt Vector Offset Register 37 */ + #define SPRN_MCSRR0 0x23A /* Machine Check Save and Restore Register 0 */ + #define SPRN_MCSRR1 0x23B /* Machine Check Save and Restore Register 1 */ + #define SPRN_MCSR 0x23C /* Machine Check Status Register */ + #define SPRN_MCAR 0x23D /* Machine Check Address Register */ + #define SPRN_DSRR0 0x23E /* Debug Save and Restore Register 0 */ + #define SPRN_DSRR1 0x23F /* Debug Save and Restore Register 1 */ ++#define SPRN_SPRG8 0x25C /* Special Purpose Register General 8 */ ++#define SPRN_SPRG9 0x25D /* Special Purpose Register General 9 */ + #define SPRN_MAS0 0x270 /* MMU Assist Register 0 */ + #define SPRN_MAS1 0x271 /* MMU Assist Register 1 */ + #define SPRN_MAS2 0x272 /* MMU Assist Register 2 */ +@@ -140,15 +147,18 @@ + #define SPRN_MAS4 0x274 /* MMU Assist Register 4 */ + #define SPRN_MAS5 0x275 /* MMU Assist Register 5 */ + #define SPRN_MAS6 0x276 /* MMU Assist Register 6 */ +-#define SPRN_MAS7 0x3b0 /* MMU Assist Register 7 */ + #define SPRN_PID1 0x279 /* Process ID Register 1 */ + #define SPRN_PID2 0x27A /* Process ID Register 2 */ + #define SPRN_TLB0CFG 0x2B0 /* TLB 0 Config Register */ + #define SPRN_TLB1CFG 0x2B1 /* TLB 1 Config Register */ ++#define SPRN_EPR 0x2BE /* External Proxy Register */ + #define SPRN_CCR1 0x378 /* Core Configuration Register 1 */ + #define SPRN_ZPR 0x3B0 /* Zone Protection Register (40x) */ ++#define SPRN_MAS7 0x3B0 /* MMU Assist Register 7 */ + #define SPRN_MMUCR 0x3B2 /* MMU Control Register */ + #define SPRN_CCR0 0x3B3 /* Core Configuration Register 0 */ ++#define SPRN_EPLC 0x3B3 /* External Process ID Load Context */ ++#define SPRN_EPSC 0x3B4 /* External Process ID Store Context */ + #define SPRN_SGR 0x3B9 /* Storage Guarded Register */ + #define SPRN_DCWR 0x3BA /* Data Cache Write-thru Register */ + #define SPRN_SLER 0x3BB /* Little-endian real mode */ +@@ -159,6 +169,7 @@ + #define SPRN_L1CSR0 0x3F2 /* L1 Cache Control and Status Register 0 */ + #define SPRN_L1CSR1 0x3F3 /* L1 Cache Control and Status Register 1 */ + #define SPRN_PIT 0x3DB /* Programmable Interval Timer */ ++#define SPRN_BUCSR 0x3F5 /* Branch Unit Control and Status */ + #define SPRN_DCCR 0x3FA /* Data Cache Cacheability Register */ + #define SPRN_ICCR 0x3FB /* Instruction Cache Cacheability Register */ + #define SPRN_SVR 0x3FF /* System Version Register */ +@@ -207,7 +218,6 @@ + #define CCR1_TCS 0x00000080 /* Timer Clock Select */ + + /* Bit definitions for the MCSR. */ +-#ifdef CONFIG_440A + #define MCSR_MCS 0x80000000 /* Machine Check Summary */ + #define MCSR_IB 0x40000000 /* Instruction PLB Error */ + #define MCSR_DRB 0x20000000 /* Data Read PLB Error */ +@@ -217,7 +227,7 @@ + #define MCSR_DCSP 0x02000000 /* D-Cache Search Parity Error */ + #define MCSR_DCFP 0x01000000 /* D-Cache Flush Parity Error */ + #define MCSR_IMPE 0x00800000 /* Imprecise Machine Check Exception */ +-#endif ++ + #ifdef CONFIG_E500 + #define MCSR_MCP 0x80000000UL /* Machine Check Input Pin */ + #define MCSR_ICPERR 0x40000000UL /* I-Cache Parity Error */ +@@ -293,7 +303,7 @@ + #define ESR_IMCB 0x20000000 /* Instr. Machine Check - Bus error */ + #define ESR_IMCT 0x10000000 /* Instr. Machine Check - Timeout */ + #define ESR_PIL 0x08000000 /* Program Exception - Illegal */ +-#define ESR_PPR 0x04000000 /* Program Exception - Priveleged */ ++#define ESR_PPR 0x04000000 /* Program Exception - Privileged */ + #define ESR_PTR 0x02000000 /* Program Exception - Trap */ + #define ESR_FP 0x01000000 /* Floating Point Operation */ + #define ESR_DST 0x00800000 /* Storage Exception - Data miss */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/setjmp.h powerpc.git/include/asm-powerpc/setjmp.h +--- linux-2.6.24/include/asm-powerpc/setjmp.h 1970-01-01 01:00:00.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/setjmp.h 2008-01-28 20:26:42.000000000 +0100 +@@ -0,0 +1,18 @@ ++/* ++ * Copyright © 2008 Michael Neuling IBM Corporation ++ * ++ * This program is free software; you can redistribute it and/or ++ * modify it under the terms of the GNU General Public License ++ * as published by the Free Software Foundation; either version ++ * 2 of the License, or (at your option) any later version. ++ * ++ */ ++#ifndef _ASM_POWERPC_SETJMP_H ++#define _ASM_POWERPC_SETJMP_H ++ ++#define JMP_BUF_LEN 23 ++ ++extern long setjmp(long *); ++extern void longjmp(long *, long); ++ ++#endif /* _ASM_POWERPC_SETJMP_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/smu.h powerpc.git/include/asm-powerpc/smu.h +--- linux-2.6.24/include/asm-powerpc/smu.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/smu.h 2008-01-28 20:26:42.000000000 +0100 +@@ -22,7 +22,7 @@ + * Partition info commands + * + * These commands are used to retrieve the sdb-partition-XX datas from +- * the SMU. The lenght is always 2. First byte is the subcommand code ++ * the SMU. The length is always 2. First byte is the subcommand code + * and second byte is the partition ID. + * + * The reply is 6 bytes: +@@ -173,12 +173,12 @@ + * Power supply control + * + * The "sub" command is an ASCII string in the data, the +- * data lenght is that of the string. ++ * data length is that of the string. + * + * The VSLEW command can be used to get or set the voltage slewing. +- * - lenght 5 (only "VSLEW") : it returns "DONE" and 3 bytes of ++ * - length 5 (only "VSLEW") : it returns "DONE" and 3 bytes of + * reply at data offset 6, 7 and 8. +- * - lenght 8 ("VSLEWxyz") has 3 additional bytes appended, and is ++ * - length 8 ("VSLEWxyz") has 3 additional bytes appended, and is + * used to set the voltage slewing point. The SMU replies with "DONE" + * I yet have to figure out their exact meaning of those 3 bytes in + * both cases. They seem to be: +@@ -201,20 +201,90 @@ + */ + #define SMU_CMD_READ_ADC 0xd8 + ++ + /* Misc commands + * + * This command seem to be a grab bag of various things ++ * ++ * Parameters: ++ * 1: subcommand + */ + #define SMU_CMD_MISC_df_COMMAND 0xdf +-#define SMU_CMD_MISC_df_SET_DISPLAY_LIT 0x02 /* i: 1 byte */ ++ ++/* ++ * Sets "system ready" status ++ * ++ * I did not yet understand how it exactly works or what it does. ++ * ++ * Guessing from OF code, 0x02 activates the display backlight. Apple uses/used ++ * the same codebase for all OF versions. On PowerBooks, this command would ++ * enable the backlight. For the G5s, it only activates the front LED. However, ++ * don't take this for granted. ++ * ++ * Parameters: ++ * 2: status [0x00, 0x01 or 0x02] ++ */ ++#define SMU_CMD_MISC_df_SET_DISPLAY_LIT 0x02 ++ ++/* ++ * Sets mode of power switch. ++ * ++ * What this actually does is not yet known. Maybe it enables some interrupt. ++ * ++ * Parameters: ++ * 2: enable power switch? [0x00 or 0x01] ++ * 3 (optional): enable nmi? [0x00 or 0x01] ++ * ++ * Returns: ++ * If parameter 2 is 0x00 and parameter 3 is not specified, returns wether ++ * NMI is enabled. Otherwise unknown. ++ */ + #define SMU_CMD_MISC_df_NMI_OPTION 0x04 + ++/* Sets LED dimm offset. ++ * ++ * The front LED dimms itself during sleep. Its brightness (or, well, the PWM ++ * frequency) depends on current time. Therefore, the SMU needs to know the ++ * timezone. ++ * ++ * Parameters: ++ * 2-8: unknown (BCD coding) ++ */ ++#define SMU_CMD_MISC_df_DIMM_OFFSET 0x99 ++ ++ + /* + * Version info commands + * +- * I haven't quite tried to figure out how these work ++ * Parameters: ++ * 1 (optional): Specifies version part to retrieve ++ * ++ * Returns: ++ * Version value + */ + #define SMU_CMD_VERSION_COMMAND 0xea ++#define SMU_VERSION_RUNNING 0x00 ++#define SMU_VERSION_BASE 0x01 ++#define SMU_VERSION_UPDATE 0x02 ++ ++ ++/* ++ * Switches ++ * ++ * These are switches whose status seems to be known to the SMU. ++ * ++ * Parameters: ++ * none ++ * ++ * Result: ++ * Switch bits (ORed, see below) ++ */ ++#define SMU_CMD_SWITCHES 0xdc ++ ++/* Switches bits */ ++#define SMU_SWITCH_CASE_CLOSED 0x01 ++#define SMU_SWITCH_AC_POWER 0x04 ++#define SMU_SWITCH_POWER_SWITCH 0x08 + + + /* +@@ -243,10 +313,64 @@ + */ + #define SMU_CMD_MISC_ee_COMMAND 0xee + #define SMU_CMD_MISC_ee_GET_DATABLOCK_REC 0x02 +-#define SMU_CMD_MISC_ee_LEDS_CTRL 0x04 /* i: 00 (00,01) [00] */ ++ ++/* Retrieves currently used watts. ++ * ++ * Parameters: ++ * 1: 0x03 (Meaning unknown) ++ */ ++#define SMU_CMD_MISC_ee_GET_WATTS 0x03 ++ ++#define SMU_CMD_MISC_ee_LEDS_CTRL 0x04 /* i: 00 (00,01) [00] */ + #define SMU_CMD_MISC_ee_GET_DATA 0x05 /* i: 00 , o: ?? */ + + ++/* ++ * Power related commands ++ * ++ * Parameters: ++ * 1: subcommand ++ */ ++#define SMU_CMD_POWER_EVENTS_COMMAND 0x8f ++ ++/* SMU_POWER_EVENTS subcommands */ ++enum { ++ SMU_PWR_GET_POWERUP_EVENTS = 0x00, ++ SMU_PWR_SET_POWERUP_EVENTS = 0x01, ++ SMU_PWR_CLR_POWERUP_EVENTS = 0x02, ++ SMU_PWR_GET_WAKEUP_EVENTS = 0x03, ++ SMU_PWR_SET_WAKEUP_EVENTS = 0x04, ++ SMU_PWR_CLR_WAKEUP_EVENTS = 0x05, ++ ++ /* ++ * Get last shutdown cause ++ * ++ * Returns: ++ * 1 byte (signed char): Last shutdown cause. Exact meaning unknown. ++ */ ++ SMU_PWR_LAST_SHUTDOWN_CAUSE = 0x07, ++ ++ /* ++ * Sets or gets server ID. Meaning or use is unknown. ++ * ++ * Parameters: ++ * 2 (optional): Set server ID (1 byte) ++ * ++ * Returns: ++ * 1 byte (server ID?) ++ */ ++ SMU_PWR_SERVER_ID = 0x08, ++}; ++ ++/* Power events wakeup bits */ ++enum { ++ SMU_PWR_WAKEUP_KEY = 0x01, /* Wake on key press */ ++ SMU_PWR_WAKEUP_AC_INSERT = 0x02, /* Wake on AC adapter plug */ ++ SMU_PWR_WAKEUP_AC_CHANGE = 0x04, ++ SMU_PWR_WAKEUP_LID_OPEN = 0x08, ++ SMU_PWR_WAKEUP_RING = 0x10, ++}; ++ + + /* + * - Kernel side interface - +@@ -564,13 +688,13 @@ + + __u8 cmd; /* SMU command byte */ + __u8 pad[3]; /* padding */ +- __u32 data_len; /* Lenght of data following */ ++ __u32 data_len; /* Length of data following */ + }; + + struct smu_user_reply_hdr + { + __u32 status; /* Command status */ +- __u32 reply_len; /* Lenght of data follwing */ ++ __u32 reply_len; /* Length of data follwing */ + }; + + #endif /* _SMU_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/sparsemem.h powerpc.git/include/asm-powerpc/sparsemem.h +--- linux-2.6.24/include/asm-powerpc/sparsemem.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/sparsemem.h 2008-01-28 20:26:42.000000000 +0100 +@@ -10,13 +10,8 @@ + */ + #define SECTION_SIZE_BITS 24 + +-#if defined(CONFIG_PS3_USE_LPAR_ADDR) +-#define MAX_PHYSADDR_BITS 47 +-#define MAX_PHYSMEM_BITS 47 +-#else + #define MAX_PHYSADDR_BITS 44 + #define MAX_PHYSMEM_BITS 44 +-#endif + + #ifdef CONFIG_MEMORY_HOTPLUG + extern void create_section_mapping(unsigned long start, unsigned long end); +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/spu.h powerpc.git/include/asm-powerpc/spu.h +--- linux-2.6.24/include/asm-powerpc/spu.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/spu.h 2008-01-28 20:26:42.000000000 +0100 +@@ -104,6 +104,7 @@ + + struct spu_context; + struct spu_runqueue; ++struct spu_lscsa; + struct device_node; + + enum spu_utilization_state { +@@ -145,7 +146,6 @@ + void (* ibox_callback)(struct spu *spu); + void (* stop_callback)(struct spu *spu); + void (* mfc_callback)(struct spu *spu); +- void (* dma_callback)(struct spu *spu, int type); + + char irq_c0[8]; + char irq_c1[8]; +@@ -196,10 +196,11 @@ + extern struct cbe_spu_info cbe_spu_info[]; + + void spu_init_channels(struct spu *spu); +-int spu_irq_class_0_bottom(struct spu *spu); +-int spu_irq_class_1_bottom(struct spu *spu); + void spu_irq_setaffinity(struct spu *spu, int cpu); + ++void spu_setup_kernel_slbs(struct spu *spu, struct spu_lscsa *lscsa, ++ void *code, int code_size); ++ + #ifdef CONFIG_KEXEC + void crash_register_spus(struct list_head *list); + #else +@@ -210,6 +211,7 @@ + + extern void spu_invalidate_slbs(struct spu *spu); + extern void spu_associate_mm(struct spu *spu, struct mm_struct *mm); ++int spu_64k_pages_available(void); + + /* Calls from the memory management to the SPU */ + struct mm_struct; +@@ -279,6 +281,8 @@ + int spu_add_sysdev_attr_group(struct attribute_group *attrs); + void spu_remove_sysdev_attr_group(struct attribute_group *attrs); + ++int spu_handle_mm_fault(struct mm_struct *mm, unsigned long ea, ++ unsigned long dsisr, unsigned *flt); + + /* + * Notifier blocks: +@@ -303,7 +307,7 @@ + extern void do_notify_spus_active(void); + + /* +- * This defines the Local Store, Problem Area and Privlege Area of an SPU. ++ * This defines the Local Store, Problem Area and Privilege Area of an SPU. + */ + + union mfc_tag_size_class_cmd { +@@ -524,8 +528,24 @@ + #define CLASS2_ENABLE_SPU_STOP_INTR 0x2L + #define CLASS2_ENABLE_SPU_HALT_INTR 0x4L + #define CLASS2_ENABLE_SPU_DMA_TAG_GROUP_COMPLETE_INTR 0x8L ++#define CLASS2_ENABLE_MAILBOX_THRESHOLD_INTR 0x10L + u8 pad_0x118_0x140[0x28]; /* 0x118 */ + u64 int_stat_RW[3]; /* 0x140 */ ++#define CLASS0_DMA_ALIGNMENT_INTR 0x1L ++#define CLASS0_INVALID_DMA_COMMAND_INTR 0x2L ++#define CLASS0_SPU_ERROR_INTR 0x4L ++#define CLASS0_INTR_MASK 0x7L ++#define CLASS1_SEGMENT_FAULT_INTR 0x1L ++#define CLASS1_STORAGE_FAULT_INTR 0x2L ++#define CLASS1_LS_COMPARE_SUSPEND_ON_GET_INTR 0x4L ++#define CLASS1_LS_COMPARE_SUSPEND_ON_PUT_INTR 0x8L ++#define CLASS1_INTR_MASK 0xfL ++#define CLASS2_MAILBOX_INTR 0x1L ++#define CLASS2_SPU_STOP_INTR 0x2L ++#define CLASS2_SPU_HALT_INTR 0x4L ++#define CLASS2_SPU_DMA_TAG_GROUP_COMPLETE_INTR 0x8L ++#define CLASS2_MAILBOX_THRESHOLD_INTR 0x10L ++#define CLASS2_INTR_MASK 0x1fL + u8 pad_0x158_0x180[0x28]; /* 0x158 */ + u64 int_route_RW; /* 0x180 */ + +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/spu_csa.h powerpc.git/include/asm-powerpc/spu_csa.h +--- linux-2.6.24/include/asm-powerpc/spu_csa.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/spu_csa.h 2008-01-28 20:26:42.000000000 +0100 +@@ -194,7 +194,7 @@ + }; + + /* +- * struct spu_priv2_collapsed - condensed priviliged 2 area, w/o pads. ++ * struct spu_priv2_collapsed - condensed privileged 2 area, w/o pads. + */ + struct spu_priv2_collapsed { + u64 slb_index_W; +@@ -254,20 +254,11 @@ + u64 spu_chnldata_RW[32]; + u32 spu_mailbox_data[4]; + u32 pu_mailbox_data[1]; +- u64 dar, dsisr; ++ u64 dar, dsisr, class_0_pending; + unsigned long suspend_time; + spinlock_t register_lock; + }; + +-extern int spu_init_csa(struct spu_state *csa); +-extern void spu_fini_csa(struct spu_state *csa); +-extern int spu_save(struct spu_state *prev, struct spu *spu); +-extern int spu_restore(struct spu_state *new, struct spu *spu); +-extern int spu_switch(struct spu_state *prev, struct spu_state *new, +- struct spu *spu); +-extern int spu_alloc_lscsa(struct spu_state *csa); +-extern void spu_free_lscsa(struct spu_state *csa); +- + #endif /* !__SPU__ */ + #endif /* __KERNEL__ */ + #endif /* !__ASSEMBLY__ */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/spu_priv1.h powerpc.git/include/asm-powerpc/spu_priv1.h +--- linux-2.6.24/include/asm-powerpc/spu_priv1.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/spu_priv1.h 2008-01-28 20:26:42.000000000 +0100 +@@ -24,6 +24,7 @@ + #include <linux/types.h> + + struct spu; ++struct spu_context; + + /* access to priv1 registers */ + +@@ -178,6 +179,8 @@ + int (*enumerate_spus)(int (*fn)(void *data)); + int (*create_spu)(struct spu *spu, void *data); + int (*destroy_spu)(struct spu *spu); ++ void (*enable_spu)(struct spu_context *ctx); ++ void (*disable_spu)(struct spu_context *ctx); + int (*init_affinity)(void); + }; + +@@ -207,6 +210,18 @@ + return spu_management_ops->init_affinity(); + } + ++static inline void ++spu_enable_spu (struct spu_context *ctx) ++{ ++ spu_management_ops->enable_spu(ctx); ++} ++ ++static inline void ++spu_disable_spu (struct spu_context *ctx) ++{ ++ spu_management_ops->disable_spu(ctx); ++} ++ + /* + * The declarations folowing are put here for convenience + * and only intended to be used by the platform setup code. +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/system.h powerpc.git/include/asm-powerpc/system.h +--- linux-2.6.24/include/asm-powerpc/system.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/system.h 2008-01-28 20:26:42.000000000 +0100 +@@ -169,6 +169,8 @@ + extern void bad_page_fault(struct pt_regs *, unsigned long, int); + extern int die(const char *, struct pt_regs *, long); + extern void _exception(int, struct pt_regs *, int, unsigned long); ++extern void _nmask_and_or_msr(unsigned long nmask, unsigned long or_val); ++ + #ifdef CONFIG_BOOKE_WDT + extern u32 booke_wdt_enabled; + extern u32 booke_wdt_period; +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-powerpc/udbg.h powerpc.git/include/asm-powerpc/udbg.h +--- linux-2.6.24/include/asm-powerpc/udbg.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-powerpc/udbg.h 2008-01-28 20:26:42.000000000 +0100 +@@ -48,6 +48,7 @@ + extern void __init udbg_init_debug_beat(void); + extern void __init udbg_init_btext(void); + extern void __init udbg_init_44x_as1(void); ++extern void __init udbg_init_40x_realmode(void); + extern void __init udbg_init_cpm(void); + + #endif /* __KERNEL__ */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-ppc/8xx_immap.h powerpc.git/include/asm-ppc/8xx_immap.h +--- linux-2.6.24/include/asm-ppc/8xx_immap.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-ppc/8xx_immap.h 2008-01-28 20:26:42.000000000 +0100 +@@ -123,7 +123,7 @@ + #define OR_G5LA 0x00000400 /* Output #GPL5 on #GPL_A5 */ + #define OR_G5LS 0x00000200 /* Drive #GPL high on falling edge of...*/ + #define OR_BI 0x00000100 /* Burst inhibit */ +-#define OR_SCY_MSK 0x000000f0 /* Cycle Lenght in Clocks */ ++#define OR_SCY_MSK 0x000000f0 /* Cycle Length in Clocks */ + #define OR_SCY_0_CLK 0x00000000 /* 0 clock cycles wait states */ + #define OR_SCY_1_CLK 0x00000010 /* 1 clock cycles wait states */ + #define OR_SCY_2_CLK 0x00000020 /* 2 clock cycles wait states */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-ppc/commproc.h powerpc.git/include/asm-ppc/commproc.h +--- linux-2.6.24/include/asm-ppc/commproc.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-ppc/commproc.h 2008-01-28 20:26:42.000000000 +0100 +@@ -681,7 +681,7 @@ + #define CICR_SCC_SCC3 ((uint)0x00200000) /* SCC3 @ SCCc */ + #define CICR_SCB_SCC2 ((uint)0x00040000) /* SCC2 @ SCCb */ + #define CICR_SCA_SCC1 ((uint)0x00000000) /* SCC1 @ SCCa */ +-#define CICR_IRL_MASK ((uint)0x0000e000) /* Core interrrupt */ ++#define CICR_IRL_MASK ((uint)0x0000e000) /* Core interrupt */ + #define CICR_HP_MASK ((uint)0x00001f00) /* Hi-pri int. */ + #define CICR_IEN ((uint)0x00000080) /* Int. enable */ + #define CICR_SPS ((uint)0x00000001) /* SCC Spread */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-ppc/mmu.h powerpc.git/include/asm-ppc/mmu.h +--- linux-2.6.24/include/asm-ppc/mmu.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-ppc/mmu.h 2008-01-28 20:26:43.000000000 +0100 +@@ -383,6 +383,12 @@ + #define BOOKE_PAGESZ_256GB 14 + #define BOOKE_PAGESZ_1TB 15 + ++#ifndef CONFIG_SERIAL_TEXT_DEBUG ++#define PPC44x_EARLY_TLBS 1 ++#else ++#define PPC44x_EARLY_TLBS 2 ++#endif ++ + /* + * Freescale Book-E MMU support + */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-ppc/mpc52xx_psc.h powerpc.git/include/asm-ppc/mpc52xx_psc.h +--- linux-2.6.24/include/asm-ppc/mpc52xx_psc.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-ppc/mpc52xx_psc.h 2008-01-28 20:26:43.000000000 +0100 +@@ -159,6 +159,9 @@ + u8 reserved16[3]; + u8 irfdr; /* PSC + 0x54 */ + u8 reserved17[3]; ++}; ++ ++struct mpc52xx_psc_fifo { + u16 rfnum; /* PSC + 0x58 */ + u16 reserved18; + u16 tfnum; /* PSC + 0x5c */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/asm-ppc/reg_booke.h powerpc.git/include/asm-ppc/reg_booke.h +--- linux-2.6.24/include/asm-ppc/reg_booke.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/asm-ppc/reg_booke.h 2008-01-28 20:26:43.000000000 +0100 +@@ -207,7 +207,7 @@ + #define CCR1_TCS 0x00000080 /* Timer Clock Select */ + + /* Bit definitions for the MCSR. */ +-#ifdef CONFIG_440A ++#ifdef CONFIG_4xx + #define MCSR_MCS 0x80000000 /* Machine Check Summary */ + #define MCSR_IB 0x40000000 /* Instruction PLB Error */ + #define MCSR_DRB 0x20000000 /* Data Read PLB Error */ +@@ -283,7 +283,7 @@ + #define ESR_IMCB 0x20000000 /* Instr. Machine Check - Bus error */ + #define ESR_IMCT 0x10000000 /* Instr. Machine Check - Timeout */ + #define ESR_PIL 0x08000000 /* Program Exception - Illegal */ +-#define ESR_PPR 0x04000000 /* Program Exception - Priveleged */ ++#define ESR_PPR 0x04000000 /* Program Exception - Privileged */ + #define ESR_PTR 0x02000000 /* Program Exception - Trap */ + #define ESR_FP 0x01000000 /* Floating Point Operation */ + #define ESR_DST 0x00800000 /* Storage Exception - Data miss */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/linux/of.h powerpc.git/include/linux/of.h +--- linux-2.6.24/include/linux/of.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/linux/of.h 2008-01-28 20:26:44.000000000 +0100 +@@ -17,6 +17,7 @@ + */ + #include <linux/types.h> + #include <linux/bitops.h> ++#include <linux/mod_devicetable.h> + + #include <asm/prom.h> + +@@ -41,11 +42,20 @@ + #define for_each_compatible_node(dn, type, compatible) \ + for (dn = of_find_compatible_node(NULL, type, compatible); dn; \ + dn = of_find_compatible_node(dn, type, compatible)) ++extern struct device_node *of_find_matching_node(struct device_node *from, ++ const struct of_device_id *matches); ++#define for_each_matching_node(dn, matches) \ ++ for (dn = of_find_matching_node(NULL, matches); dn; \ ++ dn = of_find_matching_node(dn, matches)) + extern struct device_node *of_find_node_by_path(const char *path); + extern struct device_node *of_find_node_by_phandle(phandle handle); + extern struct device_node *of_get_parent(const struct device_node *node); + extern struct device_node *of_get_next_child(const struct device_node *node, + struct device_node *prev); ++#define for_each_child_of_node(parent, child) \ ++ for (child = of_get_next_child(parent, NULL); child != NULL; \ ++ child = of_get_next_child(parent, child)) ++ + extern struct property *of_find_property(const struct device_node *np, + const char *name, + int *lenp); +@@ -56,5 +66,7 @@ + int *lenp); + extern int of_n_addr_cells(struct device_node *np); + extern int of_n_size_cells(struct device_node *np); ++extern const struct of_device_id *of_match_node( ++ const struct of_device_id *matches, const struct device_node *node); + + #endif /* _LINUX_OF_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/linux/of_device.h powerpc.git/include/linux/of_device.h +--- linux-2.6.24/include/linux/of_device.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/linux/of_device.h 2008-01-28 20:26:44.000000000 +0100 +@@ -10,8 +10,6 @@ + + #define to_of_device(d) container_of(d, struct of_device, dev) + +-extern const struct of_device_id *of_match_node( +- const struct of_device_id *matches, const struct device_node *node); + extern const struct of_device_id *of_match_device( + const struct of_device_id *matches, const struct of_device *dev); + +diff -x .git -x .gitignore -Nur linux-2.6.24/include/linux/pata_platform.h powerpc.git/include/linux/pata_platform.h +--- linux-2.6.24/include/linux/pata_platform.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/linux/pata_platform.h 2008-01-28 20:26:44.000000000 +0100 +@@ -15,4 +15,13 @@ + unsigned int irq_flags; + }; + ++extern int __devinit __pata_platform_probe(struct device *dev, ++ struct resource *io_res, ++ struct resource *ctl_res, ++ struct resource *irq_res, ++ unsigned int ioport_shift, ++ int __pio_mask); ++ ++extern int __devexit __pata_platform_remove(struct device *dev); ++ + #endif /* __LINUX_PATA_PLATFORM_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/linux/phy_fixed.h powerpc.git/include/linux/phy_fixed.h +--- linux-2.6.24/include/linux/phy_fixed.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/linux/phy_fixed.h 2008-01-28 20:26:44.000000000 +0100 +@@ -1,38 +1,31 @@ + #ifndef __PHY_FIXED_H + #define __PHY_FIXED_H + +-#define MII_REGS_NUM 29 +- +-/* max number of virtual phy stuff */ +-#define MAX_PHY_AMNT 10 +-/* +- The idea is to emulate normal phy behavior by responding with +- pre-defined values to mii BMCR read, so that read_status hook could +- take all the needed info. +-*/ +- + struct fixed_phy_status { +- u8 link; +- u16 speed; +- u8 duplex; ++ int link; ++ int speed; ++ int duplex; ++ int pause; ++ int asym_pause; + }; + +-/*----------------------------------------------------------------------------- +- * Private information hoder for mii_bus +- *-----------------------------------------------------------------------------*/ +-struct fixed_info { +- u16 *regs; +- u8 regs_num; +- struct fixed_phy_status phy_status; +- struct phy_device *phydev; /* pointer to the container */ +- /* link & speed cb */ +- int (*link_update) (struct net_device *, struct fixed_phy_status *); ++#ifdef CONFIG_FIXED_PHY ++extern int fixed_phy_add(unsigned int irq, int phy_id, ++ struct fixed_phy_status *status); ++#else ++static inline int fixed_phy_add(unsigned int irq, int phy_id, ++ struct fixed_phy_status *status) ++{ ++ return -ENODEV; ++} ++#endif /* CONFIG_FIXED_PHY */ + +-}; +- +- +-int fixed_mdio_set_link_update(struct phy_device *, +- int (*link_update) (struct net_device *, struct fixed_phy_status *)); +-struct fixed_info *fixed_mdio_get_phydev (int phydev_ind); ++/* ++ * This function issued only by fixed_phy-aware drivers, no need ++ * protect it with #ifdef ++ */ ++extern int fixed_phy_set_link_update(struct phy_device *phydev, ++ int (*link_update)(struct net_device *, ++ struct fixed_phy_status *)); + + #endif /* __PHY_FIXED_H */ +diff -x .git -x .gitignore -Nur linux-2.6.24/include/linux/pmu.h powerpc.git/include/linux/pmu.h +--- linux-2.6.24/include/linux/pmu.h 2008-01-24 23:58:37.000000000 +0100 ++++ powerpc.git/include/linux/pmu.h 2008-01-28 20:26:44.000000000 +0100 +@@ -159,41 +159,7 @@ + extern int pmu_present(void); + extern int pmu_get_model(void); + +-#ifdef CONFIG_PM +-/* +- * Stuff for putting the powerbook to sleep and waking it again. +- * +- */ +-#include <linux/list.h> +- +-struct pmu_sleep_notifier +-{ +- void (*notifier_call)(struct pmu_sleep_notifier *self, int when); +- int priority; +- struct list_head list; +-}; +- +-/* Code values for calling sleep/wakeup handlers +- */ +-#define PBOOK_SLEEP_REQUEST 1 +-#define PBOOK_SLEEP_NOW 2 +-#define PBOOK_WAKE 3 +- +-/* priority levels in notifiers */ +-#define SLEEP_LEVEL_VIDEO 100 /* Video driver (first wake) */ +-#define SLEEP_LEVEL_MEDIABAY 90 /* Media bay driver */ +-#define SLEEP_LEVEL_BLOCK 80 /* IDE, SCSI */ +-#define SLEEP_LEVEL_NET 70 /* bmac, gmac */ +-#define SLEEP_LEVEL_MISC 60 /* Anything else */ +-#define SLEEP_LEVEL_USERLAND 55 /* Reserved for apm_emu */ +-#define SLEEP_LEVEL_ADB 50 /* ADB (async) */ +-#define SLEEP_LEVEL_SOUND 40 /* Sound driver (blocking) */ +- +-/* special register notifier functions */ +-int pmu_register_sleep_notifier(struct pmu_sleep_notifier* notifier); +-int pmu_unregister_sleep_notifier(struct pmu_sleep_notifier* notifier); +- +-#endif /* CONFIG_PM */ ++extern void pmu_backlight_set_sleep(int sleep); + + #define PMU_MAX_BATTERIES 2 + |