diff options
111 files changed, 6416 insertions, 1612 deletions
diff --git a/Documentation/DMA-attributes.txt b/Documentation/DMA-attributes.txt index 6d772f84b477..b768cc0e402b 100644 --- a/Documentation/DMA-attributes.txt +++ b/Documentation/DMA-attributes.txt | |||
@@ -22,3 +22,12 @@ ready and available in memory. The DMA of the "completion indication" | |||
22 | could race with data DMA. Mapping the memory used for completion | 22 | could race with data DMA. Mapping the memory used for completion |
23 | indications with DMA_ATTR_WRITE_BARRIER would prevent the race. | 23 | indications with DMA_ATTR_WRITE_BARRIER would prevent the race. |
24 | 24 | ||
25 | DMA_ATTR_WEAK_ORDERING | ||
26 | ---------------------- | ||
27 | |||
28 | DMA_ATTR_WEAK_ORDERING specifies that reads and writes to the mapping | ||
29 | may be weakly ordered, that is that reads and writes may pass each other. | ||
30 | |||
31 | Since it is optional for platforms to implement DMA_ATTR_WEAK_ORDERING, | ||
32 | those that do not will simply ignore the attribute and exhibit default | ||
33 | behavior. | ||
diff --git a/Documentation/powerpc/booting-without-of.txt b/Documentation/powerpc/booting-without-of.txt index aee243a846a2..ea1b70b35793 100644 --- a/Documentation/powerpc/booting-without-of.txt +++ b/Documentation/powerpc/booting-without-of.txt | |||
@@ -89,10 +89,12 @@ Table of Contents | |||
89 | 3) OpenPIC Interrupt Controllers | 89 | 3) OpenPIC Interrupt Controllers |
90 | 4) ISA Interrupt Controllers | 90 | 4) ISA Interrupt Controllers |
91 | 91 | ||
92 | VIII - Specifying GPIO information for devices | 92 | IX - Specifying GPIO information for devices |
93 | 1) gpios property | 93 | 1) gpios property |
94 | 2) gpio-controller nodes | 94 | 2) gpio-controller nodes |
95 | 95 | ||
96 | X - Specifying device power management information (sleep property) | ||
97 | |||
96 | Appendix A - Sample SOC node for MPC8540 | 98 | Appendix A - Sample SOC node for MPC8540 |
97 | 99 | ||
98 | 100 | ||
@@ -2488,8 +2490,8 @@ encodings listed below: | |||
2488 | 2 = high to low edge sensitive type enabled | 2490 | 2 = high to low edge sensitive type enabled |
2489 | 3 = low to high edge sensitive type enabled | 2491 | 3 = low to high edge sensitive type enabled |
2490 | 2492 | ||
2491 | VIII - Specifying GPIO information for devices | 2493 | IX - Specifying GPIO information for devices |
2492 | ============================================== | 2494 | ============================================ |
2493 | 2495 | ||
2494 | 1) gpios property | 2496 | 1) gpios property |
2495 | ----------------- | 2497 | ----------------- |
@@ -2537,116 +2539,151 @@ Example of two SOC GPIO banks defined as gpio-controller nodes: | |||
2537 | gpio-controller; | 2539 | gpio-controller; |
2538 | }; | 2540 | }; |
2539 | 2541 | ||
2542 | X - Specifying Device Power Management Information (sleep property) | ||
2543 | =================================================================== | ||
2544 | |||
2545 | Devices on SOCs often have mechanisms for placing devices into low-power | ||
2546 | states that are decoupled from the devices' own register blocks. Sometimes, | ||
2547 | this information is more complicated than a cell-index property can | ||
2548 | reasonably describe. Thus, each device controlled in such a manner | ||
2549 | may contain a "sleep" property which describes these connections. | ||
2550 | |||
2551 | The sleep property consists of one or more sleep resources, each of | ||
2552 | which consists of a phandle to a sleep controller, followed by a | ||
2553 | controller-specific sleep specifier of zero or more cells. | ||
2554 | |||
2555 | The semantics of what type of low power modes are possible are defined | ||
2556 | by the sleep controller. Some examples of the types of low power modes | ||
2557 | that may be supported are: | ||
2558 | |||
2559 | - Dynamic: The device may be disabled or enabled at any time. | ||
2560 | - System Suspend: The device may request to be disabled or remain | ||
2561 | awake during system suspend, but will not be disabled until then. | ||
2562 | - Permanent: The device is disabled permanently (until the next hard | ||
2563 | reset). | ||
2564 | |||
2565 | Some devices may share a clock domain with each other, such that they should | ||
2566 | only be suspended when none of the devices are in use. Where reasonable, | ||
2567 | such nodes should be placed on a virtual bus, where the bus has the sleep | ||
2568 | property. If the clock domain is shared among devices that cannot be | ||
2569 | reasonably grouped in this manner, then create a virtual sleep controller | ||
2570 | (similar to an interrupt nexus, except that defining a standardized | ||
2571 | sleep-map should wait until its necessity is demonstrated). | ||
2572 | |||
2540 | Appendix A - Sample SOC node for MPC8540 | 2573 | Appendix A - Sample SOC node for MPC8540 |
2541 | ======================================== | 2574 | ======================================== |
2542 | 2575 | ||
2543 | Note that the #address-cells and #size-cells for the SoC node | 2576 | soc@e0000000 { |
2544 | in this example have been explicitly listed; these are likely | ||
2545 | not necessary as they are usually the same as the root node. | ||
2546 | |||
2547 | soc8540@e0000000 { | ||
2548 | #address-cells = <1>; | 2577 | #address-cells = <1>; |
2549 | #size-cells = <1>; | 2578 | #size-cells = <1>; |
2550 | #interrupt-cells = <2>; | 2579 | compatible = "fsl,mpc8540-ccsr", "simple-bus"; |
2551 | device_type = "soc"; | 2580 | device_type = "soc"; |
2552 | ranges = <00000000 e0000000 00100000> | 2581 | ranges = <0x00000000 0xe0000000 0x00100000> |
2553 | reg = <e0000000 00003000>; | ||
2554 | bus-frequency = <0>; | 2582 | bus-frequency = <0>; |
2555 | 2583 | interrupt-parent = <&pic>; | |
2556 | mdio@24520 { | ||
2557 | reg = <24520 20>; | ||
2558 | device_type = "mdio"; | ||
2559 | compatible = "gianfar"; | ||
2560 | |||
2561 | ethernet-phy@0 { | ||
2562 | linux,phandle = <2452000> | ||
2563 | interrupt-parent = <40000>; | ||
2564 | interrupts = <35 1>; | ||
2565 | reg = <0>; | ||
2566 | device_type = "ethernet-phy"; | ||
2567 | }; | ||
2568 | |||
2569 | ethernet-phy@1 { | ||
2570 | linux,phandle = <2452001> | ||
2571 | interrupt-parent = <40000>; | ||
2572 | interrupts = <35 1>; | ||
2573 | reg = <1>; | ||
2574 | device_type = "ethernet-phy"; | ||
2575 | }; | ||
2576 | |||
2577 | ethernet-phy@3 { | ||
2578 | linux,phandle = <2452002> | ||
2579 | interrupt-parent = <40000>; | ||
2580 | interrupts = <35 1>; | ||
2581 | reg = <3>; | ||
2582 | device_type = "ethernet-phy"; | ||
2583 | }; | ||
2584 | |||
2585 | }; | ||
2586 | 2584 | ||
2587 | ethernet@24000 { | 2585 | ethernet@24000 { |
2588 | #size-cells = <0>; | 2586 | #address-cells = <1>; |
2587 | #size-cells = <1>; | ||
2589 | device_type = "network"; | 2588 | device_type = "network"; |
2590 | model = "TSEC"; | 2589 | model = "TSEC"; |
2591 | compatible = "gianfar"; | 2590 | compatible = "gianfar", "simple-bus"; |
2592 | reg = <24000 1000>; | 2591 | reg = <0x24000 0x1000>; |
2593 | mac-address = [ 00 E0 0C 00 73 00 ]; | 2592 | local-mac-address = [ 00 E0 0C 00 73 00 ]; |
2594 | interrupts = <d 3 e 3 12 3>; | 2593 | interrupts = <29 2 30 2 34 2>; |
2595 | interrupt-parent = <40000>; | 2594 | phy-handle = <&phy0>; |
2596 | phy-handle = <2452000>; | 2595 | sleep = <&pmc 00000080>; |
2596 | ranges; | ||
2597 | |||
2598 | mdio@24520 { | ||
2599 | reg = <0x24520 0x20>; | ||
2600 | compatible = "fsl,gianfar-mdio"; | ||
2601 | |||
2602 | phy0: ethernet-phy@0 { | ||
2603 | interrupts = <5 1>; | ||
2604 | reg = <0>; | ||
2605 | device_type = "ethernet-phy"; | ||
2606 | }; | ||
2607 | |||
2608 | phy1: ethernet-phy@1 { | ||
2609 | interrupts = <5 1>; | ||
2610 | reg = <1>; | ||
2611 | device_type = "ethernet-phy"; | ||
2612 | }; | ||
2613 | |||
2614 | phy3: ethernet-phy@3 { | ||
2615 | interrupts = <7 1>; | ||
2616 | reg = <3>; | ||
2617 | device_type = "ethernet-phy"; | ||
2618 | }; | ||
2619 | }; | ||
2597 | }; | 2620 | }; |
2598 | 2621 | ||
2599 | ethernet@25000 { | 2622 | ethernet@25000 { |
2600 | #address-cells = <1>; | ||
2601 | #size-cells = <0>; | ||
2602 | device_type = "network"; | 2623 | device_type = "network"; |
2603 | model = "TSEC"; | 2624 | model = "TSEC"; |
2604 | compatible = "gianfar"; | 2625 | compatible = "gianfar"; |
2605 | reg = <25000 1000>; | 2626 | reg = <0x25000 0x1000>; |
2606 | mac-address = [ 00 E0 0C 00 73 01 ]; | 2627 | local-mac-address = [ 00 E0 0C 00 73 01 ]; |
2607 | interrupts = <13 3 14 3 18 3>; | 2628 | interrupts = <13 2 14 2 18 2>; |
2608 | interrupt-parent = <40000>; | 2629 | phy-handle = <&phy1>; |
2609 | phy-handle = <2452001>; | 2630 | sleep = <&pmc 00000040>; |
2610 | }; | 2631 | }; |
2611 | 2632 | ||
2612 | ethernet@26000 { | 2633 | ethernet@26000 { |
2613 | #address-cells = <1>; | ||
2614 | #size-cells = <0>; | ||
2615 | device_type = "network"; | 2634 | device_type = "network"; |
2616 | model = "FEC"; | 2635 | model = "FEC"; |
2617 | compatible = "gianfar"; | 2636 | compatible = "gianfar"; |
2618 | reg = <26000 1000>; | 2637 | reg = <0x26000 0x1000>; |
2619 | mac-address = [ 00 E0 0C 00 73 02 ]; | 2638 | local-mac-address = [ 00 E0 0C 00 73 02 ]; |
2620 | interrupts = <19 3>; | 2639 | interrupts = <41 2>; |
2621 | interrupt-parent = <40000>; | 2640 | phy-handle = <&phy3>; |
2622 | phy-handle = <2452002>; | 2641 | sleep = <&pmc 00000020>; |
2623 | }; | 2642 | }; |
2624 | 2643 | ||
2625 | serial@4500 { | 2644 | serial@4500 { |
2626 | device_type = "serial"; | 2645 | #address-cells = <1>; |
2627 | compatible = "ns16550"; | 2646 | #size-cells = <1>; |
2628 | reg = <4500 100>; | 2647 | compatible = "fsl,mpc8540-duart", "simple-bus"; |
2629 | clock-frequency = <0>; | 2648 | sleep = <&pmc 00000002>; |
2630 | interrupts = <1a 3>; | 2649 | ranges; |
2631 | interrupt-parent = <40000>; | 2650 | |
2651 | serial@4500 { | ||
2652 | device_type = "serial"; | ||
2653 | compatible = "ns16550"; | ||
2654 | reg = <0x4500 0x100>; | ||
2655 | clock-frequency = <0>; | ||
2656 | interrupts = <42 2>; | ||
2657 | }; | ||
2658 | |||
2659 | serial@4600 { | ||
2660 | device_type = "serial"; | ||
2661 | compatible = "ns16550"; | ||
2662 | reg = <0x4600 0x100>; | ||
2663 | clock-frequency = <0>; | ||
2664 | interrupts = <42 2>; | ||
2665 | }; | ||
2632 | }; | 2666 | }; |
2633 | 2667 | ||
2634 | pic@40000 { | 2668 | pic: pic@40000 { |
2635 | linux,phandle = <40000>; | ||
2636 | interrupt-controller; | 2669 | interrupt-controller; |
2637 | #address-cells = <0>; | 2670 | #address-cells = <0>; |
2638 | reg = <40000 40000>; | 2671 | #interrupt-cells = <2>; |
2672 | reg = <0x40000 0x40000>; | ||
2639 | compatible = "chrp,open-pic"; | 2673 | compatible = "chrp,open-pic"; |
2640 | device_type = "open-pic"; | 2674 | device_type = "open-pic"; |
2641 | }; | 2675 | }; |
2642 | 2676 | ||
2643 | i2c@3000 { | 2677 | i2c@3000 { |
2644 | interrupt-parent = <40000>; | 2678 | interrupts = <43 2>; |
2645 | interrupts = <1b 3>; | 2679 | reg = <0x3000 0x100>; |
2646 | reg = <3000 18>; | ||
2647 | device_type = "i2c"; | ||
2648 | compatible = "fsl-i2c"; | 2680 | compatible = "fsl-i2c"; |
2649 | dfsrr; | 2681 | dfsrr; |
2682 | sleep = <&pmc 00000004>; | ||
2650 | }; | 2683 | }; |
2651 | 2684 | ||
2685 | pmc: power@e0070 { | ||
2686 | compatible = "fsl,mpc8540-pmc", "fsl,mpc8548-pmc"; | ||
2687 | reg = <0xe0070 0x20>; | ||
2688 | }; | ||
2652 | }; | 2689 | }; |
diff --git a/Documentation/powerpc/dts-bindings/fsl/cpm_qe/gpio.txt b/Documentation/powerpc/dts-bindings/fsl/cpm_qe/gpio.txt new file mode 100644 index 000000000000..1815dfede1bc --- /dev/null +++ b/Documentation/powerpc/dts-bindings/fsl/cpm_qe/gpio.txt | |||
@@ -0,0 +1,38 @@ | |||
1 | Every GPIO controller node must have #gpio-cells property defined, | ||
2 | this information will be used to translate gpio-specifiers. | ||
3 | |||
4 | On CPM1 devices, all ports are using slightly different register layouts. | ||
5 | Ports A, C and D are 16bit ports and Ports B and E are 32bit ports. | ||
6 | |||
7 | On CPM2 devices, all ports are 32bit ports and use a common register layout. | ||
8 | |||
9 | Required properties: | ||
10 | - compatible : "fsl,cpm1-pario-bank-a", "fsl,cpm1-pario-bank-b", | ||
11 | "fsl,cpm1-pario-bank-c", "fsl,cpm1-pario-bank-d", | ||
12 | "fsl,cpm1-pario-bank-e", "fsl,cpm2-pario-bank" | ||
13 | - #gpio-cells : Should be two. The first cell is the pin number and the | ||
14 | second cell is used to specify optional paramters (currently unused). | ||
15 | - gpio-controller : Marks the port as GPIO controller. | ||
16 | |||
17 | Example of three SOC GPIO banks defined as gpio-controller nodes: | ||
18 | |||
19 | CPM1_PIO_A: gpio-controller@950 { | ||
20 | #gpio-cells = <2>; | ||
21 | compatible = "fsl,cpm1-pario-bank-a"; | ||
22 | reg = <0x950 0x10>; | ||
23 | gpio-controller; | ||
24 | }; | ||
25 | |||
26 | CPM1_PIO_B: gpio-controller@ab8 { | ||
27 | #gpio-cells = <2>; | ||
28 | compatible = "fsl,cpm1-pario-bank-b"; | ||
29 | reg = <0xab8 0x10>; | ||
30 | gpio-controller; | ||
31 | }; | ||
32 | |||
33 | CPM1_PIO_E: gpio-controller@ac8 { | ||
34 | #gpio-cells = <2>; | ||
35 | compatible = "fsl,cpm1-pario-bank-e"; | ||
36 | reg = <0xac8 0x18>; | ||
37 | gpio-controller; | ||
38 | }; | ||
diff --git a/Documentation/powerpc/dts-bindings/fsl/cpm_qe/qe/usb.txt b/Documentation/powerpc/dts-bindings/fsl/cpm_qe/qe/usb.txt index c8f44d6bcbcf..9ccd5f30405b 100644 --- a/Documentation/powerpc/dts-bindings/fsl/cpm_qe/qe/usb.txt +++ b/Documentation/powerpc/dts-bindings/fsl/cpm_qe/qe/usb.txt | |||
@@ -1,22 +1,37 @@ | |||
1 | * USB (Universal Serial Bus Controller) | 1 | Freescale QUICC Engine USB Controller |
2 | 2 | ||
3 | Required properties: | 3 | Required properties: |
4 | - compatible : could be "qe_udc" or "fhci-hcd". | 4 | - compatible : should be "fsl,<chip>-qe-usb", "fsl,mpc8323-qe-usb". |
5 | - mode : the could be "host" or "slave". | 5 | - reg : the first two cells should contain usb registers location and |
6 | - reg : Offset and length of the register set for the device | 6 | length, the next two two cells should contain PRAM location and |
7 | - interrupts : <a b> where a is the interrupt number and b is a | 7 | length. |
8 | field that represents an encoding of the sense and level | 8 | - interrupts : should contain USB interrupt. |
9 | information for the interrupt. This should be encoded based on | 9 | - interrupt-parent : interrupt source phandle. |
10 | the information in section 2) depending on the type of interrupt | 10 | - fsl,fullspeed-clock : specifies the full speed USB clock source: |
11 | controller you have. | 11 | "none": clock source is disabled |
12 | - interrupt-parent : the phandle for the interrupt controller that | 12 | "brg1" through "brg16": clock source is BRG1-BRG16, respectively |
13 | services interrupts for this device. | 13 | "clk1" through "clk24": clock source is CLK1-CLK24, respectively |
14 | - fsl,lowspeed-clock : specifies the low speed USB clock source: | ||
15 | "none": clock source is disabled | ||
16 | "brg1" through "brg16": clock source is BRG1-BRG16, respectively | ||
17 | "clk1" through "clk24": clock source is CLK1-CLK24, respectively | ||
18 | - hub-power-budget : USB power budget for the root hub, in mA. | ||
19 | - gpios : should specify GPIOs in this order: USBOE, USBTP, USBTN, USBRP, | ||
20 | USBRN, SPEED (optional), and POWER (optional). | ||
14 | 21 | ||
15 | Example(slave): | 22 | Example: |
16 | usb@6c0 { | 23 | |
17 | compatible = "qe_udc"; | 24 | usb@6c0 { |
18 | reg = <6c0 40>; | 25 | compatible = "fsl,mpc8360-qe-usb", "fsl,mpc8323-qe-usb"; |
19 | interrupts = <8b 0>; | 26 | reg = <0x6c0 0x40 0x8b00 0x100>; |
20 | interrupt-parent = <700>; | 27 | interrupts = <11>; |
21 | mode = "slave"; | 28 | interrupt-parent = <&qeic>; |
22 | }; | 29 | fsl,fullspeed-clock = "clk21"; |
30 | gpios = <&qe_pio_b 2 0 /* USBOE */ | ||
31 | &qe_pio_b 3 0 /* USBTP */ | ||
32 | &qe_pio_b 8 0 /* USBTN */ | ||
33 | &qe_pio_b 9 0 /* USBRP */ | ||
34 | &qe_pio_b 11 0 /* USBRN */ | ||
35 | &qe_pio_e 20 0 /* SPEED */ | ||
36 | &qe_pio_e 21 0 /* POWER */>; | ||
37 | }; | ||
diff --git a/Documentation/powerpc/dts-bindings/fsl/mcu-mpc8349emitx.txt b/Documentation/powerpc/dts-bindings/fsl/mcu-mpc8349emitx.txt new file mode 100644 index 000000000000..0f766333b6eb --- /dev/null +++ b/Documentation/powerpc/dts-bindings/fsl/mcu-mpc8349emitx.txt | |||
@@ -0,0 +1,17 @@ | |||
1 | Freescale MPC8349E-mITX-compatible Power Management Micro Controller Unit (MCU) | ||
2 | |||
3 | Required properties: | ||
4 | - compatible : "fsl,<mcu-chip>-<board>", "fsl,mcu-mpc8349emitx". | ||
5 | - reg : should specify I2C address (0x0a). | ||
6 | - #gpio-cells : should be 2. | ||
7 | - gpio-controller : should be present. | ||
8 | |||
9 | Example: | ||
10 | |||
11 | mcu@0a { | ||
12 | #gpio-cells = <2>; | ||
13 | compatible = "fsl,mc9s08qg8-mpc8349emitx", | ||
14 | "fsl,mcu-mpc8349emitx"; | ||
15 | reg = <0x0a>; | ||
16 | gpio-controller; | ||
17 | }; | ||
diff --git a/Documentation/powerpc/dts-bindings/fsl/pmc.txt b/Documentation/powerpc/dts-bindings/fsl/pmc.txt new file mode 100644 index 000000000000..02f6f43ee1b7 --- /dev/null +++ b/Documentation/powerpc/dts-bindings/fsl/pmc.txt | |||
@@ -0,0 +1,63 @@ | |||
1 | * Power Management Controller | ||
2 | |||
3 | Properties: | ||
4 | - compatible: "fsl,<chip>-pmc". | ||
5 | |||
6 | "fsl,mpc8349-pmc" should be listed for any chip whose PMC is | ||
7 | compatible. "fsl,mpc8313-pmc" should also be listed for any chip | ||
8 | whose PMC is compatible, and implies deep-sleep capability. | ||
9 | |||
10 | "fsl,mpc8548-pmc" should be listed for any chip whose PMC is | ||
11 | compatible. "fsl,mpc8536-pmc" should also be listed for any chip | ||
12 | whose PMC is compatible, and implies deep-sleep capability. | ||
13 | |||
14 | "fsl,mpc8641d-pmc" should be listed for any chip whose PMC is | ||
15 | compatible; all statements below that apply to "fsl,mpc8548-pmc" also | ||
16 | apply to "fsl,mpc8641d-pmc". | ||
17 | |||
18 | Compatibility does not include bit assigments in SCCR/PMCDR/DEVDISR; these | ||
19 | bit assigments are indicated via the sleep specifier in each device's | ||
20 | sleep property. | ||
21 | |||
22 | - reg: For devices compatible with "fsl,mpc8349-pmc", the first resource | ||
23 | is the PMC block, and the second resource is the Clock Configuration | ||
24 | block. | ||
25 | |||
26 | For devices compatible with "fsl,mpc8548-pmc", the first resource | ||
27 | is a 32-byte block beginning with DEVDISR. | ||
28 | |||
29 | - interrupts: For "fsl,mpc8349-pmc"-compatible devices, the first | ||
30 | resource is the PMC block interrupt. | ||
31 | |||
32 | - fsl,mpc8313-wakeup-timer: For "fsl,mpc8313-pmc"-compatible devices, | ||
33 | this is a phandle to an "fsl,gtm" node on which timer 4 can be used as | ||
34 | a wakeup source from deep sleep. | ||
35 | |||
36 | Sleep specifiers: | ||
37 | |||
38 | fsl,mpc8349-pmc: Sleep specifiers consist of one cell. For each bit | ||
39 | that is set in the cell, the corresponding bit in SCCR will be saved | ||
40 | and cleared on suspend, and restored on resume. This sleep controller | ||
41 | supports disabling and resuming devices at any time. | ||
42 | |||
43 | fsl,mpc8536-pmc: Sleep specifiers consist of three cells, the third of | ||
44 | which will be ORed into PMCDR upon suspend, and cleared from PMCDR | ||
45 | upon resume. The first two cells are as described for fsl,mpc8578-pmc. | ||
46 | This sleep controller only supports disabling devices during system | ||
47 | sleep, or permanently. | ||
48 | |||
49 | fsl,mpc8548-pmc: Sleep specifiers consist of one or two cells, the | ||
50 | first of which will be ORed into DEVDISR (and the second into | ||
51 | DEVDISR2, if present -- this cell should be zero or absent if the | ||
52 | hardware does not have DEVDISR2) upon a request for permanent device | ||
53 | disabling. This sleep controller does not support configuring devices | ||
54 | to disable during system sleep (unless supported by another compatible | ||
55 | match), or dynamically. | ||
56 | |||
57 | Example: | ||
58 | |||
59 | power@b00 { | ||
60 | compatible = "fsl,mpc8313-pmc", "fsl,mpc8349-pmc"; | ||
61 | reg = <0xb00 0x100 0xa00 0x100>; | ||
62 | interrupts = <80 8>; | ||
63 | }; | ||
diff --git a/Documentation/powerpc/dts-bindings/fsl/tsec.txt b/Documentation/powerpc/dts-bindings/fsl/tsec.txt index 583ef6b56c43..cf55fa4112d2 100644 --- a/Documentation/powerpc/dts-bindings/fsl/tsec.txt +++ b/Documentation/powerpc/dts-bindings/fsl/tsec.txt | |||
@@ -24,46 +24,39 @@ Example: | |||
24 | 24 | ||
25 | * Gianfar-compatible ethernet nodes | 25 | * Gianfar-compatible ethernet nodes |
26 | 26 | ||
27 | Required properties: | 27 | Properties: |
28 | 28 | ||
29 | - device_type : Should be "network" | 29 | - device_type : Should be "network" |
30 | - model : Model of the device. Can be "TSEC", "eTSEC", or "FEC" | 30 | - model : Model of the device. Can be "TSEC", "eTSEC", or "FEC" |
31 | - compatible : Should be "gianfar" | 31 | - compatible : Should be "gianfar" |
32 | - reg : Offset and length of the register set for the device | 32 | - reg : Offset and length of the register set for the device |
33 | - mac-address : List of bytes representing the ethernet address of | 33 | - local-mac-address : List of bytes representing the ethernet address of |
34 | this controller | 34 | this controller |
35 | - interrupts : <a b> where a is the interrupt number and b is a | 35 | - interrupts : For FEC devices, the first interrupt is the device's |
36 | field that represents an encoding of the sense and level | 36 | interrupt. For TSEC and eTSEC devices, the first interrupt is |
37 | information for the interrupt. This should be encoded based on | 37 | transmit, the second is receive, and the third is error. |
38 | the information in section 2) depending on the type of interrupt | ||
39 | controller you have. | ||
40 | - interrupt-parent : the phandle for the interrupt controller that | ||
41 | services interrupts for this device. | ||
42 | - phy-handle : The phandle for the PHY connected to this ethernet | 38 | - phy-handle : The phandle for the PHY connected to this ethernet |
43 | controller. | 39 | controller. |
44 | - fixed-link : <a b c d e> where a is emulated phy id - choose any, | 40 | - fixed-link : <a b c d e> where a is emulated phy id - choose any, |
45 | but unique to the all specified fixed-links, b is duplex - 0 half, | 41 | but unique to the all specified fixed-links, b is duplex - 0 half, |
46 | 1 full, c is link speed - d#10/d#100/d#1000, d is pause - 0 no | 42 | 1 full, c is link speed - d#10/d#100/d#1000, d is pause - 0 no |
47 | pause, 1 pause, e is asym_pause - 0 no asym_pause, 1 asym_pause. | 43 | pause, 1 pause, e is asym_pause - 0 no asym_pause, 1 asym_pause. |
48 | |||
49 | Recommended properties: | ||
50 | |||
51 | - phy-connection-type : a string naming the controller/PHY interface type, | 44 | - phy-connection-type : a string naming the controller/PHY interface type, |
52 | i.e., "mii" (default), "rmii", "gmii", "rgmii", "rgmii-id", "sgmii", | 45 | i.e., "mii" (default), "rmii", "gmii", "rgmii", "rgmii-id", "sgmii", |
53 | "tbi", or "rtbi". This property is only really needed if the connection | 46 | "tbi", or "rtbi". This property is only really needed if the connection |
54 | is of type "rgmii-id", as all other connection types are detected by | 47 | is of type "rgmii-id", as all other connection types are detected by |
55 | hardware. | 48 | hardware. |
56 | 49 | - fsl,magic-packet : If present, indicates that the hardware supports | |
50 | waking up via magic packet. | ||
57 | 51 | ||
58 | Example: | 52 | Example: |
59 | ethernet@24000 { | 53 | ethernet@24000 { |
60 | #size-cells = <0>; | ||
61 | device_type = "network"; | 54 | device_type = "network"; |
62 | model = "TSEC"; | 55 | model = "TSEC"; |
63 | compatible = "gianfar"; | 56 | compatible = "gianfar"; |
64 | reg = <24000 1000>; | 57 | reg = <0x24000 0x1000>; |
65 | mac-address = [ 00 E0 0C 00 73 00 ]; | 58 | local-mac-address = [ 00 E0 0C 00 73 00 ]; |
66 | interrupts = <d 3 e 3 12 3>; | 59 | interrupts = <29 2 30 2 34 2>; |
67 | interrupt-parent = <40000>; | 60 | interrupt-parent = <&mpic>; |
68 | phy-handle = <2452000> | 61 | phy-handle = <&phy0> |
69 | }; | 62 | }; |
diff --git a/Documentation/powerpc/dts-bindings/fsl/upm-nand.txt b/Documentation/powerpc/dts-bindings/fsl/upm-nand.txt new file mode 100644 index 000000000000..84a04d5eb8e6 --- /dev/null +++ b/Documentation/powerpc/dts-bindings/fsl/upm-nand.txt | |||
@@ -0,0 +1,28 @@ | |||
1 | Freescale Localbus UPM programmed to work with NAND flash | ||
2 | |||
3 | Required properties: | ||
4 | - compatible : "fsl,upm-nand". | ||
5 | - reg : should specify localbus chip select and size used for the chip. | ||
6 | - fsl,upm-addr-offset : UPM pattern offset for the address latch. | ||
7 | - fsl,upm-cmd-offset : UPM pattern offset for the command latch. | ||
8 | - gpios : may specify optional GPIO connected to the Ready-Not-Busy pin. | ||
9 | |||
10 | Example: | ||
11 | |||
12 | upm@1,0 { | ||
13 | compatible = "fsl,upm-nand"; | ||
14 | reg = <1 0 1>; | ||
15 | fsl,upm-addr-offset = <16>; | ||
16 | fsl,upm-cmd-offset = <8>; | ||
17 | gpios = <&qe_pio_e 18 0>; | ||
18 | |||
19 | flash { | ||
20 | #address-cells = <1>; | ||
21 | #size-cells = <1>; | ||
22 | compatible = "..."; | ||
23 | |||
24 | partition@0 { | ||
25 | ... | ||
26 | }; | ||
27 | }; | ||
28 | }; | ||
diff --git a/Documentation/powerpc/dts-bindings/gpio/led.txt b/Documentation/powerpc/dts-bindings/gpio/led.txt new file mode 100644 index 000000000000..ff51f4c0fa9d --- /dev/null +++ b/Documentation/powerpc/dts-bindings/gpio/led.txt | |||
@@ -0,0 +1,15 @@ | |||
1 | LED connected to GPIO | ||
2 | |||
3 | Required properties: | ||
4 | - compatible : should be "gpio-led". | ||
5 | - label : (optional) the label for this LED. If omitted, the label is | ||
6 | taken from the node name (excluding the unit address). | ||
7 | - gpios : should specify LED GPIO. | ||
8 | |||
9 | Example: | ||
10 | |||
11 | led@0 { | ||
12 | compatible = "gpio-led"; | ||
13 | label = "hdd"; | ||
14 | gpios = <&mcu_pio 0 1>; | ||
15 | }; | ||
diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig index de88972c5896..4c22242b396f 100644 --- a/arch/powerpc/Kconfig +++ b/arch/powerpc/Kconfig | |||
@@ -199,7 +199,7 @@ config ARCH_HIBERNATION_POSSIBLE | |||
199 | 199 | ||
200 | config ARCH_SUSPEND_POSSIBLE | 200 | config ARCH_SUSPEND_POSSIBLE |
201 | def_bool y | 201 | def_bool y |
202 | depends on ADB_PMU || PPC_EFIKA || PPC_LITE5200 | 202 | depends on ADB_PMU || PPC_EFIKA || PPC_LITE5200 || PPC_83xx |
203 | 203 | ||
204 | config PPC_DCR_NATIVE | 204 | config PPC_DCR_NATIVE |
205 | bool | 205 | bool |
@@ -568,11 +568,15 @@ config FSL_GTM | |||
568 | config MCA | 568 | config MCA |
569 | bool | 569 | bool |
570 | 570 | ||
571 | # Platforms that what PCI turned unconditionally just do select PCI | ||
572 | # in their config node. Platforms that want to choose at config | ||
573 | # time should select PPC_PCI_CHOICE | ||
574 | config PPC_PCI_CHOICE | ||
575 | bool | ||
576 | |||
571 | config PCI | 577 | config PCI |
572 | bool "PCI support" if 40x || CPM2 || PPC_83xx || PPC_85xx || PPC_86xx \ | 578 | bool "PCI support" if PPC_PCI_CHOICE |
573 | || PPC_MPC52xx || (EMBEDDED && (PPC_PSERIES || PPC_ISERIES)) \ | 579 | default y if !40x && !CPM2 && !8xx && !PPC_83xx \ |
574 | || PPC_PS3 || 44x | ||
575 | default y if !40x && !CPM2 && !8xx && !PPC_MPC512x && !PPC_83xx \ | ||
576 | && !PPC_85xx && !PPC_86xx | 580 | && !PPC_85xx && !PPC_86xx |
577 | default PCI_PERMEDIA if !4xx && !CPM2 && !8xx | 581 | default PCI_PERMEDIA if !4xx && !CPM2 && !8xx |
578 | default PCI_QSPAN if !4xx && !CPM2 && 8xx | 582 | default PCI_QSPAN if !4xx && !CPM2 && 8xx |
diff --git a/arch/powerpc/boot/Makefile b/arch/powerpc/boot/Makefile index 19f83c8f219d..14174aa24074 100644 --- a/arch/powerpc/boot/Makefile +++ b/arch/powerpc/boot/Makefile | |||
@@ -163,12 +163,12 @@ quiet_cmd_flex = FLEX $@ | |||
163 | cmd_flex = $(FLEX) -o$@ $<; cp $@ $@_shipped | 163 | cmd_flex = $(FLEX) -o$@ $<; cp $@ $@_shipped |
164 | 164 | ||
165 | $(obj)/dtc-src/dtc-parser.tab.c: $(src)/dtc-src/dtc-parser.y FORCE | 165 | $(obj)/dtc-src/dtc-parser.tab.c: $(src)/dtc-src/dtc-parser.y FORCE |
166 | $(call if_changed,bison) | 166 | $(call if_changed,bison) |
167 | 167 | ||
168 | $(obj)/dtc-src/dtc-parser.tab.h: $(obj)/dtc-src/dtc-parser.tab.c | 168 | $(obj)/dtc-src/dtc-parser.tab.h: $(obj)/dtc-src/dtc-parser.tab.c |
169 | 169 | ||
170 | $(obj)/dtc-src/dtc-lexer.lex.c: $(src)/dtc-src/dtc-lexer.l FORCE | 170 | $(obj)/dtc-src/dtc-lexer.lex.c: $(src)/dtc-src/dtc-lexer.l FORCE |
171 | $(call if_changed,flex) | 171 | $(call if_changed,flex) |
172 | endif | 172 | endif |
173 | 173 | ||
174 | ############# | 174 | ############# |
diff --git a/arch/powerpc/boot/dts/mpc7448hpc2.dts b/arch/powerpc/boot/dts/mpc7448hpc2.dts index 705c23c14f32..2544f3ecd6e9 100644 --- a/arch/powerpc/boot/dts/mpc7448hpc2.dts +++ b/arch/powerpc/boot/dts/mpc7448hpc2.dts | |||
@@ -18,6 +18,16 @@ | |||
18 | #address-cells = <1>; | 18 | #address-cells = <1>; |
19 | #size-cells = <1>; | 19 | #size-cells = <1>; |
20 | 20 | ||
21 | aliases { | ||
22 | ethernet0 = &enet0; | ||
23 | ethernet1 = &enet1; | ||
24 | |||
25 | serial0 = &serial0; | ||
26 | serial1 = &serial1; | ||
27 | |||
28 | pci0 = &pci0; | ||
29 | }; | ||
30 | |||
21 | cpus { | 31 | cpus { |
22 | #address-cells = <1>; | 32 | #address-cells = <1>; |
23 | #size-cells =<0>; | 33 | #size-cells =<0>; |
@@ -78,7 +88,7 @@ | |||
78 | 88 | ||
79 | }; | 89 | }; |
80 | 90 | ||
81 | ethernet@6200 { | 91 | enet0: ethernet@6200 { |
82 | linux,network-index = <0>; | 92 | linux,network-index = <0>; |
83 | #size-cells = <0>; | 93 | #size-cells = <0>; |
84 | device_type = "network"; | 94 | device_type = "network"; |
@@ -91,7 +101,7 @@ | |||
91 | phy-handle = <&phy8>; | 101 | phy-handle = <&phy8>; |
92 | }; | 102 | }; |
93 | 103 | ||
94 | ethernet@6600 { | 104 | enet1: ethernet@6600 { |
95 | linux,network-index = <1>; | 105 | linux,network-index = <1>; |
96 | #address-cells = <1>; | 106 | #address-cells = <1>; |
97 | #size-cells = <0>; | 107 | #size-cells = <0>; |
@@ -105,7 +115,7 @@ | |||
105 | phy-handle = <&phy9>; | 115 | phy-handle = <&phy9>; |
106 | }; | 116 | }; |
107 | 117 | ||
108 | serial@7808 { | 118 | serial0: serial@7808 { |
109 | device_type = "serial"; | 119 | device_type = "serial"; |
110 | compatible = "ns16550"; | 120 | compatible = "ns16550"; |
111 | reg = <0x7808 0x200>; | 121 | reg = <0x7808 0x200>; |
@@ -114,7 +124,7 @@ | |||
114 | interrupt-parent = <&mpic>; | 124 | interrupt-parent = <&mpic>; |
115 | }; | 125 | }; |
116 | 126 | ||
117 | serial@7c08 { | 127 | serial1: serial@7c08 { |
118 | device_type = "serial"; | 128 | device_type = "serial"; |
119 | compatible = "ns16550"; | 129 | compatible = "ns16550"; |
120 | reg = <0x7c08 0x200>; | 130 | reg = <0x7c08 0x200>; |
@@ -131,7 +141,7 @@ | |||
131 | compatible = "chrp,open-pic"; | 141 | compatible = "chrp,open-pic"; |
132 | device_type = "open-pic"; | 142 | device_type = "open-pic"; |
133 | }; | 143 | }; |
134 | pci@1000 { | 144 | pci0: pci@1000 { |
135 | compatible = "tsi108-pci"; | 145 | compatible = "tsi108-pci"; |
136 | device_type = "pci"; | 146 | device_type = "pci"; |
137 | #interrupt-cells = <1>; | 147 | #interrupt-cells = <1>; |
@@ -184,8 +194,4 @@ | |||
184 | }; | 194 | }; |
185 | }; | 195 | }; |
186 | }; | 196 | }; |
187 | chosen { | ||
188 | linux,stdout-path = "/tsi108@c0000000/serial@7808"; | ||
189 | }; | ||
190 | |||
191 | }; | 197 | }; |
diff --git a/arch/powerpc/boot/dts/mpc8313erdb.dts b/arch/powerpc/boot/dts/mpc8313erdb.dts index 3664fb584026..2a94ae0dc8b8 100644 --- a/arch/powerpc/boot/dts/mpc8313erdb.dts +++ b/arch/powerpc/boot/dts/mpc8313erdb.dts | |||
@@ -109,18 +109,38 @@ | |||
109 | reg = <0x200 0x100>; | 109 | reg = <0x200 0x100>; |
110 | }; | 110 | }; |
111 | 111 | ||
112 | i2c@3000 { | 112 | sleep-nexus { |
113 | #address-cells = <1>; | 113 | #address-cells = <1>; |
114 | #size-cells = <0>; | 114 | #size-cells = <1>; |
115 | cell-index = <0>; | 115 | compatible = "simple-bus"; |
116 | compatible = "fsl-i2c"; | 116 | sleep = <&pmc 0x03000000>; |
117 | reg = <0x3000 0x100>; | 117 | ranges; |
118 | interrupts = <14 0x8>; | 118 | |
119 | interrupt-parent = <&ipic>; | 119 | i2c@3000 { |
120 | dfsrr; | 120 | #address-cells = <1>; |
121 | rtc@68 { | 121 | #size-cells = <0>; |
122 | compatible = "dallas,ds1339"; | 122 | cell-index = <0>; |
123 | reg = <0x68>; | 123 | compatible = "fsl-i2c"; |
124 | reg = <0x3000 0x100>; | ||
125 | interrupts = <14 0x8>; | ||
126 | interrupt-parent = <&ipic>; | ||
127 | dfsrr; | ||
128 | rtc@68 { | ||
129 | compatible = "dallas,ds1339"; | ||
130 | reg = <0x68>; | ||
131 | }; | ||
132 | }; | ||
133 | |||
134 | crypto@30000 { | ||
135 | compatible = "fsl,sec2.2", "fsl,sec2.1", | ||
136 | "fsl,sec2.0"; | ||
137 | reg = <0x30000 0x10000>; | ||
138 | interrupts = <11 0x8>; | ||
139 | interrupt-parent = <&ipic>; | ||
140 | fsl,num-channels = <1>; | ||
141 | fsl,channel-fifo-len = <24>; | ||
142 | fsl,exec-units-mask = <0x4c>; | ||
143 | fsl,descriptor-types-mask = <0x0122003f>; | ||
124 | }; | 144 | }; |
125 | }; | 145 | }; |
126 | 146 | ||
@@ -188,37 +208,44 @@ | |||
188 | interrupt-parent = <&ipic>; | 208 | interrupt-parent = <&ipic>; |
189 | interrupts = <38 0x8>; | 209 | interrupts = <38 0x8>; |
190 | phy_type = "utmi_wide"; | 210 | phy_type = "utmi_wide"; |
211 | sleep = <&pmc 0x00300000>; | ||
191 | }; | 212 | }; |
192 | 213 | ||
193 | mdio@24520 { | 214 | enet0: ethernet@24000 { |
194 | #address-cells = <1>; | 215 | #address-cells = <1>; |
195 | #size-cells = <0>; | 216 | #size-cells = <1>; |
196 | compatible = "fsl,gianfar-mdio"; | 217 | sleep = <&pmc 0x20000000>; |
197 | reg = <0x24520 0x20>; | 218 | ranges; |
198 | phy1: ethernet-phy@1 { | ||
199 | interrupt-parent = <&ipic>; | ||
200 | interrupts = <19 0x8>; | ||
201 | reg = <0x1>; | ||
202 | device_type = "ethernet-phy"; | ||
203 | }; | ||
204 | phy4: ethernet-phy@4 { | ||
205 | interrupt-parent = <&ipic>; | ||
206 | interrupts = <20 0x8>; | ||
207 | reg = <0x4>; | ||
208 | device_type = "ethernet-phy"; | ||
209 | }; | ||
210 | }; | ||
211 | 219 | ||
212 | enet0: ethernet@24000 { | ||
213 | cell-index = <0>; | 220 | cell-index = <0>; |
214 | device_type = "network"; | 221 | device_type = "network"; |
215 | model = "eTSEC"; | 222 | model = "eTSEC"; |
216 | compatible = "gianfar"; | 223 | compatible = "gianfar", "simple-bus"; |
217 | reg = <0x24000 0x1000>; | 224 | reg = <0x24000 0x1000>; |
218 | local-mac-address = [ 00 00 00 00 00 00 ]; | 225 | local-mac-address = [ 00 00 00 00 00 00 ]; |
219 | interrupts = <37 0x8 36 0x8 35 0x8>; | 226 | interrupts = <37 0x8 36 0x8 35 0x8>; |
220 | interrupt-parent = <&ipic>; | 227 | interrupt-parent = <&ipic>; |
221 | phy-handle = < &phy1 >; | 228 | phy-handle = < &phy1 >; |
229 | fsl,magic-packet; | ||
230 | |||
231 | mdio@24520 { | ||
232 | #address-cells = <1>; | ||
233 | #size-cells = <0>; | ||
234 | compatible = "fsl,gianfar-mdio"; | ||
235 | reg = <0x24520 0x20>; | ||
236 | phy1: ethernet-phy@1 { | ||
237 | interrupt-parent = <&ipic>; | ||
238 | interrupts = <19 0x8>; | ||
239 | reg = <0x1>; | ||
240 | device_type = "ethernet-phy"; | ||
241 | }; | ||
242 | phy4: ethernet-phy@4 { | ||
243 | interrupt-parent = <&ipic>; | ||
244 | interrupts = <20 0x8>; | ||
245 | reg = <0x4>; | ||
246 | device_type = "ethernet-phy"; | ||
247 | }; | ||
248 | }; | ||
222 | }; | 249 | }; |
223 | 250 | ||
224 | enet1: ethernet@25000 { | 251 | enet1: ethernet@25000 { |
@@ -231,6 +258,8 @@ | |||
231 | interrupts = <34 0x8 33 0x8 32 0x8>; | 258 | interrupts = <34 0x8 33 0x8 32 0x8>; |
232 | interrupt-parent = <&ipic>; | 259 | interrupt-parent = <&ipic>; |
233 | phy-handle = < &phy4 >; | 260 | phy-handle = < &phy4 >; |
261 | sleep = <&pmc 0x10000000>; | ||
262 | fsl,magic-packet; | ||
234 | }; | 263 | }; |
235 | 264 | ||
236 | serial0: serial@4500 { | 265 | serial0: serial@4500 { |
@@ -253,17 +282,6 @@ | |||
253 | interrupt-parent = <&ipic>; | 282 | interrupt-parent = <&ipic>; |
254 | }; | 283 | }; |
255 | 284 | ||
256 | crypto@30000 { | ||
257 | compatible = "fsl,sec2.2", "fsl,sec2.1", "fsl,sec2.0"; | ||
258 | reg = <0x30000 0x10000>; | ||
259 | interrupts = <11 0x8>; | ||
260 | interrupt-parent = <&ipic>; | ||
261 | fsl,num-channels = <1>; | ||
262 | fsl,channel-fifo-len = <24>; | ||
263 | fsl,exec-units-mask = <0x4c>; | ||
264 | fsl,descriptor-types-mask = <0x0122003f>; | ||
265 | }; | ||
266 | |||
267 | /* IPIC | 285 | /* IPIC |
268 | * interrupts cell = <intr #, sense> | 286 | * interrupts cell = <intr #, sense> |
269 | * sense values match linux IORESOURCE_IRQ_* defines: | 287 | * sense values match linux IORESOURCE_IRQ_* defines: |
@@ -277,36 +295,119 @@ | |||
277 | reg = <0x700 0x100>; | 295 | reg = <0x700 0x100>; |
278 | device_type = "ipic"; | 296 | device_type = "ipic"; |
279 | }; | 297 | }; |
298 | |||
299 | pmc: power@b00 { | ||
300 | compatible = "fsl,mpc8313-pmc", "fsl,mpc8349-pmc"; | ||
301 | reg = <0xb00 0x100 0xa00 0x100>; | ||
302 | interrupts = <80 8>; | ||
303 | interrupt-parent = <&ipic>; | ||
304 | fsl,mpc8313-wakeup-timer = <>m1>; | ||
305 | |||
306 | /* Remove this (or change to "okay") if you have | ||
307 | * a REVA3 or later board, if you apply one of the | ||
308 | * workarounds listed in section 8.5 of the board | ||
309 | * manual, or if you are adapting this device tree | ||
310 | * to a different board. | ||
311 | */ | ||
312 | status = "fail"; | ||
313 | }; | ||
314 | |||
315 | gtm1: timer@500 { | ||
316 | compatible = "fsl,mpc8313-gtm", "fsl,gtm"; | ||
317 | reg = <0x500 0x100>; | ||
318 | interrupts = <90 8 78 8 84 8 72 8>; | ||
319 | interrupt-parent = <&ipic>; | ||
320 | }; | ||
321 | |||
322 | timer@600 { | ||
323 | compatible = "fsl,mpc8313-gtm", "fsl,gtm"; | ||
324 | reg = <0x600 0x100>; | ||
325 | interrupts = <91 8 79 8 85 8 73 8>; | ||
326 | interrupt-parent = <&ipic>; | ||
327 | }; | ||
280 | }; | 328 | }; |
281 | 329 | ||
282 | pci0: pci@e0008500 { | 330 | sleep-nexus { |
283 | cell-index = <1>; | 331 | #address-cells = <1>; |
284 | interrupt-map-mask = <0xf800 0x0 0x0 0x7>; | 332 | #size-cells = <1>; |
285 | interrupt-map = < | 333 | compatible = "simple-bus"; |
286 | 334 | sleep = <&pmc 0x00010000>; | |
287 | /* IDSEL 0x0E -mini PCI */ | 335 | ranges; |
288 | 0x7000 0x0 0x0 0x1 &ipic 18 0x8 | 336 | |
289 | 0x7000 0x0 0x0 0x2 &ipic 18 0x8 | 337 | pci0: pci@e0008500 { |
290 | 0x7000 0x0 0x0 0x3 &ipic 18 0x8 | 338 | cell-index = <1>; |
291 | 0x7000 0x0 0x0 0x4 &ipic 18 0x8 | 339 | interrupt-map-mask = <0xf800 0x0 0x0 0x7>; |
292 | 340 | interrupt-map = < | |
293 | /* IDSEL 0x0F - PCI slot */ | 341 | /* IDSEL 0x0E -mini PCI */ |
294 | 0x7800 0x0 0x0 0x1 &ipic 17 0x8 | 342 | 0x7000 0x0 0x0 0x1 &ipic 18 0x8 |
295 | 0x7800 0x0 0x0 0x2 &ipic 18 0x8 | 343 | 0x7000 0x0 0x0 0x2 &ipic 18 0x8 |
296 | 0x7800 0x0 0x0 0x3 &ipic 17 0x8 | 344 | 0x7000 0x0 0x0 0x3 &ipic 18 0x8 |
297 | 0x7800 0x0 0x0 0x4 &ipic 18 0x8>; | 345 | 0x7000 0x0 0x0 0x4 &ipic 18 0x8 |
298 | interrupt-parent = <&ipic>; | 346 | |
299 | interrupts = <66 0x8>; | 347 | /* IDSEL 0x0F - PCI slot */ |
300 | bus-range = <0x0 0x0>; | 348 | 0x7800 0x0 0x0 0x1 &ipic 17 0x8 |
301 | ranges = <0x02000000 0x0 0x90000000 0x90000000 0x0 0x10000000 | 349 | 0x7800 0x0 0x0 0x2 &ipic 18 0x8 |
302 | 0x42000000 0x0 0x80000000 0x80000000 0x0 0x10000000 | 350 | 0x7800 0x0 0x0 0x3 &ipic 17 0x8 |
303 | 0x01000000 0x0 0x00000000 0xe2000000 0x0 0x00100000>; | 351 | 0x7800 0x0 0x0 0x4 &ipic 18 0x8>; |
304 | clock-frequency = <66666666>; | 352 | interrupt-parent = <&ipic>; |
305 | #interrupt-cells = <1>; | 353 | interrupts = <66 0x8>; |
306 | #size-cells = <2>; | 354 | bus-range = <0x0 0x0>; |
307 | #address-cells = <3>; | 355 | ranges = <0x02000000 0x0 0x90000000 0x90000000 0x0 0x10000000 |
308 | reg = <0xe0008500 0x100>; | 356 | 0x42000000 0x0 0x80000000 0x80000000 0x0 0x10000000 |
309 | compatible = "fsl,mpc8349-pci"; | 357 | 0x01000000 0x0 0x00000000 0xe2000000 0x0 0x00100000>; |
310 | device_type = "pci"; | 358 | clock-frequency = <66666666>; |
359 | #interrupt-cells = <1>; | ||
360 | #size-cells = <2>; | ||
361 | #address-cells = <3>; | ||
362 | reg = <0xe0008500 0x100>; | ||
363 | compatible = "fsl,mpc8349-pci"; | ||
364 | device_type = "pci"; | ||
365 | }; | ||
366 | |||
367 | dma@82a8 { | ||
368 | #address-cells = <1>; | ||
369 | #size-cells = <1>; | ||
370 | compatible = "fsl,mpc8313-dma", "fsl,elo-dma"; | ||
371 | reg = <0xe00082a8 4>; | ||
372 | ranges = <0 0xe0008100 0x1a8>; | ||
373 | interrupt-parent = <&ipic>; | ||
374 | interrupts = <71 8>; | ||
375 | |||
376 | dma-channel@0 { | ||
377 | compatible = "fsl,mpc8313-dma-channel", | ||
378 | "fsl,elo-dma-channel"; | ||
379 | reg = <0 0x28>; | ||
380 | interrupt-parent = <&ipic>; | ||
381 | interrupts = <71 8>; | ||
382 | cell-index = <0>; | ||
383 | }; | ||
384 | |||
385 | dma-channel@80 { | ||
386 | compatible = "fsl,mpc8313-dma-channel", | ||
387 | "fsl,elo-dma-channel"; | ||
388 | reg = <0x80 0x28>; | ||
389 | interrupt-parent = <&ipic>; | ||
390 | interrupts = <71 8>; | ||
391 | cell-index = <1>; | ||
392 | }; | ||
393 | |||
394 | dma-channel@100 { | ||
395 | compatible = "fsl,mpc8313-dma-channel", | ||
396 | "fsl,elo-dma-channel"; | ||
397 | reg = <0x100 0x28>; | ||
398 | interrupt-parent = <&ipic>; | ||
399 | interrupts = <71 8>; | ||
400 | cell-index = <2>; | ||
401 | }; | ||
402 | |||
403 | dma-channel@180 { | ||
404 | compatible = "fsl,mpc8313-dma-channel", | ||
405 | "fsl,elo-dma-channel"; | ||
406 | reg = <0x180 0x28>; | ||
407 | interrupt-parent = <&ipic>; | ||
408 | interrupts = <71 8>; | ||
409 | cell-index = <3>; | ||
410 | }; | ||
411 | }; | ||
311 | }; | 412 | }; |
312 | }; | 413 | }; |
diff --git a/arch/powerpc/boot/dts/mpc8610_hpcd.dts b/arch/powerpc/boot/dts/mpc8610_hpcd.dts index 981941e5d7a5..666185f59459 100644 --- a/arch/powerpc/boot/dts/mpc8610_hpcd.dts +++ b/arch/powerpc/boot/dts/mpc8610_hpcd.dts | |||
@@ -388,6 +388,20 @@ | |||
388 | 0x01000000 0x0 0x00000000 | 388 | 0x01000000 0x0 0x00000000 |
389 | 0x01000000 0x0 0x00000000 | 389 | 0x01000000 0x0 0x00000000 |
390 | 0x0 0x00100000>; | 390 | 0x0 0x00100000>; |
391 | |||
392 | isa@1e { | ||
393 | device_type = "isa"; | ||
394 | #size-cells = <1>; | ||
395 | #address-cells = <2>; | ||
396 | reg = <0xf000 0 0 0 0>; | ||
397 | ranges = <1 0 0x01000000 0 0 | ||
398 | 0x00001000>; | ||
399 | |||
400 | rtc@70 { | ||
401 | compatible = "pnpPNP,b00"; | ||
402 | reg = <1 0x70 2>; | ||
403 | }; | ||
404 | }; | ||
391 | }; | 405 | }; |
392 | }; | 406 | }; |
393 | }; | 407 | }; |
diff --git a/arch/powerpc/configs/85xx/mpc8544_ds_defconfig b/arch/powerpc/configs/85xx/mpc8544_ds_defconfig index 042a85ea7b72..a0583e5119f5 100644 --- a/arch/powerpc/configs/85xx/mpc8544_ds_defconfig +++ b/arch/powerpc/configs/85xx/mpc8544_ds_defconfig | |||
@@ -997,10 +997,12 @@ CONFIG_SND=y | |||
997 | CONFIG_SND_TIMER=y | 997 | CONFIG_SND_TIMER=y |
998 | CONFIG_SND_PCM=y | 998 | CONFIG_SND_PCM=y |
999 | # CONFIG_SND_SEQUENCER is not set | 999 | # CONFIG_SND_SEQUENCER is not set |
1000 | # CONFIG_SND_MIXER_OSS is not set | 1000 | CONFIG_SND_OSSEMUL=y |
1001 | # CONFIG_SND_PCM_OSS is not set | 1001 | CONFIG_SND_MIXER_OSS=y |
1002 | CONFIG_SND_PCM_OSS=y | ||
1003 | CONFIG_SND_PCM_OSS_PLUGINS=y | ||
1002 | # CONFIG_SND_DYNAMIC_MINORS is not set | 1004 | # CONFIG_SND_DYNAMIC_MINORS is not set |
1003 | CONFIG_SND_SUPPORT_OLD_API=y | 1005 | # CONFIG_SND_SUPPORT_OLD_API is not set |
1004 | CONFIG_SND_VERBOSE_PROCFS=y | 1006 | CONFIG_SND_VERBOSE_PROCFS=y |
1005 | # CONFIG_SND_VERBOSE_PRINTK is not set | 1007 | # CONFIG_SND_VERBOSE_PRINTK is not set |
1006 | # CONFIG_SND_DEBUG is not set | 1008 | # CONFIG_SND_DEBUG is not set |
diff --git a/arch/powerpc/configs/85xx/mpc8572_ds_defconfig b/arch/powerpc/configs/85xx/mpc8572_ds_defconfig index 03627cfebcb4..164fd9606ee6 100644 --- a/arch/powerpc/configs/85xx/mpc8572_ds_defconfig +++ b/arch/powerpc/configs/85xx/mpc8572_ds_defconfig | |||
@@ -997,10 +997,12 @@ CONFIG_SND=y | |||
997 | CONFIG_SND_TIMER=y | 997 | CONFIG_SND_TIMER=y |
998 | CONFIG_SND_PCM=y | 998 | CONFIG_SND_PCM=y |
999 | # CONFIG_SND_SEQUENCER is not set | 999 | # CONFIG_SND_SEQUENCER is not set |
1000 | # CONFIG_SND_MIXER_OSS is not set | 1000 | CONFIG_SND_OSSEMUL=y |
1001 | # CONFIG_SND_PCM_OSS is not set | 1001 | CONFIG_SND_MIXER_OSS=y |
1002 | CONFIG_SND_PCM_OSS=y | ||
1003 | CONFIG_SND_PCM_OSS_PLUGINS=y | ||
1002 | # CONFIG_SND_DYNAMIC_MINORS is not set | 1004 | # CONFIG_SND_DYNAMIC_MINORS is not set |
1003 | CONFIG_SND_SUPPORT_OLD_API=y | 1005 | # CONFIG_SND_SUPPORT_OLD_API is not set |
1004 | CONFIG_SND_VERBOSE_PROCFS=y | 1006 | CONFIG_SND_VERBOSE_PROCFS=y |
1005 | # CONFIG_SND_VERBOSE_PRINTK is not set | 1007 | # CONFIG_SND_VERBOSE_PRINTK is not set |
1006 | # CONFIG_SND_DEBUG is not set | 1008 | # CONFIG_SND_DEBUG is not set |
diff --git a/arch/powerpc/configs/mpc85xx_defconfig b/arch/powerpc/configs/mpc85xx_defconfig index 3efab71a603b..fa0170504b88 100644 --- a/arch/powerpc/configs/mpc85xx_defconfig +++ b/arch/powerpc/configs/mpc85xx_defconfig | |||
@@ -1005,10 +1005,12 @@ CONFIG_SND=y | |||
1005 | CONFIG_SND_TIMER=y | 1005 | CONFIG_SND_TIMER=y |
1006 | CONFIG_SND_PCM=y | 1006 | CONFIG_SND_PCM=y |
1007 | # CONFIG_SND_SEQUENCER is not set | 1007 | # CONFIG_SND_SEQUENCER is not set |
1008 | # CONFIG_SND_MIXER_OSS is not set | 1008 | CONFIG_SND_OSSEMUL=y |
1009 | # CONFIG_SND_PCM_OSS is not set | 1009 | CONFIG_SND_MIXER_OSS=y |
1010 | CONFIG_SND_PCM_OSS=y | ||
1011 | CONFIG_SND_PCM_OSS_PLUGINS=y | ||
1010 | # CONFIG_SND_DYNAMIC_MINORS is not set | 1012 | # CONFIG_SND_DYNAMIC_MINORS is not set |
1011 | CONFIG_SND_SUPPORT_OLD_API=y | 1013 | # CONFIG_SND_SUPPORT_OLD_API is not set |
1012 | CONFIG_SND_VERBOSE_PROCFS=y | 1014 | CONFIG_SND_VERBOSE_PROCFS=y |
1013 | # CONFIG_SND_VERBOSE_PRINTK is not set | 1015 | # CONFIG_SND_VERBOSE_PRINTK is not set |
1014 | # CONFIG_SND_DEBUG is not set | 1016 | # CONFIG_SND_DEBUG is not set |
diff --git a/arch/powerpc/configs/mpc8610_hpcd_defconfig b/arch/powerpc/configs/mpc8610_hpcd_defconfig index 5612d40d0463..cdf98ae3682b 100644 --- a/arch/powerpc/configs/mpc8610_hpcd_defconfig +++ b/arch/powerpc/configs/mpc8610_hpcd_defconfig | |||
@@ -1,7 +1,7 @@ | |||
1 | # | 1 | # |
2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
3 | # Linux kernel version: 2.6.26-rc5 | 3 | # Linux kernel version: 2.6.26 |
4 | # Mon Jun 9 08:50:24 2008 | 4 | # Tue Jul 15 08:31:01 2008 |
5 | # | 5 | # |
6 | # CONFIG_PPC64 is not set | 6 | # CONFIG_PPC64 is not set |
7 | 7 | ||
@@ -51,6 +51,8 @@ CONFIG_PPC_UDBG_16550=y | |||
51 | CONFIG_AUDIT_ARCH=y | 51 | CONFIG_AUDIT_ARCH=y |
52 | CONFIG_GENERIC_BUG=y | 52 | CONFIG_GENERIC_BUG=y |
53 | CONFIG_DEFAULT_UIMAGE=y | 53 | CONFIG_DEFAULT_UIMAGE=y |
54 | CONFIG_HIBERNATE_32=y | ||
55 | CONFIG_ARCH_HIBERNATION_POSSIBLE=y | ||
54 | # CONFIG_PPC_DCR_NATIVE is not set | 56 | # CONFIG_PPC_DCR_NATIVE is not set |
55 | # CONFIG_PPC_DCR_MMIO is not set | 57 | # CONFIG_PPC_DCR_MMIO is not set |
56 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | 58 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" |
@@ -97,6 +99,7 @@ CONFIG_HOTPLUG=y | |||
97 | CONFIG_PRINTK=y | 99 | CONFIG_PRINTK=y |
98 | CONFIG_BUG=y | 100 | CONFIG_BUG=y |
99 | # CONFIG_ELF_CORE is not set | 101 | # CONFIG_ELF_CORE is not set |
102 | CONFIG_PCSPKR_PLATFORM=y | ||
100 | CONFIG_COMPAT_BRK=y | 103 | CONFIG_COMPAT_BRK=y |
101 | CONFIG_BASE_FULL=y | 104 | CONFIG_BASE_FULL=y |
102 | CONFIG_FUTEX=y | 105 | CONFIG_FUTEX=y |
@@ -117,7 +120,7 @@ CONFIG_HAVE_OPROFILE=y | |||
117 | # CONFIG_KPROBES is not set | 120 | # CONFIG_KPROBES is not set |
118 | CONFIG_HAVE_KPROBES=y | 121 | CONFIG_HAVE_KPROBES=y |
119 | CONFIG_HAVE_KRETPROBES=y | 122 | CONFIG_HAVE_KRETPROBES=y |
120 | # CONFIG_HAVE_DMA_ATTRS is not set | 123 | CONFIG_HAVE_DMA_ATTRS=y |
121 | CONFIG_PROC_PAGE_MONITOR=y | 124 | CONFIG_PROC_PAGE_MONITOR=y |
122 | CONFIG_SLABINFO=y | 125 | CONFIG_SLABINFO=y |
123 | CONFIG_RT_MUTEXES=y | 126 | CONFIG_RT_MUTEXES=y |
@@ -153,31 +156,43 @@ CONFIG_CLASSIC_RCU=y | |||
153 | # | 156 | # |
154 | # Platform support | 157 | # Platform support |
155 | # | 158 | # |
156 | # CONFIG_PPC_MULTIPLATFORM is not set | 159 | CONFIG_PPC_MULTIPLATFORM=y |
157 | # CONFIG_PPC_82xx is not set | 160 | CONFIG_CLASSIC32=y |
158 | # CONFIG_PPC_83xx is not set | 161 | CONFIG_PPC_CHRP=y |
159 | CONFIG_PPC_86xx=y | ||
160 | # CONFIG_PPC_MPC512x is not set | 162 | # CONFIG_PPC_MPC512x is not set |
161 | # CONFIG_PPC_MPC5121 is not set | 163 | # CONFIG_PPC_MPC5121 is not set |
164 | # CONFIG_MPC5121_ADS is not set | ||
165 | # CONFIG_PPC_MPC52xx is not set | ||
166 | CONFIG_PPC_PMAC=y | ||
162 | # CONFIG_PPC_CELL is not set | 167 | # CONFIG_PPC_CELL is not set |
163 | # CONFIG_PPC_CELL_NATIVE is not set | 168 | # CONFIG_PPC_CELL_NATIVE is not set |
169 | # CONFIG_PPC_82xx is not set | ||
164 | # CONFIG_PQ2ADS is not set | 170 | # CONFIG_PQ2ADS is not set |
171 | # CONFIG_PPC_83xx is not set | ||
172 | CONFIG_PPC_86xx=y | ||
165 | # CONFIG_MPC8641_HPCN is not set | 173 | # CONFIG_MPC8641_HPCN is not set |
166 | # CONFIG_SBC8641D is not set | 174 | # CONFIG_SBC8641D is not set |
167 | CONFIG_MPC8610_HPCD=y | 175 | CONFIG_MPC8610_HPCD=y |
168 | CONFIG_MPC8610=y | 176 | CONFIG_MPC8610=y |
177 | # CONFIG_EMBEDDED6xx is not set | ||
178 | CONFIG_PPC_NATIVE=y | ||
179 | # CONFIG_UDBG_RTAS_CONSOLE is not set | ||
169 | # CONFIG_IPIC is not set | 180 | # CONFIG_IPIC is not set |
170 | CONFIG_MPIC=y | 181 | CONFIG_MPIC=y |
171 | # CONFIG_MPIC_WEIRD is not set | 182 | # CONFIG_MPIC_WEIRD is not set |
172 | # CONFIG_PPC_I8259 is not set | 183 | CONFIG_PPC_I8259=y |
173 | # CONFIG_PPC_RTAS is not set | 184 | CONFIG_PPC_RTAS=y |
185 | # CONFIG_RTAS_ERROR_LOGGING is not set | ||
186 | CONFIG_RTAS_PROC=y | ||
174 | # CONFIG_MMIO_NVRAM is not set | 187 | # CONFIG_MMIO_NVRAM is not set |
175 | # CONFIG_PPC_MPC106 is not set | 188 | CONFIG_PPC_MPC106=y |
176 | # CONFIG_PPC_970_NAP is not set | 189 | # CONFIG_PPC_970_NAP is not set |
177 | # CONFIG_PPC_INDIRECT_IO is not set | 190 | # CONFIG_PPC_INDIRECT_IO is not set |
178 | # CONFIG_GENERIC_IOMAP is not set | 191 | # CONFIG_GENERIC_IOMAP is not set |
179 | # CONFIG_CPU_FREQ is not set | 192 | # CONFIG_CPU_FREQ is not set |
180 | # CONFIG_FSL_ULI1575 is not set | 193 | # CONFIG_PPC601_SYNC_FIX is not set |
194 | # CONFIG_TAU is not set | ||
195 | CONFIG_FSL_ULI1575=y | ||
181 | 196 | ||
182 | # | 197 | # |
183 | # Kernel options | 198 | # Kernel options |
@@ -202,6 +217,7 @@ CONFIG_BINFMT_ELF=y | |||
202 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 217 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
203 | CONFIG_ARCH_HAS_WALK_MEMORY=y | 218 | CONFIG_ARCH_HAS_WALK_MEMORY=y |
204 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | 219 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y |
220 | # CONFIG_KEXEC is not set | ||
205 | CONFIG_ARCH_FLATMEM_ENABLE=y | 221 | CONFIG_ARCH_FLATMEM_ENABLE=y |
206 | CONFIG_ARCH_POPULATES_NODE_MAP=y | 222 | CONFIG_ARCH_POPULATES_NODE_MAP=y |
207 | CONFIG_SELECT_MEMORY_MODEL=y | 223 | CONFIG_SELECT_MEMORY_MODEL=y |
@@ -228,11 +244,13 @@ CONFIG_ISA_DMA_API=y | |||
228 | # | 244 | # |
229 | # Bus options | 245 | # Bus options |
230 | # | 246 | # |
247 | # CONFIG_ISA is not set | ||
231 | CONFIG_ZONE_DMA=y | 248 | CONFIG_ZONE_DMA=y |
232 | CONFIG_GENERIC_ISA_DMA=y | 249 | CONFIG_GENERIC_ISA_DMA=y |
233 | CONFIG_PPC_INDIRECT_PCI=y | 250 | CONFIG_PPC_INDIRECT_PCI=y |
234 | CONFIG_FSL_SOC=y | 251 | CONFIG_FSL_SOC=y |
235 | CONFIG_FSL_PCI=y | 252 | CONFIG_FSL_PCI=y |
253 | CONFIG_PPC_PCI_CHOICE=y | ||
236 | CONFIG_PCI=y | 254 | CONFIG_PCI=y |
237 | CONFIG_PCI_DOMAINS=y | 255 | CONFIG_PCI_DOMAINS=y |
238 | CONFIG_PCI_SYSCALL=y | 256 | CONFIG_PCI_SYSCALL=y |
@@ -469,6 +487,7 @@ CONFIG_OF_I2C=y | |||
469 | # CONFIG_PARPORT is not set | 487 | # CONFIG_PARPORT is not set |
470 | CONFIG_BLK_DEV=y | 488 | CONFIG_BLK_DEV=y |
471 | # CONFIG_BLK_DEV_FD is not set | 489 | # CONFIG_BLK_DEV_FD is not set |
490 | # CONFIG_MAC_FLOPPY is not set | ||
472 | # CONFIG_BLK_CPQ_DA is not set | 491 | # CONFIG_BLK_CPQ_DA is not set |
473 | # CONFIG_BLK_CPQ_CISS_DA is not set | 492 | # CONFIG_BLK_CPQ_CISS_DA is not set |
474 | # CONFIG_BLK_DEV_DAC960 is not set | 493 | # CONFIG_BLK_DEV_DAC960 is not set |
@@ -571,6 +590,8 @@ CONFIG_SCSI_LOWLEVEL=y | |||
571 | # CONFIG_SCSI_DC390T is not set | 590 | # CONFIG_SCSI_DC390T is not set |
572 | # CONFIG_SCSI_NSP32 is not set | 591 | # CONFIG_SCSI_NSP32 is not set |
573 | # CONFIG_SCSI_DEBUG is not set | 592 | # CONFIG_SCSI_DEBUG is not set |
593 | # CONFIG_SCSI_MESH is not set | ||
594 | # CONFIG_SCSI_MAC53C94 is not set | ||
574 | # CONFIG_SCSI_SRP is not set | 595 | # CONFIG_SCSI_SRP is not set |
575 | CONFIG_ATA=y | 596 | CONFIG_ATA=y |
576 | # CONFIG_ATA_NONSTANDARD is not set | 597 | # CONFIG_ATA_NONSTANDARD is not set |
@@ -639,6 +660,10 @@ CONFIG_PATA_ALI=y | |||
639 | # | 660 | # |
640 | # IEEE 1394 (FireWire) support | 661 | # IEEE 1394 (FireWire) support |
641 | # | 662 | # |
663 | |||
664 | # | ||
665 | # Enable only one of the two stacks, unless you know what you are doing | ||
666 | # | ||
642 | # CONFIG_FIREWIRE is not set | 667 | # CONFIG_FIREWIRE is not set |
643 | # CONFIG_IEEE1394 is not set | 668 | # CONFIG_IEEE1394 is not set |
644 | # CONFIG_I2O is not set | 669 | # CONFIG_I2O is not set |
@@ -655,6 +680,8 @@ CONFIG_DUMMY=y | |||
655 | # CONFIG_PHYLIB is not set | 680 | # CONFIG_PHYLIB is not set |
656 | CONFIG_NET_ETHERNET=y | 681 | CONFIG_NET_ETHERNET=y |
657 | # CONFIG_MII is not set | 682 | # CONFIG_MII is not set |
683 | # CONFIG_MACE is not set | ||
684 | # CONFIG_BMAC is not set | ||
658 | # CONFIG_HAPPYMEAL is not set | 685 | # CONFIG_HAPPYMEAL is not set |
659 | # CONFIG_SUNGEM is not set | 686 | # CONFIG_SUNGEM is not set |
660 | # CONFIG_CASSINI is not set | 687 | # CONFIG_CASSINI is not set |
@@ -762,14 +789,16 @@ CONFIG_SERIAL_8250_RSA=y | |||
762 | # CONFIG_SERIAL_UARTLITE is not set | 789 | # CONFIG_SERIAL_UARTLITE is not set |
763 | CONFIG_SERIAL_CORE=y | 790 | CONFIG_SERIAL_CORE=y |
764 | CONFIG_SERIAL_CORE_CONSOLE=y | 791 | CONFIG_SERIAL_CORE_CONSOLE=y |
792 | # CONFIG_SERIAL_PMACZILOG is not set | ||
765 | # CONFIG_SERIAL_JSM is not set | 793 | # CONFIG_SERIAL_JSM is not set |
766 | # CONFIG_SERIAL_OF_PLATFORM is not set | 794 | # CONFIG_SERIAL_OF_PLATFORM is not set |
767 | CONFIG_UNIX98_PTYS=y | 795 | CONFIG_UNIX98_PTYS=y |
768 | # CONFIG_LEGACY_PTYS is not set | 796 | # CONFIG_LEGACY_PTYS is not set |
797 | # CONFIG_BRIQ_PANEL is not set | ||
798 | # CONFIG_HVC_RTAS is not set | ||
769 | # CONFIG_IPMI_HANDLER is not set | 799 | # CONFIG_IPMI_HANDLER is not set |
770 | # CONFIG_HW_RANDOM is not set | 800 | # CONFIG_HW_RANDOM is not set |
771 | # CONFIG_NVRAM is not set | 801 | # CONFIG_NVRAM is not set |
772 | # CONFIG_GEN_RTC is not set | ||
773 | # CONFIG_R3964 is not set | 802 | # CONFIG_R3964 is not set |
774 | # CONFIG_APPLICOM is not set | 803 | # CONFIG_APPLICOM is not set |
775 | # CONFIG_RAW_DRIVER is not set | 804 | # CONFIG_RAW_DRIVER is not set |
@@ -787,9 +816,11 @@ CONFIG_I2C_BOARDINFO=y | |||
787 | # CONFIG_I2C_ALI15X3 is not set | 816 | # CONFIG_I2C_ALI15X3 is not set |
788 | # CONFIG_I2C_AMD756 is not set | 817 | # CONFIG_I2C_AMD756 is not set |
789 | # CONFIG_I2C_AMD8111 is not set | 818 | # CONFIG_I2C_AMD8111 is not set |
819 | # CONFIG_I2C_HYDRA is not set | ||
790 | # CONFIG_I2C_I801 is not set | 820 | # CONFIG_I2C_I801 is not set |
791 | # CONFIG_I2C_I810 is not set | 821 | # CONFIG_I2C_I810 is not set |
792 | # CONFIG_I2C_PIIX4 is not set | 822 | # CONFIG_I2C_PIIX4 is not set |
823 | CONFIG_I2C_POWERMAC=y | ||
793 | CONFIG_I2C_MPC=y | 824 | CONFIG_I2C_MPC=y |
794 | # CONFIG_I2C_NFORCE2 is not set | 825 | # CONFIG_I2C_NFORCE2 is not set |
795 | # CONFIG_I2C_OCORES is not set | 826 | # CONFIG_I2C_OCORES is not set |
@@ -826,6 +857,7 @@ CONFIG_I2C_MPC=y | |||
826 | # CONFIG_POWER_SUPPLY is not set | 857 | # CONFIG_POWER_SUPPLY is not set |
827 | # CONFIG_HWMON is not set | 858 | # CONFIG_HWMON is not set |
828 | # CONFIG_THERMAL is not set | 859 | # CONFIG_THERMAL is not set |
860 | # CONFIG_THERMAL_HWMON is not set | ||
829 | # CONFIG_WATCHDOG is not set | 861 | # CONFIG_WATCHDOG is not set |
830 | 862 | ||
831 | # | 863 | # |
@@ -888,6 +920,9 @@ CONFIG_FB_CFB_IMAGEBLIT=y | |||
888 | # CONFIG_FB_PM2 is not set | 920 | # CONFIG_FB_PM2 is not set |
889 | # CONFIG_FB_CYBER2000 is not set | 921 | # CONFIG_FB_CYBER2000 is not set |
890 | # CONFIG_FB_OF is not set | 922 | # CONFIG_FB_OF is not set |
923 | # CONFIG_FB_CONTROL is not set | ||
924 | # CONFIG_FB_PLATINUM is not set | ||
925 | # CONFIG_FB_VALKYRIE is not set | ||
891 | # CONFIG_FB_CT65550 is not set | 926 | # CONFIG_FB_CT65550 is not set |
892 | # CONFIG_FB_ASILIANT is not set | 927 | # CONFIG_FB_ASILIANT is not set |
893 | # CONFIG_FB_IMSTT is not set | 928 | # CONFIG_FB_IMSTT is not set |
@@ -1027,12 +1062,19 @@ CONFIG_SND_VERBOSE_PROCFS=y | |||
1027 | # | 1062 | # |
1028 | # ALSA PowerMac devices | 1063 | # ALSA PowerMac devices |
1029 | # | 1064 | # |
1065 | # CONFIG_SND_POWERMAC is not set | ||
1030 | 1066 | ||
1031 | # | 1067 | # |
1032 | # ALSA PowerPC devices | 1068 | # ALSA PowerPC devices |
1033 | # | 1069 | # |
1034 | 1070 | ||
1035 | # | 1071 | # |
1072 | # Apple Onboard Audio driver | ||
1073 | # | ||
1074 | # CONFIG_SND_AOA is not set | ||
1075 | # CONFIG_SND_AOA_SOUNDBUS is not set | ||
1076 | |||
1077 | # | ||
1036 | # System on Chip audio support | 1078 | # System on Chip audio support |
1037 | # | 1079 | # |
1038 | CONFIG_SND_SOC=y | 1080 | CONFIG_SND_SOC=y |
@@ -1075,7 +1117,57 @@ CONFIG_USB_ARCH_HAS_EHCI=y | |||
1075 | # CONFIG_ACCESSIBILITY is not set | 1117 | # CONFIG_ACCESSIBILITY is not set |
1076 | # CONFIG_INFINIBAND is not set | 1118 | # CONFIG_INFINIBAND is not set |
1077 | # CONFIG_EDAC is not set | 1119 | # CONFIG_EDAC is not set |
1078 | # CONFIG_RTC_CLASS is not set | 1120 | CONFIG_RTC_LIB=y |
1121 | CONFIG_RTC_CLASS=y | ||
1122 | CONFIG_RTC_HCTOSYS=y | ||
1123 | CONFIG_RTC_HCTOSYS_DEVICE="rtc0" | ||
1124 | # CONFIG_RTC_DEBUG is not set | ||
1125 | |||
1126 | # | ||
1127 | # RTC interfaces | ||
1128 | # | ||
1129 | CONFIG_RTC_INTF_SYSFS=y | ||
1130 | CONFIG_RTC_INTF_PROC=y | ||
1131 | CONFIG_RTC_INTF_DEV=y | ||
1132 | # CONFIG_RTC_INTF_DEV_UIE_EMUL is not set | ||
1133 | # CONFIG_RTC_DRV_TEST is not set | ||
1134 | |||
1135 | # | ||
1136 | # I2C RTC drivers | ||
1137 | # | ||
1138 | # CONFIG_RTC_DRV_DS1307 is not set | ||
1139 | # CONFIG_RTC_DRV_DS1374 is not set | ||
1140 | # CONFIG_RTC_DRV_DS1672 is not set | ||
1141 | # CONFIG_RTC_DRV_MAX6900 is not set | ||
1142 | # CONFIG_RTC_DRV_RS5C372 is not set | ||
1143 | # CONFIG_RTC_DRV_ISL1208 is not set | ||
1144 | # CONFIG_RTC_DRV_X1205 is not set | ||
1145 | # CONFIG_RTC_DRV_PCF8563 is not set | ||
1146 | # CONFIG_RTC_DRV_PCF8583 is not set | ||
1147 | # CONFIG_RTC_DRV_M41T80 is not set | ||
1148 | # CONFIG_RTC_DRV_S35390A is not set | ||
1149 | # CONFIG_RTC_DRV_FM3130 is not set | ||
1150 | |||
1151 | # | ||
1152 | # SPI RTC drivers | ||
1153 | # | ||
1154 | |||
1155 | # | ||
1156 | # Platform RTC drivers | ||
1157 | # | ||
1158 | CONFIG_RTC_DRV_CMOS=y | ||
1159 | # CONFIG_RTC_DRV_DS1511 is not set | ||
1160 | # CONFIG_RTC_DRV_DS1553 is not set | ||
1161 | # CONFIG_RTC_DRV_DS1742 is not set | ||
1162 | # CONFIG_RTC_DRV_STK17TA8 is not set | ||
1163 | # CONFIG_RTC_DRV_M48T86 is not set | ||
1164 | # CONFIG_RTC_DRV_M48T59 is not set | ||
1165 | # CONFIG_RTC_DRV_V3020 is not set | ||
1166 | |||
1167 | # | ||
1168 | # on-CPU RTC drivers | ||
1169 | # | ||
1170 | # CONFIG_RTC_DRV_PPC is not set | ||
1079 | # CONFIG_DMADEVICES is not set | 1171 | # CONFIG_DMADEVICES is not set |
1080 | # CONFIG_UIO is not set | 1172 | # CONFIG_UIO is not set |
1081 | 1173 | ||
@@ -1295,8 +1387,11 @@ CONFIG_DEBUG_INFO=y | |||
1295 | # CONFIG_DEBUG_STACK_USAGE is not set | 1387 | # CONFIG_DEBUG_STACK_USAGE is not set |
1296 | # CONFIG_DEBUG_PAGEALLOC is not set | 1388 | # CONFIG_DEBUG_PAGEALLOC is not set |
1297 | # CONFIG_DEBUGGER is not set | 1389 | # CONFIG_DEBUGGER is not set |
1390 | # CONFIG_CODE_PATCHING_SELFTEST is not set | ||
1391 | # CONFIG_FTR_FIXUP_SELFTEST is not set | ||
1298 | # CONFIG_IRQSTACKS is not set | 1392 | # CONFIG_IRQSTACKS is not set |
1299 | # CONFIG_BDI_SWITCH is not set | 1393 | # CONFIG_BDI_SWITCH is not set |
1394 | # CONFIG_BOOTX_TEXT is not set | ||
1300 | # CONFIG_PPC_EARLY_DEBUG is not set | 1395 | # CONFIG_PPC_EARLY_DEBUG is not set |
1301 | 1396 | ||
1302 | # | 1397 | # |
diff --git a/arch/powerpc/configs/mpc8641_hpcn_defconfig b/arch/powerpc/configs/mpc8641_hpcn_defconfig index 4a8171507391..867b8c0215f3 100644 --- a/arch/powerpc/configs/mpc8641_hpcn_defconfig +++ b/arch/powerpc/configs/mpc8641_hpcn_defconfig | |||
@@ -991,10 +991,12 @@ CONFIG_SND=y | |||
991 | CONFIG_SND_TIMER=y | 991 | CONFIG_SND_TIMER=y |
992 | CONFIG_SND_PCM=y | 992 | CONFIG_SND_PCM=y |
993 | # CONFIG_SND_SEQUENCER is not set | 993 | # CONFIG_SND_SEQUENCER is not set |
994 | # CONFIG_SND_MIXER_OSS is not set | 994 | CONFIG_SND_OSSEMUL=y |
995 | # CONFIG_SND_PCM_OSS is not set | 995 | CONFIG_SND_MIXER_OSS=y |
996 | CONFIG_SND_PCM_OSS=y | ||
997 | CONFIG_SND_PCM_OSS_PLUGINS=y | ||
996 | # CONFIG_SND_DYNAMIC_MINORS is not set | 998 | # CONFIG_SND_DYNAMIC_MINORS is not set |
997 | CONFIG_SND_SUPPORT_OLD_API=y | 999 | # CONFIG_SND_SUPPORT_OLD_API is not set |
998 | CONFIG_SND_VERBOSE_PROCFS=y | 1000 | CONFIG_SND_VERBOSE_PROCFS=y |
999 | # CONFIG_SND_VERBOSE_PRINTK is not set | 1001 | # CONFIG_SND_VERBOSE_PRINTK is not set |
1000 | # CONFIG_SND_DEBUG is not set | 1002 | # CONFIG_SND_DEBUG is not set |
diff --git a/arch/powerpc/configs/ppc6xx_defconfig b/arch/powerpc/configs/ppc6xx_defconfig new file mode 100644 index 000000000000..e6e91c85da31 --- /dev/null +++ b/arch/powerpc/configs/ppc6xx_defconfig | |||
@@ -0,0 +1,3304 @@ | |||
1 | # powerpc | ||
2 | # | ||
3 | # Automatically generated make config: don't edit | ||
4 | # Linux kernel version: 2.6.26-git2 | ||
5 | # Tue Jul 15 23:54:18 2008 | ||
6 | # | ||
7 | # CONFIG_PPC64 is not set | ||
8 | |||
9 | # | ||
10 | # Processor support | ||
11 | # | ||
12 | CONFIG_6xx=y | ||
13 | # CONFIG_PPC_85xx is not set | ||
14 | # CONFIG_PPC_8xx is not set | ||
15 | # CONFIG_40x is not set | ||
16 | # CONFIG_44x is not set | ||
17 | # CONFIG_E200 is not set | ||
18 | CONFIG_PPC_FPU=y | ||
19 | CONFIG_FSL_EMB_PERFMON=y | ||
20 | CONFIG_ALTIVEC=y | ||
21 | CONFIG_PPC_STD_MMU=y | ||
22 | CONFIG_PPC_STD_MMU_32=y | ||
23 | # CONFIG_PPC_MM_SLICES is not set | ||
24 | # CONFIG_SMP is not set | ||
25 | CONFIG_PPC32=y | ||
26 | CONFIG_WORD_SIZE=32 | ||
27 | CONFIG_PPC_MERGE=y | ||
28 | CONFIG_MMU=y | ||
29 | CONFIG_GENERIC_CMOS_UPDATE=y | ||
30 | CONFIG_GENERIC_TIME=y | ||
31 | CONFIG_GENERIC_TIME_VSYSCALL=y | ||
32 | CONFIG_GENERIC_CLOCKEVENTS=y | ||
33 | CONFIG_GENERIC_HARDIRQS=y | ||
34 | # CONFIG_HAVE_SETUP_PER_CPU_AREA is not set | ||
35 | CONFIG_IRQ_PER_CPU=y | ||
36 | CONFIG_STACKTRACE_SUPPORT=y | ||
37 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | ||
38 | CONFIG_LOCKDEP_SUPPORT=y | ||
39 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | ||
40 | CONFIG_ARCH_HAS_ILOG2_U32=y | ||
41 | CONFIG_GENERIC_HWEIGHT=y | ||
42 | CONFIG_GENERIC_CALIBRATE_DELAY=y | ||
43 | CONFIG_GENERIC_FIND_NEXT_BIT=y | ||
44 | CONFIG_GENERIC_GPIO=y | ||
45 | # CONFIG_ARCH_NO_VIRT_TO_BUS is not set | ||
46 | CONFIG_PPC=y | ||
47 | CONFIG_EARLY_PRINTK=y | ||
48 | CONFIG_GENERIC_NVRAM=y | ||
49 | CONFIG_SCHED_NO_NO_OMIT_FRAME_POINTER=y | ||
50 | CONFIG_ARCH_MAY_HAVE_PC_FDC=y | ||
51 | CONFIG_PPC_OF=y | ||
52 | CONFIG_OF=y | ||
53 | CONFIG_PPC_UDBG_16550=y | ||
54 | # CONFIG_GENERIC_TBSYNC is not set | ||
55 | CONFIG_AUDIT_ARCH=y | ||
56 | CONFIG_GENERIC_BUG=y | ||
57 | CONFIG_SYS_SUPPORTS_APM_EMULATION=y | ||
58 | CONFIG_DEFAULT_UIMAGE=y | ||
59 | CONFIG_REDBOOT=y | ||
60 | CONFIG_HIBERNATE_32=y | ||
61 | CONFIG_ARCH_HIBERNATION_POSSIBLE=y | ||
62 | CONFIG_ARCH_SUSPEND_POSSIBLE=y | ||
63 | # CONFIG_PPC_DCR_NATIVE is not set | ||
64 | # CONFIG_PPC_DCR_MMIO is not set | ||
65 | CONFIG_DEFCONFIG_LIST="/lib/modules/$UNAME_RELEASE/.config" | ||
66 | |||
67 | # | ||
68 | # General setup | ||
69 | # | ||
70 | CONFIG_EXPERIMENTAL=y | ||
71 | CONFIG_BROKEN_ON_SMP=y | ||
72 | CONFIG_INIT_ENV_ARG_LIMIT=32 | ||
73 | CONFIG_LOCALVERSION="" | ||
74 | # CONFIG_LOCALVERSION_AUTO is not set | ||
75 | CONFIG_SWAP=y | ||
76 | CONFIG_SYSVIPC=y | ||
77 | CONFIG_SYSVIPC_SYSCTL=y | ||
78 | CONFIG_POSIX_MQUEUE=y | ||
79 | CONFIG_BSD_PROCESS_ACCT=y | ||
80 | # CONFIG_BSD_PROCESS_ACCT_V3 is not set | ||
81 | CONFIG_TASKSTATS=y | ||
82 | CONFIG_TASK_DELAY_ACCT=y | ||
83 | CONFIG_TASK_XACCT=y | ||
84 | CONFIG_TASK_IO_ACCOUNTING=y | ||
85 | CONFIG_AUDIT=y | ||
86 | CONFIG_AUDITSYSCALL=y | ||
87 | CONFIG_AUDIT_TREE=y | ||
88 | # CONFIG_IKCONFIG is not set | ||
89 | CONFIG_LOG_BUF_SHIFT=17 | ||
90 | CONFIG_CGROUPS=y | ||
91 | # CONFIG_CGROUP_DEBUG is not set | ||
92 | CONFIG_CGROUP_NS=y | ||
93 | CONFIG_CGROUP_DEVICE=y | ||
94 | CONFIG_GROUP_SCHED=y | ||
95 | CONFIG_FAIR_GROUP_SCHED=y | ||
96 | CONFIG_RT_GROUP_SCHED=y | ||
97 | # CONFIG_USER_SCHED is not set | ||
98 | CONFIG_CGROUP_SCHED=y | ||
99 | CONFIG_CGROUP_CPUACCT=y | ||
100 | CONFIG_RESOURCE_COUNTERS=y | ||
101 | # CONFIG_CGROUP_MEM_RES_CTLR is not set | ||
102 | # CONFIG_SYSFS_DEPRECATED_V2 is not set | ||
103 | CONFIG_RELAY=y | ||
104 | CONFIG_NAMESPACES=y | ||
105 | CONFIG_UTS_NS=y | ||
106 | CONFIG_IPC_NS=y | ||
107 | CONFIG_USER_NS=y | ||
108 | CONFIG_PID_NS=y | ||
109 | CONFIG_BLK_DEV_INITRD=y | ||
110 | CONFIG_INITRAMFS_SOURCE="" | ||
111 | CONFIG_CC_OPTIMIZE_FOR_SIZE=y | ||
112 | CONFIG_SYSCTL=y | ||
113 | # CONFIG_EMBEDDED is not set | ||
114 | CONFIG_SYSCTL_SYSCALL=y | ||
115 | CONFIG_SYSCTL_SYSCALL_CHECK=y | ||
116 | CONFIG_KALLSYMS=y | ||
117 | CONFIG_KALLSYMS_ALL=y | ||
118 | CONFIG_KALLSYMS_EXTRA_PASS=y | ||
119 | CONFIG_HOTPLUG=y | ||
120 | CONFIG_PRINTK=y | ||
121 | CONFIG_BUG=y | ||
122 | CONFIG_ELF_CORE=y | ||
123 | CONFIG_PCSPKR_PLATFORM=y | ||
124 | # CONFIG_COMPAT_BRK is not set | ||
125 | CONFIG_BASE_FULL=y | ||
126 | CONFIG_FUTEX=y | ||
127 | CONFIG_ANON_INODES=y | ||
128 | CONFIG_EPOLL=y | ||
129 | CONFIG_SIGNALFD=y | ||
130 | CONFIG_TIMERFD=y | ||
131 | CONFIG_EVENTFD=y | ||
132 | CONFIG_SHMEM=y | ||
133 | CONFIG_VM_EVENT_COUNTERS=y | ||
134 | CONFIG_SLUB_DEBUG=y | ||
135 | # CONFIG_SLAB is not set | ||
136 | CONFIG_SLUB=y | ||
137 | # CONFIG_SLOB is not set | ||
138 | CONFIG_PROFILING=y | ||
139 | CONFIG_MARKERS=y | ||
140 | CONFIG_OPROFILE=m | ||
141 | CONFIG_HAVE_OPROFILE=y | ||
142 | CONFIG_KPROBES=y | ||
143 | CONFIG_KRETPROBES=y | ||
144 | CONFIG_HAVE_KPROBES=y | ||
145 | CONFIG_HAVE_KRETPROBES=y | ||
146 | # CONFIG_HAVE_DMA_ATTRS is not set | ||
147 | # CONFIG_USE_GENERIC_SMP_HELPERS is not set | ||
148 | CONFIG_PROC_PAGE_MONITOR=y | ||
149 | CONFIG_SLABINFO=y | ||
150 | CONFIG_RT_MUTEXES=y | ||
151 | # CONFIG_TINY_SHMEM is not set | ||
152 | CONFIG_BASE_SMALL=0 | ||
153 | CONFIG_MODULES=y | ||
154 | # CONFIG_MODULE_FORCE_LOAD is not set | ||
155 | CONFIG_MODULE_UNLOAD=y | ||
156 | # CONFIG_MODULE_FORCE_UNLOAD is not set | ||
157 | # CONFIG_MODVERSIONS is not set | ||
158 | CONFIG_MODULE_SRCVERSION_ALL=y | ||
159 | CONFIG_KMOD=y | ||
160 | CONFIG_BLOCK=y | ||
161 | CONFIG_LBD=y | ||
162 | CONFIG_BLK_DEV_IO_TRACE=y | ||
163 | CONFIG_LSF=y | ||
164 | CONFIG_BLK_DEV_BSG=y | ||
165 | CONFIG_BLK_DEV_INTEGRITY=y | ||
166 | |||
167 | # | ||
168 | # IO Schedulers | ||
169 | # | ||
170 | CONFIG_IOSCHED_NOOP=y | ||
171 | CONFIG_IOSCHED_AS=y | ||
172 | CONFIG_IOSCHED_DEADLINE=y | ||
173 | CONFIG_IOSCHED_CFQ=y | ||
174 | # CONFIG_DEFAULT_AS is not set | ||
175 | # CONFIG_DEFAULT_DEADLINE is not set | ||
176 | CONFIG_DEFAULT_CFQ=y | ||
177 | # CONFIG_DEFAULT_NOOP is not set | ||
178 | CONFIG_DEFAULT_IOSCHED="cfq" | ||
179 | CONFIG_CLASSIC_RCU=y | ||
180 | |||
181 | # | ||
182 | # Platform support | ||
183 | # | ||
184 | CONFIG_PPC_MULTIPLATFORM=y | ||
185 | CONFIG_CLASSIC32=y | ||
186 | CONFIG_PPC_CHRP=y | ||
187 | # CONFIG_MPC5121_ADS is not set | ||
188 | # CONFIG_MPC5121_GENERIC is not set | ||
189 | CONFIG_PPC_MPC52xx=y | ||
190 | # CONFIG_PPC_MPC5200_SIMPLE is not set | ||
191 | CONFIG_PPC_EFIKA=y | ||
192 | # CONFIG_PPC_LITE5200 is not set | ||
193 | CONFIG_PPC_MPC5200_BUGFIX=y | ||
194 | CONFIG_PPC_MPC5200_GPIO=y | ||
195 | CONFIG_PPC_PMAC=y | ||
196 | # CONFIG_PPC_CELL is not set | ||
197 | # CONFIG_PPC_CELL_NATIVE is not set | ||
198 | CONFIG_PPC_82xx=y | ||
199 | CONFIG_MPC8272_ADS=y | ||
200 | CONFIG_PQ2FADS=y | ||
201 | CONFIG_EP8248E=y | ||
202 | CONFIG_PQ2ADS=y | ||
203 | CONFIG_8260=y | ||
204 | CONFIG_8272=y | ||
205 | CONFIG_PQ2_ADS_PCI_PIC=y | ||
206 | CONFIG_PPC_83xx=y | ||
207 | CONFIG_MPC831x_RDB=y | ||
208 | CONFIG_MPC832x_MDS=y | ||
209 | CONFIG_MPC832x_RDB=y | ||
210 | CONFIG_MPC834x_MDS=y | ||
211 | CONFIG_MPC834x_ITX=y | ||
212 | CONFIG_MPC836x_MDS=y | ||
213 | CONFIG_MPC836x_RDK=y | ||
214 | CONFIG_MPC837x_MDS=y | ||
215 | CONFIG_MPC837x_RDB=y | ||
216 | CONFIG_SBC834x=y | ||
217 | CONFIG_ASP834x=y | ||
218 | CONFIG_PPC_MPC831x=y | ||
219 | CONFIG_PPC_MPC832x=y | ||
220 | CONFIG_PPC_MPC834x=y | ||
221 | CONFIG_PPC_MPC837x=y | ||
222 | CONFIG_PPC_86xx=y | ||
223 | CONFIG_MPC8641_HPCN=y | ||
224 | CONFIG_SBC8641D=y | ||
225 | CONFIG_MPC8610_HPCD=y | ||
226 | CONFIG_MPC8641=y | ||
227 | CONFIG_MPC8610=y | ||
228 | # CONFIG_EMBEDDED6xx is not set | ||
229 | CONFIG_PPC_NATIVE=y | ||
230 | # CONFIG_UDBG_RTAS_CONSOLE is not set | ||
231 | CONFIG_IPIC=y | ||
232 | CONFIG_MPIC=y | ||
233 | # CONFIG_MPIC_WEIRD is not set | ||
234 | CONFIG_PPC_I8259=y | ||
235 | CONFIG_PPC_RTAS=y | ||
236 | # CONFIG_RTAS_ERROR_LOGGING is not set | ||
237 | CONFIG_RTAS_PROC=y | ||
238 | # CONFIG_MMIO_NVRAM is not set | ||
239 | CONFIG_PPC_MPC106=y | ||
240 | # CONFIG_PPC_970_NAP is not set | ||
241 | # CONFIG_PPC_INDIRECT_IO is not set | ||
242 | # CONFIG_GENERIC_IOMAP is not set | ||
243 | CONFIG_CPU_FREQ=y | ||
244 | CONFIG_CPU_FREQ_TABLE=y | ||
245 | CONFIG_CPU_FREQ_DEBUG=y | ||
246 | CONFIG_CPU_FREQ_STAT=m | ||
247 | CONFIG_CPU_FREQ_STAT_DETAILS=y | ||
248 | # CONFIG_CPU_FREQ_DEFAULT_GOV_PERFORMANCE is not set | ||
249 | # CONFIG_CPU_FREQ_DEFAULT_GOV_POWERSAVE is not set | ||
250 | CONFIG_CPU_FREQ_DEFAULT_GOV_USERSPACE=y | ||
251 | # CONFIG_CPU_FREQ_DEFAULT_GOV_ONDEMAND is not set | ||
252 | # CONFIG_CPU_FREQ_DEFAULT_GOV_CONSERVATIVE is not set | ||
253 | CONFIG_CPU_FREQ_GOV_PERFORMANCE=y | ||
254 | CONFIG_CPU_FREQ_GOV_POWERSAVE=m | ||
255 | CONFIG_CPU_FREQ_GOV_USERSPACE=y | ||
256 | CONFIG_CPU_FREQ_GOV_ONDEMAND=m | ||
257 | CONFIG_CPU_FREQ_GOV_CONSERVATIVE=m | ||
258 | |||
259 | # | ||
260 | # CPU Frequency drivers | ||
261 | # | ||
262 | CONFIG_CPU_FREQ_PMAC=y | ||
263 | # CONFIG_PPC601_SYNC_FIX is not set | ||
264 | CONFIG_TAU=y | ||
265 | # CONFIG_TAU_INT is not set | ||
266 | CONFIG_TAU_AVERAGE=y | ||
267 | CONFIG_QUICC_ENGINE=y | ||
268 | CONFIG_CPM2=y | ||
269 | CONFIG_PPC_CPM_NEW_BINDING=y | ||
270 | CONFIG_FSL_ULI1575=y | ||
271 | CONFIG_CPM=y | ||
272 | CONFIG_PPC_BESTCOMM=y | ||
273 | CONFIG_PPC_BESTCOMM_ATA=m | ||
274 | CONFIG_PPC_BESTCOMM_FEC=m | ||
275 | CONFIG_PPC_BESTCOMM_GEN_BD=m | ||
276 | |||
277 | # | ||
278 | # Kernel options | ||
279 | # | ||
280 | CONFIG_HIGHMEM=y | ||
281 | CONFIG_TICK_ONESHOT=y | ||
282 | CONFIG_NO_HZ=y | ||
283 | CONFIG_HIGH_RES_TIMERS=y | ||
284 | CONFIG_GENERIC_CLOCKEVENTS_BUILD=y | ||
285 | # CONFIG_HZ_100 is not set | ||
286 | # CONFIG_HZ_250 is not set | ||
287 | # CONFIG_HZ_300 is not set | ||
288 | CONFIG_HZ_1000=y | ||
289 | CONFIG_HZ=1000 | ||
290 | # CONFIG_SCHED_HRTICK is not set | ||
291 | # CONFIG_PREEMPT_NONE is not set | ||
292 | CONFIG_PREEMPT_VOLUNTARY=y | ||
293 | # CONFIG_PREEMPT is not set | ||
294 | CONFIG_BINFMT_ELF=y | ||
295 | CONFIG_BINFMT_MISC=y | ||
296 | # CONFIG_MATH_EMULATION is not set | ||
297 | # CONFIG_IOMMU_HELPER is not set | ||
298 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | ||
299 | CONFIG_ARCH_HAS_WALK_MEMORY=y | ||
300 | CONFIG_ARCH_ENABLE_MEMORY_HOTREMOVE=y | ||
301 | # CONFIG_KEXEC is not set | ||
302 | CONFIG_ARCH_FLATMEM_ENABLE=y | ||
303 | CONFIG_ARCH_POPULATES_NODE_MAP=y | ||
304 | CONFIG_SELECT_MEMORY_MODEL=y | ||
305 | CONFIG_FLATMEM_MANUAL=y | ||
306 | # CONFIG_DISCONTIGMEM_MANUAL is not set | ||
307 | # CONFIG_SPARSEMEM_MANUAL is not set | ||
308 | CONFIG_FLATMEM=y | ||
309 | CONFIG_FLAT_NODE_MEM_MAP=y | ||
310 | # CONFIG_SPARSEMEM_STATIC is not set | ||
311 | # CONFIG_SPARSEMEM_VMEMMAP_ENABLE is not set | ||
312 | CONFIG_PAGEFLAGS_EXTENDED=y | ||
313 | CONFIG_SPLIT_PTLOCK_CPUS=4 | ||
314 | CONFIG_RESOURCES_64BIT=y | ||
315 | CONFIG_ZONE_DMA_FLAG=1 | ||
316 | CONFIG_BOUNCE=y | ||
317 | CONFIG_VIRT_TO_BUS=y | ||
318 | CONFIG_FORCE_MAX_ZONEORDER=11 | ||
319 | CONFIG_PROC_DEVICETREE=y | ||
320 | # CONFIG_CMDLINE_BOOL is not set | ||
321 | CONFIG_EXTRA_TARGETS="" | ||
322 | CONFIG_ARCH_WANTS_FREEZER_CONTROL=y | ||
323 | CONFIG_PM=y | ||
324 | CONFIG_PM_DEBUG=y | ||
325 | # CONFIG_PM_VERBOSE is not set | ||
326 | CONFIG_CAN_PM_TRACE=y | ||
327 | CONFIG_PM_SLEEP=y | ||
328 | CONFIG_SUSPEND=y | ||
329 | CONFIG_SUSPEND_FREEZER=y | ||
330 | CONFIG_HIBERNATION=y | ||
331 | CONFIG_PM_STD_PARTITION="" | ||
332 | CONFIG_APM_EMULATION=y | ||
333 | CONFIG_SECCOMP=y | ||
334 | CONFIG_ISA_DMA_API=y | ||
335 | |||
336 | # | ||
337 | # Bus options | ||
338 | # | ||
339 | CONFIG_ISA=y | ||
340 | CONFIG_ZONE_DMA=y | ||
341 | CONFIG_GENERIC_ISA_DMA=y | ||
342 | CONFIG_PPC_INDIRECT_PCI=y | ||
343 | CONFIG_FSL_SOC=y | ||
344 | CONFIG_FSL_PCI=y | ||
345 | CONFIG_FSL_LBC=y | ||
346 | CONFIG_FSL_GTM=y | ||
347 | CONFIG_PCI=y | ||
348 | CONFIG_PCI_DOMAINS=y | ||
349 | CONFIG_PCI_SYSCALL=y | ||
350 | CONFIG_PCI_8260=y | ||
351 | CONFIG_PCIEPORTBUS=y | ||
352 | CONFIG_PCIEAER=y | ||
353 | CONFIG_PCIEASPM=y | ||
354 | # CONFIG_PCIEASPM_DEBUG is not set | ||
355 | CONFIG_ARCH_SUPPORTS_MSI=y | ||
356 | CONFIG_PCI_MSI=y | ||
357 | CONFIG_PCI_LEGACY=y | ||
358 | # CONFIG_PCI_DEBUG is not set | ||
359 | CONFIG_PCCARD=y | ||
360 | # CONFIG_PCMCIA_DEBUG is not set | ||
361 | CONFIG_PCMCIA=y | ||
362 | CONFIG_PCMCIA_LOAD_CIS=y | ||
363 | CONFIG_PCMCIA_IOCTL=y | ||
364 | CONFIG_CARDBUS=y | ||
365 | |||
366 | # | ||
367 | # PC-card bridges | ||
368 | # | ||
369 | CONFIG_YENTA=y | ||
370 | CONFIG_YENTA_O2=y | ||
371 | CONFIG_YENTA_RICOH=y | ||
372 | CONFIG_YENTA_TI=y | ||
373 | CONFIG_YENTA_ENE_TUNE=y | ||
374 | CONFIG_YENTA_TOSHIBA=y | ||
375 | CONFIG_PD6729=m | ||
376 | CONFIG_I82092=m | ||
377 | CONFIG_I82365=m | ||
378 | # CONFIG_TCIC is not set | ||
379 | CONFIG_PCMCIA_PROBE=y | ||
380 | CONFIG_PCCARD_NONSTATIC=y | ||
381 | # CONFIG_HOTPLUG_PCI is not set | ||
382 | CONFIG_HAS_RAPIDIO=y | ||
383 | # CONFIG_RAPIDIO is not set | ||
384 | |||
385 | # | ||
386 | # Advanced setup | ||
387 | # | ||
388 | CONFIG_ADVANCED_OPTIONS=y | ||
389 | # CONFIG_LOWMEM_SIZE_BOOL is not set | ||
390 | CONFIG_LOWMEM_SIZE=0x30000000 | ||
391 | # CONFIG_PAGE_OFFSET_BOOL is not set | ||
392 | CONFIG_PAGE_OFFSET=0xc0000000 | ||
393 | # CONFIG_KERNEL_START_BOOL is not set | ||
394 | CONFIG_KERNEL_START=0xc0000000 | ||
395 | CONFIG_PHYSICAL_START=0x00000000 | ||
396 | # CONFIG_TASK_SIZE_BOOL is not set | ||
397 | CONFIG_TASK_SIZE=0xc0000000 | ||
398 | |||
399 | # | ||
400 | # Networking | ||
401 | # | ||
402 | CONFIG_NET=y | ||
403 | |||
404 | # | ||
405 | # Networking options | ||
406 | # | ||
407 | CONFIG_PACKET=y | ||
408 | CONFIG_PACKET_MMAP=y | ||
409 | CONFIG_UNIX=y | ||
410 | CONFIG_XFRM=y | ||
411 | CONFIG_XFRM_USER=y | ||
412 | CONFIG_XFRM_SUB_POLICY=y | ||
413 | CONFIG_XFRM_MIGRATE=y | ||
414 | CONFIG_XFRM_STATISTICS=y | ||
415 | CONFIG_NET_KEY=m | ||
416 | CONFIG_NET_KEY_MIGRATE=y | ||
417 | CONFIG_INET=y | ||
418 | CONFIG_IP_MULTICAST=y | ||
419 | CONFIG_IP_ADVANCED_ROUTER=y | ||
420 | CONFIG_ASK_IP_FIB_HASH=y | ||
421 | # CONFIG_IP_FIB_TRIE is not set | ||
422 | CONFIG_IP_FIB_HASH=y | ||
423 | CONFIG_IP_MULTIPLE_TABLES=y | ||
424 | CONFIG_IP_ROUTE_MULTIPATH=y | ||
425 | CONFIG_IP_ROUTE_VERBOSE=y | ||
426 | # CONFIG_IP_PNP is not set | ||
427 | CONFIG_NET_IPIP=m | ||
428 | CONFIG_NET_IPGRE=m | ||
429 | CONFIG_NET_IPGRE_BROADCAST=y | ||
430 | CONFIG_IP_MROUTE=y | ||
431 | CONFIG_IP_PIMSM_V1=y | ||
432 | CONFIG_IP_PIMSM_V2=y | ||
433 | # CONFIG_ARPD is not set | ||
434 | CONFIG_SYN_COOKIES=y | ||
435 | CONFIG_INET_AH=m | ||
436 | CONFIG_INET_ESP=m | ||
437 | CONFIG_INET_IPCOMP=m | ||
438 | CONFIG_INET_XFRM_TUNNEL=m | ||
439 | CONFIG_INET_TUNNEL=m | ||
440 | CONFIG_INET_XFRM_MODE_TRANSPORT=m | ||
441 | CONFIG_INET_XFRM_MODE_TUNNEL=m | ||
442 | CONFIG_INET_XFRM_MODE_BEET=m | ||
443 | CONFIG_INET_LRO=y | ||
444 | CONFIG_INET_DIAG=m | ||
445 | CONFIG_INET_TCP_DIAG=m | ||
446 | CONFIG_TCP_CONG_ADVANCED=y | ||
447 | CONFIG_TCP_CONG_BIC=m | ||
448 | CONFIG_TCP_CONG_CUBIC=y | ||
449 | CONFIG_TCP_CONG_WESTWOOD=m | ||
450 | CONFIG_TCP_CONG_HTCP=m | ||
451 | CONFIG_TCP_CONG_HSTCP=m | ||
452 | CONFIG_TCP_CONG_HYBLA=m | ||
453 | CONFIG_TCP_CONG_VEGAS=m | ||
454 | CONFIG_TCP_CONG_SCALABLE=m | ||
455 | CONFIG_TCP_CONG_LP=m | ||
456 | CONFIG_TCP_CONG_VENO=m | ||
457 | CONFIG_TCP_CONG_YEAH=m | ||
458 | CONFIG_TCP_CONG_ILLINOIS=m | ||
459 | # CONFIG_DEFAULT_BIC is not set | ||
460 | CONFIG_DEFAULT_CUBIC=y | ||
461 | # CONFIG_DEFAULT_HTCP is not set | ||
462 | # CONFIG_DEFAULT_VEGAS is not set | ||
463 | # CONFIG_DEFAULT_WESTWOOD is not set | ||
464 | # CONFIG_DEFAULT_RENO is not set | ||
465 | CONFIG_DEFAULT_TCP_CONG="cubic" | ||
466 | CONFIG_TCP_MD5SIG=y | ||
467 | # CONFIG_IP_VS is not set | ||
468 | CONFIG_IPV6=m | ||
469 | CONFIG_IPV6_PRIVACY=y | ||
470 | CONFIG_IPV6_ROUTER_PREF=y | ||
471 | CONFIG_IPV6_ROUTE_INFO=y | ||
472 | CONFIG_IPV6_OPTIMISTIC_DAD=y | ||
473 | CONFIG_INET6_AH=m | ||
474 | CONFIG_INET6_ESP=m | ||
475 | CONFIG_INET6_IPCOMP=m | ||
476 | CONFIG_IPV6_MIP6=m | ||
477 | CONFIG_INET6_XFRM_TUNNEL=m | ||
478 | CONFIG_INET6_TUNNEL=m | ||
479 | CONFIG_INET6_XFRM_MODE_TRANSPORT=m | ||
480 | CONFIG_INET6_XFRM_MODE_TUNNEL=m | ||
481 | CONFIG_INET6_XFRM_MODE_BEET=m | ||
482 | CONFIG_INET6_XFRM_MODE_ROUTEOPTIMIZATION=m | ||
483 | CONFIG_IPV6_SIT=m | ||
484 | CONFIG_IPV6_NDISC_NODETYPE=y | ||
485 | CONFIG_IPV6_TUNNEL=m | ||
486 | CONFIG_IPV6_MULTIPLE_TABLES=y | ||
487 | CONFIG_IPV6_SUBTREES=y | ||
488 | CONFIG_IPV6_MROUTE=y | ||
489 | CONFIG_IPV6_PIMSM_V2=y | ||
490 | CONFIG_NETLABEL=y | ||
491 | CONFIG_NETWORK_SECMARK=y | ||
492 | CONFIG_NETFILTER=y | ||
493 | # CONFIG_NETFILTER_DEBUG is not set | ||
494 | CONFIG_NETFILTER_ADVANCED=y | ||
495 | CONFIG_BRIDGE_NETFILTER=y | ||
496 | |||
497 | # | ||
498 | # Core Netfilter Configuration | ||
499 | # | ||
500 | CONFIG_NETFILTER_NETLINK=m | ||
501 | CONFIG_NETFILTER_NETLINK_QUEUE=m | ||
502 | CONFIG_NETFILTER_NETLINK_LOG=m | ||
503 | CONFIG_NF_CONNTRACK=m | ||
504 | CONFIG_NF_CT_ACCT=y | ||
505 | CONFIG_NF_CONNTRACK_MARK=y | ||
506 | CONFIG_NF_CONNTRACK_SECMARK=y | ||
507 | CONFIG_NF_CONNTRACK_EVENTS=y | ||
508 | CONFIG_NF_CT_PROTO_DCCP=m | ||
509 | CONFIG_NF_CT_PROTO_GRE=m | ||
510 | CONFIG_NF_CT_PROTO_SCTP=m | ||
511 | CONFIG_NF_CT_PROTO_UDPLITE=m | ||
512 | CONFIG_NF_CONNTRACK_AMANDA=m | ||
513 | CONFIG_NF_CONNTRACK_FTP=m | ||
514 | CONFIG_NF_CONNTRACK_H323=m | ||
515 | CONFIG_NF_CONNTRACK_IRC=m | ||
516 | CONFIG_NF_CONNTRACK_NETBIOS_NS=m | ||
517 | CONFIG_NF_CONNTRACK_PPTP=m | ||
518 | CONFIG_NF_CONNTRACK_SANE=m | ||
519 | CONFIG_NF_CONNTRACK_SIP=m | ||
520 | CONFIG_NF_CONNTRACK_TFTP=m | ||
521 | CONFIG_NF_CT_NETLINK=m | ||
522 | CONFIG_NETFILTER_XTABLES=m | ||
523 | CONFIG_NETFILTER_XT_TARGET_CLASSIFY=m | ||
524 | CONFIG_NETFILTER_XT_TARGET_CONNMARK=m | ||
525 | CONFIG_NETFILTER_XT_TARGET_DSCP=m | ||
526 | CONFIG_NETFILTER_XT_TARGET_MARK=m | ||
527 | CONFIG_NETFILTER_XT_TARGET_NFQUEUE=m | ||
528 | CONFIG_NETFILTER_XT_TARGET_NFLOG=m | ||
529 | CONFIG_NETFILTER_XT_TARGET_NOTRACK=m | ||
530 | CONFIG_NETFILTER_XT_TARGET_RATEEST=m | ||
531 | CONFIG_NETFILTER_XT_TARGET_TRACE=m | ||
532 | CONFIG_NETFILTER_XT_TARGET_SECMARK=m | ||
533 | CONFIG_NETFILTER_XT_TARGET_CONNSECMARK=m | ||
534 | CONFIG_NETFILTER_XT_TARGET_TCPMSS=m | ||
535 | CONFIG_NETFILTER_XT_TARGET_TCPOPTSTRIP=m | ||
536 | CONFIG_NETFILTER_XT_MATCH_COMMENT=m | ||
537 | CONFIG_NETFILTER_XT_MATCH_CONNBYTES=m | ||
538 | CONFIG_NETFILTER_XT_MATCH_CONNLIMIT=m | ||
539 | CONFIG_NETFILTER_XT_MATCH_CONNMARK=m | ||
540 | CONFIG_NETFILTER_XT_MATCH_CONNTRACK=m | ||
541 | CONFIG_NETFILTER_XT_MATCH_DCCP=m | ||
542 | CONFIG_NETFILTER_XT_MATCH_DSCP=m | ||
543 | CONFIG_NETFILTER_XT_MATCH_ESP=m | ||
544 | CONFIG_NETFILTER_XT_MATCH_HELPER=m | ||
545 | CONFIG_NETFILTER_XT_MATCH_IPRANGE=m | ||
546 | CONFIG_NETFILTER_XT_MATCH_LENGTH=m | ||
547 | CONFIG_NETFILTER_XT_MATCH_LIMIT=m | ||
548 | CONFIG_NETFILTER_XT_MATCH_MAC=m | ||
549 | CONFIG_NETFILTER_XT_MATCH_MARK=m | ||
550 | CONFIG_NETFILTER_XT_MATCH_OWNER=m | ||
551 | CONFIG_NETFILTER_XT_MATCH_POLICY=m | ||
552 | CONFIG_NETFILTER_XT_MATCH_MULTIPORT=m | ||
553 | CONFIG_NETFILTER_XT_MATCH_PHYSDEV=m | ||
554 | CONFIG_NETFILTER_XT_MATCH_PKTTYPE=m | ||
555 | CONFIG_NETFILTER_XT_MATCH_QUOTA=m | ||
556 | CONFIG_NETFILTER_XT_MATCH_RATEEST=m | ||
557 | CONFIG_NETFILTER_XT_MATCH_REALM=m | ||
558 | CONFIG_NETFILTER_XT_MATCH_SCTP=m | ||
559 | CONFIG_NETFILTER_XT_MATCH_STATE=m | ||
560 | CONFIG_NETFILTER_XT_MATCH_STATISTIC=m | ||
561 | CONFIG_NETFILTER_XT_MATCH_STRING=m | ||
562 | CONFIG_NETFILTER_XT_MATCH_TCPMSS=m | ||
563 | CONFIG_NETFILTER_XT_MATCH_TIME=m | ||
564 | CONFIG_NETFILTER_XT_MATCH_U32=m | ||
565 | CONFIG_NETFILTER_XT_MATCH_HASHLIMIT=m | ||
566 | |||
567 | # | ||
568 | # IP: Netfilter Configuration | ||
569 | # | ||
570 | CONFIG_NF_CONNTRACK_IPV4=m | ||
571 | # CONFIG_NF_CONNTRACK_PROC_COMPAT is not set | ||
572 | CONFIG_IP_NF_QUEUE=m | ||
573 | CONFIG_IP_NF_IPTABLES=m | ||
574 | CONFIG_IP_NF_MATCH_RECENT=m | ||
575 | CONFIG_IP_NF_MATCH_ECN=m | ||
576 | CONFIG_IP_NF_MATCH_AH=m | ||
577 | CONFIG_IP_NF_MATCH_TTL=m | ||
578 | CONFIG_IP_NF_MATCH_ADDRTYPE=m | ||
579 | CONFIG_IP_NF_FILTER=m | ||
580 | CONFIG_IP_NF_TARGET_REJECT=m | ||
581 | CONFIG_IP_NF_TARGET_LOG=m | ||
582 | CONFIG_IP_NF_TARGET_ULOG=m | ||
583 | CONFIG_NF_NAT=m | ||
584 | CONFIG_NF_NAT_NEEDED=y | ||
585 | CONFIG_IP_NF_TARGET_MASQUERADE=m | ||
586 | CONFIG_IP_NF_TARGET_REDIRECT=m | ||
587 | CONFIG_IP_NF_TARGET_NETMAP=m | ||
588 | CONFIG_NF_NAT_SNMP_BASIC=m | ||
589 | CONFIG_NF_NAT_PROTO_DCCP=m | ||
590 | CONFIG_NF_NAT_PROTO_GRE=m | ||
591 | CONFIG_NF_NAT_PROTO_UDPLITE=m | ||
592 | CONFIG_NF_NAT_PROTO_SCTP=m | ||
593 | CONFIG_NF_NAT_FTP=m | ||
594 | CONFIG_NF_NAT_IRC=m | ||
595 | CONFIG_NF_NAT_TFTP=m | ||
596 | CONFIG_NF_NAT_AMANDA=m | ||
597 | CONFIG_NF_NAT_PPTP=m | ||
598 | CONFIG_NF_NAT_H323=m | ||
599 | CONFIG_NF_NAT_SIP=m | ||
600 | CONFIG_IP_NF_MANGLE=m | ||
601 | CONFIG_IP_NF_TARGET_ECN=m | ||
602 | CONFIG_IP_NF_TARGET_TTL=m | ||
603 | CONFIG_IP_NF_TARGET_CLUSTERIP=m | ||
604 | CONFIG_IP_NF_RAW=m | ||
605 | CONFIG_IP_NF_ARPTABLES=m | ||
606 | CONFIG_IP_NF_ARPFILTER=m | ||
607 | CONFIG_IP_NF_ARP_MANGLE=m | ||
608 | |||
609 | # | ||
610 | # IPv6: Netfilter Configuration | ||
611 | # | ||
612 | CONFIG_NF_CONNTRACK_IPV6=m | ||
613 | CONFIG_IP6_NF_QUEUE=m | ||
614 | CONFIG_IP6_NF_IPTABLES=m | ||
615 | CONFIG_IP6_NF_MATCH_RT=m | ||
616 | CONFIG_IP6_NF_MATCH_OPTS=m | ||
617 | CONFIG_IP6_NF_MATCH_FRAG=m | ||
618 | CONFIG_IP6_NF_MATCH_HL=m | ||
619 | CONFIG_IP6_NF_MATCH_IPV6HEADER=m | ||
620 | CONFIG_IP6_NF_MATCH_AH=m | ||
621 | CONFIG_IP6_NF_MATCH_MH=m | ||
622 | CONFIG_IP6_NF_MATCH_EUI64=m | ||
623 | CONFIG_IP6_NF_FILTER=m | ||
624 | CONFIG_IP6_NF_TARGET_LOG=m | ||
625 | CONFIG_IP6_NF_TARGET_REJECT=m | ||
626 | CONFIG_IP6_NF_MANGLE=m | ||
627 | CONFIG_IP6_NF_TARGET_HL=m | ||
628 | CONFIG_IP6_NF_RAW=m | ||
629 | |||
630 | # | ||
631 | # DECnet: Netfilter Configuration | ||
632 | # | ||
633 | # CONFIG_DECNET_NF_GRABULATOR is not set | ||
634 | |||
635 | # | ||
636 | # Bridge: Netfilter Configuration | ||
637 | # | ||
638 | CONFIG_BRIDGE_NF_EBTABLES=m | ||
639 | CONFIG_BRIDGE_EBT_BROUTE=m | ||
640 | CONFIG_BRIDGE_EBT_T_FILTER=m | ||
641 | CONFIG_BRIDGE_EBT_T_NAT=m | ||
642 | CONFIG_BRIDGE_EBT_802_3=m | ||
643 | CONFIG_BRIDGE_EBT_AMONG=m | ||
644 | CONFIG_BRIDGE_EBT_ARP=m | ||
645 | CONFIG_BRIDGE_EBT_IP=m | ||
646 | CONFIG_BRIDGE_EBT_LIMIT=m | ||
647 | CONFIG_BRIDGE_EBT_MARK=m | ||
648 | CONFIG_BRIDGE_EBT_PKTTYPE=m | ||
649 | CONFIG_BRIDGE_EBT_STP=m | ||
650 | CONFIG_BRIDGE_EBT_VLAN=m | ||
651 | CONFIG_BRIDGE_EBT_ARPREPLY=m | ||
652 | CONFIG_BRIDGE_EBT_DNAT=m | ||
653 | CONFIG_BRIDGE_EBT_MARK_T=m | ||
654 | CONFIG_BRIDGE_EBT_REDIRECT=m | ||
655 | CONFIG_BRIDGE_EBT_SNAT=m | ||
656 | CONFIG_BRIDGE_EBT_LOG=m | ||
657 | CONFIG_BRIDGE_EBT_ULOG=m | ||
658 | CONFIG_BRIDGE_EBT_NFLOG=m | ||
659 | CONFIG_IP_DCCP=m | ||
660 | CONFIG_INET_DCCP_DIAG=m | ||
661 | CONFIG_IP_DCCP_ACKVEC=y | ||
662 | |||
663 | # | ||
664 | # DCCP CCIDs Configuration (EXPERIMENTAL) | ||
665 | # | ||
666 | CONFIG_IP_DCCP_CCID2=m | ||
667 | # CONFIG_IP_DCCP_CCID2_DEBUG is not set | ||
668 | CONFIG_IP_DCCP_CCID3=m | ||
669 | # CONFIG_IP_DCCP_CCID3_DEBUG is not set | ||
670 | CONFIG_IP_DCCP_CCID3_RTO=100 | ||
671 | CONFIG_IP_DCCP_TFRC_LIB=m | ||
672 | |||
673 | # | ||
674 | # DCCP Kernel Hacking | ||
675 | # | ||
676 | # CONFIG_IP_DCCP_DEBUG is not set | ||
677 | CONFIG_NET_DCCPPROBE=m | ||
678 | CONFIG_IP_SCTP=m | ||
679 | # CONFIG_SCTP_DBG_MSG is not set | ||
680 | # CONFIG_SCTP_DBG_OBJCNT is not set | ||
681 | # CONFIG_SCTP_HMAC_NONE is not set | ||
682 | # CONFIG_SCTP_HMAC_SHA1 is not set | ||
683 | CONFIG_SCTP_HMAC_MD5=y | ||
684 | CONFIG_TIPC=m | ||
685 | # CONFIG_TIPC_ADVANCED is not set | ||
686 | # CONFIG_TIPC_DEBUG is not set | ||
687 | CONFIG_ATM=m | ||
688 | CONFIG_ATM_CLIP=m | ||
689 | # CONFIG_ATM_CLIP_NO_ICMP is not set | ||
690 | CONFIG_ATM_LANE=m | ||
691 | # CONFIG_ATM_MPOA is not set | ||
692 | CONFIG_ATM_BR2684=m | ||
693 | # CONFIG_ATM_BR2684_IPFILTER is not set | ||
694 | CONFIG_BRIDGE=m | ||
695 | CONFIG_VLAN_8021Q=m | ||
696 | CONFIG_DECNET=m | ||
697 | CONFIG_DECNET_ROUTER=y | ||
698 | CONFIG_LLC=m | ||
699 | # CONFIG_LLC2 is not set | ||
700 | CONFIG_IPX=m | ||
701 | # CONFIG_IPX_INTERN is not set | ||
702 | CONFIG_ATALK=m | ||
703 | CONFIG_DEV_APPLETALK=m | ||
704 | # CONFIG_LTPC is not set | ||
705 | # CONFIG_COPS is not set | ||
706 | CONFIG_IPDDP=m | ||
707 | CONFIG_IPDDP_ENCAP=y | ||
708 | CONFIG_IPDDP_DECAP=y | ||
709 | # CONFIG_X25 is not set | ||
710 | # CONFIG_LAPB is not set | ||
711 | # CONFIG_ECONET is not set | ||
712 | CONFIG_WAN_ROUTER=m | ||
713 | CONFIG_NET_SCHED=y | ||
714 | |||
715 | # | ||
716 | # Queueing/Scheduling | ||
717 | # | ||
718 | CONFIG_NET_SCH_CBQ=m | ||
719 | CONFIG_NET_SCH_HTB=m | ||
720 | CONFIG_NET_SCH_HFSC=m | ||
721 | CONFIG_NET_SCH_ATM=m | ||
722 | CONFIG_NET_SCH_PRIO=m | ||
723 | CONFIG_NET_SCH_RED=m | ||
724 | CONFIG_NET_SCH_SFQ=m | ||
725 | CONFIG_NET_SCH_TEQL=m | ||
726 | CONFIG_NET_SCH_TBF=m | ||
727 | CONFIG_NET_SCH_GRED=m | ||
728 | CONFIG_NET_SCH_DSMARK=m | ||
729 | CONFIG_NET_SCH_NETEM=m | ||
730 | CONFIG_NET_SCH_INGRESS=m | ||
731 | |||
732 | # | ||
733 | # Classification | ||
734 | # | ||
735 | CONFIG_NET_CLS=y | ||
736 | CONFIG_NET_CLS_BASIC=m | ||
737 | CONFIG_NET_CLS_TCINDEX=m | ||
738 | CONFIG_NET_CLS_ROUTE4=m | ||
739 | CONFIG_NET_CLS_ROUTE=y | ||
740 | CONFIG_NET_CLS_FW=m | ||
741 | CONFIG_NET_CLS_U32=m | ||
742 | CONFIG_CLS_U32_PERF=y | ||
743 | CONFIG_CLS_U32_MARK=y | ||
744 | CONFIG_NET_CLS_RSVP=m | ||
745 | CONFIG_NET_CLS_RSVP6=m | ||
746 | CONFIG_NET_CLS_FLOW=m | ||
747 | CONFIG_NET_EMATCH=y | ||
748 | CONFIG_NET_EMATCH_STACK=32 | ||
749 | CONFIG_NET_EMATCH_CMP=m | ||
750 | CONFIG_NET_EMATCH_NBYTE=m | ||
751 | CONFIG_NET_EMATCH_U32=m | ||
752 | CONFIG_NET_EMATCH_META=m | ||
753 | CONFIG_NET_EMATCH_TEXT=m | ||
754 | CONFIG_NET_CLS_ACT=y | ||
755 | CONFIG_NET_ACT_POLICE=m | ||
756 | CONFIG_NET_ACT_GACT=m | ||
757 | CONFIG_GACT_PROB=y | ||
758 | CONFIG_NET_ACT_MIRRED=m | ||
759 | CONFIG_NET_ACT_IPT=m | ||
760 | CONFIG_NET_ACT_NAT=m | ||
761 | CONFIG_NET_ACT_PEDIT=m | ||
762 | CONFIG_NET_ACT_SIMP=m | ||
763 | CONFIG_NET_CLS_IND=y | ||
764 | CONFIG_NET_SCH_FIFO=y | ||
765 | |||
766 | # | ||
767 | # Network testing | ||
768 | # | ||
769 | # CONFIG_NET_PKTGEN is not set | ||
770 | # CONFIG_NET_TCPPROBE is not set | ||
771 | # CONFIG_HAMRADIO is not set | ||
772 | # CONFIG_CAN is not set | ||
773 | CONFIG_IRDA=m | ||
774 | |||
775 | # | ||
776 | # IrDA protocols | ||
777 | # | ||
778 | CONFIG_IRLAN=m | ||
779 | CONFIG_IRNET=m | ||
780 | CONFIG_IRCOMM=m | ||
781 | # CONFIG_IRDA_ULTRA is not set | ||
782 | |||
783 | # | ||
784 | # IrDA options | ||
785 | # | ||
786 | CONFIG_IRDA_CACHE_LAST_LSAP=y | ||
787 | CONFIG_IRDA_FAST_RR=y | ||
788 | # CONFIG_IRDA_DEBUG is not set | ||
789 | |||
790 | # | ||
791 | # Infrared-port device drivers | ||
792 | # | ||
793 | |||
794 | # | ||
795 | # SIR device drivers | ||
796 | # | ||
797 | CONFIG_IRTTY_SIR=m | ||
798 | |||
799 | # | ||
800 | # Dongle support | ||
801 | # | ||
802 | # CONFIG_DONGLE is not set | ||
803 | CONFIG_KINGSUN_DONGLE=m | ||
804 | CONFIG_KSDAZZLE_DONGLE=m | ||
805 | CONFIG_KS959_DONGLE=m | ||
806 | |||
807 | # | ||
808 | # FIR device drivers | ||
809 | # | ||
810 | CONFIG_USB_IRDA=m | ||
811 | CONFIG_SIGMATEL_FIR=m | ||
812 | CONFIG_NSC_FIR=m | ||
813 | CONFIG_WINBOND_FIR=m | ||
814 | CONFIG_TOSHIBA_FIR=m | ||
815 | CONFIG_SMC_IRCC_FIR=m | ||
816 | CONFIG_ALI_FIR=m | ||
817 | CONFIG_VLSI_FIR=m | ||
818 | CONFIG_VIA_FIR=m | ||
819 | CONFIG_MCS_FIR=m | ||
820 | CONFIG_BT=m | ||
821 | CONFIG_BT_L2CAP=m | ||
822 | CONFIG_BT_SCO=m | ||
823 | CONFIG_BT_RFCOMM=m | ||
824 | CONFIG_BT_RFCOMM_TTY=y | ||
825 | CONFIG_BT_BNEP=m | ||
826 | CONFIG_BT_BNEP_MC_FILTER=y | ||
827 | CONFIG_BT_BNEP_PROTO_FILTER=y | ||
828 | CONFIG_BT_HIDP=m | ||
829 | |||
830 | # | ||
831 | # Bluetooth device drivers | ||
832 | # | ||
833 | CONFIG_BT_HCIUSB=m | ||
834 | CONFIG_BT_HCIUSB_SCO=y | ||
835 | CONFIG_BT_HCIUART=m | ||
836 | CONFIG_BT_HCIUART_H4=y | ||
837 | CONFIG_BT_HCIUART_BCSP=y | ||
838 | CONFIG_BT_HCIUART_LL=y | ||
839 | CONFIG_BT_HCIBCM203X=m | ||
840 | CONFIG_BT_HCIBPA10X=m | ||
841 | CONFIG_BT_HCIBFUSB=m | ||
842 | CONFIG_BT_HCIDTL1=m | ||
843 | CONFIG_BT_HCIBT3C=m | ||
844 | CONFIG_BT_HCIBLUECARD=m | ||
845 | CONFIG_BT_HCIBTUART=m | ||
846 | CONFIG_BT_HCIVHCI=m | ||
847 | # CONFIG_AF_RXRPC is not set | ||
848 | CONFIG_FIB_RULES=y | ||
849 | |||
850 | # | ||
851 | # Wireless | ||
852 | # | ||
853 | CONFIG_CFG80211=m | ||
854 | CONFIG_NL80211=y | ||
855 | CONFIG_WIRELESS_EXT=y | ||
856 | CONFIG_WIRELESS_EXT_SYSFS=y | ||
857 | CONFIG_MAC80211=m | ||
858 | CONFIG_MAC80211_QOS=y | ||
859 | |||
860 | # | ||
861 | # Rate control algorithm selection | ||
862 | # | ||
863 | CONFIG_MAC80211_RC_PID=y | ||
864 | CONFIG_MAC80211_RC_DEFAULT_PID=y | ||
865 | CONFIG_MAC80211_RC_DEFAULT="pid" | ||
866 | CONFIG_MAC80211_MESH=y | ||
867 | CONFIG_MAC80211_LEDS=y | ||
868 | CONFIG_MAC80211_DEBUGFS=y | ||
869 | # CONFIG_MAC80211_DEBUG_MENU is not set | ||
870 | CONFIG_IEEE80211=m | ||
871 | CONFIG_IEEE80211_DEBUG=y | ||
872 | CONFIG_IEEE80211_CRYPT_WEP=m | ||
873 | CONFIG_IEEE80211_CRYPT_CCMP=m | ||
874 | CONFIG_IEEE80211_CRYPT_TKIP=m | ||
875 | # CONFIG_RFKILL is not set | ||
876 | CONFIG_NET_9P=m | ||
877 | CONFIG_NET_9P_VIRTIO=m | ||
878 | # CONFIG_NET_9P_DEBUG is not set | ||
879 | |||
880 | # | ||
881 | # Device Drivers | ||
882 | # | ||
883 | |||
884 | # | ||
885 | # Generic Driver Options | ||
886 | # | ||
887 | CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | ||
888 | CONFIG_STANDALONE=y | ||
889 | CONFIG_PREVENT_FIRMWARE_BUILD=y | ||
890 | CONFIG_FW_LOADER=y | ||
891 | # CONFIG_FIRMWARE_IN_KERNEL is not set | ||
892 | CONFIG_EXTRA_FIRMWARE="" | ||
893 | # CONFIG_DEBUG_DRIVER is not set | ||
894 | CONFIG_DEBUG_DEVRES=y | ||
895 | # CONFIG_SYS_HYPERVISOR is not set | ||
896 | CONFIG_CONNECTOR=y | ||
897 | CONFIG_PROC_EVENTS=y | ||
898 | # CONFIG_MTD is not set | ||
899 | CONFIG_OF_DEVICE=y | ||
900 | CONFIG_OF_GPIO=y | ||
901 | CONFIG_OF_I2C=y | ||
902 | CONFIG_PARPORT=m | ||
903 | CONFIG_PARPORT_PC=m | ||
904 | CONFIG_PARPORT_SERIAL=m | ||
905 | # CONFIG_PARPORT_PC_FIFO is not set | ||
906 | # CONFIG_PARPORT_PC_SUPERIO is not set | ||
907 | # CONFIG_PARPORT_PC_PCMCIA is not set | ||
908 | # CONFIG_PARPORT_GSC is not set | ||
909 | # CONFIG_PARPORT_AX88796 is not set | ||
910 | CONFIG_PARPORT_1284=y | ||
911 | CONFIG_PARPORT_NOT_PC=y | ||
912 | CONFIG_PNP=y | ||
913 | # CONFIG_PNP_DEBUG is not set | ||
914 | |||
915 | # | ||
916 | # Protocols | ||
917 | # | ||
918 | CONFIG_ISAPNP=y | ||
919 | # CONFIG_PNPACPI is not set | ||
920 | CONFIG_BLK_DEV=y | ||
921 | # CONFIG_BLK_DEV_FD is not set | ||
922 | CONFIG_MAC_FLOPPY=m | ||
923 | # CONFIG_BLK_DEV_XD is not set | ||
924 | # CONFIG_PARIDE is not set | ||
925 | # CONFIG_BLK_CPQ_DA is not set | ||
926 | # CONFIG_BLK_CPQ_CISS_DA is not set | ||
927 | # CONFIG_BLK_DEV_DAC960 is not set | ||
928 | # CONFIG_BLK_DEV_UMEM is not set | ||
929 | # CONFIG_BLK_DEV_COW_COMMON is not set | ||
930 | CONFIG_BLK_DEV_LOOP=m | ||
931 | CONFIG_BLK_DEV_CRYPTOLOOP=m | ||
932 | CONFIG_BLK_DEV_NBD=m | ||
933 | # CONFIG_BLK_DEV_SX8 is not set | ||
934 | # CONFIG_BLK_DEV_UB is not set | ||
935 | CONFIG_BLK_DEV_RAM=y | ||
936 | CONFIG_BLK_DEV_RAM_COUNT=16 | ||
937 | CONFIG_BLK_DEV_RAM_SIZE=16384 | ||
938 | # CONFIG_BLK_DEV_XIP is not set | ||
939 | CONFIG_CDROM_PKTCDVD=m | ||
940 | CONFIG_CDROM_PKTCDVD_BUFFERS=8 | ||
941 | # CONFIG_CDROM_PKTCDVD_WCACHE is not set | ||
942 | # CONFIG_ATA_OVER_ETH is not set | ||
943 | CONFIG_VIRTIO_BLK=m | ||
944 | CONFIG_MISC_DEVICES=y | ||
945 | # CONFIG_PHANTOM is not set | ||
946 | CONFIG_EEPROM_93CX6=m | ||
947 | # CONFIG_SGI_IOC4 is not set | ||
948 | # CONFIG_TIFM_CORE is not set | ||
949 | CONFIG_ENCLOSURE_SERVICES=m | ||
950 | CONFIG_HAVE_IDE=y | ||
951 | CONFIG_IDE=y | ||
952 | CONFIG_BLK_DEV_IDE=y | ||
953 | |||
954 | # | ||
955 | # Please see Documentation/ide/ide.txt for help/info on IDE drives | ||
956 | # | ||
957 | CONFIG_IDE_ATAPI=y | ||
958 | # CONFIG_BLK_DEV_IDE_SATA is not set | ||
959 | CONFIG_BLK_DEV_IDEDISK=y | ||
960 | CONFIG_IDEDISK_MULTI_MODE=y | ||
961 | # CONFIG_BLK_DEV_IDECS is not set | ||
962 | # CONFIG_BLK_DEV_DELKIN is not set | ||
963 | CONFIG_BLK_DEV_IDECD=m | ||
964 | CONFIG_BLK_DEV_IDECD_VERBOSE_ERRORS=y | ||
965 | # CONFIG_BLK_DEV_IDETAPE is not set | ||
966 | CONFIG_BLK_DEV_IDEFLOPPY=m | ||
967 | # CONFIG_BLK_DEV_IDESCSI is not set | ||
968 | CONFIG_IDE_TASK_IOCTL=y | ||
969 | CONFIG_IDE_PROC_FS=y | ||
970 | |||
971 | # | ||
972 | # IDE chipset support/bugfixes | ||
973 | # | ||
974 | # CONFIG_IDE_GENERIC is not set | ||
975 | # CONFIG_BLK_DEV_PLATFORM is not set | ||
976 | # CONFIG_BLK_DEV_IDEPNP is not set | ||
977 | CONFIG_BLK_DEV_IDEDMA_SFF=y | ||
978 | |||
979 | # | ||
980 | # PCI IDE chipsets support | ||
981 | # | ||
982 | CONFIG_BLK_DEV_IDEPCI=y | ||
983 | # CONFIG_IDEPCI_PCIBUS_ORDER is not set | ||
984 | # CONFIG_BLK_DEV_OFFBOARD is not set | ||
985 | CONFIG_BLK_DEV_GENERIC=y | ||
986 | # CONFIG_BLK_DEV_OPTI621 is not set | ||
987 | CONFIG_BLK_DEV_IDEDMA_PCI=y | ||
988 | # CONFIG_BLK_DEV_AEC62XX is not set | ||
989 | # CONFIG_BLK_DEV_ALI15X3 is not set | ||
990 | # CONFIG_BLK_DEV_AMD74XX is not set | ||
991 | # CONFIG_BLK_DEV_CMD64X is not set | ||
992 | # CONFIG_BLK_DEV_TRIFLEX is not set | ||
993 | # CONFIG_BLK_DEV_CY82C693 is not set | ||
994 | # CONFIG_BLK_DEV_CS5520 is not set | ||
995 | # CONFIG_BLK_DEV_CS5530 is not set | ||
996 | # CONFIG_BLK_DEV_HPT34X is not set | ||
997 | # CONFIG_BLK_DEV_HPT366 is not set | ||
998 | # CONFIG_BLK_DEV_JMICRON is not set | ||
999 | # CONFIG_BLK_DEV_SC1200 is not set | ||
1000 | # CONFIG_BLK_DEV_PIIX is not set | ||
1001 | # CONFIG_BLK_DEV_IT8213 is not set | ||
1002 | # CONFIG_BLK_DEV_IT821X is not set | ||
1003 | # CONFIG_BLK_DEV_NS87415 is not set | ||
1004 | # CONFIG_BLK_DEV_PDC202XX_OLD is not set | ||
1005 | # CONFIG_BLK_DEV_PDC202XX_NEW is not set | ||
1006 | # CONFIG_BLK_DEV_SVWKS is not set | ||
1007 | # CONFIG_BLK_DEV_SIIMAGE is not set | ||
1008 | # CONFIG_BLK_DEV_SL82C105 is not set | ||
1009 | # CONFIG_BLK_DEV_SLC90E66 is not set | ||
1010 | # CONFIG_BLK_DEV_TRM290 is not set | ||
1011 | # CONFIG_BLK_DEV_VIA82CXXX is not set | ||
1012 | # CONFIG_BLK_DEV_TC86C001 is not set | ||
1013 | CONFIG_BLK_DEV_IDE_PMAC=y | ||
1014 | CONFIG_BLK_DEV_IDE_PMAC_ATA100FIRST=y | ||
1015 | CONFIG_BLK_DEV_IDEDMA_PMAC=y | ||
1016 | CONFIG_BLK_DEV_IDEDMA=y | ||
1017 | CONFIG_BLK_DEV_HD_ONLY=y | ||
1018 | CONFIG_BLK_DEV_HD=y | ||
1019 | |||
1020 | # | ||
1021 | # SCSI device support | ||
1022 | # | ||
1023 | CONFIG_RAID_ATTRS=m | ||
1024 | CONFIG_SCSI=y | ||
1025 | CONFIG_SCSI_DMA=y | ||
1026 | CONFIG_SCSI_TGT=m | ||
1027 | # CONFIG_SCSI_NETLINK is not set | ||
1028 | CONFIG_SCSI_PROC_FS=y | ||
1029 | |||
1030 | # | ||
1031 | # SCSI support type (disk, tape, CD-ROM) | ||
1032 | # | ||
1033 | CONFIG_BLK_DEV_SD=y | ||
1034 | CONFIG_CHR_DEV_ST=m | ||
1035 | CONFIG_CHR_DEV_OSST=m | ||
1036 | CONFIG_BLK_DEV_SR=m | ||
1037 | CONFIG_BLK_DEV_SR_VENDOR=y | ||
1038 | CONFIG_CHR_DEV_SG=y | ||
1039 | CONFIG_CHR_DEV_SCH=m | ||
1040 | CONFIG_SCSI_ENCLOSURE=m | ||
1041 | |||
1042 | # | ||
1043 | # Some SCSI devices (e.g. CD jukebox) support multiple LUNs | ||
1044 | # | ||
1045 | CONFIG_SCSI_MULTI_LUN=y | ||
1046 | CONFIG_SCSI_CONSTANTS=y | ||
1047 | CONFIG_SCSI_LOGGING=y | ||
1048 | CONFIG_SCSI_SCAN_ASYNC=y | ||
1049 | CONFIG_SCSI_WAIT_SCAN=m | ||
1050 | |||
1051 | # | ||
1052 | # SCSI Transports | ||
1053 | # | ||
1054 | CONFIG_SCSI_SPI_ATTRS=m | ||
1055 | # CONFIG_SCSI_FC_ATTRS is not set | ||
1056 | # CONFIG_SCSI_ISCSI_ATTRS is not set | ||
1057 | # CONFIG_SCSI_SAS_ATTRS is not set | ||
1058 | # CONFIG_SCSI_SAS_LIBSAS is not set | ||
1059 | CONFIG_SCSI_SRP_ATTRS=m | ||
1060 | CONFIG_SCSI_SRP_TGT_ATTRS=y | ||
1061 | CONFIG_SCSI_LOWLEVEL=y | ||
1062 | # CONFIG_ISCSI_TCP is not set | ||
1063 | # CONFIG_BLK_DEV_3W_XXXX_RAID is not set | ||
1064 | # CONFIG_SCSI_3W_9XXX is not set | ||
1065 | # CONFIG_SCSI_7000FASST is not set | ||
1066 | # CONFIG_SCSI_ACARD is not set | ||
1067 | # CONFIG_SCSI_AHA152X is not set | ||
1068 | # CONFIG_SCSI_AHA1542 is not set | ||
1069 | # CONFIG_SCSI_AACRAID is not set | ||
1070 | # CONFIG_SCSI_AIC7XXX is not set | ||
1071 | # CONFIG_SCSI_AIC7XXX_OLD is not set | ||
1072 | # CONFIG_SCSI_AIC79XX is not set | ||
1073 | # CONFIG_SCSI_AIC94XX is not set | ||
1074 | # CONFIG_SCSI_DPT_I2O is not set | ||
1075 | # CONFIG_SCSI_ADVANSYS is not set | ||
1076 | # CONFIG_SCSI_IN2000 is not set | ||
1077 | # CONFIG_SCSI_ARCMSR is not set | ||
1078 | # CONFIG_MEGARAID_NEWGEN is not set | ||
1079 | # CONFIG_MEGARAID_LEGACY is not set | ||
1080 | # CONFIG_MEGARAID_SAS is not set | ||
1081 | # CONFIG_SCSI_HPTIOP is not set | ||
1082 | # CONFIG_SCSI_BUSLOGIC is not set | ||
1083 | # CONFIG_SCSI_DMX3191D is not set | ||
1084 | # CONFIG_SCSI_DTC3280 is not set | ||
1085 | # CONFIG_SCSI_EATA is not set | ||
1086 | # CONFIG_SCSI_FUTURE_DOMAIN is not set | ||
1087 | # CONFIG_SCSI_GDTH is not set | ||
1088 | # CONFIG_SCSI_GENERIC_NCR5380 is not set | ||
1089 | # CONFIG_SCSI_GENERIC_NCR5380_MMIO is not set | ||
1090 | # CONFIG_SCSI_IPS is not set | ||
1091 | # CONFIG_SCSI_INITIO is not set | ||
1092 | # CONFIG_SCSI_INIA100 is not set | ||
1093 | # CONFIG_SCSI_PPA is not set | ||
1094 | # CONFIG_SCSI_IMM is not set | ||
1095 | # CONFIG_SCSI_MVSAS is not set | ||
1096 | # CONFIG_SCSI_NCR53C406A is not set | ||
1097 | # CONFIG_SCSI_STEX is not set | ||
1098 | # CONFIG_SCSI_SYM53C8XX_2 is not set | ||
1099 | # CONFIG_SCSI_IPR is not set | ||
1100 | # CONFIG_SCSI_PAS16 is not set | ||
1101 | # CONFIG_SCSI_QLOGIC_FAS is not set | ||
1102 | # CONFIG_SCSI_QLOGIC_1280 is not set | ||
1103 | # CONFIG_SCSI_QLA_FC is not set | ||
1104 | # CONFIG_SCSI_QLA_ISCSI is not set | ||
1105 | # CONFIG_SCSI_LPFC is not set | ||
1106 | # CONFIG_SCSI_SYM53C416 is not set | ||
1107 | # CONFIG_SCSI_DC395x is not set | ||
1108 | # CONFIG_SCSI_DC390T is not set | ||
1109 | # CONFIG_SCSI_T128 is not set | ||
1110 | # CONFIG_SCSI_U14_34F is not set | ||
1111 | # CONFIG_SCSI_NSP32 is not set | ||
1112 | # CONFIG_SCSI_DEBUG is not set | ||
1113 | CONFIG_SCSI_MESH=m | ||
1114 | CONFIG_SCSI_MESH_SYNC_RATE=5 | ||
1115 | CONFIG_SCSI_MESH_RESET_DELAY_MS=4000 | ||
1116 | CONFIG_SCSI_MAC53C94=m | ||
1117 | CONFIG_SCSI_SRP=m | ||
1118 | CONFIG_SCSI_LOWLEVEL_PCMCIA=y | ||
1119 | # CONFIG_PCMCIA_AHA152X is not set | ||
1120 | # CONFIG_PCMCIA_FDOMAIN is not set | ||
1121 | # CONFIG_PCMCIA_NINJA_SCSI is not set | ||
1122 | # CONFIG_PCMCIA_QLOGIC is not set | ||
1123 | # CONFIG_PCMCIA_SYM53C500 is not set | ||
1124 | CONFIG_SCSI_DH=y | ||
1125 | CONFIG_SCSI_DH_RDAC=m | ||
1126 | CONFIG_SCSI_DH_HP_SW=m | ||
1127 | CONFIG_SCSI_DH_EMC=m | ||
1128 | CONFIG_ATA=y | ||
1129 | # CONFIG_ATA_NONSTANDARD is not set | ||
1130 | # CONFIG_SATA_PMP is not set | ||
1131 | # CONFIG_SATA_AHCI is not set | ||
1132 | # CONFIG_SATA_SIL24 is not set | ||
1133 | CONFIG_SATA_FSL=m | ||
1134 | CONFIG_ATA_SFF=y | ||
1135 | # CONFIG_SATA_SVW is not set | ||
1136 | CONFIG_ATA_PIIX=m | ||
1137 | # CONFIG_SATA_MV is not set | ||
1138 | # CONFIG_SATA_NV is not set | ||
1139 | CONFIG_PDC_ADMA=m | ||
1140 | # CONFIG_SATA_QSTOR is not set | ||
1141 | # CONFIG_SATA_PROMISE is not set | ||
1142 | # CONFIG_SATA_SX4 is not set | ||
1143 | # CONFIG_SATA_SIL is not set | ||
1144 | # CONFIG_SATA_SIS is not set | ||
1145 | # CONFIG_SATA_ULI is not set | ||
1146 | # CONFIG_SATA_VIA is not set | ||
1147 | # CONFIG_SATA_VITESSE is not set | ||
1148 | # CONFIG_SATA_INIC162X is not set | ||
1149 | # CONFIG_PATA_ALI is not set | ||
1150 | # CONFIG_PATA_AMD is not set | ||
1151 | # CONFIG_PATA_ARTOP is not set | ||
1152 | # CONFIG_PATA_ATIIXP is not set | ||
1153 | # CONFIG_PATA_CMD640_PCI is not set | ||
1154 | # CONFIG_PATA_CMD64X is not set | ||
1155 | # CONFIG_PATA_CS5520 is not set | ||
1156 | # CONFIG_PATA_CS5530 is not set | ||
1157 | # CONFIG_PATA_CYPRESS is not set | ||
1158 | # CONFIG_PATA_EFAR is not set | ||
1159 | CONFIG_ATA_GENERIC=m | ||
1160 | # CONFIG_PATA_HPT366 is not set | ||
1161 | # CONFIG_PATA_HPT37X is not set | ||
1162 | # CONFIG_PATA_HPT3X2N is not set | ||
1163 | # CONFIG_PATA_HPT3X3 is not set | ||
1164 | # CONFIG_PATA_ISAPNP is not set | ||
1165 | # CONFIG_PATA_IT821X is not set | ||
1166 | # CONFIG_PATA_IT8213 is not set | ||
1167 | # CONFIG_PATA_JMICRON is not set | ||
1168 | # CONFIG_PATA_LEGACY is not set | ||
1169 | # CONFIG_PATA_TRIFLEX is not set | ||
1170 | # CONFIG_PATA_MARVELL is not set | ||
1171 | CONFIG_PATA_MPC52xx=m | ||
1172 | # CONFIG_PATA_MPIIX is not set | ||
1173 | # CONFIG_PATA_OLDPIIX is not set | ||
1174 | # CONFIG_PATA_NETCELL is not set | ||
1175 | # CONFIG_PATA_NINJA32 is not set | ||
1176 | # CONFIG_PATA_NS87410 is not set | ||
1177 | # CONFIG_PATA_NS87415 is not set | ||
1178 | # CONFIG_PATA_OPTI is not set | ||
1179 | CONFIG_PATA_OPTIDMA=m | ||
1180 | # CONFIG_PATA_PCMCIA is not set | ||
1181 | # CONFIG_PATA_PDC_OLD is not set | ||
1182 | # CONFIG_PATA_QDI is not set | ||
1183 | # CONFIG_PATA_RADISYS is not set | ||
1184 | # CONFIG_PATA_RZ1000 is not set | ||
1185 | # CONFIG_PATA_SC1200 is not set | ||
1186 | # CONFIG_PATA_SERVERWORKS is not set | ||
1187 | # CONFIG_PATA_PDC2027X is not set | ||
1188 | # CONFIG_PATA_SIL680 is not set | ||
1189 | # CONFIG_PATA_SIS is not set | ||
1190 | CONFIG_PATA_VIA=m | ||
1191 | # CONFIG_PATA_WINBOND is not set | ||
1192 | # CONFIG_PATA_WINBOND_VLB is not set | ||
1193 | CONFIG_PATA_PLATFORM=m | ||
1194 | CONFIG_PATA_OF_PLATFORM=m | ||
1195 | CONFIG_PATA_SCH=m | ||
1196 | CONFIG_MD=y | ||
1197 | CONFIG_BLK_DEV_MD=y | ||
1198 | CONFIG_MD_LINEAR=m | ||
1199 | CONFIG_MD_RAID0=m | ||
1200 | CONFIG_MD_RAID1=m | ||
1201 | CONFIG_MD_RAID10=m | ||
1202 | CONFIG_MD_RAID456=m | ||
1203 | CONFIG_MD_RAID5_RESHAPE=y | ||
1204 | CONFIG_MD_MULTIPATH=m | ||
1205 | CONFIG_MD_FAULTY=m | ||
1206 | CONFIG_BLK_DEV_DM=m | ||
1207 | CONFIG_DM_DEBUG=y | ||
1208 | CONFIG_DM_CRYPT=m | ||
1209 | CONFIG_DM_SNAPSHOT=m | ||
1210 | CONFIG_DM_MIRROR=m | ||
1211 | CONFIG_DM_ZERO=m | ||
1212 | CONFIG_DM_MULTIPATH=m | ||
1213 | # CONFIG_DM_DELAY is not set | ||
1214 | CONFIG_DM_UEVENT=y | ||
1215 | # CONFIG_FUSION is not set | ||
1216 | |||
1217 | # | ||
1218 | # IEEE 1394 (FireWire) support | ||
1219 | # | ||
1220 | |||
1221 | # | ||
1222 | # Enable only one of the two stacks, unless you know what you are doing | ||
1223 | # | ||
1224 | CONFIG_FIREWIRE=m | ||
1225 | CONFIG_FIREWIRE_OHCI=m | ||
1226 | CONFIG_FIREWIRE_OHCI_DEBUG=y | ||
1227 | CONFIG_FIREWIRE_SBP2=m | ||
1228 | # CONFIG_IEEE1394 is not set | ||
1229 | # CONFIG_I2O is not set | ||
1230 | CONFIG_MACINTOSH_DRIVERS=y | ||
1231 | CONFIG_ADB=y | ||
1232 | CONFIG_ADB_CUDA=y | ||
1233 | CONFIG_ADB_PMU=y | ||
1234 | CONFIG_ADB_PMU_LED=y | ||
1235 | CONFIG_ADB_PMU_LED_IDE=y | ||
1236 | CONFIG_PMAC_APM_EMU=y | ||
1237 | CONFIG_PMAC_MEDIABAY=y | ||
1238 | CONFIG_PMAC_BACKLIGHT=y | ||
1239 | # CONFIG_PMAC_BACKLIGHT_LEGACY is not set | ||
1240 | CONFIG_ADB_MACIO=y | ||
1241 | CONFIG_INPUT_ADBHID=y | ||
1242 | CONFIG_MAC_EMUMOUSEBTN=y | ||
1243 | CONFIG_THERM_WINDTUNNEL=m | ||
1244 | CONFIG_THERM_ADT746X=m | ||
1245 | CONFIG_WINDFARM=y | ||
1246 | # CONFIG_ANSLCD is not set | ||
1247 | CONFIG_PMAC_RACKMETER=m | ||
1248 | CONFIG_NETDEVICES=y | ||
1249 | CONFIG_NETDEVICES_MULTIQUEUE=y | ||
1250 | CONFIG_IFB=m | ||
1251 | CONFIG_DUMMY=m | ||
1252 | CONFIG_BONDING=m | ||
1253 | CONFIG_MACVLAN=m | ||
1254 | CONFIG_EQUALIZER=m | ||
1255 | CONFIG_TUN=m | ||
1256 | CONFIG_VETH=m | ||
1257 | CONFIG_NET_SB1000=m | ||
1258 | # CONFIG_ARCNET is not set | ||
1259 | CONFIG_PHYLIB=m | ||
1260 | |||
1261 | # | ||
1262 | # MII PHY device drivers | ||
1263 | # | ||
1264 | CONFIG_MARVELL_PHY=m | ||
1265 | CONFIG_DAVICOM_PHY=m | ||
1266 | CONFIG_QSEMI_PHY=m | ||
1267 | CONFIG_LXT_PHY=m | ||
1268 | CONFIG_CICADA_PHY=m | ||
1269 | CONFIG_VITESSE_PHY=m | ||
1270 | CONFIG_SMSC_PHY=m | ||
1271 | CONFIG_BROADCOM_PHY=m | ||
1272 | CONFIG_ICPLUS_PHY=m | ||
1273 | CONFIG_REALTEK_PHY=m | ||
1274 | CONFIG_MDIO_BITBANG=y | ||
1275 | CONFIG_NET_ETHERNET=y | ||
1276 | CONFIG_MII=m | ||
1277 | CONFIG_MACE=m | ||
1278 | # CONFIG_MACE_AAUI_PORT is not set | ||
1279 | CONFIG_BMAC=m | ||
1280 | CONFIG_HAPPYMEAL=m | ||
1281 | CONFIG_SUNGEM=m | ||
1282 | CONFIG_CASSINI=m | ||
1283 | CONFIG_NET_VENDOR_3COM=y | ||
1284 | # CONFIG_EL1 is not set | ||
1285 | # CONFIG_EL2 is not set | ||
1286 | # CONFIG_ELPLUS is not set | ||
1287 | # CONFIG_EL16 is not set | ||
1288 | CONFIG_EL3=m | ||
1289 | # CONFIG_3C515 is not set | ||
1290 | CONFIG_VORTEX=m | ||
1291 | CONFIG_TYPHOON=m | ||
1292 | # CONFIG_LANCE is not set | ||
1293 | CONFIG_NET_VENDOR_SMC=y | ||
1294 | # CONFIG_WD80x3 is not set | ||
1295 | CONFIG_ULTRA=m | ||
1296 | # CONFIG_SMC9194 is not set | ||
1297 | # CONFIG_NET_VENDOR_RACAL is not set | ||
1298 | CONFIG_NET_TULIP=y | ||
1299 | CONFIG_DE2104X=m | ||
1300 | CONFIG_TULIP=m | ||
1301 | # CONFIG_TULIP_MWI is not set | ||
1302 | CONFIG_TULIP_MMIO=y | ||
1303 | # CONFIG_TULIP_NAPI is not set | ||
1304 | CONFIG_DE4X5=m | ||
1305 | CONFIG_WINBOND_840=m | ||
1306 | CONFIG_DM9102=m | ||
1307 | CONFIG_ULI526X=m | ||
1308 | CONFIG_PCMCIA_XIRCOM=m | ||
1309 | # CONFIG_AT1700 is not set | ||
1310 | # CONFIG_DEPCA is not set | ||
1311 | # CONFIG_HP100 is not set | ||
1312 | CONFIG_NET_ISA=y | ||
1313 | # CONFIG_E2100 is not set | ||
1314 | CONFIG_EWRK3=m | ||
1315 | # CONFIG_EEXPRESS is not set | ||
1316 | # CONFIG_EEXPRESS_PRO is not set | ||
1317 | # CONFIG_HPLAN_PLUS is not set | ||
1318 | # CONFIG_HPLAN is not set | ||
1319 | # CONFIG_LP486E is not set | ||
1320 | # CONFIG_ETH16I is not set | ||
1321 | CONFIG_NE2000=m | ||
1322 | # CONFIG_ZNET is not set | ||
1323 | # CONFIG_SEEQ8005 is not set | ||
1324 | # CONFIG_IBM_NEW_EMAC_ZMII is not set | ||
1325 | # CONFIG_IBM_NEW_EMAC_RGMII is not set | ||
1326 | # CONFIG_IBM_NEW_EMAC_TAH is not set | ||
1327 | # CONFIG_IBM_NEW_EMAC_EMAC4 is not set | ||
1328 | CONFIG_NET_PCI=y | ||
1329 | CONFIG_PCNET32=m | ||
1330 | CONFIG_AMD8111_ETH=m | ||
1331 | CONFIG_AMD8111E_NAPI=y | ||
1332 | CONFIG_ADAPTEC_STARFIRE=m | ||
1333 | CONFIG_ADAPTEC_STARFIRE_NAPI=y | ||
1334 | # CONFIG_AC3200 is not set | ||
1335 | # CONFIG_APRICOT is not set | ||
1336 | CONFIG_B44=m | ||
1337 | CONFIG_B44_PCI_AUTOSELECT=y | ||
1338 | CONFIG_B44_PCICORE_AUTOSELECT=y | ||
1339 | CONFIG_B44_PCI=y | ||
1340 | CONFIG_FORCEDETH=m | ||
1341 | CONFIG_FORCEDETH_NAPI=y | ||
1342 | # CONFIG_CS89x0 is not set | ||
1343 | # CONFIG_EEPRO100 is not set | ||
1344 | CONFIG_E100=m | ||
1345 | CONFIG_FEALNX=m | ||
1346 | CONFIG_NATSEMI=m | ||
1347 | CONFIG_NE2K_PCI=m | ||
1348 | CONFIG_8139CP=m | ||
1349 | CONFIG_8139TOO=m | ||
1350 | # CONFIG_8139TOO_PIO is not set | ||
1351 | # CONFIG_8139TOO_TUNE_TWISTER is not set | ||
1352 | CONFIG_8139TOO_8129=y | ||
1353 | # CONFIG_8139_OLD_RX_RESET is not set | ||
1354 | CONFIG_R6040=m | ||
1355 | CONFIG_SIS900=m | ||
1356 | CONFIG_EPIC100=m | ||
1357 | CONFIG_SUNDANCE=m | ||
1358 | # CONFIG_SUNDANCE_MMIO is not set | ||
1359 | CONFIG_TLAN=m | ||
1360 | CONFIG_VIA_RHINE=m | ||
1361 | CONFIG_VIA_RHINE_MMIO=y | ||
1362 | CONFIG_VIA_RHINE_NAPI=y | ||
1363 | CONFIG_SC92031=m | ||
1364 | CONFIG_NET_POCKET=y | ||
1365 | CONFIG_DE600=m | ||
1366 | CONFIG_DE620=m | ||
1367 | CONFIG_FEC_MPC52xx=m | ||
1368 | CONFIG_FEC_MPC52xx_MDIO=y | ||
1369 | # CONFIG_FS_ENET is not set | ||
1370 | CONFIG_NETDEV_1000=y | ||
1371 | CONFIG_ACENIC=m | ||
1372 | # CONFIG_ACENIC_OMIT_TIGON_I is not set | ||
1373 | CONFIG_DL2K=m | ||
1374 | CONFIG_E1000=m | ||
1375 | CONFIG_E1000_NAPI=y | ||
1376 | # CONFIG_E1000_DISABLE_PACKET_SPLIT is not set | ||
1377 | CONFIG_E1000E=m | ||
1378 | CONFIG_E1000E_ENABLED=y | ||
1379 | CONFIG_IP1000=m | ||
1380 | CONFIG_IGB=m | ||
1381 | CONFIG_NS83820=m | ||
1382 | CONFIG_HAMACHI=m | ||
1383 | CONFIG_YELLOWFIN=m | ||
1384 | CONFIG_R8169=m | ||
1385 | CONFIG_R8169_NAPI=y | ||
1386 | CONFIG_R8169_VLAN=y | ||
1387 | CONFIG_SIS190=m | ||
1388 | CONFIG_SKGE=m | ||
1389 | # CONFIG_SKGE_DEBUG is not set | ||
1390 | CONFIG_SKY2=m | ||
1391 | # CONFIG_SKY2_DEBUG is not set | ||
1392 | CONFIG_VIA_VELOCITY=m | ||
1393 | CONFIG_TIGON3=m | ||
1394 | CONFIG_BNX2=m | ||
1395 | CONFIG_GIANFAR=m | ||
1396 | CONFIG_GFAR_NAPI=y | ||
1397 | # CONFIG_UCC_GETH is not set | ||
1398 | CONFIG_MV643XX_ETH=m | ||
1399 | CONFIG_QLA3XXX=m | ||
1400 | CONFIG_ATL1=m | ||
1401 | CONFIG_NETDEV_10000=y | ||
1402 | CONFIG_CHELSIO_T1=m | ||
1403 | CONFIG_CHELSIO_T1_1G=y | ||
1404 | CONFIG_CHELSIO_T1_NAPI=y | ||
1405 | CONFIG_CHELSIO_T3=m | ||
1406 | CONFIG_IXGBE=m | ||
1407 | CONFIG_IXGB=m | ||
1408 | CONFIG_IXGB_NAPI=y | ||
1409 | CONFIG_S2IO=m | ||
1410 | CONFIG_S2IO_NAPI=y | ||
1411 | CONFIG_MYRI10GE=m | ||
1412 | CONFIG_NETXEN_NIC=m | ||
1413 | CONFIG_NIU=m | ||
1414 | # CONFIG_MLX4_CORE is not set | ||
1415 | CONFIG_TEHUTI=m | ||
1416 | CONFIG_BNX2X=m | ||
1417 | CONFIG_SFC=m | ||
1418 | # CONFIG_TR is not set | ||
1419 | |||
1420 | # | ||
1421 | # Wireless LAN | ||
1422 | # | ||
1423 | # CONFIG_WLAN_PRE80211 is not set | ||
1424 | # CONFIG_WLAN_80211 is not set | ||
1425 | # CONFIG_IWLWIFI_LEDS is not set | ||
1426 | |||
1427 | # | ||
1428 | # USB Network Adapters | ||
1429 | # | ||
1430 | CONFIG_USB_CATC=m | ||
1431 | CONFIG_USB_KAWETH=m | ||
1432 | CONFIG_USB_PEGASUS=m | ||
1433 | CONFIG_USB_RTL8150=m | ||
1434 | CONFIG_USB_USBNET=m | ||
1435 | CONFIG_USB_NET_AX8817X=m | ||
1436 | CONFIG_USB_NET_CDCETHER=m | ||
1437 | CONFIG_USB_NET_DM9601=m | ||
1438 | CONFIG_USB_NET_GL620A=m | ||
1439 | CONFIG_USB_NET_NET1080=m | ||
1440 | CONFIG_USB_NET_PLUSB=m | ||
1441 | CONFIG_USB_NET_MCS7830=m | ||
1442 | CONFIG_USB_NET_RNDIS_HOST=m | ||
1443 | CONFIG_USB_NET_CDC_SUBSET=m | ||
1444 | CONFIG_USB_ALI_M5632=y | ||
1445 | CONFIG_USB_AN2720=y | ||
1446 | CONFIG_USB_BELKIN=y | ||
1447 | CONFIG_USB_ARMLINUX=y | ||
1448 | CONFIG_USB_EPSON2888=y | ||
1449 | CONFIG_USB_KC2190=y | ||
1450 | CONFIG_USB_NET_ZAURUS=m | ||
1451 | CONFIG_NET_PCMCIA=y | ||
1452 | CONFIG_PCMCIA_3C589=m | ||
1453 | CONFIG_PCMCIA_3C574=m | ||
1454 | CONFIG_PCMCIA_FMVJ18X=m | ||
1455 | CONFIG_PCMCIA_PCNET=m | ||
1456 | CONFIG_PCMCIA_NMCLAN=m | ||
1457 | CONFIG_PCMCIA_SMC91C92=m | ||
1458 | CONFIG_PCMCIA_XIRC2PS=m | ||
1459 | CONFIG_PCMCIA_AXNET=m | ||
1460 | # CONFIG_WAN is not set | ||
1461 | CONFIG_ATM_DRIVERS=y | ||
1462 | # CONFIG_ATM_DUMMY is not set | ||
1463 | CONFIG_ATM_TCP=m | ||
1464 | CONFIG_ATM_LANAI=m | ||
1465 | CONFIG_ATM_ENI=m | ||
1466 | # CONFIG_ATM_ENI_DEBUG is not set | ||
1467 | # CONFIG_ATM_ENI_TUNE_BURST is not set | ||
1468 | # CONFIG_ATM_FIRESTREAM is not set | ||
1469 | # CONFIG_ATM_ZATM is not set | ||
1470 | CONFIG_ATM_NICSTAR=m | ||
1471 | # CONFIG_ATM_NICSTAR_USE_SUNI is not set | ||
1472 | # CONFIG_ATM_NICSTAR_USE_IDT77105 is not set | ||
1473 | CONFIG_ATM_IDT77252=m | ||
1474 | # CONFIG_ATM_IDT77252_DEBUG is not set | ||
1475 | # CONFIG_ATM_IDT77252_RCV_ALL is not set | ||
1476 | CONFIG_ATM_IDT77252_USE_SUNI=y | ||
1477 | # CONFIG_ATM_AMBASSADOR is not set | ||
1478 | # CONFIG_ATM_HORIZON is not set | ||
1479 | # CONFIG_ATM_IA is not set | ||
1480 | CONFIG_ATM_FORE200E_MAYBE=m | ||
1481 | # CONFIG_ATM_FORE200E_PCA is not set | ||
1482 | CONFIG_ATM_HE=m | ||
1483 | # CONFIG_ATM_HE_USE_SUNI is not set | ||
1484 | CONFIG_FDDI=y | ||
1485 | # CONFIG_DEFXX is not set | ||
1486 | CONFIG_SKFP=m | ||
1487 | # CONFIG_HIPPI is not set | ||
1488 | CONFIG_PLIP=m | ||
1489 | CONFIG_PPP=m | ||
1490 | CONFIG_PPP_MULTILINK=y | ||
1491 | CONFIG_PPP_FILTER=y | ||
1492 | CONFIG_PPP_ASYNC=m | ||
1493 | CONFIG_PPP_SYNC_TTY=m | ||
1494 | CONFIG_PPP_DEFLATE=m | ||
1495 | # CONFIG_PPP_BSDCOMP is not set | ||
1496 | CONFIG_PPP_MPPE=m | ||
1497 | CONFIG_PPPOE=m | ||
1498 | CONFIG_PPPOATM=m | ||
1499 | CONFIG_PPPOL2TP=m | ||
1500 | CONFIG_SLIP=m | ||
1501 | CONFIG_SLIP_COMPRESSED=y | ||
1502 | CONFIG_SLHC=m | ||
1503 | CONFIG_SLIP_SMART=y | ||
1504 | # CONFIG_SLIP_MODE_SLIP6 is not set | ||
1505 | CONFIG_NET_FC=y | ||
1506 | CONFIG_NETCONSOLE=m | ||
1507 | CONFIG_NETCONSOLE_DYNAMIC=y | ||
1508 | CONFIG_NETPOLL=y | ||
1509 | CONFIG_NETPOLL_TRAP=y | ||
1510 | CONFIG_NET_POLL_CONTROLLER=y | ||
1511 | CONFIG_VIRTIO_NET=m | ||
1512 | # CONFIG_ISDN is not set | ||
1513 | # CONFIG_PHONE is not set | ||
1514 | |||
1515 | # | ||
1516 | # Input device support | ||
1517 | # | ||
1518 | CONFIG_INPUT=y | ||
1519 | CONFIG_INPUT_FF_MEMLESS=y | ||
1520 | CONFIG_INPUT_POLLDEV=m | ||
1521 | |||
1522 | # | ||
1523 | # Userland interfaces | ||
1524 | # | ||
1525 | CONFIG_INPUT_MOUSEDEV=y | ||
1526 | # CONFIG_INPUT_MOUSEDEV_PSAUX is not set | ||
1527 | CONFIG_INPUT_MOUSEDEV_SCREEN_X=1024 | ||
1528 | CONFIG_INPUT_MOUSEDEV_SCREEN_Y=768 | ||
1529 | CONFIG_INPUT_JOYDEV=m | ||
1530 | CONFIG_INPUT_EVDEV=y | ||
1531 | # CONFIG_INPUT_EVBUG is not set | ||
1532 | |||
1533 | # | ||
1534 | # Input Device Drivers | ||
1535 | # | ||
1536 | CONFIG_INPUT_KEYBOARD=y | ||
1537 | CONFIG_KEYBOARD_ATKBD=y | ||
1538 | # CONFIG_KEYBOARD_SUNKBD is not set | ||
1539 | # CONFIG_KEYBOARD_LKKBD is not set | ||
1540 | # CONFIG_KEYBOARD_XTKBD is not set | ||
1541 | # CONFIG_KEYBOARD_NEWTON is not set | ||
1542 | # CONFIG_KEYBOARD_STOWAWAY is not set | ||
1543 | # CONFIG_KEYBOARD_GPIO is not set | ||
1544 | CONFIG_INPUT_MOUSE=y | ||
1545 | CONFIG_MOUSE_PS2=y | ||
1546 | CONFIG_MOUSE_PS2_ALPS=y | ||
1547 | CONFIG_MOUSE_PS2_LOGIPS2PP=y | ||
1548 | CONFIG_MOUSE_PS2_SYNAPTICS=y | ||
1549 | CONFIG_MOUSE_PS2_LIFEBOOK=y | ||
1550 | CONFIG_MOUSE_PS2_TRACKPOINT=y | ||
1551 | # CONFIG_MOUSE_PS2_TOUCHKIT is not set | ||
1552 | CONFIG_MOUSE_SERIAL=m | ||
1553 | CONFIG_MOUSE_APPLETOUCH=m | ||
1554 | # CONFIG_MOUSE_INPORT is not set | ||
1555 | # CONFIG_MOUSE_LOGIBM is not set | ||
1556 | # CONFIG_MOUSE_PC110PAD is not set | ||
1557 | CONFIG_MOUSE_VSXXXAA=m | ||
1558 | # CONFIG_MOUSE_GPIO is not set | ||
1559 | CONFIG_INPUT_JOYSTICK=y | ||
1560 | CONFIG_JOYSTICK_ANALOG=m | ||
1561 | CONFIG_JOYSTICK_A3D=m | ||
1562 | CONFIG_JOYSTICK_ADI=m | ||
1563 | CONFIG_JOYSTICK_COBRA=m | ||
1564 | CONFIG_JOYSTICK_GF2K=m | ||
1565 | CONFIG_JOYSTICK_GRIP=m | ||
1566 | CONFIG_JOYSTICK_GRIP_MP=m | ||
1567 | CONFIG_JOYSTICK_GUILLEMOT=m | ||
1568 | CONFIG_JOYSTICK_INTERACT=m | ||
1569 | CONFIG_JOYSTICK_SIDEWINDER=m | ||
1570 | CONFIG_JOYSTICK_TMDC=m | ||
1571 | CONFIG_JOYSTICK_IFORCE=m | ||
1572 | CONFIG_JOYSTICK_IFORCE_USB=y | ||
1573 | CONFIG_JOYSTICK_IFORCE_232=y | ||
1574 | CONFIG_JOYSTICK_WARRIOR=m | ||
1575 | CONFIG_JOYSTICK_MAGELLAN=m | ||
1576 | CONFIG_JOYSTICK_SPACEORB=m | ||
1577 | CONFIG_JOYSTICK_SPACEBALL=m | ||
1578 | CONFIG_JOYSTICK_STINGER=m | ||
1579 | CONFIG_JOYSTICK_TWIDJOY=m | ||
1580 | CONFIG_JOYSTICK_ZHENHUA=m | ||
1581 | CONFIG_JOYSTICK_DB9=m | ||
1582 | CONFIG_JOYSTICK_GAMECON=m | ||
1583 | CONFIG_JOYSTICK_TURBOGRAFX=m | ||
1584 | CONFIG_JOYSTICK_JOYDUMP=m | ||
1585 | CONFIG_JOYSTICK_XPAD=m | ||
1586 | CONFIG_JOYSTICK_XPAD_FF=y | ||
1587 | CONFIG_JOYSTICK_XPAD_LEDS=y | ||
1588 | CONFIG_INPUT_TABLET=y | ||
1589 | CONFIG_TABLET_USB_ACECAD=m | ||
1590 | CONFIG_TABLET_USB_AIPTEK=m | ||
1591 | CONFIG_TABLET_USB_GTCO=m | ||
1592 | CONFIG_TABLET_USB_KBTAB=m | ||
1593 | CONFIG_TABLET_USB_WACOM=m | ||
1594 | # CONFIG_INPUT_TOUCHSCREEN is not set | ||
1595 | CONFIG_INPUT_MISC=y | ||
1596 | CONFIG_INPUT_PCSPKR=m | ||
1597 | CONFIG_INPUT_ATI_REMOTE=m | ||
1598 | CONFIG_INPUT_ATI_REMOTE2=m | ||
1599 | CONFIG_INPUT_KEYSPAN_REMOTE=m | ||
1600 | CONFIG_INPUT_POWERMATE=m | ||
1601 | CONFIG_INPUT_YEALINK=m | ||
1602 | CONFIG_INPUT_UINPUT=m | ||
1603 | |||
1604 | # | ||
1605 | # Hardware I/O ports | ||
1606 | # | ||
1607 | CONFIG_SERIO=y | ||
1608 | CONFIG_SERIO_I8042=y | ||
1609 | CONFIG_SERIO_SERPORT=y | ||
1610 | # CONFIG_SERIO_PARKBD is not set | ||
1611 | # CONFIG_SERIO_PCIPS2 is not set | ||
1612 | CONFIG_SERIO_LIBPS2=y | ||
1613 | CONFIG_SERIO_RAW=m | ||
1614 | CONFIG_GAMEPORT=m | ||
1615 | CONFIG_GAMEPORT_NS558=m | ||
1616 | CONFIG_GAMEPORT_L4=m | ||
1617 | CONFIG_GAMEPORT_EMU10K1=m | ||
1618 | CONFIG_GAMEPORT_FM801=m | ||
1619 | CONFIG_INPUT_LIRC=y | ||
1620 | CONFIG_LIRC_DEV=m | ||
1621 | CONFIG_LIRC_ATIUSB=m | ||
1622 | CONFIG_LIRC_BT829=m | ||
1623 | CONFIG_LIRC_CMDIR=m | ||
1624 | CONFIG_LIRC_I2C=m | ||
1625 | CONFIG_LIRC_IGORPLUGUSB=m | ||
1626 | CONFIG_LIRC_IMON=m | ||
1627 | CONFIG_LIRC_IT87=m | ||
1628 | CONFIG_LIRC_MCEUSB=m | ||
1629 | CONFIG_LIRC_MCEUSB2=m | ||
1630 | CONFIG_LIRC_PVR150=m | ||
1631 | CONFIG_LIRC_PARALLEL=m | ||
1632 | CONFIG_LIRC_SERIAL=m | ||
1633 | CONFIG_LIRC_SIR=m | ||
1634 | CONFIG_LIRC_STREAMZAP=m | ||
1635 | CONFIG_LIRC_TTUSBIR=m | ||
1636 | |||
1637 | # | ||
1638 | # Character devices | ||
1639 | # | ||
1640 | CONFIG_VT=y | ||
1641 | CONFIG_VT_CONSOLE=y | ||
1642 | CONFIG_HW_CONSOLE=y | ||
1643 | CONFIG_VT_HW_CONSOLE_BINDING=y | ||
1644 | # CONFIG_DEVKMEM is not set | ||
1645 | CONFIG_SERIAL_NONSTANDARD=y | ||
1646 | # CONFIG_COMPUTONE is not set | ||
1647 | CONFIG_ROCKETPORT=m | ||
1648 | CONFIG_CYCLADES=m | ||
1649 | # CONFIG_CYZ_INTR is not set | ||
1650 | # CONFIG_DIGIEPCA is not set | ||
1651 | # CONFIG_ESPSERIAL is not set | ||
1652 | # CONFIG_MOXA_INTELLIO is not set | ||
1653 | # CONFIG_MOXA_SMARTIO is not set | ||
1654 | # CONFIG_ISI is not set | ||
1655 | CONFIG_SYNCLINK=m | ||
1656 | CONFIG_SYNCLINKMP=m | ||
1657 | CONFIG_SYNCLINK_GT=m | ||
1658 | CONFIG_N_HDLC=m | ||
1659 | # CONFIG_RISCOM8 is not set | ||
1660 | # CONFIG_SPECIALIX is not set | ||
1661 | # CONFIG_SX is not set | ||
1662 | # CONFIG_RIO is not set | ||
1663 | # CONFIG_STALDRV is not set | ||
1664 | CONFIG_NOZOMI=m | ||
1665 | |||
1666 | # | ||
1667 | # Serial drivers | ||
1668 | # | ||
1669 | CONFIG_SERIAL_8250=y | ||
1670 | CONFIG_SERIAL_8250_CONSOLE=y | ||
1671 | CONFIG_SERIAL_8250_PCI=y | ||
1672 | CONFIG_SERIAL_8250_PNP=y | ||
1673 | CONFIG_SERIAL_8250_CS=m | ||
1674 | CONFIG_SERIAL_8250_NR_UARTS=32 | ||
1675 | CONFIG_SERIAL_8250_RUNTIME_UARTS=4 | ||
1676 | CONFIG_SERIAL_8250_EXTENDED=y | ||
1677 | CONFIG_SERIAL_8250_MANY_PORTS=y | ||
1678 | # CONFIG_SERIAL_8250_FOURPORT is not set | ||
1679 | # CONFIG_SERIAL_8250_ACCENT is not set | ||
1680 | # CONFIG_SERIAL_8250_BOCA is not set | ||
1681 | # CONFIG_SERIAL_8250_EXAR_ST16C554 is not set | ||
1682 | # CONFIG_SERIAL_8250_HUB6 is not set | ||
1683 | CONFIG_SERIAL_8250_SHARE_IRQ=y | ||
1684 | CONFIG_SERIAL_8250_DETECT_IRQ=y | ||
1685 | CONFIG_SERIAL_8250_RSA=y | ||
1686 | |||
1687 | # | ||
1688 | # Non-8250 serial port support | ||
1689 | # | ||
1690 | CONFIG_SERIAL_UARTLITE=m | ||
1691 | CONFIG_SERIAL_CORE=y | ||
1692 | CONFIG_SERIAL_CORE_CONSOLE=y | ||
1693 | CONFIG_SERIAL_PMACZILOG=m | ||
1694 | # CONFIG_SERIAL_PMACZILOG_TTYS is not set | ||
1695 | # CONFIG_SERIAL_CPM is not set | ||
1696 | CONFIG_SERIAL_MPC52xx=y | ||
1697 | CONFIG_SERIAL_MPC52xx_CONSOLE=y | ||
1698 | CONFIG_SERIAL_MPC52xx_CONSOLE_BAUD=115200 | ||
1699 | CONFIG_SERIAL_JSM=m | ||
1700 | CONFIG_SERIAL_OF_PLATFORM=y | ||
1701 | # CONFIG_SERIAL_QE is not set | ||
1702 | CONFIG_UNIX98_PTYS=y | ||
1703 | # CONFIG_LEGACY_PTYS is not set | ||
1704 | # CONFIG_CRASH is not set | ||
1705 | CONFIG_BRIQ_PANEL=m | ||
1706 | CONFIG_PRINTER=m | ||
1707 | CONFIG_LP_CONSOLE=y | ||
1708 | CONFIG_PPDEV=m | ||
1709 | # CONFIG_HVC_RTAS is not set | ||
1710 | # CONFIG_IPMI_HANDLER is not set | ||
1711 | CONFIG_HW_RANDOM=y | ||
1712 | CONFIG_HW_RANDOM_VIRTIO=m | ||
1713 | CONFIG_NVRAM=y | ||
1714 | CONFIG_DTLK=m | ||
1715 | CONFIG_R3964=m | ||
1716 | # CONFIG_APPLICOM is not set | ||
1717 | |||
1718 | # | ||
1719 | # PCMCIA character devices | ||
1720 | # | ||
1721 | # CONFIG_SYNCLINK_CS is not set | ||
1722 | CONFIG_CARDMAN_4000=m | ||
1723 | CONFIG_CARDMAN_4040=m | ||
1724 | CONFIG_IPWIRELESS=m | ||
1725 | # CONFIG_RAW_DRIVER is not set | ||
1726 | # CONFIG_TCG_TPM is not set | ||
1727 | CONFIG_DEVPORT=y | ||
1728 | CONFIG_I2C=y | ||
1729 | CONFIG_I2C_BOARDINFO=y | ||
1730 | CONFIG_I2C_CHARDEV=m | ||
1731 | CONFIG_I2C_ALGOBIT=y | ||
1732 | CONFIG_I2C_ALGOPCA=m | ||
1733 | |||
1734 | # | ||
1735 | # I2C Hardware Bus support | ||
1736 | # | ||
1737 | |||
1738 | # | ||
1739 | # PC SMBus host controller drivers | ||
1740 | # | ||
1741 | # CONFIG_I2C_ALI1535 is not set | ||
1742 | # CONFIG_I2C_ALI1563 is not set | ||
1743 | # CONFIG_I2C_ALI15X3 is not set | ||
1744 | # CONFIG_I2C_AMD756 is not set | ||
1745 | # CONFIG_I2C_AMD8111 is not set | ||
1746 | # CONFIG_I2C_I801 is not set | ||
1747 | # CONFIG_I2C_ISCH is not set | ||
1748 | # CONFIG_I2C_PIIX4 is not set | ||
1749 | # CONFIG_I2C_NFORCE2 is not set | ||
1750 | # CONFIG_I2C_SIS5595 is not set | ||
1751 | # CONFIG_I2C_SIS630 is not set | ||
1752 | # CONFIG_I2C_SIS96X is not set | ||
1753 | # CONFIG_I2C_VIA is not set | ||
1754 | # CONFIG_I2C_VIAPRO is not set | ||
1755 | |||
1756 | # | ||
1757 | # Mac SMBus host controller drivers | ||
1758 | # | ||
1759 | CONFIG_I2C_HYDRA=m | ||
1760 | CONFIG_I2C_POWERMAC=y | ||
1761 | |||
1762 | # | ||
1763 | # I2C system bus drivers (mostly embedded / system-on-chip) | ||
1764 | # | ||
1765 | # CONFIG_I2C_CPM is not set | ||
1766 | # CONFIG_I2C_GPIO is not set | ||
1767 | CONFIG_I2C_MPC=m | ||
1768 | # CONFIG_I2C_OCORES is not set | ||
1769 | CONFIG_I2C_SIMTEC=m | ||
1770 | |||
1771 | # | ||
1772 | # External I2C/SMBus adapter drivers | ||
1773 | # | ||
1774 | CONFIG_I2C_PARPORT=m | ||
1775 | CONFIG_I2C_PARPORT_LIGHT=m | ||
1776 | # CONFIG_I2C_TAOS_EVM is not set | ||
1777 | CONFIG_I2C_TINY_USB=m | ||
1778 | |||
1779 | # | ||
1780 | # Graphics adapter I2C/DDC channel drivers | ||
1781 | # | ||
1782 | CONFIG_I2C_VOODOO3=m | ||
1783 | |||
1784 | # | ||
1785 | # Other I2C/SMBus bus drivers | ||
1786 | # | ||
1787 | # CONFIG_I2C_ELEKTOR is not set | ||
1788 | CONFIG_I2C_PCA_ISA=m | ||
1789 | CONFIG_I2C_PCA_PLATFORM=m | ||
1790 | CONFIG_I2C_STUB=m | ||
1791 | |||
1792 | # | ||
1793 | # Miscellaneous I2C Chip support | ||
1794 | # | ||
1795 | # CONFIG_DS1682 is not set | ||
1796 | CONFIG_AT24=m | ||
1797 | CONFIG_SENSORS_EEPROM=m | ||
1798 | CONFIG_SENSORS_PCF8574=m | ||
1799 | CONFIG_PCF8575=m | ||
1800 | CONFIG_SENSORS_PCA9539=m | ||
1801 | CONFIG_SENSORS_PCF8591=m | ||
1802 | # CONFIG_TPS65010 is not set | ||
1803 | CONFIG_SENSORS_MAX6875=m | ||
1804 | CONFIG_SENSORS_TSL2550=m | ||
1805 | # CONFIG_I2C_DEBUG_CORE is not set | ||
1806 | # CONFIG_I2C_DEBUG_ALGO is not set | ||
1807 | # CONFIG_I2C_DEBUG_BUS is not set | ||
1808 | # CONFIG_I2C_DEBUG_CHIP is not set | ||
1809 | # CONFIG_SPI is not set | ||
1810 | CONFIG_HAVE_GPIO_LIB=y | ||
1811 | |||
1812 | # | ||
1813 | # GPIO Support | ||
1814 | # | ||
1815 | # CONFIG_DEBUG_GPIO is not set | ||
1816 | |||
1817 | # | ||
1818 | # I2C GPIO expanders: | ||
1819 | # | ||
1820 | # CONFIG_GPIO_PCA953X is not set | ||
1821 | # CONFIG_GPIO_PCF857X is not set | ||
1822 | |||
1823 | # | ||
1824 | # SPI GPIO expanders: | ||
1825 | # | ||
1826 | CONFIG_W1=m | ||
1827 | CONFIG_W1_CON=y | ||
1828 | |||
1829 | # | ||
1830 | # 1-wire Bus Masters | ||
1831 | # | ||
1832 | # CONFIG_W1_MASTER_MATROX is not set | ||
1833 | CONFIG_W1_MASTER_DS2490=m | ||
1834 | CONFIG_W1_MASTER_DS2482=m | ||
1835 | # CONFIG_W1_MASTER_GPIO is not set | ||
1836 | |||
1837 | # | ||
1838 | # 1-wire Slaves | ||
1839 | # | ||
1840 | CONFIG_W1_SLAVE_THERM=m | ||
1841 | CONFIG_W1_SLAVE_SMEM=m | ||
1842 | CONFIG_W1_SLAVE_DS2433=m | ||
1843 | CONFIG_W1_SLAVE_DS2433_CRC=y | ||
1844 | CONFIG_W1_SLAVE_DS2760=m | ||
1845 | CONFIG_POWER_SUPPLY=m | ||
1846 | # CONFIG_POWER_SUPPLY_DEBUG is not set | ||
1847 | # CONFIG_PDA_POWER is not set | ||
1848 | CONFIG_APM_POWER=m | ||
1849 | # CONFIG_BATTERY_DS2760 is not set | ||
1850 | CONFIG_BATTERY_PMU=m | ||
1851 | CONFIG_HWMON=m | ||
1852 | CONFIG_HWMON_VID=m | ||
1853 | CONFIG_SENSORS_AD7418=m | ||
1854 | CONFIG_SENSORS_ADM1021=m | ||
1855 | CONFIG_SENSORS_ADM1025=m | ||
1856 | CONFIG_SENSORS_ADM1026=m | ||
1857 | CONFIG_SENSORS_ADM1029=m | ||
1858 | CONFIG_SENSORS_ADM1031=m | ||
1859 | CONFIG_SENSORS_ADM9240=m | ||
1860 | CONFIG_SENSORS_ADT7470=m | ||
1861 | CONFIG_SENSORS_ADT7473=m | ||
1862 | CONFIG_SENSORS_AMS=m | ||
1863 | CONFIG_SENSORS_AMS_PMU=y | ||
1864 | CONFIG_SENSORS_AMS_I2C=y | ||
1865 | CONFIG_SENSORS_ATXP1=m | ||
1866 | CONFIG_SENSORS_DS1621=m | ||
1867 | # CONFIG_SENSORS_I5K_AMB is not set | ||
1868 | CONFIG_SENSORS_F71805F=m | ||
1869 | CONFIG_SENSORS_F71882FG=m | ||
1870 | CONFIG_SENSORS_F75375S=m | ||
1871 | CONFIG_SENSORS_GL518SM=m | ||
1872 | CONFIG_SENSORS_GL520SM=m | ||
1873 | CONFIG_SENSORS_IT87=m | ||
1874 | CONFIG_SENSORS_LM63=m | ||
1875 | CONFIG_SENSORS_LM75=m | ||
1876 | CONFIG_SENSORS_LM77=m | ||
1877 | CONFIG_SENSORS_LM78=m | ||
1878 | CONFIG_SENSORS_LM80=m | ||
1879 | CONFIG_SENSORS_LM83=m | ||
1880 | CONFIG_SENSORS_LM85=m | ||
1881 | CONFIG_SENSORS_LM87=m | ||
1882 | CONFIG_SENSORS_LM90=m | ||
1883 | CONFIG_SENSORS_LM92=m | ||
1884 | CONFIG_SENSORS_LM93=m | ||
1885 | CONFIG_SENSORS_MAX1619=m | ||
1886 | CONFIG_SENSORS_MAX6650=m | ||
1887 | CONFIG_SENSORS_PC87360=m | ||
1888 | CONFIG_SENSORS_PC87427=m | ||
1889 | CONFIG_SENSORS_SIS5595=m | ||
1890 | CONFIG_SENSORS_DME1737=m | ||
1891 | CONFIG_SENSORS_SMSC47M1=m | ||
1892 | CONFIG_SENSORS_SMSC47M192=m | ||
1893 | CONFIG_SENSORS_SMSC47B397=m | ||
1894 | CONFIG_SENSORS_ADS7828=m | ||
1895 | CONFIG_SENSORS_THMC50=m | ||
1896 | CONFIG_SENSORS_VIA686A=m | ||
1897 | CONFIG_SENSORS_VT1211=m | ||
1898 | CONFIG_SENSORS_VT8231=m | ||
1899 | CONFIG_SENSORS_W83781D=m | ||
1900 | CONFIG_SENSORS_W83791D=m | ||
1901 | CONFIG_SENSORS_W83792D=m | ||
1902 | CONFIG_SENSORS_W83793=m | ||
1903 | CONFIG_SENSORS_W83L785TS=m | ||
1904 | CONFIG_SENSORS_W83L786NG=m | ||
1905 | CONFIG_SENSORS_W83627HF=m | ||
1906 | CONFIG_SENSORS_W83627EHF=m | ||
1907 | # CONFIG_HWMON_DEBUG_CHIP is not set | ||
1908 | CONFIG_THERMAL=y | ||
1909 | CONFIG_WATCHDOG=y | ||
1910 | # CONFIG_WATCHDOG_NOWAYOUT is not set | ||
1911 | |||
1912 | # | ||
1913 | # Watchdog Device Drivers | ||
1914 | # | ||
1915 | CONFIG_SOFT_WATCHDOG=m | ||
1916 | # CONFIG_MPC5200_WDT is not set | ||
1917 | CONFIG_83xx_WDT=m | ||
1918 | CONFIG_WATCHDOG_RTAS=m | ||
1919 | |||
1920 | # | ||
1921 | # ISA-based Watchdog Cards | ||
1922 | # | ||
1923 | # CONFIG_PCWATCHDOG is not set | ||
1924 | # CONFIG_MIXCOMWD is not set | ||
1925 | # CONFIG_WDT is not set | ||
1926 | |||
1927 | # | ||
1928 | # PCI-based Watchdog Cards | ||
1929 | # | ||
1930 | # CONFIG_PCIPCWATCHDOG is not set | ||
1931 | # CONFIG_WDTPCI is not set | ||
1932 | |||
1933 | # | ||
1934 | # USB-based Watchdog Cards | ||
1935 | # | ||
1936 | CONFIG_USBPCWATCHDOG=m | ||
1937 | |||
1938 | # | ||
1939 | # Sonics Silicon Backplane | ||
1940 | # | ||
1941 | CONFIG_SSB_POSSIBLE=y | ||
1942 | CONFIG_SSB=m | ||
1943 | CONFIG_SSB_SPROM=y | ||
1944 | CONFIG_SSB_PCIHOST_POSSIBLE=y | ||
1945 | CONFIG_SSB_PCIHOST=y | ||
1946 | # CONFIG_SSB_B43_PCI_BRIDGE is not set | ||
1947 | CONFIG_SSB_PCMCIAHOST_POSSIBLE=y | ||
1948 | CONFIG_SSB_PCMCIAHOST=y | ||
1949 | # CONFIG_SSB_DEBUG is not set | ||
1950 | CONFIG_SSB_DRIVER_PCICORE_POSSIBLE=y | ||
1951 | CONFIG_SSB_DRIVER_PCICORE=y | ||
1952 | |||
1953 | # | ||
1954 | # Multifunction device drivers | ||
1955 | # | ||
1956 | CONFIG_MFD_SM501=m | ||
1957 | # CONFIG_HTC_PASIC3 is not set | ||
1958 | |||
1959 | # | ||
1960 | # Multimedia devices | ||
1961 | # | ||
1962 | |||
1963 | # | ||
1964 | # Multimedia core support | ||
1965 | # | ||
1966 | CONFIG_VIDEO_DEV=m | ||
1967 | CONFIG_VIDEO_V4L2_COMMON=m | ||
1968 | CONFIG_VIDEO_ALLOW_V4L1=y | ||
1969 | CONFIG_VIDEO_V4L1_COMPAT=y | ||
1970 | CONFIG_DVB_CORE=m | ||
1971 | CONFIG_VIDEO_MEDIA=m | ||
1972 | |||
1973 | # | ||
1974 | # Multimedia drivers | ||
1975 | # | ||
1976 | CONFIG_VIDEO_SAA7146=m | ||
1977 | CONFIG_VIDEO_SAA7146_VV=m | ||
1978 | CONFIG_MEDIA_ATTACH=y | ||
1979 | CONFIG_MEDIA_TUNER=m | ||
1980 | # CONFIG_MEDIA_TUNER_CUSTOMIZE is not set | ||
1981 | CONFIG_MEDIA_TUNER_SIMPLE=m | ||
1982 | CONFIG_MEDIA_TUNER_TDA8290=m | ||
1983 | CONFIG_MEDIA_TUNER_TDA827X=m | ||
1984 | CONFIG_MEDIA_TUNER_TDA18271=m | ||
1985 | CONFIG_MEDIA_TUNER_TDA9887=m | ||
1986 | CONFIG_MEDIA_TUNER_TEA5761=m | ||
1987 | CONFIG_MEDIA_TUNER_TEA5767=m | ||
1988 | CONFIG_MEDIA_TUNER_MT20XX=m | ||
1989 | CONFIG_MEDIA_TUNER_MT2060=m | ||
1990 | CONFIG_MEDIA_TUNER_MT2266=m | ||
1991 | CONFIG_MEDIA_TUNER_MT2131=m | ||
1992 | CONFIG_MEDIA_TUNER_QT1010=m | ||
1993 | CONFIG_MEDIA_TUNER_XC2028=m | ||
1994 | CONFIG_MEDIA_TUNER_XC5000=m | ||
1995 | CONFIG_MEDIA_TUNER_MXL5005S=m | ||
1996 | CONFIG_VIDEO_V4L2=m | ||
1997 | CONFIG_VIDEO_V4L1=m | ||
1998 | CONFIG_VIDEOBUF_GEN=m | ||
1999 | CONFIG_VIDEOBUF_DMA_SG=m | ||
2000 | CONFIG_VIDEOBUF_VMALLOC=m | ||
2001 | CONFIG_VIDEOBUF_DVB=m | ||
2002 | CONFIG_VIDEO_BTCX=m | ||
2003 | CONFIG_VIDEO_IR_I2C=m | ||
2004 | CONFIG_VIDEO_IR=m | ||
2005 | CONFIG_VIDEO_TVEEPROM=m | ||
2006 | CONFIG_VIDEO_TUNER=m | ||
2007 | CONFIG_VIDEO_CAPTURE_DRIVERS=y | ||
2008 | # CONFIG_VIDEO_ADV_DEBUG is not set | ||
2009 | # CONFIG_VIDEO_HELPER_CHIPS_AUTO is not set | ||
2010 | |||
2011 | # | ||
2012 | # Encoders/decoders and other helper chips | ||
2013 | # | ||
2014 | |||
2015 | # | ||
2016 | # Audio decoders | ||
2017 | # | ||
2018 | CONFIG_VIDEO_TVAUDIO=m | ||
2019 | CONFIG_VIDEO_TDA7432=m | ||
2020 | CONFIG_VIDEO_TDA9840=m | ||
2021 | CONFIG_VIDEO_TDA9875=m | ||
2022 | CONFIG_VIDEO_TEA6415C=m | ||
2023 | CONFIG_VIDEO_TEA6420=m | ||
2024 | CONFIG_VIDEO_MSP3400=m | ||
2025 | CONFIG_VIDEO_CS5345=m | ||
2026 | CONFIG_VIDEO_CS53L32A=m | ||
2027 | CONFIG_VIDEO_M52790=m | ||
2028 | CONFIG_VIDEO_TLV320AIC23B=m | ||
2029 | CONFIG_VIDEO_WM8775=m | ||
2030 | CONFIG_VIDEO_WM8739=m | ||
2031 | CONFIG_VIDEO_VP27SMPX=m | ||
2032 | |||
2033 | # | ||
2034 | # Video decoders | ||
2035 | # | ||
2036 | CONFIG_VIDEO_BT819=m | ||
2037 | CONFIG_VIDEO_BT856=m | ||
2038 | CONFIG_VIDEO_BT866=m | ||
2039 | CONFIG_VIDEO_KS0127=m | ||
2040 | CONFIG_VIDEO_OV7670=m | ||
2041 | CONFIG_VIDEO_TCM825X=m | ||
2042 | CONFIG_VIDEO_SAA7110=m | ||
2043 | CONFIG_VIDEO_SAA7111=m | ||
2044 | CONFIG_VIDEO_SAA7114=m | ||
2045 | CONFIG_VIDEO_SAA711X=m | ||
2046 | CONFIG_VIDEO_SAA717X=m | ||
2047 | CONFIG_VIDEO_SAA7191=m | ||
2048 | CONFIG_VIDEO_TVP5150=m | ||
2049 | CONFIG_VIDEO_VPX3220=m | ||
2050 | |||
2051 | # | ||
2052 | # Video and audio decoders | ||
2053 | # | ||
2054 | CONFIG_VIDEO_CX25840=m | ||
2055 | |||
2056 | # | ||
2057 | # MPEG video encoders | ||
2058 | # | ||
2059 | CONFIG_VIDEO_CX2341X=m | ||
2060 | |||
2061 | # | ||
2062 | # Video encoders | ||
2063 | # | ||
2064 | CONFIG_VIDEO_SAA7127=m | ||
2065 | CONFIG_VIDEO_SAA7185=m | ||
2066 | CONFIG_VIDEO_ADV7170=m | ||
2067 | CONFIG_VIDEO_ADV7175=m | ||
2068 | |||
2069 | # | ||
2070 | # Video improvement chips | ||
2071 | # | ||
2072 | CONFIG_VIDEO_UPD64031A=m | ||
2073 | CONFIG_VIDEO_UPD64083=m | ||
2074 | # CONFIG_VIDEO_VIVI is not set | ||
2075 | CONFIG_VIDEO_BT848=m | ||
2076 | CONFIG_VIDEO_BT848_DVB=y | ||
2077 | CONFIG_VIDEO_SAA6588=m | ||
2078 | # CONFIG_VIDEO_PMS is not set | ||
2079 | CONFIG_VIDEO_BWQCAM=m | ||
2080 | CONFIG_VIDEO_CQCAM=m | ||
2081 | CONFIG_VIDEO_W9966=m | ||
2082 | CONFIG_VIDEO_CPIA=m | ||
2083 | CONFIG_VIDEO_CPIA_PP=m | ||
2084 | CONFIG_VIDEO_CPIA_USB=m | ||
2085 | CONFIG_VIDEO_CPIA2=m | ||
2086 | CONFIG_VIDEO_SAA5246A=m | ||
2087 | CONFIG_VIDEO_SAA5249=m | ||
2088 | CONFIG_TUNER_3036=m | ||
2089 | # CONFIG_VIDEO_STRADIS is not set | ||
2090 | # CONFIG_VIDEO_ZORAN is not set | ||
2091 | CONFIG_VIDEO_SAA7134=m | ||
2092 | CONFIG_VIDEO_SAA7134_ALSA=m | ||
2093 | CONFIG_VIDEO_SAA7134_DVB=m | ||
2094 | CONFIG_VIDEO_MXB=m | ||
2095 | CONFIG_VIDEO_DPC=m | ||
2096 | CONFIG_VIDEO_HEXIUM_ORION=m | ||
2097 | CONFIG_VIDEO_HEXIUM_GEMINI=m | ||
2098 | CONFIG_VIDEO_CX88=m | ||
2099 | CONFIG_VIDEO_CX88_ALSA=m | ||
2100 | CONFIG_VIDEO_CX88_BLACKBIRD=m | ||
2101 | CONFIG_VIDEO_CX88_DVB=m | ||
2102 | CONFIG_VIDEO_CX88_VP3054=m | ||
2103 | CONFIG_VIDEO_CX23885=m | ||
2104 | CONFIG_VIDEO_AU0828=m | ||
2105 | CONFIG_VIDEO_IVTV=m | ||
2106 | CONFIG_VIDEO_FB_IVTV=m | ||
2107 | CONFIG_VIDEO_CX18=m | ||
2108 | # CONFIG_VIDEO_CAFE_CCIC is not set | ||
2109 | CONFIG_V4L_USB_DRIVERS=y | ||
2110 | CONFIG_USB_VIDEO_CLASS=m | ||
2111 | CONFIG_VIDEO_PVRUSB2=m | ||
2112 | CONFIG_VIDEO_PVRUSB2_SYSFS=y | ||
2113 | CONFIG_VIDEO_PVRUSB2_DVB=y | ||
2114 | # CONFIG_VIDEO_PVRUSB2_DEBUGIFC is not set | ||
2115 | CONFIG_VIDEO_EM28XX=m | ||
2116 | CONFIG_VIDEO_EM28XX_ALSA=m | ||
2117 | CONFIG_VIDEO_EM28XX_DVB=m | ||
2118 | CONFIG_VIDEO_USBVISION=m | ||
2119 | CONFIG_VIDEO_USBVIDEO=m | ||
2120 | CONFIG_USB_VICAM=m | ||
2121 | CONFIG_USB_IBMCAM=m | ||
2122 | CONFIG_USB_KONICAWC=m | ||
2123 | CONFIG_USB_QUICKCAM_MESSENGER=m | ||
2124 | CONFIG_USB_ET61X251=m | ||
2125 | CONFIG_VIDEO_OVCAMCHIP=m | ||
2126 | CONFIG_USB_W9968CF=m | ||
2127 | CONFIG_USB_OV511=m | ||
2128 | CONFIG_USB_SE401=m | ||
2129 | CONFIG_USB_SN9C102=m | ||
2130 | CONFIG_USB_STV680=m | ||
2131 | CONFIG_USB_ZC0301=m | ||
2132 | CONFIG_USB_PWC=m | ||
2133 | # CONFIG_USB_PWC_DEBUG is not set | ||
2134 | CONFIG_USB_ZR364XX=m | ||
2135 | CONFIG_USB_STKWEBCAM=m | ||
2136 | CONFIG_SOC_CAMERA=m | ||
2137 | CONFIG_SOC_CAMERA_MT9M001=m | ||
2138 | # CONFIG_MT9M001_PCA9536_SWITCH is not set | ||
2139 | CONFIG_SOC_CAMERA_MT9V022=m | ||
2140 | # CONFIG_MT9V022_PCA9536_SWITCH is not set | ||
2141 | CONFIG_RADIO_ADAPTERS=y | ||
2142 | # CONFIG_RADIO_CADET is not set | ||
2143 | # CONFIG_RADIO_RTRACK is not set | ||
2144 | # CONFIG_RADIO_RTRACK2 is not set | ||
2145 | # CONFIG_RADIO_AZTECH is not set | ||
2146 | # CONFIG_RADIO_GEMTEK is not set | ||
2147 | CONFIG_RADIO_GEMTEK_PCI=m | ||
2148 | CONFIG_RADIO_MAXIRADIO=m | ||
2149 | CONFIG_RADIO_MAESTRO=m | ||
2150 | # CONFIG_RADIO_SF16FMI is not set | ||
2151 | # CONFIG_RADIO_SF16FMR2 is not set | ||
2152 | # CONFIG_RADIO_TERRATEC is not set | ||
2153 | # CONFIG_RADIO_TRUST is not set | ||
2154 | # CONFIG_RADIO_TYPHOON is not set | ||
2155 | # CONFIG_RADIO_ZOLTRIX is not set | ||
2156 | CONFIG_USB_DSBR=m | ||
2157 | CONFIG_USB_SI470X=m | ||
2158 | CONFIG_DVB_CAPTURE_DRIVERS=y | ||
2159 | |||
2160 | # | ||
2161 | # Supported SAA7146 based PCI Adapters | ||
2162 | # | ||
2163 | CONFIG_TTPCI_EEPROM=m | ||
2164 | CONFIG_DVB_AV7110=m | ||
2165 | CONFIG_DVB_AV7110_OSD=y | ||
2166 | CONFIG_DVB_BUDGET_CORE=m | ||
2167 | CONFIG_DVB_BUDGET=m | ||
2168 | CONFIG_DVB_BUDGET_CI=m | ||
2169 | CONFIG_DVB_BUDGET_AV=m | ||
2170 | CONFIG_DVB_BUDGET_PATCH=m | ||
2171 | |||
2172 | # | ||
2173 | # Supported USB Adapters | ||
2174 | # | ||
2175 | CONFIG_DVB_USB=m | ||
2176 | # CONFIG_DVB_USB_DEBUG is not set | ||
2177 | CONFIG_DVB_USB_A800=m | ||
2178 | CONFIG_DVB_USB_DIBUSB_MB=m | ||
2179 | # CONFIG_DVB_USB_DIBUSB_MB_FAULTY is not set | ||
2180 | CONFIG_DVB_USB_DIBUSB_MC=m | ||
2181 | CONFIG_DVB_USB_DIB0700=m | ||
2182 | CONFIG_DVB_USB_UMT_010=m | ||
2183 | CONFIG_DVB_USB_CXUSB=m | ||
2184 | CONFIG_DVB_USB_M920X=m | ||
2185 | CONFIG_DVB_USB_GL861=m | ||
2186 | CONFIG_DVB_USB_AU6610=m | ||
2187 | CONFIG_DVB_USB_DIGITV=m | ||
2188 | CONFIG_DVB_USB_VP7045=m | ||
2189 | CONFIG_DVB_USB_VP702X=m | ||
2190 | CONFIG_DVB_USB_GP8PSK=m | ||
2191 | CONFIG_DVB_USB_NOVA_T_USB2=m | ||
2192 | CONFIG_DVB_USB_TTUSB2=m | ||
2193 | CONFIG_DVB_USB_DTT200U=m | ||
2194 | CONFIG_DVB_USB_OPERA1=m | ||
2195 | CONFIG_DVB_USB_AF9005=m | ||
2196 | CONFIG_DVB_USB_AF9005_REMOTE=m | ||
2197 | CONFIG_DVB_TTUSB_BUDGET=m | ||
2198 | CONFIG_DVB_TTUSB_DEC=m | ||
2199 | CONFIG_DVB_CINERGYT2=m | ||
2200 | CONFIG_DVB_CINERGYT2_TUNING=y | ||
2201 | CONFIG_DVB_CINERGYT2_STREAM_URB_COUNT=32 | ||
2202 | CONFIG_DVB_CINERGYT2_STREAM_BUF_SIZE=512 | ||
2203 | CONFIG_DVB_CINERGYT2_QUERY_INTERVAL=250 | ||
2204 | CONFIG_DVB_CINERGYT2_ENABLE_RC_INPUT_DEVICE=y | ||
2205 | CONFIG_DVB_CINERGYT2_RC_QUERY_INTERVAL=100 | ||
2206 | |||
2207 | # | ||
2208 | # Supported FlexCopII (B2C2) Adapters | ||
2209 | # | ||
2210 | CONFIG_DVB_B2C2_FLEXCOP=m | ||
2211 | CONFIG_DVB_B2C2_FLEXCOP_PCI=m | ||
2212 | CONFIG_DVB_B2C2_FLEXCOP_USB=m | ||
2213 | # CONFIG_DVB_B2C2_FLEXCOP_DEBUG is not set | ||
2214 | |||
2215 | # | ||
2216 | # Supported BT878 Adapters | ||
2217 | # | ||
2218 | CONFIG_DVB_BT8XX=m | ||
2219 | |||
2220 | # | ||
2221 | # Supported Pluto2 Adapters | ||
2222 | # | ||
2223 | CONFIG_DVB_PLUTO2=m | ||
2224 | |||
2225 | # | ||
2226 | # Supported DVB Frontends | ||
2227 | # | ||
2228 | |||
2229 | # | ||
2230 | # Customise DVB Frontends | ||
2231 | # | ||
2232 | # CONFIG_DVB_FE_CUSTOMISE is not set | ||
2233 | |||
2234 | # | ||
2235 | # DVB-S (satellite) frontends | ||
2236 | # | ||
2237 | CONFIG_DVB_CX24110=m | ||
2238 | CONFIG_DVB_CX24123=m | ||
2239 | CONFIG_DVB_MT312=m | ||
2240 | CONFIG_DVB_S5H1420=m | ||
2241 | CONFIG_DVB_STV0299=m | ||
2242 | CONFIG_DVB_TDA8083=m | ||
2243 | CONFIG_DVB_TDA10086=m | ||
2244 | CONFIG_DVB_VES1X93=m | ||
2245 | CONFIG_DVB_TUNER_ITD1000=m | ||
2246 | CONFIG_DVB_TDA826X=m | ||
2247 | CONFIG_DVB_TUA6100=m | ||
2248 | |||
2249 | # | ||
2250 | # DVB-T (terrestrial) frontends | ||
2251 | # | ||
2252 | CONFIG_DVB_SP8870=m | ||
2253 | CONFIG_DVB_SP887X=m | ||
2254 | CONFIG_DVB_CX22700=m | ||
2255 | CONFIG_DVB_CX22702=m | ||
2256 | CONFIG_DVB_L64781=m | ||
2257 | CONFIG_DVB_TDA1004X=m | ||
2258 | CONFIG_DVB_NXT6000=m | ||
2259 | CONFIG_DVB_MT352=m | ||
2260 | CONFIG_DVB_ZL10353=m | ||
2261 | CONFIG_DVB_DIB3000MB=m | ||
2262 | CONFIG_DVB_DIB3000MC=m | ||
2263 | CONFIG_DVB_DIB7000M=m | ||
2264 | CONFIG_DVB_DIB7000P=m | ||
2265 | CONFIG_DVB_TDA10048=m | ||
2266 | |||
2267 | # | ||
2268 | # DVB-C (cable) frontends | ||
2269 | # | ||
2270 | CONFIG_DVB_VES1820=m | ||
2271 | CONFIG_DVB_TDA10021=m | ||
2272 | CONFIG_DVB_TDA10023=m | ||
2273 | CONFIG_DVB_STV0297=m | ||
2274 | |||
2275 | # | ||
2276 | # ATSC (North American/Korean Terrestrial/Cable DTV) frontends | ||
2277 | # | ||
2278 | CONFIG_DVB_NXT200X=m | ||
2279 | CONFIG_DVB_OR51211=m | ||
2280 | CONFIG_DVB_OR51132=m | ||
2281 | CONFIG_DVB_BCM3510=m | ||
2282 | CONFIG_DVB_LGDT330X=m | ||
2283 | CONFIG_DVB_S5H1409=m | ||
2284 | CONFIG_DVB_AU8522=m | ||
2285 | CONFIG_DVB_S5H1411=m | ||
2286 | |||
2287 | # | ||
2288 | # Digital terrestrial only tuners/PLL | ||
2289 | # | ||
2290 | CONFIG_DVB_PLL=m | ||
2291 | CONFIG_DVB_TUNER_DIB0070=m | ||
2292 | |||
2293 | # | ||
2294 | # SEC control devices for DVB-S | ||
2295 | # | ||
2296 | CONFIG_DVB_LNBP21=m | ||
2297 | CONFIG_DVB_ISL6405=m | ||
2298 | CONFIG_DVB_ISL6421=m | ||
2299 | CONFIG_DAB=y | ||
2300 | CONFIG_USB_DABUSB=m | ||
2301 | |||
2302 | # | ||
2303 | # Graphics support | ||
2304 | # | ||
2305 | CONFIG_AGP=y | ||
2306 | CONFIG_AGP_UNINORTH=y | ||
2307 | CONFIG_DRM=m | ||
2308 | CONFIG_DRM_TDFX=m | ||
2309 | CONFIG_DRM_R128=m | ||
2310 | CONFIG_DRM_RADEON=m | ||
2311 | CONFIG_DRM_MGA=m | ||
2312 | CONFIG_DRM_SIS=m | ||
2313 | CONFIG_DRM_VIA=m | ||
2314 | CONFIG_DRM_SAVAGE=m | ||
2315 | CONFIG_VGASTATE=y | ||
2316 | CONFIG_VIDEO_OUTPUT_CONTROL=m | ||
2317 | CONFIG_FB=y | ||
2318 | # CONFIG_FIRMWARE_EDID is not set | ||
2319 | CONFIG_FB_DDC=y | ||
2320 | CONFIG_FB_CFB_FILLRECT=y | ||
2321 | CONFIG_FB_CFB_COPYAREA=y | ||
2322 | CONFIG_FB_CFB_IMAGEBLIT=y | ||
2323 | # CONFIG_FB_CFB_REV_PIXELS_IN_BYTE is not set | ||
2324 | # CONFIG_FB_SYS_FILLRECT is not set | ||
2325 | # CONFIG_FB_SYS_COPYAREA is not set | ||
2326 | # CONFIG_FB_SYS_IMAGEBLIT is not set | ||
2327 | # CONFIG_FB_FOREIGN_ENDIAN is not set | ||
2328 | # CONFIG_FB_SYS_FOPS is not set | ||
2329 | CONFIG_FB_SVGALIB=m | ||
2330 | CONFIG_FB_MACMODES=y | ||
2331 | CONFIG_FB_BACKLIGHT=y | ||
2332 | CONFIG_FB_MODE_HELPERS=y | ||
2333 | CONFIG_FB_TILEBLITTING=y | ||
2334 | |||
2335 | # | ||
2336 | # Frame buffer hardware drivers | ||
2337 | # | ||
2338 | CONFIG_FB_CIRRUS=m | ||
2339 | # CONFIG_FB_PM2 is not set | ||
2340 | # CONFIG_FB_CYBER2000 is not set | ||
2341 | CONFIG_FB_OF=y | ||
2342 | # CONFIG_FB_CONTROL is not set | ||
2343 | CONFIG_FB_PLATINUM=y | ||
2344 | CONFIG_FB_VALKYRIE=y | ||
2345 | CONFIG_FB_CT65550=y | ||
2346 | # CONFIG_FB_ASILIANT is not set | ||
2347 | # CONFIG_FB_IMSTT is not set | ||
2348 | # CONFIG_FB_VGA16 is not set | ||
2349 | # CONFIG_FB_UVESA is not set | ||
2350 | # CONFIG_FB_S1D13XXX is not set | ||
2351 | CONFIG_FB_NVIDIA=y | ||
2352 | CONFIG_FB_NVIDIA_I2C=y | ||
2353 | # CONFIG_FB_NVIDIA_DEBUG is not set | ||
2354 | CONFIG_FB_NVIDIA_BACKLIGHT=y | ||
2355 | CONFIG_FB_RIVA=m | ||
2356 | # CONFIG_FB_RIVA_I2C is not set | ||
2357 | # CONFIG_FB_RIVA_DEBUG is not set | ||
2358 | CONFIG_FB_RIVA_BACKLIGHT=y | ||
2359 | CONFIG_FB_MATROX=y | ||
2360 | CONFIG_FB_MATROX_MILLENIUM=y | ||
2361 | CONFIG_FB_MATROX_MYSTIQUE=y | ||
2362 | CONFIG_FB_MATROX_G=y | ||
2363 | CONFIG_FB_MATROX_I2C=m | ||
2364 | CONFIG_FB_MATROX_MAVEN=m | ||
2365 | CONFIG_FB_MATROX_MULTIHEAD=y | ||
2366 | CONFIG_FB_RADEON=y | ||
2367 | CONFIG_FB_RADEON_I2C=y | ||
2368 | CONFIG_FB_RADEON_BACKLIGHT=y | ||
2369 | # CONFIG_FB_RADEON_DEBUG is not set | ||
2370 | CONFIG_FB_ATY128=y | ||
2371 | CONFIG_FB_ATY128_BACKLIGHT=y | ||
2372 | CONFIG_FB_ATY=y | ||
2373 | CONFIG_FB_ATY_CT=y | ||
2374 | CONFIG_FB_ATY_GENERIC_LCD=y | ||
2375 | CONFIG_FB_ATY_GX=y | ||
2376 | CONFIG_FB_ATY_BACKLIGHT=y | ||
2377 | CONFIG_FB_S3=m | ||
2378 | CONFIG_FB_SAVAGE=m | ||
2379 | CONFIG_FB_SAVAGE_I2C=y | ||
2380 | CONFIG_FB_SAVAGE_ACCEL=y | ||
2381 | # CONFIG_FB_SIS is not set | ||
2382 | CONFIG_FB_NEOMAGIC=m | ||
2383 | CONFIG_FB_KYRO=m | ||
2384 | CONFIG_FB_3DFX=m | ||
2385 | CONFIG_FB_3DFX_ACCEL=y | ||
2386 | CONFIG_FB_VOODOO1=m | ||
2387 | # CONFIG_FB_VT8623 is not set | ||
2388 | CONFIG_FB_TRIDENT=m | ||
2389 | CONFIG_FB_TRIDENT_ACCEL=y | ||
2390 | # CONFIG_FB_ARK is not set | ||
2391 | # CONFIG_FB_PM3 is not set | ||
2392 | # CONFIG_FB_FSL_DIU is not set | ||
2393 | CONFIG_FB_SM501=m | ||
2394 | CONFIG_FB_IBM_GXT4500=y | ||
2395 | # CONFIG_FB_VIRTUAL is not set | ||
2396 | CONFIG_BACKLIGHT_LCD_SUPPORT=y | ||
2397 | CONFIG_LCD_CLASS_DEVICE=m | ||
2398 | CONFIG_BACKLIGHT_CLASS_DEVICE=y | ||
2399 | # CONFIG_BACKLIGHT_CORGI is not set | ||
2400 | |||
2401 | # | ||
2402 | # Display device support | ||
2403 | # | ||
2404 | CONFIG_DISPLAY_SUPPORT=m | ||
2405 | |||
2406 | # | ||
2407 | # Display hardware drivers | ||
2408 | # | ||
2409 | |||
2410 | # | ||
2411 | # Console display driver support | ||
2412 | # | ||
2413 | CONFIG_VGA_CONSOLE=y | ||
2414 | CONFIG_VGACON_SOFT_SCROLLBACK=y | ||
2415 | CONFIG_VGACON_SOFT_SCROLLBACK_SIZE=64 | ||
2416 | # CONFIG_MDA_CONSOLE is not set | ||
2417 | CONFIG_DUMMY_CONSOLE=y | ||
2418 | CONFIG_FRAMEBUFFER_CONSOLE=y | ||
2419 | CONFIG_FRAMEBUFFER_CONSOLE_DETECT_PRIMARY=y | ||
2420 | CONFIG_FRAMEBUFFER_CONSOLE_ROTATION=y | ||
2421 | # CONFIG_FONTS is not set | ||
2422 | CONFIG_FONT_8x8=y | ||
2423 | CONFIG_FONT_8x16=y | ||
2424 | CONFIG_LOGO=y | ||
2425 | # CONFIG_LOGO_LINUX_MONO is not set | ||
2426 | # CONFIG_LOGO_LINUX_VGA16 is not set | ||
2427 | CONFIG_LOGO_LINUX_CLUT224=y | ||
2428 | CONFIG_SOUND=m | ||
2429 | CONFIG_SND=m | ||
2430 | CONFIG_SND_TIMER=m | ||
2431 | CONFIG_SND_PCM=m | ||
2432 | CONFIG_SND_HWDEP=m | ||
2433 | CONFIG_SND_RAWMIDI=m | ||
2434 | CONFIG_SND_SEQUENCER=m | ||
2435 | CONFIG_SND_SEQ_DUMMY=m | ||
2436 | CONFIG_SND_OSSEMUL=y | ||
2437 | CONFIG_SND_MIXER_OSS=m | ||
2438 | CONFIG_SND_PCM_OSS=m | ||
2439 | CONFIG_SND_PCM_OSS_PLUGINS=y | ||
2440 | CONFIG_SND_SEQUENCER_OSS=y | ||
2441 | CONFIG_SND_DYNAMIC_MINORS=y | ||
2442 | # CONFIG_SND_SUPPORT_OLD_API is not set | ||
2443 | CONFIG_SND_VERBOSE_PROCFS=y | ||
2444 | CONFIG_SND_VERBOSE_PRINTK=y | ||
2445 | CONFIG_SND_DEBUG=y | ||
2446 | CONFIG_SND_DEBUG_VERBOSE=y | ||
2447 | CONFIG_SND_PCM_XRUN_DEBUG=y | ||
2448 | CONFIG_SND_VMASTER=y | ||
2449 | CONFIG_SND_MPU401_UART=m | ||
2450 | CONFIG_SND_OPL3_LIB=m | ||
2451 | CONFIG_SND_VX_LIB=m | ||
2452 | CONFIG_SND_AC97_CODEC=m | ||
2453 | CONFIG_SND_DRIVERS=y | ||
2454 | CONFIG_SND_DUMMY=m | ||
2455 | CONFIG_SND_VIRMIDI=m | ||
2456 | CONFIG_SND_MTPAV=m | ||
2457 | CONFIG_SND_MTS64=m | ||
2458 | CONFIG_SND_SERIAL_U16550=m | ||
2459 | CONFIG_SND_MPU401=m | ||
2460 | CONFIG_SND_PORTMAN2X4=m | ||
2461 | CONFIG_SND_AC97_POWER_SAVE=y | ||
2462 | CONFIG_SND_AC97_POWER_SAVE_DEFAULT=5 | ||
2463 | CONFIG_SND_SB_COMMON=m | ||
2464 | CONFIG_SND_SB16_DSP=m | ||
2465 | CONFIG_SND_ISA=y | ||
2466 | # CONFIG_SND_ADLIB is not set | ||
2467 | # CONFIG_SND_AD1816A is not set | ||
2468 | # CONFIG_SND_AD1848 is not set | ||
2469 | # CONFIG_SND_ALS100 is not set | ||
2470 | # CONFIG_SND_AZT2320 is not set | ||
2471 | # CONFIG_SND_CMI8330 is not set | ||
2472 | # CONFIG_SND_CS4231 is not set | ||
2473 | # CONFIG_SND_CS4232 is not set | ||
2474 | # CONFIG_SND_CS4236 is not set | ||
2475 | # CONFIG_SND_DT019X is not set | ||
2476 | # CONFIG_SND_ES968 is not set | ||
2477 | # CONFIG_SND_ES1688 is not set | ||
2478 | # CONFIG_SND_ES18XX is not set | ||
2479 | # CONFIG_SND_SC6000 is not set | ||
2480 | # CONFIG_SND_GUSCLASSIC is not set | ||
2481 | # CONFIG_SND_GUSEXTREME is not set | ||
2482 | # CONFIG_SND_GUSMAX is not set | ||
2483 | # CONFIG_SND_INTERWAVE is not set | ||
2484 | # CONFIG_SND_INTERWAVE_STB is not set | ||
2485 | # CONFIG_SND_OPL3SA2 is not set | ||
2486 | # CONFIG_SND_OPTI92X_AD1848 is not set | ||
2487 | # CONFIG_SND_OPTI92X_CS4231 is not set | ||
2488 | # CONFIG_SND_OPTI93X is not set | ||
2489 | # CONFIG_SND_MIRO is not set | ||
2490 | # CONFIG_SND_SB8 is not set | ||
2491 | # CONFIG_SND_SB16 is not set | ||
2492 | # CONFIG_SND_SBAWE is not set | ||
2493 | # CONFIG_SND_SGALAXY is not set | ||
2494 | # CONFIG_SND_SSCAPE is not set | ||
2495 | # CONFIG_SND_WAVEFRONT is not set | ||
2496 | CONFIG_SND_PCI=y | ||
2497 | CONFIG_SND_AD1889=m | ||
2498 | CONFIG_SND_ALS300=m | ||
2499 | CONFIG_SND_ALS4000=m | ||
2500 | CONFIG_SND_ALI5451=m | ||
2501 | CONFIG_SND_ATIIXP=m | ||
2502 | CONFIG_SND_ATIIXP_MODEM=m | ||
2503 | CONFIG_SND_AU8810=m | ||
2504 | CONFIG_SND_AU8820=m | ||
2505 | CONFIG_SND_AU8830=m | ||
2506 | CONFIG_SND_AW2=m | ||
2507 | CONFIG_SND_AZT3328=m | ||
2508 | CONFIG_SND_BT87X=m | ||
2509 | # CONFIG_SND_BT87X_OVERCLOCK is not set | ||
2510 | CONFIG_SND_CA0106=m | ||
2511 | CONFIG_SND_CMIPCI=m | ||
2512 | CONFIG_SND_OXYGEN_LIB=m | ||
2513 | CONFIG_SND_OXYGEN=m | ||
2514 | CONFIG_SND_CS4281=m | ||
2515 | CONFIG_SND_CS46XX=m | ||
2516 | CONFIG_SND_CS46XX_NEW_DSP=y | ||
2517 | CONFIG_SND_CS5530=m | ||
2518 | CONFIG_SND_DARLA20=m | ||
2519 | CONFIG_SND_GINA20=m | ||
2520 | CONFIG_SND_LAYLA20=m | ||
2521 | CONFIG_SND_DARLA24=m | ||
2522 | CONFIG_SND_GINA24=m | ||
2523 | CONFIG_SND_LAYLA24=m | ||
2524 | CONFIG_SND_MONA=m | ||
2525 | CONFIG_SND_MIA=m | ||
2526 | CONFIG_SND_ECHO3G=m | ||
2527 | CONFIG_SND_INDIGO=m | ||
2528 | CONFIG_SND_INDIGOIO=m | ||
2529 | CONFIG_SND_INDIGODJ=m | ||
2530 | CONFIG_SND_EMU10K1=m | ||
2531 | CONFIG_SND_EMU10K1X=m | ||
2532 | CONFIG_SND_ENS1370=m | ||
2533 | CONFIG_SND_ENS1371=m | ||
2534 | CONFIG_SND_ES1938=m | ||
2535 | CONFIG_SND_ES1968=m | ||
2536 | CONFIG_SND_FM801=m | ||
2537 | CONFIG_SND_FM801_TEA575X_BOOL=y | ||
2538 | CONFIG_SND_FM801_TEA575X=m | ||
2539 | # CONFIG_SND_HDA_INTEL is not set | ||
2540 | CONFIG_SND_HDSP=m | ||
2541 | CONFIG_SND_HDSPM=m | ||
2542 | CONFIG_SND_HIFIER=m | ||
2543 | CONFIG_SND_ICE1712=m | ||
2544 | CONFIG_SND_ICE1724=m | ||
2545 | # CONFIG_SND_INTEL8X0 is not set | ||
2546 | # CONFIG_SND_INTEL8X0M is not set | ||
2547 | CONFIG_SND_KORG1212=m | ||
2548 | CONFIG_SND_MAESTRO3=m | ||
2549 | CONFIG_SND_MIXART=m | ||
2550 | CONFIG_SND_NM256=m | ||
2551 | CONFIG_SND_PCXHR=m | ||
2552 | CONFIG_SND_RIPTIDE=m | ||
2553 | CONFIG_SND_RME32=m | ||
2554 | CONFIG_SND_RME96=m | ||
2555 | CONFIG_SND_RME9652=m | ||
2556 | CONFIG_SND_SONICVIBES=m | ||
2557 | CONFIG_SND_TRIDENT=m | ||
2558 | CONFIG_SND_VIA82XX=m | ||
2559 | CONFIG_SND_VIA82XX_MODEM=m | ||
2560 | CONFIG_SND_VIRTUOSO=m | ||
2561 | CONFIG_SND_VX222=m | ||
2562 | # CONFIG_SND_YMFPCI is not set | ||
2563 | CONFIG_SND_PPC=y | ||
2564 | CONFIG_SND_POWERMAC=m | ||
2565 | CONFIG_SND_POWERMAC_AUTO_DRC=y | ||
2566 | CONFIG_SND_AOA=m | ||
2567 | CONFIG_SND_AOA_FABRIC_LAYOUT=m | ||
2568 | CONFIG_SND_AOA_ONYX=m | ||
2569 | CONFIG_SND_AOA_TAS=m | ||
2570 | CONFIG_SND_AOA_TOONIE=m | ||
2571 | CONFIG_SND_AOA_SOUNDBUS=m | ||
2572 | CONFIG_SND_AOA_SOUNDBUS_I2S=m | ||
2573 | CONFIG_SND_USB=y | ||
2574 | CONFIG_SND_USB_AUDIO=m | ||
2575 | CONFIG_SND_USB_USX2Y=m | ||
2576 | CONFIG_SND_USB_CAIAQ=m | ||
2577 | CONFIG_SND_USB_CAIAQ_INPUT=y | ||
2578 | # CONFIG_SND_PCMCIA is not set | ||
2579 | # CONFIG_SND_SOC is not set | ||
2580 | # CONFIG_SOUND_PRIME is not set | ||
2581 | CONFIG_AC97_BUS=m | ||
2582 | CONFIG_HID_SUPPORT=y | ||
2583 | CONFIG_HID=y | ||
2584 | CONFIG_HID_DEBUG=y | ||
2585 | CONFIG_HIDRAW=y | ||
2586 | |||
2587 | # | ||
2588 | # USB Input Devices | ||
2589 | # | ||
2590 | CONFIG_USB_HID=y | ||
2591 | CONFIG_USB_HIDINPUT_POWERBOOK=y | ||
2592 | CONFIG_HID_FF=y | ||
2593 | CONFIG_HID_PID=y | ||
2594 | CONFIG_LOGITECH_FF=y | ||
2595 | CONFIG_LOGIRUMBLEPAD2_FF=y | ||
2596 | CONFIG_PANTHERLORD_FF=y | ||
2597 | CONFIG_THRUSTMASTER_FF=y | ||
2598 | CONFIG_ZEROPLUS_FF=y | ||
2599 | CONFIG_USB_HIDDEV=y | ||
2600 | CONFIG_USB_SUPPORT=y | ||
2601 | CONFIG_USB_ARCH_HAS_HCD=y | ||
2602 | CONFIG_USB_ARCH_HAS_OHCI=y | ||
2603 | CONFIG_USB_ARCH_HAS_EHCI=y | ||
2604 | CONFIG_USB=y | ||
2605 | CONFIG_USB_DEBUG=y | ||
2606 | CONFIG_USB_ANNOUNCE_NEW_DEVICES=y | ||
2607 | |||
2608 | # | ||
2609 | # Miscellaneous USB options | ||
2610 | # | ||
2611 | CONFIG_USB_DEVICEFS=y | ||
2612 | # CONFIG_USB_DEVICE_CLASS is not set | ||
2613 | # CONFIG_USB_DYNAMIC_MINORS is not set | ||
2614 | CONFIG_USB_SUSPEND=y | ||
2615 | # CONFIG_USB_OTG is not set | ||
2616 | |||
2617 | # | ||
2618 | # USB Host Controller Drivers | ||
2619 | # | ||
2620 | # CONFIG_USB_C67X00_HCD is not set | ||
2621 | CONFIG_USB_EHCI_HCD=m | ||
2622 | CONFIG_USB_EHCI_ROOT_HUB_TT=y | ||
2623 | CONFIG_USB_EHCI_TT_NEWSCHED=y | ||
2624 | CONFIG_USB_EHCI_FSL=y | ||
2625 | CONFIG_USB_EHCI_HCD_PPC_OF=y | ||
2626 | # CONFIG_USB_ISP116X_HCD is not set | ||
2627 | # CONFIG_USB_ISP1760_HCD is not set | ||
2628 | CONFIG_USB_OHCI_HCD=m | ||
2629 | CONFIG_USB_OHCI_HCD_PPC_SOC=y | ||
2630 | CONFIG_USB_OHCI_HCD_PPC_OF=y | ||
2631 | CONFIG_USB_OHCI_HCD_PPC_OF_BE=y | ||
2632 | CONFIG_USB_OHCI_HCD_PPC_OF_LE=y | ||
2633 | CONFIG_USB_OHCI_HCD_PCI=y | ||
2634 | # CONFIG_USB_OHCI_HCD_SSB is not set | ||
2635 | CONFIG_USB_OHCI_BIG_ENDIAN_DESC=y | ||
2636 | CONFIG_USB_OHCI_BIG_ENDIAN_MMIO=y | ||
2637 | CONFIG_USB_OHCI_LITTLE_ENDIAN=y | ||
2638 | CONFIG_USB_UHCI_HCD=m | ||
2639 | CONFIG_USB_U132_HCD=m | ||
2640 | CONFIG_USB_SL811_HCD=m | ||
2641 | # CONFIG_USB_SL811_CS is not set | ||
2642 | # CONFIG_USB_R8A66597_HCD is not set | ||
2643 | |||
2644 | # | ||
2645 | # USB Device Class drivers | ||
2646 | # | ||
2647 | CONFIG_USB_ACM=m | ||
2648 | CONFIG_USB_PRINTER=m | ||
2649 | CONFIG_USB_WDM=m | ||
2650 | |||
2651 | # | ||
2652 | # NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' | ||
2653 | # | ||
2654 | |||
2655 | # | ||
2656 | # may also be needed; see USB_STORAGE Help for more information | ||
2657 | # | ||
2658 | CONFIG_USB_STORAGE=m | ||
2659 | # CONFIG_USB_STORAGE_DEBUG is not set | ||
2660 | CONFIG_USB_STORAGE_DATAFAB=y | ||
2661 | CONFIG_USB_STORAGE_FREECOM=y | ||
2662 | # CONFIG_USB_STORAGE_ISD200 is not set | ||
2663 | CONFIG_USB_STORAGE_DPCM=y | ||
2664 | CONFIG_USB_STORAGE_USBAT=y | ||
2665 | CONFIG_USB_STORAGE_SDDR09=y | ||
2666 | CONFIG_USB_STORAGE_SDDR55=y | ||
2667 | CONFIG_USB_STORAGE_JUMPSHOT=y | ||
2668 | CONFIG_USB_STORAGE_ALAUDA=y | ||
2669 | CONFIG_USB_STORAGE_ONETOUCH=y | ||
2670 | CONFIG_USB_STORAGE_KARMA=y | ||
2671 | CONFIG_USB_STORAGE_CYPRESS_ATACB=y | ||
2672 | # CONFIG_USB_LIBUSUAL is not set | ||
2673 | |||
2674 | # | ||
2675 | # USB Imaging devices | ||
2676 | # | ||
2677 | CONFIG_USB_MDC800=m | ||
2678 | CONFIG_USB_MICROTEK=m | ||
2679 | CONFIG_USB_MON=y | ||
2680 | |||
2681 | # | ||
2682 | # USB port drivers | ||
2683 | # | ||
2684 | CONFIG_USB_USS720=m | ||
2685 | CONFIG_USB_SERIAL=m | ||
2686 | CONFIG_USB_EZUSB=y | ||
2687 | CONFIG_USB_SERIAL_GENERIC=y | ||
2688 | CONFIG_USB_SERIAL_AIRCABLE=m | ||
2689 | CONFIG_USB_SERIAL_AIRPRIME=m | ||
2690 | CONFIG_USB_SERIAL_ARK3116=m | ||
2691 | CONFIG_USB_SERIAL_BELKIN=m | ||
2692 | CONFIG_USB_SERIAL_CH341=m | ||
2693 | CONFIG_USB_SERIAL_WHITEHEAT=m | ||
2694 | CONFIG_USB_SERIAL_DIGI_ACCELEPORT=m | ||
2695 | CONFIG_USB_SERIAL_CP2101=m | ||
2696 | CONFIG_USB_SERIAL_CYPRESS_M8=m | ||
2697 | CONFIG_USB_SERIAL_EMPEG=m | ||
2698 | CONFIG_USB_SERIAL_FTDI_SIO=m | ||
2699 | CONFIG_USB_SERIAL_FUNSOFT=m | ||
2700 | CONFIG_USB_SERIAL_VISOR=m | ||
2701 | CONFIG_USB_SERIAL_IPAQ=m | ||
2702 | CONFIG_USB_SERIAL_IR=m | ||
2703 | CONFIG_USB_SERIAL_EDGEPORT=m | ||
2704 | CONFIG_USB_SERIAL_EDGEPORT_TI=m | ||
2705 | # CONFIG_USB_SERIAL_GARMIN is not set | ||
2706 | CONFIG_USB_SERIAL_IPW=m | ||
2707 | CONFIG_USB_SERIAL_IUU=m | ||
2708 | CONFIG_USB_SERIAL_KEYSPAN_PDA=m | ||
2709 | CONFIG_USB_SERIAL_KEYSPAN=m | ||
2710 | CONFIG_USB_SERIAL_KLSI=m | ||
2711 | CONFIG_USB_SERIAL_KOBIL_SCT=m | ||
2712 | CONFIG_USB_SERIAL_MCT_U232=m | ||
2713 | CONFIG_USB_SERIAL_MOS7720=m | ||
2714 | CONFIG_USB_SERIAL_MOS7840=m | ||
2715 | CONFIG_USB_SERIAL_MOTOROLA=m | ||
2716 | CONFIG_USB_SERIAL_NAVMAN=m | ||
2717 | CONFIG_USB_SERIAL_PL2303=m | ||
2718 | CONFIG_USB_SERIAL_OTI6858=m | ||
2719 | CONFIG_USB_SERIAL_SPCP8X5=m | ||
2720 | CONFIG_USB_SERIAL_HP4X=m | ||
2721 | CONFIG_USB_SERIAL_SAFE=m | ||
2722 | CONFIG_USB_SERIAL_SAFE_PADDED=y | ||
2723 | CONFIG_USB_SERIAL_SIERRAWIRELESS=m | ||
2724 | CONFIG_USB_SERIAL_TI=m | ||
2725 | CONFIG_USB_SERIAL_CYBERJACK=m | ||
2726 | CONFIG_USB_SERIAL_XIRCOM=m | ||
2727 | CONFIG_USB_SERIAL_OPTION=m | ||
2728 | CONFIG_USB_SERIAL_OMNINET=m | ||
2729 | CONFIG_USB_SERIAL_DEBUG=m | ||
2730 | |||
2731 | # | ||
2732 | # USB Miscellaneous drivers | ||
2733 | # | ||
2734 | CONFIG_USB_EMI62=m | ||
2735 | CONFIG_USB_EMI26=m | ||
2736 | CONFIG_USB_ADUTUX=m | ||
2737 | CONFIG_USB_AUERSWALD=m | ||
2738 | # CONFIG_USB_RIO500 is not set | ||
2739 | CONFIG_USB_LEGOTOWER=m | ||
2740 | CONFIG_USB_LCD=m | ||
2741 | CONFIG_USB_BERRY_CHARGE=m | ||
2742 | CONFIG_USB_LED=m | ||
2743 | # CONFIG_USB_CYPRESS_CY7C63 is not set | ||
2744 | # CONFIG_USB_CYTHERM is not set | ||
2745 | CONFIG_USB_PHIDGET=m | ||
2746 | CONFIG_USB_PHIDGETKIT=m | ||
2747 | CONFIG_USB_PHIDGETMOTORCONTROL=m | ||
2748 | CONFIG_USB_PHIDGETSERVO=m | ||
2749 | CONFIG_USB_IDMOUSE=m | ||
2750 | CONFIG_USB_FTDI_ELAN=m | ||
2751 | CONFIG_USB_APPLEDISPLAY=m | ||
2752 | CONFIG_USB_SISUSBVGA=m | ||
2753 | CONFIG_USB_SISUSBVGA_CON=y | ||
2754 | CONFIG_USB_LD=m | ||
2755 | CONFIG_USB_TRANCEVIBRATOR=m | ||
2756 | CONFIG_USB_IOWARRIOR=m | ||
2757 | # CONFIG_USB_TEST is not set | ||
2758 | CONFIG_USB_ISIGHTFW=m | ||
2759 | CONFIG_USB_ATM=m | ||
2760 | CONFIG_USB_SPEEDTOUCH=m | ||
2761 | CONFIG_USB_CXACRU=m | ||
2762 | CONFIG_USB_UEAGLEATM=m | ||
2763 | CONFIG_USB_XUSBATM=m | ||
2764 | # CONFIG_USB_GADGET is not set | ||
2765 | # CONFIG_MMC is not set | ||
2766 | # CONFIG_MEMSTICK is not set | ||
2767 | CONFIG_NEW_LEDS=y | ||
2768 | CONFIG_LEDS_CLASS=y | ||
2769 | |||
2770 | # | ||
2771 | # LED drivers | ||
2772 | # | ||
2773 | # CONFIG_LEDS_GPIO is not set | ||
2774 | |||
2775 | # | ||
2776 | # LED Triggers | ||
2777 | # | ||
2778 | CONFIG_LEDS_TRIGGERS=y | ||
2779 | CONFIG_LEDS_TRIGGER_TIMER=m | ||
2780 | CONFIG_LEDS_TRIGGER_IDE_DISK=y | ||
2781 | CONFIG_LEDS_TRIGGER_HEARTBEAT=m | ||
2782 | CONFIG_LEDS_TRIGGER_DEFAULT_ON=m | ||
2783 | CONFIG_ACCESSIBILITY=y | ||
2784 | CONFIG_A11Y_BRAILLE_CONSOLE=y | ||
2785 | # CONFIG_INFINIBAND is not set | ||
2786 | CONFIG_EDAC=y | ||
2787 | |||
2788 | # | ||
2789 | # Reporting subsystems | ||
2790 | # | ||
2791 | # CONFIG_EDAC_DEBUG is not set | ||
2792 | CONFIG_EDAC_MM_EDAC=m | ||
2793 | CONFIG_RTC_LIB=y | ||
2794 | CONFIG_RTC_CLASS=y | ||
2795 | # CONFIG_RTC_HCTOSYS is not set | ||
2796 | # CONFIG_RTC_DEBUG is not set | ||
2797 | |||
2798 | # | ||
2799 | # RTC interfaces | ||
2800 | # | ||
2801 | CONFIG_RTC_INTF_SYSFS=y | ||
2802 | CONFIG_RTC_INTF_PROC=y | ||
2803 | CONFIG_RTC_INTF_DEV=y | ||
2804 | # CONFIG_RTC_INTF_DEV_UIE_EMUL is not set | ||
2805 | # CONFIG_RTC_DRV_TEST is not set | ||
2806 | |||
2807 | # | ||
2808 | # I2C RTC drivers | ||
2809 | # | ||
2810 | CONFIG_RTC_DRV_DS1307=m | ||
2811 | CONFIG_RTC_DRV_DS1374=m | ||
2812 | CONFIG_RTC_DRV_DS1672=m | ||
2813 | CONFIG_RTC_DRV_MAX6900=m | ||
2814 | CONFIG_RTC_DRV_RS5C372=m | ||
2815 | CONFIG_RTC_DRV_ISL1208=m | ||
2816 | CONFIG_RTC_DRV_X1205=m | ||
2817 | CONFIG_RTC_DRV_PCF8563=m | ||
2818 | CONFIG_RTC_DRV_PCF8583=m | ||
2819 | CONFIG_RTC_DRV_M41T80=m | ||
2820 | CONFIG_RTC_DRV_M41T80_WDT=y | ||
2821 | # CONFIG_RTC_DRV_S35390A is not set | ||
2822 | CONFIG_RTC_DRV_FM3130=m | ||
2823 | |||
2824 | # | ||
2825 | # SPI RTC drivers | ||
2826 | # | ||
2827 | |||
2828 | # | ||
2829 | # Platform RTC drivers | ||
2830 | # | ||
2831 | CONFIG_RTC_DRV_CMOS=y | ||
2832 | CONFIG_RTC_DRV_DS1511=m | ||
2833 | CONFIG_RTC_DRV_DS1553=m | ||
2834 | CONFIG_RTC_DRV_DS1742=m | ||
2835 | CONFIG_RTC_DRV_STK17TA8=m | ||
2836 | # CONFIG_RTC_DRV_M48T86 is not set | ||
2837 | CONFIG_RTC_DRV_M48T59=m | ||
2838 | CONFIG_RTC_DRV_V3020=m | ||
2839 | |||
2840 | # | ||
2841 | # on-CPU RTC drivers | ||
2842 | # | ||
2843 | CONFIG_RTC_DRV_PPC=y | ||
2844 | CONFIG_DMADEVICES=y | ||
2845 | |||
2846 | # | ||
2847 | # DMA Devices | ||
2848 | # | ||
2849 | # CONFIG_FSL_DMA is not set | ||
2850 | CONFIG_AUXDISPLAY=y | ||
2851 | CONFIG_KS0108=m | ||
2852 | CONFIG_KS0108_PORT=0x378 | ||
2853 | CONFIG_KS0108_DELAY=2 | ||
2854 | CONFIG_UIO=m | ||
2855 | CONFIG_UIO_CIF=m | ||
2856 | CONFIG_UIO_SMX=m | ||
2857 | |||
2858 | # | ||
2859 | # File systems | ||
2860 | # | ||
2861 | CONFIG_EXT2_FS=m | ||
2862 | CONFIG_EXT2_FS_XATTR=y | ||
2863 | CONFIG_EXT2_FS_POSIX_ACL=y | ||
2864 | CONFIG_EXT2_FS_SECURITY=y | ||
2865 | CONFIG_EXT2_FS_XIP=y | ||
2866 | CONFIG_FS_XIP=y | ||
2867 | CONFIG_EXT3_FS=m | ||
2868 | CONFIG_EXT3_FS_XATTR=y | ||
2869 | CONFIG_EXT3_FS_POSIX_ACL=y | ||
2870 | CONFIG_EXT3_FS_SECURITY=y | ||
2871 | CONFIG_EXT4DEV_FS=m | ||
2872 | CONFIG_EXT4DEV_FS_XATTR=y | ||
2873 | CONFIG_EXT4DEV_FS_POSIX_ACL=y | ||
2874 | CONFIG_EXT4DEV_FS_SECURITY=y | ||
2875 | CONFIG_JBD=m | ||
2876 | # CONFIG_JBD_DEBUG is not set | ||
2877 | CONFIG_JBD2=m | ||
2878 | CONFIG_JBD2_DEBUG=y | ||
2879 | CONFIG_FS_MBCACHE=m | ||
2880 | CONFIG_REISERFS_FS=m | ||
2881 | # CONFIG_REISERFS_CHECK is not set | ||
2882 | CONFIG_REISERFS_PROC_INFO=y | ||
2883 | CONFIG_REISERFS_FS_XATTR=y | ||
2884 | CONFIG_REISERFS_FS_POSIX_ACL=y | ||
2885 | CONFIG_REISERFS_FS_SECURITY=y | ||
2886 | CONFIG_JFS_FS=m | ||
2887 | CONFIG_JFS_POSIX_ACL=y | ||
2888 | CONFIG_JFS_SECURITY=y | ||
2889 | # CONFIG_JFS_DEBUG is not set | ||
2890 | # CONFIG_JFS_STATISTICS is not set | ||
2891 | CONFIG_FS_POSIX_ACL=y | ||
2892 | CONFIG_XFS_FS=m | ||
2893 | CONFIG_XFS_QUOTA=y | ||
2894 | CONFIG_XFS_POSIX_ACL=y | ||
2895 | # CONFIG_XFS_RT is not set | ||
2896 | # CONFIG_XFS_DEBUG is not set | ||
2897 | CONFIG_GFS2_FS=m | ||
2898 | CONFIG_GFS2_FS_LOCKING_DLM=m | ||
2899 | CONFIG_OCFS2_FS=m | ||
2900 | CONFIG_OCFS2_FS_O2CB=m | ||
2901 | CONFIG_OCFS2_FS_USERSPACE_CLUSTER=m | ||
2902 | # CONFIG_OCFS2_DEBUG_MASKLOG is not set | ||
2903 | # CONFIG_OCFS2_DEBUG_FS is not set | ||
2904 | CONFIG_DNOTIFY=y | ||
2905 | CONFIG_INOTIFY=y | ||
2906 | CONFIG_INOTIFY_USER=y | ||
2907 | CONFIG_QUOTA=y | ||
2908 | CONFIG_QUOTA_NETLINK_INTERFACE=y | ||
2909 | # CONFIG_PRINT_QUOTA_WARNING is not set | ||
2910 | # CONFIG_QFMT_V1 is not set | ||
2911 | CONFIG_QFMT_V2=y | ||
2912 | CONFIG_QUOTACTL=y | ||
2913 | CONFIG_AUTOFS_FS=m | ||
2914 | CONFIG_AUTOFS4_FS=m | ||
2915 | CONFIG_FUSE_FS=m | ||
2916 | CONFIG_GENERIC_ACL=y | ||
2917 | |||
2918 | # | ||
2919 | # CD-ROM/DVD Filesystems | ||
2920 | # | ||
2921 | CONFIG_ISO9660_FS=y | ||
2922 | CONFIG_JOLIET=y | ||
2923 | CONFIG_ZISOFS=y | ||
2924 | CONFIG_UDF_FS=m | ||
2925 | CONFIG_UDF_NLS=y | ||
2926 | |||
2927 | # | ||
2928 | # DOS/FAT/NT Filesystems | ||
2929 | # | ||
2930 | CONFIG_FAT_FS=m | ||
2931 | CONFIG_MSDOS_FS=m | ||
2932 | CONFIG_VFAT_FS=m | ||
2933 | CONFIG_FAT_DEFAULT_CODEPAGE=437 | ||
2934 | CONFIG_FAT_DEFAULT_IOCHARSET="ascii" | ||
2935 | # CONFIG_NTFS_FS is not set | ||
2936 | |||
2937 | # | ||
2938 | # Pseudo filesystems | ||
2939 | # | ||
2940 | CONFIG_PROC_FS=y | ||
2941 | CONFIG_PROC_KCORE=y | ||
2942 | CONFIG_PROC_SYSCTL=y | ||
2943 | CONFIG_SYSFS=y | ||
2944 | CONFIG_TMPFS=y | ||
2945 | CONFIG_TMPFS_POSIX_ACL=y | ||
2946 | # CONFIG_HUGETLB_PAGE is not set | ||
2947 | CONFIG_CONFIGFS_FS=m | ||
2948 | |||
2949 | # | ||
2950 | # Miscellaneous filesystems | ||
2951 | # | ||
2952 | # CONFIG_ADFS_FS is not set | ||
2953 | CONFIG_AFFS_FS=m | ||
2954 | CONFIG_ECRYPT_FS=m | ||
2955 | CONFIG_HFS_FS=m | ||
2956 | CONFIG_HFSPLUS_FS=m | ||
2957 | CONFIG_BEFS_FS=m | ||
2958 | # CONFIG_BEFS_DEBUG is not set | ||
2959 | CONFIG_BFS_FS=m | ||
2960 | CONFIG_EFS_FS=m | ||
2961 | CONFIG_CRAMFS=m | ||
2962 | CONFIG_SQUASHFS=m | ||
2963 | # CONFIG_SQUASHFS_EMBEDDED is not set | ||
2964 | CONFIG_SQUASHFS_FRAGMENT_CACHE_SIZE=3 | ||
2965 | CONFIG_VXFS_FS=m | ||
2966 | CONFIG_MINIX_FS=m | ||
2967 | # CONFIG_HPFS_FS is not set | ||
2968 | CONFIG_QNX4FS_FS=m | ||
2969 | CONFIG_ROMFS_FS=m | ||
2970 | CONFIG_SYSV_FS=m | ||
2971 | CONFIG_UFS_FS=m | ||
2972 | # CONFIG_UFS_FS_WRITE is not set | ||
2973 | # CONFIG_UFS_DEBUG is not set | ||
2974 | CONFIG_NETWORK_FILESYSTEMS=y | ||
2975 | CONFIG_NFS_FS=m | ||
2976 | CONFIG_NFS_V3=y | ||
2977 | CONFIG_NFS_V3_ACL=y | ||
2978 | CONFIG_NFS_V4=y | ||
2979 | CONFIG_NFSD=m | ||
2980 | CONFIG_NFSD_V2_ACL=y | ||
2981 | CONFIG_NFSD_V3=y | ||
2982 | CONFIG_NFSD_V3_ACL=y | ||
2983 | CONFIG_NFSD_V4=y | ||
2984 | CONFIG_LOCKD=m | ||
2985 | CONFIG_LOCKD_V4=y | ||
2986 | CONFIG_EXPORTFS=m | ||
2987 | CONFIG_NFS_ACL_SUPPORT=m | ||
2988 | CONFIG_NFS_COMMON=y | ||
2989 | CONFIG_SUNRPC=m | ||
2990 | CONFIG_SUNRPC_GSS=m | ||
2991 | CONFIG_SUNRPC_BIND34=y | ||
2992 | CONFIG_RPCSEC_GSS_KRB5=m | ||
2993 | CONFIG_RPCSEC_GSS_SPKM3=m | ||
2994 | # CONFIG_SMB_FS is not set | ||
2995 | CONFIG_CIFS=m | ||
2996 | # CONFIG_CIFS_STATS is not set | ||
2997 | CONFIG_CIFS_WEAK_PW_HASH=y | ||
2998 | CONFIG_CIFS_XATTR=y | ||
2999 | CONFIG_CIFS_POSIX=y | ||
3000 | # CONFIG_CIFS_DEBUG2 is not set | ||
3001 | CONFIG_CIFS_EXPERIMENTAL=y | ||
3002 | CONFIG_CIFS_UPCALL=y | ||
3003 | CONFIG_CIFS_DFS_UPCALL=y | ||
3004 | CONFIG_NCP_FS=m | ||
3005 | CONFIG_NCPFS_PACKET_SIGNING=y | ||
3006 | CONFIG_NCPFS_IOCTL_LOCKING=y | ||
3007 | CONFIG_NCPFS_STRONG=y | ||
3008 | CONFIG_NCPFS_NFS_NS=y | ||
3009 | CONFIG_NCPFS_OS2_NS=y | ||
3010 | CONFIG_NCPFS_SMALLDOS=y | ||
3011 | CONFIG_NCPFS_NLS=y | ||
3012 | CONFIG_NCPFS_EXTRAS=y | ||
3013 | CONFIG_CODA_FS=m | ||
3014 | # CONFIG_CODA_FS_OLD_API is not set | ||
3015 | # CONFIG_AFS_FS is not set | ||
3016 | CONFIG_9P_FS=m | ||
3017 | |||
3018 | # | ||
3019 | # Partition Types | ||
3020 | # | ||
3021 | CONFIG_PARTITION_ADVANCED=y | ||
3022 | # CONFIG_ACORN_PARTITION is not set | ||
3023 | CONFIG_OSF_PARTITION=y | ||
3024 | CONFIG_AMIGA_PARTITION=y | ||
3025 | # CONFIG_ATARI_PARTITION is not set | ||
3026 | CONFIG_MAC_PARTITION=y | ||
3027 | CONFIG_MSDOS_PARTITION=y | ||
3028 | CONFIG_BSD_DISKLABEL=y | ||
3029 | CONFIG_MINIX_SUBPARTITION=y | ||
3030 | CONFIG_SOLARIS_X86_PARTITION=y | ||
3031 | CONFIG_UNIXWARE_DISKLABEL=y | ||
3032 | # CONFIG_LDM_PARTITION is not set | ||
3033 | CONFIG_SGI_PARTITION=y | ||
3034 | # CONFIG_ULTRIX_PARTITION is not set | ||
3035 | CONFIG_SUN_PARTITION=y | ||
3036 | CONFIG_KARMA_PARTITION=y | ||
3037 | CONFIG_EFI_PARTITION=y | ||
3038 | # CONFIG_SYSV68_PARTITION is not set | ||
3039 | CONFIG_NLS=y | ||
3040 | CONFIG_NLS_DEFAULT="utf8" | ||
3041 | CONFIG_NLS_CODEPAGE_437=y | ||
3042 | CONFIG_NLS_CODEPAGE_737=m | ||
3043 | CONFIG_NLS_CODEPAGE_775=m | ||
3044 | CONFIG_NLS_CODEPAGE_850=m | ||
3045 | CONFIG_NLS_CODEPAGE_852=m | ||
3046 | CONFIG_NLS_CODEPAGE_855=m | ||
3047 | CONFIG_NLS_CODEPAGE_857=m | ||
3048 | CONFIG_NLS_CODEPAGE_860=m | ||
3049 | CONFIG_NLS_CODEPAGE_861=m | ||
3050 | CONFIG_NLS_CODEPAGE_862=m | ||
3051 | CONFIG_NLS_CODEPAGE_863=m | ||
3052 | CONFIG_NLS_CODEPAGE_864=m | ||
3053 | CONFIG_NLS_CODEPAGE_865=m | ||
3054 | CONFIG_NLS_CODEPAGE_866=m | ||
3055 | CONFIG_NLS_CODEPAGE_869=m | ||
3056 | CONFIG_NLS_CODEPAGE_936=m | ||
3057 | CONFIG_NLS_CODEPAGE_950=m | ||
3058 | CONFIG_NLS_CODEPAGE_932=m | ||
3059 | CONFIG_NLS_CODEPAGE_949=m | ||
3060 | CONFIG_NLS_CODEPAGE_874=m | ||
3061 | CONFIG_NLS_ISO8859_8=m | ||
3062 | CONFIG_NLS_CODEPAGE_1250=m | ||
3063 | CONFIG_NLS_CODEPAGE_1251=m | ||
3064 | CONFIG_NLS_ASCII=y | ||
3065 | CONFIG_NLS_ISO8859_1=m | ||
3066 | CONFIG_NLS_ISO8859_2=m | ||
3067 | CONFIG_NLS_ISO8859_3=m | ||
3068 | CONFIG_NLS_ISO8859_4=m | ||
3069 | CONFIG_NLS_ISO8859_5=m | ||
3070 | CONFIG_NLS_ISO8859_6=m | ||
3071 | CONFIG_NLS_ISO8859_7=m | ||
3072 | CONFIG_NLS_ISO8859_9=m | ||
3073 | CONFIG_NLS_ISO8859_13=m | ||
3074 | CONFIG_NLS_ISO8859_14=m | ||
3075 | CONFIG_NLS_ISO8859_15=m | ||
3076 | CONFIG_NLS_KOI8_R=m | ||
3077 | CONFIG_NLS_KOI8_U=m | ||
3078 | CONFIG_NLS_UTF8=m | ||
3079 | CONFIG_DLM=m | ||
3080 | CONFIG_DLM_DEBUG=y | ||
3081 | CONFIG_QE_GPIO=y | ||
3082 | |||
3083 | # | ||
3084 | # Library routines | ||
3085 | # | ||
3086 | CONFIG_BITREVERSE=y | ||
3087 | # CONFIG_GENERIC_FIND_FIRST_BIT is not set | ||
3088 | CONFIG_CRC_CCITT=m | ||
3089 | CONFIG_CRC16=m | ||
3090 | CONFIG_CRC_T10DIF=m | ||
3091 | CONFIG_CRC_ITU_T=m | ||
3092 | CONFIG_CRC32=y | ||
3093 | # CONFIG_CRC7 is not set | ||
3094 | CONFIG_LIBCRC32C=m | ||
3095 | CONFIG_ZLIB_INFLATE=y | ||
3096 | CONFIG_ZLIB_DEFLATE=m | ||
3097 | CONFIG_LZO_COMPRESS=m | ||
3098 | CONFIG_LZO_DECOMPRESS=m | ||
3099 | CONFIG_TEXTSEARCH=y | ||
3100 | CONFIG_TEXTSEARCH_KMP=m | ||
3101 | CONFIG_TEXTSEARCH_BM=m | ||
3102 | CONFIG_TEXTSEARCH_FSM=m | ||
3103 | CONFIG_PLIST=y | ||
3104 | CONFIG_HAS_IOMEM=y | ||
3105 | CONFIG_HAS_IOPORT=y | ||
3106 | CONFIG_HAS_DMA=y | ||
3107 | CONFIG_HAVE_LMB=y | ||
3108 | |||
3109 | # | ||
3110 | # Kernel hacking | ||
3111 | # | ||
3112 | # CONFIG_PRINTK_TIME is not set | ||
3113 | # CONFIG_ENABLE_WARN_DEPRECATED is not set | ||
3114 | CONFIG_ENABLE_MUST_CHECK=y | ||
3115 | CONFIG_FRAME_WARN=1024 | ||
3116 | CONFIG_MAGIC_SYSRQ=y | ||
3117 | CONFIG_UNUSED_SYMBOLS=y | ||
3118 | CONFIG_DEBUG_FS=y | ||
3119 | CONFIG_HEADERS_CHECK=y | ||
3120 | CONFIG_DEBUG_KERNEL=y | ||
3121 | CONFIG_DEBUG_SHIRQ=y | ||
3122 | CONFIG_DETECT_SOFTLOCKUP=y | ||
3123 | CONFIG_SCHED_DEBUG=y | ||
3124 | CONFIG_SCHEDSTATS=y | ||
3125 | CONFIG_TIMER_STATS=y | ||
3126 | CONFIG_DEBUG_OBJECTS=y | ||
3127 | # CONFIG_DEBUG_OBJECTS_SELFTEST is not set | ||
3128 | CONFIG_DEBUG_OBJECTS_FREE=y | ||
3129 | CONFIG_DEBUG_OBJECTS_TIMERS=y | ||
3130 | CONFIG_SLUB_DEBUG_ON=y | ||
3131 | # CONFIG_SLUB_STATS is not set | ||
3132 | CONFIG_DEBUG_RT_MUTEXES=y | ||
3133 | CONFIG_DEBUG_PI_LIST=y | ||
3134 | # CONFIG_RT_MUTEX_TESTER is not set | ||
3135 | CONFIG_DEBUG_SPINLOCK=y | ||
3136 | CONFIG_DEBUG_MUTEXES=y | ||
3137 | CONFIG_DEBUG_SPINLOCK_SLEEP=y | ||
3138 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | ||
3139 | CONFIG_STACKTRACE=y | ||
3140 | # CONFIG_DEBUG_KOBJECT is not set | ||
3141 | CONFIG_DEBUG_HIGHMEM=y | ||
3142 | CONFIG_DEBUG_BUGVERBOSE=y | ||
3143 | CONFIG_DEBUG_INFO=y | ||
3144 | CONFIG_DEBUG_VM=y | ||
3145 | CONFIG_DEBUG_WRITECOUNT=y | ||
3146 | CONFIG_DEBUG_LIST=y | ||
3147 | CONFIG_DEBUG_SG=y | ||
3148 | CONFIG_FRAME_POINTER=y | ||
3149 | CONFIG_BOOT_PRINTK_DELAY=y | ||
3150 | # CONFIG_RCU_TORTURE_TEST is not set | ||
3151 | # CONFIG_KPROBES_SANITY_TEST is not set | ||
3152 | # CONFIG_BACKTRACE_SELF_TEST is not set | ||
3153 | # CONFIG_LKDTM is not set | ||
3154 | CONFIG_FAULT_INJECTION=y | ||
3155 | CONFIG_FAILSLAB=y | ||
3156 | CONFIG_FAIL_PAGE_ALLOC=y | ||
3157 | CONFIG_FAIL_MAKE_REQUEST=y | ||
3158 | CONFIG_FAULT_INJECTION_DEBUG_FS=y | ||
3159 | CONFIG_FAULT_INJECTION_STACKTRACE_FILTER=y | ||
3160 | CONFIG_LATENCYTOP=y | ||
3161 | CONFIG_HAVE_FTRACE=y | ||
3162 | CONFIG_HAVE_DYNAMIC_FTRACE=y | ||
3163 | CONFIG_TRACER_MAX_TRACE=y | ||
3164 | CONFIG_TRACING=y | ||
3165 | CONFIG_FTRACE=y | ||
3166 | CONFIG_SCHED_TRACER=y | ||
3167 | CONFIG_CONTEXT_SWITCH_TRACER=y | ||
3168 | CONFIG_DYNAMIC_FTRACE=y | ||
3169 | # CONFIG_FTRACE_STARTUP_TEST is not set | ||
3170 | # CONFIG_FIREWIRE_OHCI_REMOTE_DMA is not set | ||
3171 | # CONFIG_SAMPLES is not set | ||
3172 | CONFIG_DEBUG_STACKOVERFLOW=y | ||
3173 | CONFIG_DEBUG_STACK_USAGE=y | ||
3174 | CONFIG_DEBUGGER=y | ||
3175 | # CONFIG_CODE_PATCHING_SELFTEST is not set | ||
3176 | # CONFIG_FTR_FIXUP_SELFTEST is not set | ||
3177 | # CONFIG_KGDB_CONSOLE is not set | ||
3178 | CONFIG_XMON=y | ||
3179 | # CONFIG_XMON_DEFAULT is not set | ||
3180 | CONFIG_XMON_DISASSEMBLY=y | ||
3181 | CONFIG_IRQSTACKS=y | ||
3182 | # CONFIG_VIRQ_DEBUG is not set | ||
3183 | # CONFIG_BDI_SWITCH is not set | ||
3184 | CONFIG_BOOTX_TEXT=y | ||
3185 | # CONFIG_PPC_EARLY_DEBUG is not set | ||
3186 | |||
3187 | # | ||
3188 | # Security options | ||
3189 | # | ||
3190 | CONFIG_KEYS=y | ||
3191 | CONFIG_KEYS_DEBUG_PROC_KEYS=y | ||
3192 | CONFIG_SECURITY=y | ||
3193 | CONFIG_SECURITY_NETWORK=y | ||
3194 | CONFIG_SECURITY_NETWORK_XFRM=y | ||
3195 | CONFIG_SECURITY_FILE_CAPABILITIES=y | ||
3196 | # CONFIG_SECURITY_ROOTPLUG is not set | ||
3197 | CONFIG_SECURITY_DEFAULT_MMAP_MIN_ADDR=65536 | ||
3198 | CONFIG_SECURITY_SELINUX=y | ||
3199 | CONFIG_SECURITY_SELINUX_BOOTPARAM=y | ||
3200 | CONFIG_SECURITY_SELINUX_BOOTPARAM_VALUE=1 | ||
3201 | CONFIG_SECURITY_SELINUX_DISABLE=y | ||
3202 | CONFIG_SECURITY_SELINUX_DEVELOP=y | ||
3203 | CONFIG_SECURITY_SELINUX_AVC_STATS=y | ||
3204 | CONFIG_SECURITY_SELINUX_CHECKREQPROT_VALUE=1 | ||
3205 | CONFIG_SECURITY_SELINUX_ENABLE_SECMARK_DEFAULT=y | ||
3206 | # CONFIG_SECURITY_SELINUX_POLICYDB_VERSION_MAX is not set | ||
3207 | # CONFIG_SECURITY_SMACK is not set | ||
3208 | CONFIG_XOR_BLOCKS=m | ||
3209 | CONFIG_ASYNC_CORE=m | ||
3210 | CONFIG_ASYNC_MEMCPY=m | ||
3211 | CONFIG_ASYNC_XOR=m | ||
3212 | CONFIG_CRYPTO=y | ||
3213 | |||
3214 | # | ||
3215 | # Crypto core or helper | ||
3216 | # | ||
3217 | CONFIG_CRYPTO_ALGAPI=y | ||
3218 | CONFIG_CRYPTO_AEAD=m | ||
3219 | CONFIG_CRYPTO_BLKCIPHER=m | ||
3220 | CONFIG_CRYPTO_HASH=y | ||
3221 | CONFIG_CRYPTO_MANAGER=y | ||
3222 | CONFIG_CRYPTO_GF128MUL=m | ||
3223 | CONFIG_CRYPTO_NULL=m | ||
3224 | # CONFIG_CRYPTO_CRYPTD is not set | ||
3225 | CONFIG_CRYPTO_AUTHENC=m | ||
3226 | CONFIG_CRYPTO_TEST=m | ||
3227 | |||
3228 | # | ||
3229 | # Authenticated Encryption with Associated Data | ||
3230 | # | ||
3231 | CONFIG_CRYPTO_CCM=m | ||
3232 | CONFIG_CRYPTO_GCM=m | ||
3233 | CONFIG_CRYPTO_SEQIV=m | ||
3234 | |||
3235 | # | ||
3236 | # Block modes | ||
3237 | # | ||
3238 | CONFIG_CRYPTO_CBC=m | ||
3239 | CONFIG_CRYPTO_CTR=m | ||
3240 | CONFIG_CRYPTO_CTS=m | ||
3241 | CONFIG_CRYPTO_ECB=m | ||
3242 | CONFIG_CRYPTO_LRW=m | ||
3243 | CONFIG_CRYPTO_PCBC=m | ||
3244 | CONFIG_CRYPTO_XTS=m | ||
3245 | |||
3246 | # | ||
3247 | # Hash modes | ||
3248 | # | ||
3249 | CONFIG_CRYPTO_HMAC=y | ||
3250 | CONFIG_CRYPTO_XCBC=m | ||
3251 | |||
3252 | # | ||
3253 | # Digest | ||
3254 | # | ||
3255 | CONFIG_CRYPTO_CRC32C=m | ||
3256 | CONFIG_CRYPTO_MD4=m | ||
3257 | CONFIG_CRYPTO_MD5=y | ||
3258 | CONFIG_CRYPTO_MICHAEL_MIC=m | ||
3259 | CONFIG_CRYPTO_RMD128=m | ||
3260 | CONFIG_CRYPTO_RMD160=m | ||
3261 | CONFIG_CRYPTO_RMD256=m | ||
3262 | CONFIG_CRYPTO_RMD320=m | ||
3263 | CONFIG_CRYPTO_SHA1=y | ||
3264 | CONFIG_CRYPTO_SHA256=m | ||
3265 | CONFIG_CRYPTO_SHA512=m | ||
3266 | CONFIG_CRYPTO_TGR192=m | ||
3267 | CONFIG_CRYPTO_WP512=m | ||
3268 | |||
3269 | # | ||
3270 | # Ciphers | ||
3271 | # | ||
3272 | CONFIG_CRYPTO_AES=m | ||
3273 | CONFIG_CRYPTO_ANUBIS=m | ||
3274 | CONFIG_CRYPTO_ARC4=m | ||
3275 | CONFIG_CRYPTO_BLOWFISH=m | ||
3276 | CONFIG_CRYPTO_CAMELLIA=m | ||
3277 | CONFIG_CRYPTO_CAST5=m | ||
3278 | CONFIG_CRYPTO_CAST6=m | ||
3279 | CONFIG_CRYPTO_DES=m | ||
3280 | CONFIG_CRYPTO_FCRYPT=m | ||
3281 | CONFIG_CRYPTO_KHAZAD=m | ||
3282 | CONFIG_CRYPTO_SALSA20=m | ||
3283 | CONFIG_CRYPTO_SEED=m | ||
3284 | CONFIG_CRYPTO_SERPENT=m | ||
3285 | CONFIG_CRYPTO_TEA=m | ||
3286 | CONFIG_CRYPTO_TWOFISH=m | ||
3287 | CONFIG_CRYPTO_TWOFISH_COMMON=m | ||
3288 | |||
3289 | # | ||
3290 | # Compression | ||
3291 | # | ||
3292 | CONFIG_CRYPTO_DEFLATE=m | ||
3293 | CONFIG_CRYPTO_LZO=m | ||
3294 | CONFIG_CRYPTO_HW=y | ||
3295 | CONFIG_CRYPTO_DEV_HIFN_795X=m | ||
3296 | CONFIG_CRYPTO_DEV_HIFN_795X_RNG=y | ||
3297 | CONFIG_CRYPTO_DEV_TALITOS=m | ||
3298 | CONFIG_PPC_CLOCK=y | ||
3299 | CONFIG_PPC_LIB_RHEAP=y | ||
3300 | CONFIG_VIRTUALIZATION=y | ||
3301 | CONFIG_VIRTIO=m | ||
3302 | CONFIG_VIRTIO_RING=m | ||
3303 | CONFIG_VIRTIO_PCI=m | ||
3304 | CONFIG_VIRTIO_BALLOON=m | ||
diff --git a/arch/powerpc/configs/ps3_defconfig b/arch/powerpc/configs/ps3_defconfig index 71d79e428d20..f9a3d3b394cf 100644 --- a/arch/powerpc/configs/ps3_defconfig +++ b/arch/powerpc/configs/ps3_defconfig | |||
@@ -1,7 +1,7 @@ | |||
1 | # | 1 | # |
2 | # Automatically generated make config: don't edit | 2 | # Automatically generated make config: don't edit |
3 | # Linux kernel version: 2.6.25 | 3 | # Linux kernel version: 2.6.26 |
4 | # Mon Apr 28 12:39:10 2008 | 4 | # Wed Jul 16 13:59:24 2008 |
5 | # | 5 | # |
6 | CONFIG_PPC64=y | 6 | CONFIG_PPC64=y |
7 | 7 | ||
@@ -14,8 +14,9 @@ CONFIG_POWER4=y | |||
14 | CONFIG_TUNE_CELL=y | 14 | CONFIG_TUNE_CELL=y |
15 | CONFIG_PPC_FPU=y | 15 | CONFIG_PPC_FPU=y |
16 | CONFIG_ALTIVEC=y | 16 | CONFIG_ALTIVEC=y |
17 | # CONFIG_VSX is not set | ||
17 | CONFIG_PPC_STD_MMU=y | 18 | CONFIG_PPC_STD_MMU=y |
18 | # CONFIG_PPC_MM_SLICES is not set | 19 | CONFIG_PPC_MM_SLICES=y |
19 | CONFIG_VIRT_CPU_ACCOUNTING=y | 20 | CONFIG_VIRT_CPU_ACCOUNTING=y |
20 | CONFIG_SMP=y | 21 | CONFIG_SMP=y |
21 | CONFIG_NR_CPUS=2 | 22 | CONFIG_NR_CPUS=2 |
@@ -31,6 +32,7 @@ CONFIG_GENERIC_HARDIRQS=y | |||
31 | CONFIG_HAVE_SETUP_PER_CPU_AREA=y | 32 | CONFIG_HAVE_SETUP_PER_CPU_AREA=y |
32 | CONFIG_IRQ_PER_CPU=y | 33 | CONFIG_IRQ_PER_CPU=y |
33 | CONFIG_STACKTRACE_SUPPORT=y | 34 | CONFIG_STACKTRACE_SUPPORT=y |
35 | CONFIG_HAVE_LATENCYTOP_SUPPORT=y | ||
34 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y | 36 | CONFIG_TRACE_IRQFLAGS_SUPPORT=y |
35 | CONFIG_LOCKDEP_SUPPORT=y | 37 | CONFIG_LOCKDEP_SUPPORT=y |
36 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y | 38 | CONFIG_RWSEM_XCHGADD_ALGORITHM=y |
@@ -90,6 +92,7 @@ CONFIG_CC_OPTIMIZE_FOR_SIZE=y | |||
90 | CONFIG_SYSCTL=y | 92 | CONFIG_SYSCTL=y |
91 | # CONFIG_EMBEDDED is not set | 93 | # CONFIG_EMBEDDED is not set |
92 | CONFIG_SYSCTL_SYSCALL=y | 94 | CONFIG_SYSCTL_SYSCALL=y |
95 | CONFIG_SYSCTL_SYSCALL_CHECK=y | ||
93 | CONFIG_KALLSYMS=y | 96 | CONFIG_KALLSYMS=y |
94 | CONFIG_KALLSYMS_ALL=y | 97 | CONFIG_KALLSYMS_ALL=y |
95 | CONFIG_KALLSYMS_EXTRA_PASS=y | 98 | CONFIG_KALLSYMS_EXTRA_PASS=y |
@@ -117,12 +120,15 @@ CONFIG_HAVE_OPROFILE=y | |||
117 | # CONFIG_KPROBES is not set | 120 | # CONFIG_KPROBES is not set |
118 | CONFIG_HAVE_KPROBES=y | 121 | CONFIG_HAVE_KPROBES=y |
119 | CONFIG_HAVE_KRETPROBES=y | 122 | CONFIG_HAVE_KRETPROBES=y |
123 | CONFIG_HAVE_DMA_ATTRS=y | ||
124 | CONFIG_USE_GENERIC_SMP_HELPERS=y | ||
120 | CONFIG_PROC_PAGE_MONITOR=y | 125 | CONFIG_PROC_PAGE_MONITOR=y |
121 | CONFIG_SLABINFO=y | 126 | CONFIG_SLABINFO=y |
122 | CONFIG_RT_MUTEXES=y | 127 | CONFIG_RT_MUTEXES=y |
123 | # CONFIG_TINY_SHMEM is not set | 128 | # CONFIG_TINY_SHMEM is not set |
124 | CONFIG_BASE_SMALL=0 | 129 | CONFIG_BASE_SMALL=0 |
125 | CONFIG_MODULES=y | 130 | CONFIG_MODULES=y |
131 | # CONFIG_MODULE_FORCE_LOAD is not set | ||
126 | CONFIG_MODULE_UNLOAD=y | 132 | CONFIG_MODULE_UNLOAD=y |
127 | # CONFIG_MODULE_FORCE_UNLOAD is not set | 133 | # CONFIG_MODULE_FORCE_UNLOAD is not set |
128 | # CONFIG_MODVERSIONS is not set | 134 | # CONFIG_MODVERSIONS is not set |
@@ -132,6 +138,7 @@ CONFIG_STOP_MACHINE=y | |||
132 | CONFIG_BLOCK=y | 138 | CONFIG_BLOCK=y |
133 | # CONFIG_BLK_DEV_IO_TRACE is not set | 139 | # CONFIG_BLK_DEV_IO_TRACE is not set |
134 | CONFIG_BLK_DEV_BSG=y | 140 | CONFIG_BLK_DEV_BSG=y |
141 | # CONFIG_BLK_DEV_INTEGRITY is not set | ||
135 | CONFIG_BLOCK_COMPAT=y | 142 | CONFIG_BLOCK_COMPAT=y |
136 | 143 | ||
137 | # | 144 | # |
@@ -152,13 +159,8 @@ CONFIG_CLASSIC_RCU=y | |||
152 | # Platform support | 159 | # Platform support |
153 | # | 160 | # |
154 | CONFIG_PPC_MULTIPLATFORM=y | 161 | CONFIG_PPC_MULTIPLATFORM=y |
155 | # CONFIG_PPC_82xx is not set | ||
156 | # CONFIG_PPC_83xx is not set | ||
157 | # CONFIG_PPC_86xx is not set | ||
158 | # CONFIG_PPC_PSERIES is not set | 162 | # CONFIG_PPC_PSERIES is not set |
159 | # CONFIG_PPC_ISERIES is not set | 163 | # CONFIG_PPC_ISERIES is not set |
160 | # CONFIG_PPC_MPC512x is not set | ||
161 | # CONFIG_PPC_MPC5121 is not set | ||
162 | # CONFIG_PPC_PMAC is not set | 164 | # CONFIG_PPC_PMAC is not set |
163 | # CONFIG_PPC_MAPLE is not set | 165 | # CONFIG_PPC_MAPLE is not set |
164 | # CONFIG_PPC_PASEMI is not set | 166 | # CONFIG_PPC_PASEMI is not set |
@@ -187,6 +189,7 @@ CONFIG_PPC_CELL=y | |||
187 | # Cell Broadband Engine options | 189 | # Cell Broadband Engine options |
188 | # | 190 | # |
189 | CONFIG_SPU_FS=y | 191 | CONFIG_SPU_FS=y |
192 | CONFIG_SPU_FS_64K_LS=y | ||
190 | CONFIG_SPU_BASE=y | 193 | CONFIG_SPU_BASE=y |
191 | # CONFIG_PQ2ADS is not set | 194 | # CONFIG_PQ2ADS is not set |
192 | # CONFIG_IPIC is not set | 195 | # CONFIG_IPIC is not set |
@@ -222,6 +225,7 @@ CONFIG_PREEMPT_NONE=y | |||
222 | CONFIG_BINFMT_ELF=y | 225 | CONFIG_BINFMT_ELF=y |
223 | CONFIG_COMPAT_BINFMT_ELF=y | 226 | CONFIG_COMPAT_BINFMT_ELF=y |
224 | CONFIG_BINFMT_MISC=y | 227 | CONFIG_BINFMT_MISC=y |
228 | CONFIG_HUGETLB_PAGE_SIZE_VARIABLE=y | ||
225 | # CONFIG_IOMMU_VMERGE is not set | 229 | # CONFIG_IOMMU_VMERGE is not set |
226 | CONFIG_IOMMU_HELPER=y | 230 | CONFIG_IOMMU_HELPER=y |
227 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y | 231 | CONFIG_ARCH_ENABLE_MEMORY_HOTPLUG=y |
@@ -248,18 +252,22 @@ CONFIG_SPARSEMEM_VMEMMAP_ENABLE=y | |||
248 | # CONFIG_SPARSEMEM_VMEMMAP is not set | 252 | # CONFIG_SPARSEMEM_VMEMMAP is not set |
249 | CONFIG_MEMORY_HOTPLUG=y | 253 | CONFIG_MEMORY_HOTPLUG=y |
250 | CONFIG_MEMORY_HOTPLUG_SPARSE=y | 254 | CONFIG_MEMORY_HOTPLUG_SPARSE=y |
255 | CONFIG_PAGEFLAGS_EXTENDED=y | ||
251 | CONFIG_SPLIT_PTLOCK_CPUS=4 | 256 | CONFIG_SPLIT_PTLOCK_CPUS=4 |
252 | CONFIG_RESOURCES_64BIT=y | 257 | CONFIG_RESOURCES_64BIT=y |
253 | CONFIG_ZONE_DMA_FLAG=1 | 258 | CONFIG_ZONE_DMA_FLAG=1 |
254 | CONFIG_BOUNCE=y | 259 | CONFIG_BOUNCE=y |
255 | CONFIG_ARCH_MEMORY_PROBE=y | 260 | CONFIG_ARCH_MEMORY_PROBE=y |
256 | # CONFIG_PPC_HAS_HASH_64K is not set | 261 | CONFIG_PPC_HAS_HASH_64K=y |
257 | # CONFIG_PPC_64K_PAGES is not set | 262 | # CONFIG_PPC_64K_PAGES is not set |
258 | CONFIG_FORCE_MAX_ZONEORDER=13 | 263 | CONFIG_FORCE_MAX_ZONEORDER=13 |
259 | # CONFIG_SCHED_SMT is not set | 264 | CONFIG_SCHED_SMT=y |
260 | CONFIG_PROC_DEVICETREE=y | 265 | CONFIG_PROC_DEVICETREE=y |
261 | # CONFIG_CMDLINE_BOOL is not set | 266 | # CONFIG_CMDLINE_BOOL is not set |
262 | # CONFIG_PM is not set | 267 | CONFIG_EXTRA_TARGETS="" |
268 | CONFIG_PM=y | ||
269 | CONFIG_PM_DEBUG=y | ||
270 | # CONFIG_PM_VERBOSE is not set | ||
263 | # CONFIG_SECCOMP is not set | 271 | # CONFIG_SECCOMP is not set |
264 | CONFIG_ISA_DMA_API=y | 272 | CONFIG_ISA_DMA_API=y |
265 | 273 | ||
@@ -273,6 +281,7 @@ CONFIG_GENERIC_ISA_DMA=y | |||
273 | # CONFIG_PCI_SYSCALL is not set | 281 | # CONFIG_PCI_SYSCALL is not set |
274 | # CONFIG_ARCH_SUPPORTS_MSI is not set | 282 | # CONFIG_ARCH_SUPPORTS_MSI is not set |
275 | # CONFIG_PCCARD is not set | 283 | # CONFIG_PCCARD is not set |
284 | # CONFIG_HAS_RAPIDIO is not set | ||
276 | CONFIG_PAGE_OFFSET=0xc000000000000000 | 285 | CONFIG_PAGE_OFFSET=0xc000000000000000 |
277 | CONFIG_KERNEL_START=0xc000000000000000 | 286 | CONFIG_KERNEL_START=0xc000000000000000 |
278 | CONFIG_PHYSICAL_START=0x00000000 | 287 | CONFIG_PHYSICAL_START=0x00000000 |
@@ -412,6 +421,8 @@ CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug" | |||
412 | CONFIG_STANDALONE=y | 421 | CONFIG_STANDALONE=y |
413 | CONFIG_PREVENT_FIRMWARE_BUILD=y | 422 | CONFIG_PREVENT_FIRMWARE_BUILD=y |
414 | CONFIG_FW_LOADER=m | 423 | CONFIG_FW_LOADER=m |
424 | # CONFIG_FIRMWARE_IN_KERNEL is not set | ||
425 | CONFIG_EXTRA_FIRMWARE="" | ||
415 | # CONFIG_DEBUG_DRIVER is not set | 426 | # CONFIG_DEBUG_DRIVER is not set |
416 | # CONFIG_DEBUG_DEVRES is not set | 427 | # CONFIG_DEBUG_DEVRES is not set |
417 | # CONFIG_SYS_HYPERVISOR is not set | 428 | # CONFIG_SYS_HYPERVISOR is not set |
@@ -478,6 +489,7 @@ CONFIG_SCSI_WAIT_SCAN=m | |||
478 | # CONFIG_SCSI_SAS_LIBSAS is not set | 489 | # CONFIG_SCSI_SAS_LIBSAS is not set |
479 | # CONFIG_SCSI_SRP_ATTRS is not set | 490 | # CONFIG_SCSI_SRP_ATTRS is not set |
480 | # CONFIG_SCSI_LOWLEVEL is not set | 491 | # CONFIG_SCSI_LOWLEVEL is not set |
492 | # CONFIG_SCSI_DH is not set | ||
481 | # CONFIG_ATA is not set | 493 | # CONFIG_ATA is not set |
482 | # CONFIG_MD is not set | 494 | # CONFIG_MD is not set |
483 | # CONFIG_MACINTOSH_DRIVERS is not set | 495 | # CONFIG_MACINTOSH_DRIVERS is not set |
@@ -533,8 +545,18 @@ CONFIG_USB_NET_MCS7830=m | |||
533 | # CONFIG_USB_NET_CDC_SUBSET is not set | 545 | # CONFIG_USB_NET_CDC_SUBSET is not set |
534 | # CONFIG_USB_NET_ZAURUS is not set | 546 | # CONFIG_USB_NET_ZAURUS is not set |
535 | # CONFIG_WAN is not set | 547 | # CONFIG_WAN is not set |
536 | # CONFIG_PPP is not set | 548 | CONFIG_PPP=m |
549 | CONFIG_PPP_MULTILINK=y | ||
550 | # CONFIG_PPP_FILTER is not set | ||
551 | CONFIG_PPP_ASYNC=m | ||
552 | # CONFIG_PPP_SYNC_TTY is not set | ||
553 | CONFIG_PPP_DEFLATE=m | ||
554 | # CONFIG_PPP_BSDCOMP is not set | ||
555 | # CONFIG_PPP_MPPE is not set | ||
556 | CONFIG_PPPOE=m | ||
557 | # CONFIG_PPPOL2TP is not set | ||
537 | # CONFIG_SLIP is not set | 558 | # CONFIG_SLIP is not set |
559 | CONFIG_SLHC=m | ||
538 | # CONFIG_NETCONSOLE is not set | 560 | # CONFIG_NETCONSOLE is not set |
539 | # CONFIG_NETPOLL is not set | 561 | # CONFIG_NETPOLL is not set |
540 | # CONFIG_NET_POLL_CONTROLLER is not set | 562 | # CONFIG_NET_POLL_CONTROLLER is not set |
@@ -603,6 +625,7 @@ CONFIG_VT=y | |||
603 | CONFIG_VT_CONSOLE=y | 625 | CONFIG_VT_CONSOLE=y |
604 | CONFIG_HW_CONSOLE=y | 626 | CONFIG_HW_CONSOLE=y |
605 | CONFIG_VT_HW_CONSOLE_BINDING=y | 627 | CONFIG_VT_HW_CONSOLE_BINDING=y |
628 | CONFIG_DEVKMEM=y | ||
606 | # CONFIG_SERIAL_NONSTANDARD is not set | 629 | # CONFIG_SERIAL_NONSTANDARD is not set |
607 | 630 | ||
608 | # | 631 | # |
@@ -618,23 +641,17 @@ CONFIG_LEGACY_PTYS=y | |||
618 | CONFIG_LEGACY_PTY_COUNT=16 | 641 | CONFIG_LEGACY_PTY_COUNT=16 |
619 | # CONFIG_IPMI_HANDLER is not set | 642 | # CONFIG_IPMI_HANDLER is not set |
620 | # CONFIG_HW_RANDOM is not set | 643 | # CONFIG_HW_RANDOM is not set |
621 | CONFIG_GEN_RTC=y | ||
622 | # CONFIG_GEN_RTC_X is not set | ||
623 | # CONFIG_R3964 is not set | 644 | # CONFIG_R3964 is not set |
624 | # CONFIG_RAW_DRIVER is not set | 645 | # CONFIG_RAW_DRIVER is not set |
625 | # CONFIG_HANGCHECK_TIMER is not set | 646 | # CONFIG_HANGCHECK_TIMER is not set |
626 | # CONFIG_TCG_TPM is not set | 647 | # CONFIG_TCG_TPM is not set |
627 | # CONFIG_I2C is not set | 648 | # CONFIG_I2C is not set |
628 | |||
629 | # | ||
630 | # SPI support | ||
631 | # | ||
632 | # CONFIG_SPI is not set | 649 | # CONFIG_SPI is not set |
633 | # CONFIG_SPI_MASTER is not set | ||
634 | # CONFIG_W1 is not set | 650 | # CONFIG_W1 is not set |
635 | # CONFIG_POWER_SUPPLY is not set | 651 | # CONFIG_POWER_SUPPLY is not set |
636 | # CONFIG_HWMON is not set | 652 | # CONFIG_HWMON is not set |
637 | # CONFIG_THERMAL is not set | 653 | # CONFIG_THERMAL is not set |
654 | # CONFIG_THERMAL_HWMON is not set | ||
638 | # CONFIG_WATCHDOG is not set | 655 | # CONFIG_WATCHDOG is not set |
639 | 656 | ||
640 | # | 657 | # |
@@ -652,8 +669,17 @@ CONFIG_SSB_POSSIBLE=y | |||
652 | # | 669 | # |
653 | # Multimedia devices | 670 | # Multimedia devices |
654 | # | 671 | # |
672 | |||
673 | # | ||
674 | # Multimedia core support | ||
675 | # | ||
655 | # CONFIG_VIDEO_DEV is not set | 676 | # CONFIG_VIDEO_DEV is not set |
656 | # CONFIG_DVB_CORE is not set | 677 | # CONFIG_DVB_CORE is not set |
678 | # CONFIG_VIDEO_MEDIA is not set | ||
679 | |||
680 | # | ||
681 | # Multimedia drivers | ||
682 | # | ||
657 | # CONFIG_DAB is not set | 683 | # CONFIG_DAB is not set |
658 | 684 | ||
659 | # | 685 | # |
@@ -671,8 +697,8 @@ CONFIG_FB=y | |||
671 | CONFIG_FB_SYS_FILLRECT=y | 697 | CONFIG_FB_SYS_FILLRECT=y |
672 | CONFIG_FB_SYS_COPYAREA=y | 698 | CONFIG_FB_SYS_COPYAREA=y |
673 | CONFIG_FB_SYS_IMAGEBLIT=y | 699 | CONFIG_FB_SYS_IMAGEBLIT=y |
700 | # CONFIG_FB_FOREIGN_ENDIAN is not set | ||
674 | CONFIG_FB_SYS_FOPS=y | 701 | CONFIG_FB_SYS_FOPS=y |
675 | CONFIG_FB_DEFERRED_IO=y | ||
676 | # CONFIG_FB_SVGALIB is not set | 702 | # CONFIG_FB_SVGALIB is not set |
677 | # CONFIG_FB_MACMODES is not set | 703 | # CONFIG_FB_MACMODES is not set |
678 | # CONFIG_FB_BACKLIGHT is not set | 704 | # CONFIG_FB_BACKLIGHT is not set |
@@ -712,18 +738,12 @@ CONFIG_FB_LOGO_EXTRA=y | |||
712 | # CONFIG_LOGO_LINUX_MONO is not set | 738 | # CONFIG_LOGO_LINUX_MONO is not set |
713 | # CONFIG_LOGO_LINUX_VGA16 is not set | 739 | # CONFIG_LOGO_LINUX_VGA16 is not set |
714 | CONFIG_LOGO_LINUX_CLUT224=y | 740 | CONFIG_LOGO_LINUX_CLUT224=y |
715 | |||
716 | # | ||
717 | # Sound | ||
718 | # | ||
719 | CONFIG_SOUND=m | 741 | CONFIG_SOUND=m |
720 | |||
721 | # | ||
722 | # Advanced Linux Sound Architecture | ||
723 | # | ||
724 | CONFIG_SND=m | 742 | CONFIG_SND=m |
725 | CONFIG_SND_TIMER=m | 743 | CONFIG_SND_TIMER=m |
726 | CONFIG_SND_PCM=m | 744 | CONFIG_SND_PCM=m |
745 | CONFIG_SND_HWDEP=m | ||
746 | CONFIG_SND_RAWMIDI=m | ||
727 | # CONFIG_SND_SEQUENCER is not set | 747 | # CONFIG_SND_SEQUENCER is not set |
728 | # CONFIG_SND_MIXER_OSS is not set | 748 | # CONFIG_SND_MIXER_OSS is not set |
729 | # CONFIG_SND_PCM_OSS is not set | 749 | # CONFIG_SND_PCM_OSS is not set |
@@ -732,53 +752,20 @@ CONFIG_SND_SUPPORT_OLD_API=y | |||
732 | CONFIG_SND_VERBOSE_PROCFS=y | 752 | CONFIG_SND_VERBOSE_PROCFS=y |
733 | # CONFIG_SND_VERBOSE_PRINTK is not set | 753 | # CONFIG_SND_VERBOSE_PRINTK is not set |
734 | # CONFIG_SND_DEBUG is not set | 754 | # CONFIG_SND_DEBUG is not set |
735 | 755 | # CONFIG_SND_DRIVERS is not set | |
736 | # | 756 | CONFIG_SND_PPC=y |
737 | # Generic devices | ||
738 | # | ||
739 | # CONFIG_SND_DUMMY is not set | ||
740 | # CONFIG_SND_MTPAV is not set | ||
741 | # CONFIG_SND_SERIAL_U16550 is not set | ||
742 | # CONFIG_SND_MPU401 is not set | ||
743 | |||
744 | # | ||
745 | # ALSA PowerMac devices | ||
746 | # | ||
747 | |||
748 | # | ||
749 | # ALSA PowerMac requires I2C | ||
750 | # | ||
751 | |||
752 | # | ||
753 | # ALSA PowerPC devices | ||
754 | # | ||
755 | CONFIG_SND_PS3=m | 757 | CONFIG_SND_PS3=m |
756 | CONFIG_SND_PS3_DEFAULT_START_DELAY=2000 | 758 | CONFIG_SND_PS3_DEFAULT_START_DELAY=2000 |
757 | 759 | CONFIG_SND_USB=y | |
758 | # | 760 | CONFIG_SND_USB_AUDIO=m |
759 | # USB devices | ||
760 | # | ||
761 | # CONFIG_SND_USB_AUDIO is not set | ||
762 | # CONFIG_SND_USB_USX2Y is not set | 761 | # CONFIG_SND_USB_USX2Y is not set |
763 | # CONFIG_SND_USB_CAIAQ is not set | 762 | # CONFIG_SND_USB_CAIAQ is not set |
764 | |||
765 | # | ||
766 | # System on Chip audio support | ||
767 | # | ||
768 | # CONFIG_SND_SOC is not set | 763 | # CONFIG_SND_SOC is not set |
769 | |||
770 | # | ||
771 | # ALSA SoC audio for Freescale SOCs | ||
772 | # | ||
773 | |||
774 | # | ||
775 | # Open Sound System | ||
776 | # | ||
777 | # CONFIG_SOUND_PRIME is not set | 764 | # CONFIG_SOUND_PRIME is not set |
778 | CONFIG_HID_SUPPORT=y | 765 | CONFIG_HID_SUPPORT=y |
779 | CONFIG_HID=y | 766 | CONFIG_HID=y |
780 | # CONFIG_HID_DEBUG is not set | 767 | # CONFIG_HID_DEBUG is not set |
781 | # CONFIG_HIDRAW is not set | 768 | CONFIG_HIDRAW=y |
782 | 769 | ||
783 | # | 770 | # |
784 | # USB Input Devices | 771 | # USB Input Devices |
@@ -807,17 +794,20 @@ CONFIG_USB=m | |||
807 | CONFIG_USB_DEVICEFS=y | 794 | CONFIG_USB_DEVICEFS=y |
808 | # CONFIG_USB_DEVICE_CLASS is not set | 795 | # CONFIG_USB_DEVICE_CLASS is not set |
809 | # CONFIG_USB_DYNAMIC_MINORS is not set | 796 | # CONFIG_USB_DYNAMIC_MINORS is not set |
797 | CONFIG_USB_SUSPEND=y | ||
810 | # CONFIG_USB_OTG is not set | 798 | # CONFIG_USB_OTG is not set |
811 | 799 | ||
812 | # | 800 | # |
813 | # USB Host Controller Drivers | 801 | # USB Host Controller Drivers |
814 | # | 802 | # |
803 | # CONFIG_USB_C67X00_HCD is not set | ||
815 | CONFIG_USB_EHCI_HCD=m | 804 | CONFIG_USB_EHCI_HCD=m |
816 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set | 805 | # CONFIG_USB_EHCI_ROOT_HUB_TT is not set |
817 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set | 806 | # CONFIG_USB_EHCI_TT_NEWSCHED is not set |
818 | CONFIG_USB_EHCI_BIG_ENDIAN_MMIO=y | 807 | CONFIG_USB_EHCI_BIG_ENDIAN_MMIO=y |
819 | # CONFIG_USB_EHCI_HCD_PPC_OF is not set | 808 | # CONFIG_USB_EHCI_HCD_PPC_OF is not set |
820 | # CONFIG_USB_ISP116X_HCD is not set | 809 | # CONFIG_USB_ISP116X_HCD is not set |
810 | # CONFIG_USB_ISP1760_HCD is not set | ||
821 | CONFIG_USB_OHCI_HCD=m | 811 | CONFIG_USB_OHCI_HCD=m |
822 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set | 812 | # CONFIG_USB_OHCI_HCD_PPC_OF is not set |
823 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set | 813 | # CONFIG_USB_OHCI_BIG_ENDIAN_DESC is not set |
@@ -831,6 +821,7 @@ CONFIG_USB_OHCI_LITTLE_ENDIAN=y | |||
831 | # | 821 | # |
832 | # CONFIG_USB_ACM is not set | 822 | # CONFIG_USB_ACM is not set |
833 | # CONFIG_USB_PRINTER is not set | 823 | # CONFIG_USB_PRINTER is not set |
824 | # CONFIG_USB_WDM is not set | ||
834 | 825 | ||
835 | # | 826 | # |
836 | # NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' | 827 | # NOTE: USB_STORAGE enables SCSI, and 'SCSI disk support' |
@@ -890,12 +881,45 @@ CONFIG_USB_MON=y | |||
890 | # CONFIG_USB_TRANCEVIBRATOR is not set | 881 | # CONFIG_USB_TRANCEVIBRATOR is not set |
891 | # CONFIG_USB_IOWARRIOR is not set | 882 | # CONFIG_USB_IOWARRIOR is not set |
892 | # CONFIG_USB_TEST is not set | 883 | # CONFIG_USB_TEST is not set |
884 | # CONFIG_USB_ISIGHTFW is not set | ||
893 | # CONFIG_USB_GADGET is not set | 885 | # CONFIG_USB_GADGET is not set |
894 | # CONFIG_MMC is not set | 886 | # CONFIG_MMC is not set |
895 | # CONFIG_MEMSTICK is not set | 887 | # CONFIG_MEMSTICK is not set |
896 | # CONFIG_NEW_LEDS is not set | 888 | # CONFIG_NEW_LEDS is not set |
889 | # CONFIG_ACCESSIBILITY is not set | ||
897 | # CONFIG_EDAC is not set | 890 | # CONFIG_EDAC is not set |
898 | # CONFIG_RTC_CLASS is not set | 891 | CONFIG_RTC_LIB=m |
892 | CONFIG_RTC_CLASS=m | ||
893 | |||
894 | # | ||
895 | # RTC interfaces | ||
896 | # | ||
897 | CONFIG_RTC_INTF_SYSFS=y | ||
898 | CONFIG_RTC_INTF_PROC=y | ||
899 | CONFIG_RTC_INTF_DEV=y | ||
900 | # CONFIG_RTC_INTF_DEV_UIE_EMUL is not set | ||
901 | # CONFIG_RTC_DRV_TEST is not set | ||
902 | |||
903 | # | ||
904 | # SPI RTC drivers | ||
905 | # | ||
906 | |||
907 | # | ||
908 | # Platform RTC drivers | ||
909 | # | ||
910 | # CONFIG_RTC_DRV_CMOS is not set | ||
911 | # CONFIG_RTC_DRV_DS1511 is not set | ||
912 | # CONFIG_RTC_DRV_DS1553 is not set | ||
913 | # CONFIG_RTC_DRV_DS1742 is not set | ||
914 | # CONFIG_RTC_DRV_STK17TA8 is not set | ||
915 | # CONFIG_RTC_DRV_M48T86 is not set | ||
916 | # CONFIG_RTC_DRV_M48T59 is not set | ||
917 | # CONFIG_RTC_DRV_V3020 is not set | ||
918 | |||
919 | # | ||
920 | # on-CPU RTC drivers | ||
921 | # | ||
922 | CONFIG_RTC_DRV_PPC=m | ||
899 | # CONFIG_DMADEVICES is not set | 923 | # CONFIG_DMADEVICES is not set |
900 | # CONFIG_UIO is not set | 924 | # CONFIG_UIO is not set |
901 | 925 | ||
@@ -911,6 +935,7 @@ CONFIG_EXT3_FS_XATTR=y | |||
911 | # CONFIG_EXT3_FS_SECURITY is not set | 935 | # CONFIG_EXT3_FS_SECURITY is not set |
912 | # CONFIG_EXT4DEV_FS is not set | 936 | # CONFIG_EXT4DEV_FS is not set |
913 | CONFIG_JBD=y | 937 | CONFIG_JBD=y |
938 | # CONFIG_JBD_DEBUG is not set | ||
914 | CONFIG_FS_MBCACHE=y | 939 | CONFIG_FS_MBCACHE=y |
915 | # CONFIG_REISERFS_FS is not set | 940 | # CONFIG_REISERFS_FS is not set |
916 | # CONFIG_JFS_FS is not set | 941 | # CONFIG_JFS_FS is not set |
@@ -959,8 +984,8 @@ CONFIG_PROC_SYSCTL=y | |||
959 | CONFIG_SYSFS=y | 984 | CONFIG_SYSFS=y |
960 | CONFIG_TMPFS=y | 985 | CONFIG_TMPFS=y |
961 | # CONFIG_TMPFS_POSIX_ACL is not set | 986 | # CONFIG_TMPFS_POSIX_ACL is not set |
962 | # CONFIG_HUGETLBFS is not set | 987 | CONFIG_HUGETLBFS=y |
963 | # CONFIG_HUGETLB_PAGE is not set | 988 | CONFIG_HUGETLB_PAGE=y |
964 | # CONFIG_CONFIGFS_FS is not set | 989 | # CONFIG_CONFIGFS_FS is not set |
965 | 990 | ||
966 | # | 991 | # |
@@ -1059,12 +1084,15 @@ CONFIG_NLS_ISO8859_1=y | |||
1059 | # | 1084 | # |
1060 | CONFIG_BITREVERSE=y | 1085 | CONFIG_BITREVERSE=y |
1061 | # CONFIG_GENERIC_FIND_FIRST_BIT is not set | 1086 | # CONFIG_GENERIC_FIND_FIRST_BIT is not set |
1062 | # CONFIG_CRC_CCITT is not set | 1087 | CONFIG_CRC_CCITT=m |
1063 | # CONFIG_CRC16 is not set | 1088 | # CONFIG_CRC16 is not set |
1089 | # CONFIG_CRC_T10DIF is not set | ||
1064 | CONFIG_CRC_ITU_T=m | 1090 | CONFIG_CRC_ITU_T=m |
1065 | CONFIG_CRC32=y | 1091 | CONFIG_CRC32=y |
1066 | # CONFIG_CRC7 is not set | 1092 | # CONFIG_CRC7 is not set |
1067 | # CONFIG_LIBCRC32C is not set | 1093 | # CONFIG_LIBCRC32C is not set |
1094 | CONFIG_ZLIB_INFLATE=m | ||
1095 | CONFIG_ZLIB_DEFLATE=m | ||
1068 | CONFIG_LZO_COMPRESS=m | 1096 | CONFIG_LZO_COMPRESS=m |
1069 | CONFIG_LZO_DECOMPRESS=m | 1097 | CONFIG_LZO_DECOMPRESS=m |
1070 | CONFIG_PLIST=y | 1098 | CONFIG_PLIST=y |
@@ -1082,7 +1110,7 @@ CONFIG_ENABLE_MUST_CHECK=y | |||
1082 | CONFIG_FRAME_WARN=2048 | 1110 | CONFIG_FRAME_WARN=2048 |
1083 | CONFIG_MAGIC_SYSRQ=y | 1111 | CONFIG_MAGIC_SYSRQ=y |
1084 | # CONFIG_UNUSED_SYMBOLS is not set | 1112 | # CONFIG_UNUSED_SYMBOLS is not set |
1085 | # CONFIG_DEBUG_FS is not set | 1113 | CONFIG_DEBUG_FS=y |
1086 | # CONFIG_HEADERS_CHECK is not set | 1114 | # CONFIG_HEADERS_CHECK is not set |
1087 | CONFIG_DEBUG_KERNEL=y | 1115 | CONFIG_DEBUG_KERNEL=y |
1088 | # CONFIG_DEBUG_SHIRQ is not set | 1116 | # CONFIG_DEBUG_SHIRQ is not set |
@@ -1090,33 +1118,49 @@ CONFIG_DETECT_SOFTLOCKUP=y | |||
1090 | CONFIG_SCHED_DEBUG=y | 1118 | CONFIG_SCHED_DEBUG=y |
1091 | # CONFIG_SCHEDSTATS is not set | 1119 | # CONFIG_SCHEDSTATS is not set |
1092 | # CONFIG_TIMER_STATS is not set | 1120 | # CONFIG_TIMER_STATS is not set |
1121 | # CONFIG_DEBUG_OBJECTS is not set | ||
1093 | # CONFIG_DEBUG_SLAB is not set | 1122 | # CONFIG_DEBUG_SLAB is not set |
1094 | # CONFIG_DEBUG_RT_MUTEXES is not set | 1123 | # CONFIG_DEBUG_RT_MUTEXES is not set |
1095 | # CONFIG_RT_MUTEX_TESTER is not set | 1124 | # CONFIG_RT_MUTEX_TESTER is not set |
1096 | CONFIG_DEBUG_SPINLOCK=y | 1125 | CONFIG_DEBUG_SPINLOCK=y |
1097 | CONFIG_DEBUG_MUTEXES=y | 1126 | CONFIG_DEBUG_MUTEXES=y |
1098 | # CONFIG_DEBUG_LOCK_ALLOC is not set | 1127 | CONFIG_DEBUG_LOCK_ALLOC=y |
1099 | # CONFIG_PROVE_LOCKING is not set | 1128 | CONFIG_PROVE_LOCKING=y |
1129 | CONFIG_LOCKDEP=y | ||
1100 | # CONFIG_LOCK_STAT is not set | 1130 | # CONFIG_LOCK_STAT is not set |
1131 | CONFIG_DEBUG_LOCKDEP=y | ||
1132 | CONFIG_TRACE_IRQFLAGS=y | ||
1101 | CONFIG_DEBUG_SPINLOCK_SLEEP=y | 1133 | CONFIG_DEBUG_SPINLOCK_SLEEP=y |
1102 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set | 1134 | # CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set |
1135 | CONFIG_STACKTRACE=y | ||
1103 | # CONFIG_DEBUG_KOBJECT is not set | 1136 | # CONFIG_DEBUG_KOBJECT is not set |
1104 | CONFIG_DEBUG_BUGVERBOSE=y | 1137 | CONFIG_DEBUG_BUGVERBOSE=y |
1105 | CONFIG_DEBUG_INFO=y | 1138 | CONFIG_DEBUG_INFO=y |
1106 | # CONFIG_DEBUG_VM is not set | 1139 | # CONFIG_DEBUG_VM is not set |
1107 | # CONFIG_DEBUG_WRITECOUNT is not set | 1140 | CONFIG_DEBUG_WRITECOUNT=y |
1108 | CONFIG_DEBUG_LIST=y | 1141 | CONFIG_DEBUG_LIST=y |
1109 | # CONFIG_DEBUG_SG is not set | 1142 | # CONFIG_DEBUG_SG is not set |
1143 | CONFIG_FRAME_POINTER=y | ||
1110 | # CONFIG_BOOT_PRINTK_DELAY is not set | 1144 | # CONFIG_BOOT_PRINTK_DELAY is not set |
1111 | # CONFIG_RCU_TORTURE_TEST is not set | 1145 | # CONFIG_RCU_TORTURE_TEST is not set |
1112 | # CONFIG_BACKTRACE_SELF_TEST is not set | 1146 | # CONFIG_BACKTRACE_SELF_TEST is not set |
1113 | # CONFIG_FAULT_INJECTION is not set | 1147 | # CONFIG_FAULT_INJECTION is not set |
1148 | # CONFIG_LATENCYTOP is not set | ||
1149 | CONFIG_HAVE_FTRACE=y | ||
1150 | CONFIG_HAVE_DYNAMIC_FTRACE=y | ||
1151 | # CONFIG_FTRACE is not set | ||
1152 | # CONFIG_IRQSOFF_TRACER is not set | ||
1153 | # CONFIG_SCHED_TRACER is not set | ||
1154 | # CONFIG_CONTEXT_SWITCH_TRACER is not set | ||
1114 | # CONFIG_SAMPLES is not set | 1155 | # CONFIG_SAMPLES is not set |
1115 | CONFIG_DEBUG_STACKOVERFLOW=y | 1156 | CONFIG_DEBUG_STACKOVERFLOW=y |
1116 | # CONFIG_DEBUG_STACK_USAGE is not set | 1157 | # CONFIG_DEBUG_STACK_USAGE is not set |
1117 | # CONFIG_DEBUG_PAGEALLOC is not set | 1158 | # CONFIG_DEBUG_PAGEALLOC is not set |
1118 | # CONFIG_DEBUGGER is not set | 1159 | # CONFIG_DEBUGGER is not set |
1160 | # CONFIG_CODE_PATCHING_SELFTEST is not set | ||
1161 | # CONFIG_FTR_FIXUP_SELFTEST is not set | ||
1119 | CONFIG_IRQSTACKS=y | 1162 | CONFIG_IRQSTACKS=y |
1163 | # CONFIG_VIRQ_DEBUG is not set | ||
1120 | # CONFIG_BOOTX_TEXT is not set | 1164 | # CONFIG_BOOTX_TEXT is not set |
1121 | # CONFIG_PPC_EARLY_DEBUG is not set | 1165 | # CONFIG_PPC_EARLY_DEBUG is not set |
1122 | 1166 | ||
@@ -1172,6 +1216,10 @@ CONFIG_CRYPTO_PCBC=m | |||
1172 | # CONFIG_CRYPTO_MD4 is not set | 1216 | # CONFIG_CRYPTO_MD4 is not set |
1173 | CONFIG_CRYPTO_MD5=y | 1217 | CONFIG_CRYPTO_MD5=y |
1174 | CONFIG_CRYPTO_MICHAEL_MIC=m | 1218 | CONFIG_CRYPTO_MICHAEL_MIC=m |
1219 | # CONFIG_CRYPTO_RMD128 is not set | ||
1220 | # CONFIG_CRYPTO_RMD160 is not set | ||
1221 | # CONFIG_CRYPTO_RMD256 is not set | ||
1222 | # CONFIG_CRYPTO_RMD320 is not set | ||
1175 | # CONFIG_CRYPTO_SHA1 is not set | 1223 | # CONFIG_CRYPTO_SHA1 is not set |
1176 | # CONFIG_CRYPTO_SHA256 is not set | 1224 | # CONFIG_CRYPTO_SHA256 is not set |
1177 | # CONFIG_CRYPTO_SHA512 is not set | 1225 | # CONFIG_CRYPTO_SHA512 is not set |
diff --git a/arch/powerpc/kernel/cputable.c b/arch/powerpc/kernel/cputable.c index f7f3c215d06f..b936a1dd0a50 100644 --- a/arch/powerpc/kernel/cputable.c +++ b/arch/powerpc/kernel/cputable.c | |||
@@ -355,6 +355,7 @@ static struct cpu_spec __initdata cpu_specs[] = { | |||
355 | .icache_bsize = 128, | 355 | .icache_bsize = 128, |
356 | .dcache_bsize = 128, | 356 | .dcache_bsize = 128, |
357 | .machine_check = machine_check_generic, | 357 | .machine_check = machine_check_generic, |
358 | .oprofile_cpu_type = "ppc64/compat-power5+", | ||
358 | .platform = "power5+", | 359 | .platform = "power5+", |
359 | }, | 360 | }, |
360 | { /* Power6 */ | 361 | { /* Power6 */ |
@@ -386,6 +387,7 @@ static struct cpu_spec __initdata cpu_specs[] = { | |||
386 | .icache_bsize = 128, | 387 | .icache_bsize = 128, |
387 | .dcache_bsize = 128, | 388 | .dcache_bsize = 128, |
388 | .machine_check = machine_check_generic, | 389 | .machine_check = machine_check_generic, |
390 | .oprofile_cpu_type = "ppc64/compat-power6", | ||
389 | .platform = "power6", | 391 | .platform = "power6", |
390 | }, | 392 | }, |
391 | { /* 2.06-compliant processor, i.e. Power7 "architected" mode */ | 393 | { /* 2.06-compliant processor, i.e. Power7 "architected" mode */ |
@@ -397,6 +399,7 @@ static struct cpu_spec __initdata cpu_specs[] = { | |||
397 | .icache_bsize = 128, | 399 | .icache_bsize = 128, |
398 | .dcache_bsize = 128, | 400 | .dcache_bsize = 128, |
399 | .machine_check = machine_check_generic, | 401 | .machine_check = machine_check_generic, |
402 | .oprofile_cpu_type = "ppc64/compat-power7", | ||
400 | .platform = "power7", | 403 | .platform = "power7", |
401 | }, | 404 | }, |
402 | { /* Power7 */ | 405 | { /* Power7 */ |
@@ -1629,6 +1632,23 @@ struct cpu_spec * __init identify_cpu(unsigned long offset, unsigned int pvr) | |||
1629 | t->cpu_setup = s->cpu_setup; | 1632 | t->cpu_setup = s->cpu_setup; |
1630 | t->cpu_restore = s->cpu_restore; | 1633 | t->cpu_restore = s->cpu_restore; |
1631 | t->platform = s->platform; | 1634 | t->platform = s->platform; |
1635 | /* | ||
1636 | * If we have passed through this logic once | ||
1637 | * before and have pulled the default case | ||
1638 | * because the real PVR was not found inside | ||
1639 | * cpu_specs[], then we are possibly running in | ||
1640 | * compatibility mode. In that case, let the | ||
1641 | * oprofiler know which set of compatibility | ||
1642 | * counters to pull from by making sure the | ||
1643 | * oprofile_cpu_type string is set to that of | ||
1644 | * compatibility mode. If the oprofile_cpu_type | ||
1645 | * already has a value, then we are possibly | ||
1646 | * overriding a real PVR with a logical one, and, | ||
1647 | * in that case, keep the current value for | ||
1648 | * oprofile_cpu_type. | ||
1649 | */ | ||
1650 | if (t->oprofile_cpu_type == NULL) | ||
1651 | t->oprofile_cpu_type = s->oprofile_cpu_type; | ||
1632 | } else | 1652 | } else |
1633 | *t = *s; | 1653 | *t = *s; |
1634 | *PTRRELOC(&cur_cpu_spec) = &the_cpu_spec; | 1654 | *PTRRELOC(&cur_cpu_spec) = &the_cpu_spec; |
diff --git a/arch/powerpc/kernel/head_fsl_booke.S b/arch/powerpc/kernel/head_fsl_booke.S index c4268500e856..3cb52fa0eda3 100644 --- a/arch/powerpc/kernel/head_fsl_booke.S +++ b/arch/powerpc/kernel/head_fsl_booke.S | |||
@@ -151,16 +151,11 @@ skpinv: addi r6,r6,1 /* Increment */ | |||
151 | /* Invalidate TLB0 */ | 151 | /* Invalidate TLB0 */ |
152 | li r6,0x04 | 152 | li r6,0x04 |
153 | tlbivax 0,r6 | 153 | tlbivax 0,r6 |
154 | #ifdef CONFIG_SMP | 154 | TLBSYNC |
155 | tlbsync | ||
156 | #endif | ||
157 | /* Invalidate TLB1 */ | 155 | /* Invalidate TLB1 */ |
158 | li r6,0x0c | 156 | li r6,0x0c |
159 | tlbivax 0,r6 | 157 | tlbivax 0,r6 |
160 | #ifdef CONFIG_SMP | 158 | TLBSYNC |
161 | tlbsync | ||
162 | #endif | ||
163 | msync | ||
164 | 159 | ||
165 | /* 3. Setup a temp mapping and jump to it */ | 160 | /* 3. Setup a temp mapping and jump to it */ |
166 | andi. r5, r3, 0x1 /* Find an entry not used and is non-zero */ | 161 | andi. r5, r3, 0x1 /* Find an entry not used and is non-zero */ |
@@ -238,10 +233,7 @@ skpinv: addi r6,r6,1 /* Increment */ | |||
238 | /* Invalidate TLB1 */ | 233 | /* Invalidate TLB1 */ |
239 | li r9,0x0c | 234 | li r9,0x0c |
240 | tlbivax 0,r9 | 235 | tlbivax 0,r9 |
241 | #ifdef CONFIG_SMP | 236 | TLBSYNC |
242 | tlbsync | ||
243 | #endif | ||
244 | msync | ||
245 | 237 | ||
246 | /* 6. Setup KERNELBASE mapping in TLB1[0] */ | 238 | /* 6. Setup KERNELBASE mapping in TLB1[0] */ |
247 | lis r6,0x1000 /* Set MAS0(TLBSEL) = TLB1(1), ESEL = 0 */ | 239 | lis r6,0x1000 /* Set MAS0(TLBSEL) = TLB1(1), ESEL = 0 */ |
@@ -283,10 +275,7 @@ skpinv: addi r6,r6,1 /* Increment */ | |||
283 | /* Invalidate TLB1 */ | 275 | /* Invalidate TLB1 */ |
284 | li r9,0x0c | 276 | li r9,0x0c |
285 | tlbivax 0,r9 | 277 | tlbivax 0,r9 |
286 | #ifdef CONFIG_SMP | 278 | TLBSYNC |
287 | tlbsync | ||
288 | #endif | ||
289 | msync | ||
290 | 279 | ||
291 | /* Establish the interrupt vector offsets */ | 280 | /* Establish the interrupt vector offsets */ |
292 | SET_IVOR(0, CriticalInput); | 281 | SET_IVOR(0, CriticalInput); |
@@ -483,90 +472,16 @@ interrupt_base: | |||
483 | 472 | ||
484 | /* Data Storage Interrupt */ | 473 | /* Data Storage Interrupt */ |
485 | START_EXCEPTION(DataStorage) | 474 | START_EXCEPTION(DataStorage) |
486 | mtspr SPRN_SPRG0, r10 /* Save some working registers */ | 475 | NORMAL_EXCEPTION_PROLOG |
487 | mtspr SPRN_SPRG1, r11 | 476 | mfspr r5,SPRN_ESR /* Grab the ESR, save it, pass arg3 */ |
488 | mtspr SPRN_SPRG4W, r12 | 477 | stw r5,_ESR(r11) |
489 | mtspr SPRN_SPRG5W, r13 | 478 | mfspr r4,SPRN_DEAR /* Grab the DEAR, save it, pass arg2 */ |
490 | mfcr r11 | 479 | andis. r10,r5,(ESR_ILK|ESR_DLK)@h |
491 | mtspr SPRN_SPRG7W, r11 | 480 | bne 1f |
492 | 481 | EXC_XFER_EE_LITE(0x0300, handle_page_fault) | |
493 | /* | 482 | 1: |
494 | * Check if it was a store fault, if not then bail | 483 | addi r3,r1,STACK_FRAME_OVERHEAD |
495 | * because a user tried to access a kernel or | 484 | EXC_XFER_EE_LITE(0x0300, CacheLockingException) |
496 | * read-protected page. Otherwise, get the | ||
497 | * offending address and handle it. | ||
498 | */ | ||
499 | mfspr r10, SPRN_ESR | ||
500 | andis. r10, r10, ESR_ST@h | ||
501 | beq 2f | ||
502 | |||
503 | mfspr r10, SPRN_DEAR /* Get faulting address */ | ||
504 | |||
505 | /* If we are faulting a kernel address, we have to use the | ||
506 | * kernel page tables. | ||
507 | */ | ||
508 | lis r11, PAGE_OFFSET@h | ||
509 | cmplw 0, r10, r11 | ||
510 | bge 2f | ||
511 | |||
512 | /* Get the PGD for the current thread */ | ||
513 | 3: | ||
514 | mfspr r11,SPRN_SPRG3 | ||
515 | lwz r11,PGDIR(r11) | ||
516 | 4: | ||
517 | FIND_PTE | ||
518 | |||
519 | /* Are _PAGE_USER & _PAGE_RW set & _PAGE_HWWRITE not? */ | ||
520 | andi. r13, r11, _PAGE_RW|_PAGE_USER|_PAGE_HWWRITE | ||
521 | cmpwi 0, r13, _PAGE_RW|_PAGE_USER | ||
522 | bne 2f /* Bail if not */ | ||
523 | |||
524 | /* Update 'changed'. */ | ||
525 | ori r11, r11, _PAGE_DIRTY|_PAGE_ACCESSED|_PAGE_HWWRITE | ||
526 | stw r11, PTE_FLAGS_OFFSET(r12) /* Update Linux page table */ | ||
527 | |||
528 | /* MAS2 not updated as the entry does exist in the tlb, this | ||
529 | fault taken to detect state transition (eg: COW -> DIRTY) | ||
530 | */ | ||
531 | andi. r11, r11, _PAGE_HWEXEC | ||
532 | rlwimi r11, r11, 31, 27, 27 /* SX <- _PAGE_HWEXEC */ | ||
533 | ori r11, r11, (MAS3_UW|MAS3_SW|MAS3_UR|MAS3_SR)@l /* set static perms */ | ||
534 | |||
535 | /* update search PID in MAS6, AS = 0 */ | ||
536 | mfspr r12, SPRN_PID0 | ||
537 | slwi r12, r12, 16 | ||
538 | mtspr SPRN_MAS6, r12 | ||
539 | |||
540 | /* find the TLB index that caused the fault. It has to be here. */ | ||
541 | tlbsx 0, r10 | ||
542 | |||
543 | /* only update the perm bits, assume the RPN is fine */ | ||
544 | mfspr r12, SPRN_MAS3 | ||
545 | rlwimi r12, r11, 0, 20, 31 | ||
546 | mtspr SPRN_MAS3,r12 | ||
547 | tlbwe | ||
548 | |||
549 | /* Done...restore registers and get out of here. */ | ||
550 | mfspr r11, SPRN_SPRG7R | ||
551 | mtcr r11 | ||
552 | mfspr r13, SPRN_SPRG5R | ||
553 | mfspr r12, SPRN_SPRG4R | ||
554 | mfspr r11, SPRN_SPRG1 | ||
555 | mfspr r10, SPRN_SPRG0 | ||
556 | rfi /* Force context change */ | ||
557 | |||
558 | 2: | ||
559 | /* | ||
560 | * The bailout. Restore registers to pre-exception conditions | ||
561 | * and call the heavyweights to help us out. | ||
562 | */ | ||
563 | mfspr r11, SPRN_SPRG7R | ||
564 | mtcr r11 | ||
565 | mfspr r13, SPRN_SPRG5R | ||
566 | mfspr r12, SPRN_SPRG4R | ||
567 | mfspr r11, SPRN_SPRG1 | ||
568 | mfspr r10, SPRN_SPRG0 | ||
569 | b data_access | ||
570 | 485 | ||
571 | /* Instruction Storage Interrupt */ | 486 | /* Instruction Storage Interrupt */ |
572 | INSTRUCTION_STORAGE_EXCEPTION | 487 | INSTRUCTION_STORAGE_EXCEPTION |
@@ -645,15 +560,30 @@ interrupt_base: | |||
645 | lwz r11,PGDIR(r11) | 560 | lwz r11,PGDIR(r11) |
646 | 561 | ||
647 | 4: | 562 | 4: |
563 | /* Mask of required permission bits. Note that while we | ||
564 | * do copy ESR:ST to _PAGE_RW position as trying to write | ||
565 | * to an RO page is pretty common, we don't do it with | ||
566 | * _PAGE_DIRTY. We could do it, but it's a fairly rare | ||
567 | * event so I'd rather take the overhead when it happens | ||
568 | * rather than adding an instruction here. We should measure | ||
569 | * whether the whole thing is worth it in the first place | ||
570 | * as we could avoid loading SPRN_ESR completely in the first | ||
571 | * place... | ||
572 | * | ||
573 | * TODO: Is it worth doing that mfspr & rlwimi in the first | ||
574 | * place or can we save a couple of instructions here ? | ||
575 | */ | ||
576 | mfspr r12,SPRN_ESR | ||
577 | li r13,_PAGE_PRESENT|_PAGE_ACCESSED | ||
578 | rlwimi r13,r12,11,29,29 | ||
579 | |||
648 | FIND_PTE | 580 | FIND_PTE |
649 | andi. r13, r11, _PAGE_PRESENT /* Is the page present? */ | 581 | andc. r13,r13,r11 /* Check permission */ |
650 | beq 2f /* Bail if not present */ | 582 | bne 2f /* Bail if permission mismach */ |
651 | 583 | ||
652 | #ifdef CONFIG_PTE_64BIT | 584 | #ifdef CONFIG_PTE_64BIT |
653 | lwz r13, 0(r12) | 585 | lwz r13, 0(r12) |
654 | #endif | 586 | #endif |
655 | ori r11, r11, _PAGE_ACCESSED | ||
656 | stw r11, PTE_FLAGS_OFFSET(r12) | ||
657 | 587 | ||
658 | /* Jump to common tlb load */ | 588 | /* Jump to common tlb load */ |
659 | b finish_tlb_load | 589 | b finish_tlb_load |
@@ -667,7 +597,7 @@ interrupt_base: | |||
667 | mfspr r12, SPRN_SPRG4R | 597 | mfspr r12, SPRN_SPRG4R |
668 | mfspr r11, SPRN_SPRG1 | 598 | mfspr r11, SPRN_SPRG1 |
669 | mfspr r10, SPRN_SPRG0 | 599 | mfspr r10, SPRN_SPRG0 |
670 | b data_access | 600 | b DataStorage |
671 | 601 | ||
672 | /* Instruction TLB Error Interrupt */ | 602 | /* Instruction TLB Error Interrupt */ |
673 | /* | 603 | /* |
@@ -705,15 +635,16 @@ interrupt_base: | |||
705 | lwz r11,PGDIR(r11) | 635 | lwz r11,PGDIR(r11) |
706 | 636 | ||
707 | 4: | 637 | 4: |
638 | /* Make up the required permissions */ | ||
639 | li r13,_PAGE_PRESENT | _PAGE_ACCESSED | _PAGE_HWEXEC | ||
640 | |||
708 | FIND_PTE | 641 | FIND_PTE |
709 | andi. r13, r11, _PAGE_PRESENT /* Is the page present? */ | 642 | andc. r13,r13,r11 /* Check permission */ |
710 | beq 2f /* Bail if not present */ | 643 | bne 2f /* Bail if permission mismach */ |
711 | 644 | ||
712 | #ifdef CONFIG_PTE_64BIT | 645 | #ifdef CONFIG_PTE_64BIT |
713 | lwz r13, 0(r12) | 646 | lwz r13, 0(r12) |
714 | #endif | 647 | #endif |
715 | ori r11, r11, _PAGE_ACCESSED | ||
716 | stw r11, PTE_FLAGS_OFFSET(r12) | ||
717 | 648 | ||
718 | /* Jump to common TLB load point */ | 649 | /* Jump to common TLB load point */ |
719 | b finish_tlb_load | 650 | b finish_tlb_load |
@@ -768,29 +699,13 @@ interrupt_base: | |||
768 | * Local functions | 699 | * Local functions |
769 | */ | 700 | */ |
770 | 701 | ||
771 | /* | ||
772 | * Data TLB exceptions will bail out to this point | ||
773 | * if they can't resolve the lightweight TLB fault. | ||
774 | */ | ||
775 | data_access: | ||
776 | NORMAL_EXCEPTION_PROLOG | ||
777 | mfspr r5,SPRN_ESR /* Grab the ESR, save it, pass arg3 */ | ||
778 | stw r5,_ESR(r11) | ||
779 | mfspr r4,SPRN_DEAR /* Grab the DEAR, save it, pass arg2 */ | ||
780 | andis. r10,r5,(ESR_ILK|ESR_DLK)@h | ||
781 | bne 1f | ||
782 | EXC_XFER_EE_LITE(0x0300, handle_page_fault) | ||
783 | 1: | ||
784 | addi r3,r1,STACK_FRAME_OVERHEAD | ||
785 | EXC_XFER_EE_LITE(0x0300, CacheLockingException) | ||
786 | |||
787 | /* | 702 | /* |
788 | |||
789 | * Both the instruction and data TLB miss get to this | 703 | * Both the instruction and data TLB miss get to this |
790 | * point to load the TLB. | 704 | * point to load the TLB. |
791 | * r10 - EA of fault | 705 | * r10 - EA of fault |
792 | * r11 - TLB (info from Linux PTE) | 706 | * r11 - TLB (info from Linux PTE) |
793 | * r12, r13 - available to use | 707 | * r12 - available to use |
708 | * r13 - upper bits of PTE (if PTE_64BIT) or available to use | ||
794 | * CR5 - results of addr >= PAGE_OFFSET | 709 | * CR5 - results of addr >= PAGE_OFFSET |
795 | * MAS0, MAS1 - loaded with proper value when we get here | 710 | * MAS0, MAS1 - loaded with proper value when we get here |
796 | * MAS2, MAS3 - will need additional info from Linux PTE | 711 | * MAS2, MAS3 - will need additional info from Linux PTE |
@@ -812,20 +727,14 @@ finish_tlb_load: | |||
812 | #endif | 727 | #endif |
813 | mtspr SPRN_MAS2, r12 | 728 | mtspr SPRN_MAS2, r12 |
814 | 729 | ||
815 | bge 5, 1f | 730 | li r10, (_PAGE_HWEXEC | _PAGE_PRESENT) |
816 | 731 | rlwimi r10, r11, 31, 29, 29 /* extract _PAGE_DIRTY into SW */ | |
817 | /* is user addr */ | 732 | and r12, r11, r10 |
818 | andi. r12, r11, (_PAGE_USER | _PAGE_HWWRITE | _PAGE_HWEXEC) | ||
819 | andi. r10, r11, _PAGE_USER /* Test for _PAGE_USER */ | 733 | andi. r10, r11, _PAGE_USER /* Test for _PAGE_USER */ |
820 | srwi r10, r12, 1 | 734 | slwi r10, r12, 1 |
821 | or r12, r12, r10 /* Copy user perms into supervisor */ | 735 | or r10, r10, r12 |
822 | iseleq r12, 0, r12 | 736 | iseleq r12, r12, r10 |
823 | b 2f | 737 | |
824 | |||
825 | /* is kernel addr */ | ||
826 | 1: rlwinm r12, r11, 31, 29, 29 /* Extract _PAGE_HWWRITE into SW */ | ||
827 | ori r12, r12, (MAS3_SX | MAS3_SR) | ||
828 | |||
829 | #ifdef CONFIG_PTE_64BIT | 738 | #ifdef CONFIG_PTE_64BIT |
830 | 2: rlwimi r12, r13, 24, 0, 7 /* grab RPN[32:39] */ | 739 | 2: rlwimi r12, r13, 24, 0, 7 /* grab RPN[32:39] */ |
831 | rlwimi r12, r11, 24, 8, 19 /* grab RPN[40:51] */ | 740 | rlwimi r12, r11, 24, 8, 19 /* grab RPN[40:51] */ |
diff --git a/arch/powerpc/kernel/iommu.c b/arch/powerpc/kernel/iommu.c index 8c68ee9e5d1c..2385f68c1751 100644 --- a/arch/powerpc/kernel/iommu.c +++ b/arch/powerpc/kernel/iommu.c | |||
@@ -186,7 +186,8 @@ static unsigned long iommu_range_alloc(struct device *dev, | |||
186 | static dma_addr_t iommu_alloc(struct device *dev, struct iommu_table *tbl, | 186 | static dma_addr_t iommu_alloc(struct device *dev, struct iommu_table *tbl, |
187 | void *page, unsigned int npages, | 187 | void *page, unsigned int npages, |
188 | enum dma_data_direction direction, | 188 | enum dma_data_direction direction, |
189 | unsigned long mask, unsigned int align_order) | 189 | unsigned long mask, unsigned int align_order, |
190 | struct dma_attrs *attrs) | ||
190 | { | 191 | { |
191 | unsigned long entry, flags; | 192 | unsigned long entry, flags; |
192 | dma_addr_t ret = DMA_ERROR_CODE; | 193 | dma_addr_t ret = DMA_ERROR_CODE; |
@@ -205,7 +206,7 @@ static dma_addr_t iommu_alloc(struct device *dev, struct iommu_table *tbl, | |||
205 | 206 | ||
206 | /* Put the TCEs in the HW table */ | 207 | /* Put the TCEs in the HW table */ |
207 | ppc_md.tce_build(tbl, entry, npages, (unsigned long)page & IOMMU_PAGE_MASK, | 208 | ppc_md.tce_build(tbl, entry, npages, (unsigned long)page & IOMMU_PAGE_MASK, |
208 | direction); | 209 | direction, attrs); |
209 | 210 | ||
210 | 211 | ||
211 | /* Flush/invalidate TLB caches if necessary */ | 212 | /* Flush/invalidate TLB caches if necessary */ |
@@ -336,7 +337,8 @@ int iommu_map_sg(struct device *dev, struct iommu_table *tbl, | |||
336 | npages, entry, dma_addr); | 337 | npages, entry, dma_addr); |
337 | 338 | ||
338 | /* Insert into HW table */ | 339 | /* Insert into HW table */ |
339 | ppc_md.tce_build(tbl, entry, npages, vaddr & IOMMU_PAGE_MASK, direction); | 340 | ppc_md.tce_build(tbl, entry, npages, vaddr & IOMMU_PAGE_MASK, |
341 | direction, attrs); | ||
340 | 342 | ||
341 | /* If we are in an open segment, try merging */ | 343 | /* If we are in an open segment, try merging */ |
342 | if (segstart != s) { | 344 | if (segstart != s) { |
@@ -573,7 +575,8 @@ dma_addr_t iommu_map_single(struct device *dev, struct iommu_table *tbl, | |||
573 | align = PAGE_SHIFT - IOMMU_PAGE_SHIFT; | 575 | align = PAGE_SHIFT - IOMMU_PAGE_SHIFT; |
574 | 576 | ||
575 | dma_handle = iommu_alloc(dev, tbl, vaddr, npages, direction, | 577 | dma_handle = iommu_alloc(dev, tbl, vaddr, npages, direction, |
576 | mask >> IOMMU_PAGE_SHIFT, align); | 578 | mask >> IOMMU_PAGE_SHIFT, align, |
579 | attrs); | ||
577 | if (dma_handle == DMA_ERROR_CODE) { | 580 | if (dma_handle == DMA_ERROR_CODE) { |
578 | if (printk_ratelimit()) { | 581 | if (printk_ratelimit()) { |
579 | printk(KERN_INFO "iommu_alloc failed, " | 582 | printk(KERN_INFO "iommu_alloc failed, " |
@@ -642,7 +645,7 @@ void *iommu_alloc_coherent(struct device *dev, struct iommu_table *tbl, | |||
642 | nio_pages = size >> IOMMU_PAGE_SHIFT; | 645 | nio_pages = size >> IOMMU_PAGE_SHIFT; |
643 | io_order = get_iommu_order(size); | 646 | io_order = get_iommu_order(size); |
644 | mapping = iommu_alloc(dev, tbl, ret, nio_pages, DMA_BIDIRECTIONAL, | 647 | mapping = iommu_alloc(dev, tbl, ret, nio_pages, DMA_BIDIRECTIONAL, |
645 | mask >> IOMMU_PAGE_SHIFT, io_order); | 648 | mask >> IOMMU_PAGE_SHIFT, io_order, NULL); |
646 | if (mapping == DMA_ERROR_CODE) { | 649 | if (mapping == DMA_ERROR_CODE) { |
647 | free_pages((unsigned long)ret, order); | 650 | free_pages((unsigned long)ret, order); |
648 | return NULL; | 651 | return NULL; |
diff --git a/arch/powerpc/kernel/pci-common.c b/arch/powerpc/kernel/pci-common.c index 063cdd413049..224e9a11765c 100644 --- a/arch/powerpc/kernel/pci-common.c +++ b/arch/powerpc/kernel/pci-common.c | |||
@@ -598,6 +598,7 @@ void __devinit pci_process_bridge_OF_ranges(struct pci_controller *hose, | |||
598 | res->start = pci_addr; | 598 | res->start = pci_addr; |
599 | break; | 599 | break; |
600 | case 2: /* PCI Memory space */ | 600 | case 2: /* PCI Memory space */ |
601 | case 3: /* PCI 64 bits Memory space */ | ||
601 | printk(KERN_INFO | 602 | printk(KERN_INFO |
602 | " MEM 0x%016llx..0x%016llx -> 0x%016llx %s\n", | 603 | " MEM 0x%016llx..0x%016llx -> 0x%016llx %s\n", |
603 | cpu_addr, cpu_addr + size - 1, pci_addr, | 604 | cpu_addr, cpu_addr + size - 1, pci_addr, |
diff --git a/arch/powerpc/kernel/prom_parse.c b/arch/powerpc/kernel/prom_parse.c index 90eb3a3e383e..bc1fb27368af 100644 --- a/arch/powerpc/kernel/prom_parse.c +++ b/arch/powerpc/kernel/prom_parse.c | |||
@@ -128,12 +128,35 @@ static void of_bus_pci_count_cells(struct device_node *np, | |||
128 | *sizec = 2; | 128 | *sizec = 2; |
129 | } | 129 | } |
130 | 130 | ||
131 | static unsigned int of_bus_pci_get_flags(const u32 *addr) | ||
132 | { | ||
133 | unsigned int flags = 0; | ||
134 | u32 w = addr[0]; | ||
135 | |||
136 | switch((w >> 24) & 0x03) { | ||
137 | case 0x01: | ||
138 | flags |= IORESOURCE_IO; | ||
139 | break; | ||
140 | case 0x02: /* 32 bits */ | ||
141 | case 0x03: /* 64 bits */ | ||
142 | flags |= IORESOURCE_MEM; | ||
143 | break; | ||
144 | } | ||
145 | if (w & 0x40000000) | ||
146 | flags |= IORESOURCE_PREFETCH; | ||
147 | return flags; | ||
148 | } | ||
149 | |||
131 | static u64 of_bus_pci_map(u32 *addr, const u32 *range, int na, int ns, int pna) | 150 | static u64 of_bus_pci_map(u32 *addr, const u32 *range, int na, int ns, int pna) |
132 | { | 151 | { |
133 | u64 cp, s, da; | 152 | u64 cp, s, da; |
153 | unsigned int af, rf; | ||
154 | |||
155 | af = of_bus_pci_get_flags(addr); | ||
156 | rf = of_bus_pci_get_flags(range); | ||
134 | 157 | ||
135 | /* Check address type match */ | 158 | /* Check address type match */ |
136 | if ((addr[0] ^ range[0]) & 0x03000000) | 159 | if ((af ^ rf) & (IORESOURCE_MEM | IORESOURCE_IO)) |
137 | return OF_BAD_ADDR; | 160 | return OF_BAD_ADDR; |
138 | 161 | ||
139 | /* Read address values, skipping high cell */ | 162 | /* Read address values, skipping high cell */ |
@@ -153,25 +176,6 @@ static int of_bus_pci_translate(u32 *addr, u64 offset, int na) | |||
153 | return of_bus_default_translate(addr + 1, offset, na - 1); | 176 | return of_bus_default_translate(addr + 1, offset, na - 1); |
154 | } | 177 | } |
155 | 178 | ||
156 | static unsigned int of_bus_pci_get_flags(const u32 *addr) | ||
157 | { | ||
158 | unsigned int flags = 0; | ||
159 | u32 w = addr[0]; | ||
160 | |||
161 | switch((w >> 24) & 0x03) { | ||
162 | case 0x01: | ||
163 | flags |= IORESOURCE_IO; | ||
164 | break; | ||
165 | case 0x02: /* 32 bits */ | ||
166 | case 0x03: /* 64 bits */ | ||
167 | flags |= IORESOURCE_MEM; | ||
168 | break; | ||
169 | } | ||
170 | if (w & 0x40000000) | ||
171 | flags |= IORESOURCE_PREFETCH; | ||
172 | return flags; | ||
173 | } | ||
174 | |||
175 | const u32 *of_get_pci_address(struct device_node *dev, int bar_no, u64 *size, | 179 | const u32 *of_get_pci_address(struct device_node *dev, int bar_no, u64 *size, |
176 | unsigned int *flags) | 180 | unsigned int *flags) |
177 | { | 181 | { |
diff --git a/arch/powerpc/kernel/stacktrace.c b/arch/powerpc/kernel/stacktrace.c index 071bee3ec749..f2589645870a 100644 --- a/arch/powerpc/kernel/stacktrace.c +++ b/arch/powerpc/kernel/stacktrace.c | |||
@@ -59,6 +59,6 @@ EXPORT_SYMBOL_GPL(save_stack_trace); | |||
59 | 59 | ||
60 | void save_stack_trace_tsk(struct task_struct *tsk, struct stack_trace *trace) | 60 | void save_stack_trace_tsk(struct task_struct *tsk, struct stack_trace *trace) |
61 | { | 61 | { |
62 | save_context_stack(trace, tsk->thread.regs->gpr[1], tsk, 0); | 62 | save_context_stack(trace, tsk->thread.ksp, tsk, 0); |
63 | } | 63 | } |
64 | EXPORT_SYMBOL_GPL(save_stack_trace_tsk); | 64 | EXPORT_SYMBOL_GPL(save_stack_trace_tsk); |
diff --git a/arch/powerpc/kernel/vmlinux.lds.S b/arch/powerpc/kernel/vmlinux.lds.S index 87a72c66ce27..a914411bced5 100644 --- a/arch/powerpc/kernel/vmlinux.lds.S +++ b/arch/powerpc/kernel/vmlinux.lds.S | |||
@@ -9,6 +9,25 @@ | |||
9 | 9 | ||
10 | ENTRY(_stext) | 10 | ENTRY(_stext) |
11 | 11 | ||
12 | PHDRS { | ||
13 | kernel PT_LOAD FLAGS(7); /* RWX */ | ||
14 | notes PT_NOTE FLAGS(0); | ||
15 | dummy PT_NOTE FLAGS(0); | ||
16 | |||
17 | /* binutils < 2.18 has a bug that makes it misbehave when taking an | ||
18 | ELF file with all segments at load address 0 as input. This | ||
19 | happens when running "strip" on vmlinux, because of the AT() magic | ||
20 | in this linker script. People using GCC >= 4.2 won't run into | ||
21 | this problem, because the "build-id" support will put some data | ||
22 | into the "notes" segment (at a non-zero load address). | ||
23 | |||
24 | To work around this, we force some data into both the "dummy" | ||
25 | segment and the kernel segment, so the dummy segment will get a | ||
26 | non-zero load address. It's not enough to always create the | ||
27 | "notes" segment, since if nothing gets assigned to it, its load | ||
28 | address will be zero. */ | ||
29 | } | ||
30 | |||
12 | #ifdef CONFIG_PPC64 | 31 | #ifdef CONFIG_PPC64 |
13 | OUTPUT_ARCH(powerpc:common64) | 32 | OUTPUT_ARCH(powerpc:common64) |
14 | jiffies = jiffies_64; | 33 | jiffies = jiffies_64; |
@@ -50,7 +69,7 @@ SECTIONS | |||
50 | . = ALIGN(PAGE_SIZE); | 69 | . = ALIGN(PAGE_SIZE); |
51 | _etext = .; | 70 | _etext = .; |
52 | PROVIDE32 (etext = .); | 71 | PROVIDE32 (etext = .); |
53 | } | 72 | } :kernel |
54 | 73 | ||
55 | /* Read-only data */ | 74 | /* Read-only data */ |
56 | RODATA | 75 | RODATA |
@@ -62,7 +81,13 @@ SECTIONS | |||
62 | __stop___ex_table = .; | 81 | __stop___ex_table = .; |
63 | } | 82 | } |
64 | 83 | ||
65 | NOTES | 84 | NOTES :kernel :notes |
85 | |||
86 | /* The dummy segment contents for the bug workaround mentioned above | ||
87 | near PHDRS. */ | ||
88 | .dummy : { | ||
89 | LONG(0xf177) | ||
90 | } :kernel :dummy | ||
66 | 91 | ||
67 | /* | 92 | /* |
68 | * Init sections discarded at runtime | 93 | * Init sections discarded at runtime |
@@ -74,7 +99,7 @@ SECTIONS | |||
74 | _sinittext = .; | 99 | _sinittext = .; |
75 | INIT_TEXT | 100 | INIT_TEXT |
76 | _einittext = .; | 101 | _einittext = .; |
77 | } | 102 | } :kernel |
78 | 103 | ||
79 | /* .exit.text is discarded at runtime, not link time, | 104 | /* .exit.text is discarded at runtime, not link time, |
80 | * to deal with references from __bug_table | 105 | * to deal with references from __bug_table |
diff --git a/arch/powerpc/lib/feature-fixups.c b/arch/powerpc/lib/feature-fixups.c index 4e43702b9813..8c5a03be31e0 100644 --- a/arch/powerpc/lib/feature-fixups.c +++ b/arch/powerpc/lib/feature-fixups.c | |||
@@ -99,7 +99,7 @@ void do_feature_fixups(unsigned long value, void *fixup_start, void *fixup_end) | |||
99 | 99 | ||
100 | for (; fcur < fend; fcur++) { | 100 | for (; fcur < fend; fcur++) { |
101 | if (patch_feature_section(value, fcur)) { | 101 | if (patch_feature_section(value, fcur)) { |
102 | __WARN(); | 102 | WARN_ON(1); |
103 | printk("Unable to patch feature section at %p - %p" \ | 103 | printk("Unable to patch feature section at %p - %p" \ |
104 | " with %p - %p\n", | 104 | " with %p - %p\n", |
105 | calc_addr(fcur, fcur->start_off), | 105 | calc_addr(fcur, fcur->start_off), |
diff --git a/arch/powerpc/lib/string.S b/arch/powerpc/lib/string.S index 49eb1f1a2bb4..64e2e499e32a 100644 --- a/arch/powerpc/lib/string.S +++ b/arch/powerpc/lib/string.S | |||
@@ -13,13 +13,7 @@ | |||
13 | #include <asm/ppc_asm.h> | 13 | #include <asm/ppc_asm.h> |
14 | 14 | ||
15 | .section __ex_table,"a" | 15 | .section __ex_table,"a" |
16 | #ifdef CONFIG_PPC64 | 16 | PPC_LONG_ALIGN |
17 | .align 3 | ||
18 | #define EXTBL .llong | ||
19 | #else | ||
20 | .align 2 | ||
21 | #define EXTBL .long | ||
22 | #endif | ||
23 | .text | 17 | .text |
24 | 18 | ||
25 | _GLOBAL(strcpy) | 19 | _GLOBAL(strcpy) |
@@ -160,9 +154,9 @@ _GLOBAL(__clear_user) | |||
160 | blr | 154 | blr |
161 | 155 | ||
162 | .section __ex_table,"a" | 156 | .section __ex_table,"a" |
163 | EXTBL 11b,90b | 157 | PPC_LONG 11b,90b |
164 | EXTBL 1b,91b | 158 | PPC_LONG 1b,91b |
165 | EXTBL 8b,92b | 159 | PPC_LONG 8b,92b |
166 | .text | 160 | .text |
167 | 161 | ||
168 | _GLOBAL(__strncpy_from_user) | 162 | _GLOBAL(__strncpy_from_user) |
@@ -183,7 +177,7 @@ _GLOBAL(__strncpy_from_user) | |||
183 | blr | 177 | blr |
184 | 178 | ||
185 | .section __ex_table,"a" | 179 | .section __ex_table,"a" |
186 | EXTBL 1b,99b | 180 | PPC_LONG 1b,99b |
187 | .text | 181 | .text |
188 | 182 | ||
189 | /* r3 = str, r4 = len (> 0), r5 = top (highest addr) */ | 183 | /* r3 = str, r4 = len (> 0), r5 = top (highest addr) */ |
@@ -208,4 +202,4 @@ _GLOBAL(__strnlen_user) | |||
208 | blr | 202 | blr |
209 | 203 | ||
210 | .section __ex_table,"a" | 204 | .section __ex_table,"a" |
211 | EXTBL 1b,99b | 205 | PPC_LONG 1b,99b |
diff --git a/arch/powerpc/platforms/52xx/Kconfig b/arch/powerpc/platforms/52xx/Kconfig index acd2fc8cf492..d664b1bce381 100644 --- a/arch/powerpc/platforms/52xx/Kconfig +++ b/arch/powerpc/platforms/52xx/Kconfig | |||
@@ -3,6 +3,7 @@ config PPC_MPC52xx | |||
3 | depends on PPC_MULTIPLATFORM && PPC32 | 3 | depends on PPC_MULTIPLATFORM && PPC32 |
4 | select FSL_SOC | 4 | select FSL_SOC |
5 | select PPC_CLOCK | 5 | select PPC_CLOCK |
6 | select PPC_PCI_CHOICE | ||
6 | 7 | ||
7 | config PPC_MPC5200_SIMPLE | 8 | config PPC_MPC5200_SIMPLE |
8 | bool "Generic support for simple MPC5200 based boards" | 9 | bool "Generic support for simple MPC5200 based boards" |
diff --git a/arch/powerpc/platforms/82xx/Kconfig b/arch/powerpc/platforms/82xx/Kconfig index 1c8034bfa796..75eb1ede5497 100644 --- a/arch/powerpc/platforms/82xx/Kconfig +++ b/arch/powerpc/platforms/82xx/Kconfig | |||
@@ -30,6 +30,7 @@ config EP8248E | |||
30 | select 8272 | 30 | select 8272 |
31 | select 8260 | 31 | select 8260 |
32 | select FSL_SOC | 32 | select FSL_SOC |
33 | select PHYLIB | ||
33 | select MDIO_BITBANG | 34 | select MDIO_BITBANG |
34 | help | 35 | help |
35 | This enables support for the Embedded Planet EP8248E board. | 36 | This enables support for the Embedded Planet EP8248E board. |
diff --git a/arch/powerpc/platforms/82xx/ep8248e.c b/arch/powerpc/platforms/82xx/ep8248e.c index 373e993a5ed5..d5770fdf7f09 100644 --- a/arch/powerpc/platforms/82xx/ep8248e.c +++ b/arch/powerpc/platforms/82xx/ep8248e.c | |||
@@ -59,7 +59,6 @@ static void __init ep8248e_pic_init(void) | |||
59 | of_node_put(np); | 59 | of_node_put(np); |
60 | } | 60 | } |
61 | 61 | ||
62 | #ifdef CONFIG_FS_ENET_MDIO_FCC | ||
63 | static void ep8248e_set_mdc(struct mdiobb_ctrl *ctrl, int level) | 62 | static void ep8248e_set_mdc(struct mdiobb_ctrl *ctrl, int level) |
64 | { | 63 | { |
65 | if (level) | 64 | if (level) |
@@ -165,7 +164,6 @@ static struct of_platform_driver ep8248e_mdio_driver = { | |||
165 | .probe = ep8248e_mdio_probe, | 164 | .probe = ep8248e_mdio_probe, |
166 | .remove = ep8248e_mdio_remove, | 165 | .remove = ep8248e_mdio_remove, |
167 | }; | 166 | }; |
168 | #endif | ||
169 | 167 | ||
170 | struct cpm_pin { | 168 | struct cpm_pin { |
171 | int port, pin, flags; | 169 | int port, pin, flags; |
@@ -298,9 +296,7 @@ static __initdata struct of_device_id of_bus_ids[] = { | |||
298 | static int __init declare_of_platform_devices(void) | 296 | static int __init declare_of_platform_devices(void) |
299 | { | 297 | { |
300 | of_platform_bus_probe(NULL, of_bus_ids, NULL); | 298 | of_platform_bus_probe(NULL, of_bus_ids, NULL); |
301 | #ifdef CONFIG_FS_ENET_MDIO_FCC | ||
302 | of_register_platform_driver(&ep8248e_mdio_driver); | 299 | of_register_platform_driver(&ep8248e_mdio_driver); |
303 | #endif | ||
304 | 300 | ||
305 | return 0; | 301 | return 0; |
306 | } | 302 | } |
diff --git a/arch/powerpc/platforms/83xx/Kconfig b/arch/powerpc/platforms/83xx/Kconfig index 27d9bf86de01..6159c5d4e5f1 100644 --- a/arch/powerpc/platforms/83xx/Kconfig +++ b/arch/powerpc/platforms/83xx/Kconfig | |||
@@ -2,7 +2,8 @@ menuconfig PPC_83xx | |||
2 | bool "83xx-based boards" | 2 | bool "83xx-based boards" |
3 | depends on 6xx && PPC_MULTIPLATFORM | 3 | depends on 6xx && PPC_MULTIPLATFORM |
4 | select PPC_UDBG_16550 | 4 | select PPC_UDBG_16550 |
5 | select PPC_INDIRECT_PCI | 5 | select PPC_PCI_CHOICE |
6 | select FSL_PCI if PCI | ||
6 | select FSL_SOC | 7 | select FSL_SOC |
7 | select IPIC | 8 | select IPIC |
8 | 9 | ||
diff --git a/arch/powerpc/platforms/83xx/Makefile b/arch/powerpc/platforms/83xx/Makefile index f331fd7dd836..ba5028e29890 100644 --- a/arch/powerpc/platforms/83xx/Makefile +++ b/arch/powerpc/platforms/83xx/Makefile | |||
@@ -2,7 +2,7 @@ | |||
2 | # Makefile for the PowerPC 83xx linux kernel. | 2 | # Makefile for the PowerPC 83xx linux kernel. |
3 | # | 3 | # |
4 | obj-y := misc.o usb.o | 4 | obj-y := misc.o usb.o |
5 | obj-$(CONFIG_PCI) += pci.o | 5 | obj-$(CONFIG_SUSPEND) += suspend.o suspend-asm.o |
6 | obj-$(CONFIG_MPC831x_RDB) += mpc831x_rdb.o | 6 | obj-$(CONFIG_MPC831x_RDB) += mpc831x_rdb.o |
7 | obj-$(CONFIG_MPC832x_RDB) += mpc832x_rdb.o | 7 | obj-$(CONFIG_MPC832x_RDB) += mpc832x_rdb.o |
8 | obj-$(CONFIG_MPC834x_MDS) += mpc834x_mds.o | 8 | obj-$(CONFIG_MPC834x_MDS) += mpc834x_mds.o |
diff --git a/arch/powerpc/platforms/83xx/mpc831x_rdb.c b/arch/powerpc/platforms/83xx/mpc831x_rdb.c index c4db5172b27a..a428f8d1ac80 100644 --- a/arch/powerpc/platforms/83xx/mpc831x_rdb.c +++ b/arch/powerpc/platforms/83xx/mpc831x_rdb.c | |||
@@ -19,6 +19,7 @@ | |||
19 | #include <asm/time.h> | 19 | #include <asm/time.h> |
20 | #include <asm/ipic.h> | 20 | #include <asm/ipic.h> |
21 | #include <asm/udbg.h> | 21 | #include <asm/udbg.h> |
22 | #include <sysdev/fsl_pci.h> | ||
22 | 23 | ||
23 | #include "mpc83xx.h" | 24 | #include "mpc83xx.h" |
24 | 25 | ||
diff --git a/arch/powerpc/platforms/83xx/mpc832x_mds.c b/arch/powerpc/platforms/83xx/mpc832x_mds.c index 6dbc6eabcb02..dd4be4aee314 100644 --- a/arch/powerpc/platforms/83xx/mpc832x_mds.c +++ b/arch/powerpc/platforms/83xx/mpc832x_mds.c | |||
@@ -36,6 +36,7 @@ | |||
36 | #include <asm/prom.h> | 36 | #include <asm/prom.h> |
37 | #include <asm/udbg.h> | 37 | #include <asm/udbg.h> |
38 | #include <sysdev/fsl_soc.h> | 38 | #include <sysdev/fsl_soc.h> |
39 | #include <sysdev/fsl_pci.h> | ||
39 | #include <asm/qe.h> | 40 | #include <asm/qe.h> |
40 | #include <asm/qe_ic.h> | 41 | #include <asm/qe_ic.h> |
41 | 42 | ||
diff --git a/arch/powerpc/platforms/83xx/mpc832x_rdb.c b/arch/powerpc/platforms/83xx/mpc832x_rdb.c index e7f706b624fe..f049d692d4c8 100644 --- a/arch/powerpc/platforms/83xx/mpc832x_rdb.c +++ b/arch/powerpc/platforms/83xx/mpc832x_rdb.c | |||
@@ -27,6 +27,7 @@ | |||
27 | #include <asm/qe.h> | 27 | #include <asm/qe.h> |
28 | #include <asm/qe_ic.h> | 28 | #include <asm/qe_ic.h> |
29 | #include <sysdev/fsl_soc.h> | 29 | #include <sysdev/fsl_soc.h> |
30 | #include <sysdev/fsl_pci.h> | ||
30 | 31 | ||
31 | #include "mpc83xx.h" | 32 | #include "mpc83xx.h" |
32 | 33 | ||
diff --git a/arch/powerpc/platforms/83xx/mpc834x_itx.c b/arch/powerpc/platforms/83xx/mpc834x_itx.c index 50e8f632061c..7301d77a08ee 100644 --- a/arch/powerpc/platforms/83xx/mpc834x_itx.c +++ b/arch/powerpc/platforms/83xx/mpc834x_itx.c | |||
@@ -35,6 +35,7 @@ | |||
35 | #include <asm/prom.h> | 35 | #include <asm/prom.h> |
36 | #include <asm/udbg.h> | 36 | #include <asm/udbg.h> |
37 | #include <sysdev/fsl_soc.h> | 37 | #include <sysdev/fsl_soc.h> |
38 | #include <sysdev/fsl_pci.h> | ||
38 | 39 | ||
39 | #include "mpc83xx.h" | 40 | #include "mpc83xx.h" |
40 | 41 | ||
diff --git a/arch/powerpc/platforms/83xx/mpc834x_mds.c b/arch/powerpc/platforms/83xx/mpc834x_mds.c index 2b8a0a3f8557..30d509aa9f08 100644 --- a/arch/powerpc/platforms/83xx/mpc834x_mds.c +++ b/arch/powerpc/platforms/83xx/mpc834x_mds.c | |||
@@ -35,6 +35,7 @@ | |||
35 | #include <asm/prom.h> | 35 | #include <asm/prom.h> |
36 | #include <asm/udbg.h> | 36 | #include <asm/udbg.h> |
37 | #include <sysdev/fsl_soc.h> | 37 | #include <sysdev/fsl_soc.h> |
38 | #include <sysdev/fsl_pci.h> | ||
38 | 39 | ||
39 | #include "mpc83xx.h" | 40 | #include "mpc83xx.h" |
40 | 41 | ||
diff --git a/arch/powerpc/platforms/83xx/mpc836x_mds.c b/arch/powerpc/platforms/83xx/mpc836x_mds.c index c2e5de60c055..75b80e836576 100644 --- a/arch/powerpc/platforms/83xx/mpc836x_mds.c +++ b/arch/powerpc/platforms/83xx/mpc836x_mds.c | |||
@@ -42,6 +42,7 @@ | |||
42 | #include <asm/prom.h> | 42 | #include <asm/prom.h> |
43 | #include <asm/udbg.h> | 43 | #include <asm/udbg.h> |
44 | #include <sysdev/fsl_soc.h> | 44 | #include <sysdev/fsl_soc.h> |
45 | #include <sysdev/fsl_pci.h> | ||
45 | #include <asm/qe.h> | 46 | #include <asm/qe.h> |
46 | #include <asm/qe_ic.h> | 47 | #include <asm/qe_ic.h> |
47 | 48 | ||
diff --git a/arch/powerpc/platforms/83xx/mpc836x_rdk.c b/arch/powerpc/platforms/83xx/mpc836x_rdk.c index c10dec4bf178..a5273bb28e1b 100644 --- a/arch/powerpc/platforms/83xx/mpc836x_rdk.c +++ b/arch/powerpc/platforms/83xx/mpc836x_rdk.c | |||
@@ -23,6 +23,7 @@ | |||
23 | #include <asm/qe.h> | 23 | #include <asm/qe.h> |
24 | #include <asm/qe_ic.h> | 24 | #include <asm/qe_ic.h> |
25 | #include <sysdev/fsl_soc.h> | 25 | #include <sysdev/fsl_soc.h> |
26 | #include <sysdev/fsl_pci.h> | ||
26 | 27 | ||
27 | #include "mpc83xx.h" | 28 | #include "mpc83xx.h" |
28 | 29 | ||
diff --git a/arch/powerpc/platforms/83xx/mpc837x_mds.c b/arch/powerpc/platforms/83xx/mpc837x_mds.c index 64d17b0d6455..be62de23bead 100644 --- a/arch/powerpc/platforms/83xx/mpc837x_mds.c +++ b/arch/powerpc/platforms/83xx/mpc837x_mds.c | |||
@@ -19,6 +19,7 @@ | |||
19 | #include <asm/ipic.h> | 19 | #include <asm/ipic.h> |
20 | #include <asm/udbg.h> | 20 | #include <asm/udbg.h> |
21 | #include <asm/prom.h> | 21 | #include <asm/prom.h> |
22 | #include <sysdev/fsl_pci.h> | ||
22 | 23 | ||
23 | #include "mpc83xx.h" | 24 | #include "mpc83xx.h" |
24 | 25 | ||
diff --git a/arch/powerpc/platforms/83xx/mpc837x_rdb.c b/arch/powerpc/platforms/83xx/mpc837x_rdb.c index c00356bdb1dd..da030afa2e2c 100644 --- a/arch/powerpc/platforms/83xx/mpc837x_rdb.c +++ b/arch/powerpc/platforms/83xx/mpc837x_rdb.c | |||
@@ -17,6 +17,7 @@ | |||
17 | #include <asm/time.h> | 17 | #include <asm/time.h> |
18 | #include <asm/ipic.h> | 18 | #include <asm/ipic.h> |
19 | #include <asm/udbg.h> | 19 | #include <asm/udbg.h> |
20 | #include <sysdev/fsl_pci.h> | ||
20 | 21 | ||
21 | #include "mpc83xx.h" | 22 | #include "mpc83xx.h" |
22 | 23 | ||
diff --git a/arch/powerpc/platforms/83xx/mpc83xx.h b/arch/powerpc/platforms/83xx/mpc83xx.h index 88a3b5cabb18..2a7cbabb410a 100644 --- a/arch/powerpc/platforms/83xx/mpc83xx.h +++ b/arch/powerpc/platforms/83xx/mpc83xx.h | |||
@@ -26,6 +26,8 @@ | |||
26 | #define MPC834X_SICRL_USB1 0x20000000 | 26 | #define MPC834X_SICRL_USB1 0x20000000 |
27 | #define MPC831X_SICRL_USB_MASK 0x00000c00 | 27 | #define MPC831X_SICRL_USB_MASK 0x00000c00 |
28 | #define MPC831X_SICRL_USB_ULPI 0x00000800 | 28 | #define MPC831X_SICRL_USB_ULPI 0x00000800 |
29 | #define MPC8315_SICRL_USB_MASK 0x000000fc | ||
30 | #define MPC8315_SICRL_USB_ULPI 0x00000054 | ||
29 | #define MPC837X_SICRL_USB_MASK 0xf0000000 | 31 | #define MPC837X_SICRL_USB_MASK 0xf0000000 |
30 | #define MPC837X_SICRL_USB_ULPI 0x50000000 | 32 | #define MPC837X_SICRL_USB_ULPI 0x50000000 |
31 | 33 | ||
@@ -34,6 +36,8 @@ | |||
34 | #define MPC834X_SICRH_USB_UTMI 0x00020000 | 36 | #define MPC834X_SICRH_USB_UTMI 0x00020000 |
35 | #define MPC831X_SICRH_USB_MASK 0x000000e0 | 37 | #define MPC831X_SICRH_USB_MASK 0x000000e0 |
36 | #define MPC831X_SICRH_USB_ULPI 0x000000a0 | 38 | #define MPC831X_SICRH_USB_ULPI 0x000000a0 |
39 | #define MPC8315_SICRH_USB_MASK 0x0000ff00 | ||
40 | #define MPC8315_SICRH_USB_ULPI 0x00000000 | ||
37 | 41 | ||
38 | /* USB Control Register */ | 42 | /* USB Control Register */ |
39 | #define FSL_USB2_CONTROL_OFFS 0x500 | 43 | #define FSL_USB2_CONTROL_OFFS 0x500 |
@@ -55,7 +59,6 @@ | |||
55 | * mpc83xx_* files. Mostly for use by mpc83xx_setup | 59 | * mpc83xx_* files. Mostly for use by mpc83xx_setup |
56 | */ | 60 | */ |
57 | 61 | ||
58 | extern int mpc83xx_add_bridge(struct device_node *dev); | ||
59 | extern void mpc83xx_restart(char *cmd); | 62 | extern void mpc83xx_restart(char *cmd); |
60 | extern long mpc83xx_time_init(void); | 63 | extern long mpc83xx_time_init(void); |
61 | extern int mpc834x_usb_cfg(void); | 64 | extern int mpc834x_usb_cfg(void); |
diff --git a/arch/powerpc/platforms/83xx/pci.c b/arch/powerpc/platforms/83xx/pci.c deleted file mode 100644 index 14f1080c6c9d..000000000000 --- a/arch/powerpc/platforms/83xx/pci.c +++ /dev/null | |||
@@ -1,91 +0,0 @@ | |||
1 | /* | ||
2 | * FSL SoC setup code | ||
3 | * | ||
4 | * Maintained by Kumar Gala (see MAINTAINERS for contact information) | ||
5 | * | ||
6 | * This program is free software; you can redistribute it and/or modify it | ||
7 | * under the terms of the GNU General Public License as published by the | ||
8 | * Free Software Foundation; either version 2 of the License, or (at your | ||
9 | * option) any later version. | ||
10 | */ | ||
11 | |||
12 | #include <linux/stddef.h> | ||
13 | #include <linux/kernel.h> | ||
14 | #include <linux/init.h> | ||
15 | #include <linux/errno.h> | ||
16 | #include <linux/pci.h> | ||
17 | #include <linux/delay.h> | ||
18 | #include <linux/irq.h> | ||
19 | #include <linux/module.h> | ||
20 | |||
21 | #include <asm/system.h> | ||
22 | #include <asm/atomic.h> | ||
23 | #include <asm/io.h> | ||
24 | #include <asm/pci-bridge.h> | ||
25 | #include <asm/prom.h> | ||
26 | #include <sysdev/fsl_soc.h> | ||
27 | |||
28 | #undef DEBUG | ||
29 | |||
30 | #ifdef DEBUG | ||
31 | #define DBG(x...) printk(x) | ||
32 | #else | ||
33 | #define DBG(x...) | ||
34 | #endif | ||
35 | |||
36 | int __init mpc83xx_add_bridge(struct device_node *dev) | ||
37 | { | ||
38 | int len; | ||
39 | struct pci_controller *hose; | ||
40 | struct resource rsrc; | ||
41 | const int *bus_range; | ||
42 | int primary = 1, has_address = 0; | ||
43 | phys_addr_t immr = get_immrbase(); | ||
44 | |||
45 | DBG("Adding PCI host bridge %s\n", dev->full_name); | ||
46 | |||
47 | /* Fetch host bridge registers address */ | ||
48 | has_address = (of_address_to_resource(dev, 0, &rsrc) == 0); | ||
49 | |||
50 | /* Get bus range if any */ | ||
51 | bus_range = of_get_property(dev, "bus-range", &len); | ||
52 | if (bus_range == NULL || len < 2 * sizeof(int)) { | ||
53 | printk(KERN_WARNING "Can't get bus-range for %s, assume" | ||
54 | " bus 0\n", dev->full_name); | ||
55 | } | ||
56 | |||
57 | ppc_pci_flags |= PPC_PCI_REASSIGN_ALL_BUS; | ||
58 | hose = pcibios_alloc_controller(dev); | ||
59 | if (!hose) | ||
60 | return -ENOMEM; | ||
61 | |||
62 | hose->first_busno = bus_range ? bus_range[0] : 0; | ||
63 | hose->last_busno = bus_range ? bus_range[1] : 0xff; | ||
64 | |||
65 | /* MPC83xx supports up to two host controllers one at 0x8500 from immrbar | ||
66 | * the other at 0x8600, we consider the 0x8500 the primary controller | ||
67 | */ | ||
68 | /* PCI 1 */ | ||
69 | if ((rsrc.start & 0xfffff) == 0x8500) { | ||
70 | setup_indirect_pci(hose, immr + 0x8300, immr + 0x8304, 0); | ||
71 | } | ||
72 | /* PCI 2 */ | ||
73 | if ((rsrc.start & 0xfffff) == 0x8600) { | ||
74 | setup_indirect_pci(hose, immr + 0x8380, immr + 0x8384, 0); | ||
75 | primary = 0; | ||
76 | } | ||
77 | |||
78 | printk(KERN_INFO "Found MPC83xx PCI host bridge at 0x%016llx. " | ||
79 | "Firmware bus number: %d->%d\n", | ||
80 | (unsigned long long)rsrc.start, hose->first_busno, | ||
81 | hose->last_busno); | ||
82 | |||
83 | DBG(" ->Hose at 0x%p, cfg_addr=0x%p,cfg_data=0x%p\n", | ||
84 | hose, hose->cfg_addr, hose->cfg_data); | ||
85 | |||
86 | /* Interpret the "ranges" property */ | ||
87 | /* This also maps the I/O region and sets isa_io/mem_base */ | ||
88 | pci_process_bridge_OF_ranges(hose, dev, primary); | ||
89 | |||
90 | return 0; | ||
91 | } | ||
diff --git a/arch/powerpc/platforms/83xx/sbc834x.c b/arch/powerpc/platforms/83xx/sbc834x.c index cf382474a83d..fc21f5c15bab 100644 --- a/arch/powerpc/platforms/83xx/sbc834x.c +++ b/arch/powerpc/platforms/83xx/sbc834x.c | |||
@@ -37,6 +37,7 @@ | |||
37 | #include <asm/prom.h> | 37 | #include <asm/prom.h> |
38 | #include <asm/udbg.h> | 38 | #include <asm/udbg.h> |
39 | #include <sysdev/fsl_soc.h> | 39 | #include <sysdev/fsl_soc.h> |
40 | #include <sysdev/fsl_pci.h> | ||
40 | 41 | ||
41 | #include "mpc83xx.h" | 42 | #include "mpc83xx.h" |
42 | 43 | ||
diff --git a/arch/powerpc/platforms/83xx/suspend-asm.S b/arch/powerpc/platforms/83xx/suspend-asm.S new file mode 100644 index 000000000000..1930543c98d3 --- /dev/null +++ b/arch/powerpc/platforms/83xx/suspend-asm.S | |||
@@ -0,0 +1,533 @@ | |||
1 | /* | ||
2 | * Enter and leave deep sleep state on MPC83xx | ||
3 | * | ||
4 | * Copyright (c) 2006-2008 Freescale Semiconductor, Inc. | ||
5 | * Author: Scott Wood <scottwood@freescale.com> | ||
6 | * | ||
7 | * This program is free software; you can redistribute it and/or modify it | ||
8 | * under the terms of the GNU General Public License version 2 as published | ||
9 | * by the Free Software Foundation. | ||
10 | */ | ||
11 | |||
12 | #include <asm/page.h> | ||
13 | #include <asm/ppc_asm.h> | ||
14 | #include <asm/reg.h> | ||
15 | #include <asm/asm-offsets.h> | ||
16 | |||
17 | #define SS_MEMSAVE 0x00 /* First 8 bytes of RAM */ | ||
18 | #define SS_HID 0x08 /* 3 HIDs */ | ||
19 | #define SS_IABR 0x14 /* 2 IABRs */ | ||
20 | #define SS_IBCR 0x1c | ||
21 | #define SS_DABR 0x20 /* 2 DABRs */ | ||
22 | #define SS_DBCR 0x28 | ||
23 | #define SS_SP 0x2c | ||
24 | #define SS_SR 0x30 /* 16 segment registers */ | ||
25 | #define SS_R2 0x70 | ||
26 | #define SS_MSR 0x74 | ||
27 | #define SS_SDR1 0x78 | ||
28 | #define SS_LR 0x7c | ||
29 | #define SS_SPRG 0x80 /* 4 SPRGs */ | ||
30 | #define SS_DBAT 0x90 /* 8 DBATs */ | ||
31 | #define SS_IBAT 0xd0 /* 8 IBATs */ | ||
32 | #define SS_TB 0x110 | ||
33 | #define SS_CR 0x118 | ||
34 | #define SS_GPREG 0x11c /* r12-r31 */ | ||
35 | #define STATE_SAVE_SIZE 0x16c | ||
36 | |||
37 | .section .data | ||
38 | .align 5 | ||
39 | |||
40 | mpc83xx_sleep_save_area: | ||
41 | .space STATE_SAVE_SIZE | ||
42 | immrbase: | ||
43 | .long 0 | ||
44 | |||
45 | .section .text | ||
46 | .align 5 | ||
47 | |||
48 | /* r3 = physical address of IMMR */ | ||
49 | _GLOBAL(mpc83xx_enter_deep_sleep) | ||
50 | lis r4, immrbase@ha | ||
51 | stw r3, immrbase@l(r4) | ||
52 | |||
53 | /* The first 2 words of memory are used to communicate with the | ||
54 | * bootloader, to tell it how to resume. | ||
55 | * | ||
56 | * The first word is the magic number 0xf5153ae5, and the second | ||
57 | * is the pointer to mpc83xx_deep_resume. | ||
58 | * | ||
59 | * The original content of these two words is saved in SS_MEMSAVE. | ||
60 | */ | ||
61 | |||
62 | lis r3, mpc83xx_sleep_save_area@h | ||
63 | ori r3, r3, mpc83xx_sleep_save_area@l | ||
64 | |||
65 | lis r4, KERNELBASE@h | ||
66 | lwz r5, 0(r4) | ||
67 | lwz r6, 4(r4) | ||
68 | |||
69 | stw r5, SS_MEMSAVE+0(r3) | ||
70 | stw r6, SS_MEMSAVE+4(r3) | ||
71 | |||
72 | mfspr r5, SPRN_HID0 | ||
73 | mfspr r6, SPRN_HID1 | ||
74 | mfspr r7, SPRN_HID2 | ||
75 | |||
76 | stw r5, SS_HID+0(r3) | ||
77 | stw r6, SS_HID+4(r3) | ||
78 | stw r7, SS_HID+8(r3) | ||
79 | |||
80 | mfspr r4, SPRN_IABR | ||
81 | mfspr r5, SPRN_IABR2 | ||
82 | mfspr r6, SPRN_IBCR | ||
83 | mfspr r7, SPRN_DABR | ||
84 | mfspr r8, SPRN_DABR2 | ||
85 | mfspr r9, SPRN_DBCR | ||
86 | |||
87 | stw r4, SS_IABR+0(r3) | ||
88 | stw r5, SS_IABR+4(r3) | ||
89 | stw r6, SS_IBCR(r3) | ||
90 | stw r7, SS_DABR+0(r3) | ||
91 | stw r8, SS_DABR+4(r3) | ||
92 | stw r9, SS_DBCR(r3) | ||
93 | |||
94 | mfspr r4, SPRN_SPRG0 | ||
95 | mfspr r5, SPRN_SPRG1 | ||
96 | mfspr r6, SPRN_SPRG2 | ||
97 | mfspr r7, SPRN_SPRG3 | ||
98 | mfsdr1 r8 | ||
99 | |||
100 | stw r4, SS_SPRG+0(r3) | ||
101 | stw r5, SS_SPRG+4(r3) | ||
102 | stw r6, SS_SPRG+8(r3) | ||
103 | stw r7, SS_SPRG+12(r3) | ||
104 | stw r8, SS_SDR1(r3) | ||
105 | |||
106 | mfspr r4, SPRN_DBAT0U | ||
107 | mfspr r5, SPRN_DBAT0L | ||
108 | mfspr r6, SPRN_DBAT1U | ||
109 | mfspr r7, SPRN_DBAT1L | ||
110 | |||
111 | stw r4, SS_DBAT+0x00(r3) | ||
112 | stw r5, SS_DBAT+0x04(r3) | ||
113 | stw r6, SS_DBAT+0x08(r3) | ||
114 | stw r7, SS_DBAT+0x0c(r3) | ||
115 | |||
116 | mfspr r4, SPRN_DBAT2U | ||
117 | mfspr r5, SPRN_DBAT2L | ||
118 | mfspr r6, SPRN_DBAT3U | ||
119 | mfspr r7, SPRN_DBAT3L | ||
120 | |||
121 | stw r4, SS_DBAT+0x10(r3) | ||
122 | stw r5, SS_DBAT+0x14(r3) | ||
123 | stw r6, SS_DBAT+0x18(r3) | ||
124 | stw r7, SS_DBAT+0x1c(r3) | ||
125 | |||
126 | mfspr r4, SPRN_DBAT4U | ||
127 | mfspr r5, SPRN_DBAT4L | ||
128 | mfspr r6, SPRN_DBAT5U | ||
129 | mfspr r7, SPRN_DBAT5L | ||
130 | |||
131 | stw r4, SS_DBAT+0x20(r3) | ||
132 | stw r5, SS_DBAT+0x24(r3) | ||
133 | stw r6, SS_DBAT+0x28(r3) | ||
134 | stw r7, SS_DBAT+0x2c(r3) | ||
135 | |||
136 | mfspr r4, SPRN_DBAT6U | ||
137 | mfspr r5, SPRN_DBAT6L | ||
138 | mfspr r6, SPRN_DBAT7U | ||
139 | mfspr r7, SPRN_DBAT7L | ||
140 | |||
141 | stw r4, SS_DBAT+0x30(r3) | ||
142 | stw r5, SS_DBAT+0x34(r3) | ||
143 | stw r6, SS_DBAT+0x38(r3) | ||
144 | stw r7, SS_DBAT+0x3c(r3) | ||
145 | |||
146 | mfspr r4, SPRN_IBAT0U | ||
147 | mfspr r5, SPRN_IBAT0L | ||
148 | mfspr r6, SPRN_IBAT1U | ||
149 | mfspr r7, SPRN_IBAT1L | ||
150 | |||
151 | stw r4, SS_IBAT+0x00(r3) | ||
152 | stw r5, SS_IBAT+0x04(r3) | ||
153 | stw r6, SS_IBAT+0x08(r3) | ||
154 | stw r7, SS_IBAT+0x0c(r3) | ||
155 | |||
156 | mfspr r4, SPRN_IBAT2U | ||
157 | mfspr r5, SPRN_IBAT2L | ||
158 | mfspr r6, SPRN_IBAT3U | ||
159 | mfspr r7, SPRN_IBAT3L | ||
160 | |||
161 | stw r4, SS_IBAT+0x10(r3) | ||
162 | stw r5, SS_IBAT+0x14(r3) | ||
163 | stw r6, SS_IBAT+0x18(r3) | ||
164 | stw r7, SS_IBAT+0x1c(r3) | ||
165 | |||
166 | mfspr r4, SPRN_IBAT4U | ||
167 | mfspr r5, SPRN_IBAT4L | ||
168 | mfspr r6, SPRN_IBAT5U | ||
169 | mfspr r7, SPRN_IBAT5L | ||
170 | |||
171 | stw r4, SS_IBAT+0x20(r3) | ||
172 | stw r5, SS_IBAT+0x24(r3) | ||
173 | stw r6, SS_IBAT+0x28(r3) | ||
174 | stw r7, SS_IBAT+0x2c(r3) | ||
175 | |||
176 | mfspr r4, SPRN_IBAT6U | ||
177 | mfspr r5, SPRN_IBAT6L | ||
178 | mfspr r6, SPRN_IBAT7U | ||
179 | mfspr r7, SPRN_IBAT7L | ||
180 | |||
181 | stw r4, SS_IBAT+0x30(r3) | ||
182 | stw r5, SS_IBAT+0x34(r3) | ||
183 | stw r6, SS_IBAT+0x38(r3) | ||
184 | stw r7, SS_IBAT+0x3c(r3) | ||
185 | |||
186 | mfmsr r4 | ||
187 | mflr r5 | ||
188 | mfcr r6 | ||
189 | |||
190 | stw r4, SS_MSR(r3) | ||
191 | stw r5, SS_LR(r3) | ||
192 | stw r6, SS_CR(r3) | ||
193 | stw r1, SS_SP(r3) | ||
194 | stw r2, SS_R2(r3) | ||
195 | |||
196 | 1: mftbu r4 | ||
197 | mftb r5 | ||
198 | mftbu r6 | ||
199 | cmpw r4, r6 | ||
200 | bne 1b | ||
201 | |||
202 | stw r4, SS_TB+0(r3) | ||
203 | stw r5, SS_TB+4(r3) | ||
204 | |||
205 | stmw r12, SS_GPREG(r3) | ||
206 | |||
207 | li r4, 0 | ||
208 | addi r6, r3, SS_SR-4 | ||
209 | 1: mfsrin r5, r4 | ||
210 | stwu r5, 4(r6) | ||
211 | addis r4, r4, 0x1000 | ||
212 | cmpwi r4, 0 | ||
213 | bne 1b | ||
214 | |||
215 | /* Disable machine checks and critical exceptions */ | ||
216 | mfmsr r4 | ||
217 | rlwinm r4, r4, 0, ~MSR_CE | ||
218 | rlwinm r4, r4, 0, ~MSR_ME | ||
219 | mtmsr r4 | ||
220 | isync | ||
221 | |||
222 | #define TMP_VIRT_IMMR 0xf0000000 | ||
223 | #define DEFAULT_IMMR_VALUE 0xff400000 | ||
224 | #define IMMRBAR_BASE 0x0000 | ||
225 | |||
226 | lis r4, immrbase@ha | ||
227 | lwz r4, immrbase@l(r4) | ||
228 | |||
229 | /* Use DBAT0 to address the current IMMR space */ | ||
230 | |||
231 | ori r4, r4, 0x002a | ||
232 | mtspr SPRN_DBAT0L, r4 | ||
233 | lis r8, TMP_VIRT_IMMR@h | ||
234 | ori r4, r8, 0x001e /* 1 MByte accessable from Kernel Space only */ | ||
235 | mtspr SPRN_DBAT0U, r4 | ||
236 | isync | ||
237 | |||
238 | /* Use DBAT1 to address the original IMMR space */ | ||
239 | |||
240 | lis r4, DEFAULT_IMMR_VALUE@h | ||
241 | ori r4, r4, 0x002a | ||
242 | mtspr SPRN_DBAT1L, r4 | ||
243 | lis r9, (TMP_VIRT_IMMR + 0x01000000)@h | ||
244 | ori r4, r9, 0x001e /* 1 MByte accessable from Kernel Space only */ | ||
245 | mtspr SPRN_DBAT1U, r4 | ||
246 | isync | ||
247 | |||
248 | /* Use DBAT2 to address the beginning of RAM. This isn't done | ||
249 | * using the normal virtual mapping, because with page debugging | ||
250 | * enabled it will be read-only. | ||
251 | */ | ||
252 | |||
253 | li r4, 0x0002 | ||
254 | mtspr SPRN_DBAT2L, r4 | ||
255 | lis r4, KERNELBASE@h | ||
256 | ori r4, r4, 0x001e /* 1 MByte accessable from Kernel Space only */ | ||
257 | mtspr SPRN_DBAT2U, r4 | ||
258 | isync | ||
259 | |||
260 | /* Flush the cache with our BAT, as there will be TLB misses | ||
261 | * otherwise if page debugging is enabled, and these misses | ||
262 | * will disturb the PLRU algorithm. | ||
263 | */ | ||
264 | |||
265 | bl __flush_disable_L1 | ||
266 | |||
267 | /* Keep the i-cache enabled, so the hack below for low-boot | ||
268 | * flash will work. | ||
269 | */ | ||
270 | mfspr r3, SPRN_HID0 | ||
271 | ori r3, r3, HID0_ICE | ||
272 | mtspr SPRN_HID0, r3 | ||
273 | isync | ||
274 | |||
275 | lis r6, 0xf515 | ||
276 | ori r6, r6, 0x3ae5 | ||
277 | |||
278 | lis r7, mpc83xx_deep_resume@h | ||
279 | ori r7, r7, mpc83xx_deep_resume@l | ||
280 | tophys(r7, r7) | ||
281 | |||
282 | lis r5, KERNELBASE@h | ||
283 | stw r6, 0(r5) | ||
284 | stw r7, 4(r5) | ||
285 | |||
286 | /* Reset BARs */ | ||
287 | |||
288 | li r4, 0 | ||
289 | stw r4, 0x0024(r8) | ||
290 | stw r4, 0x002c(r8) | ||
291 | stw r4, 0x0034(r8) | ||
292 | stw r4, 0x003c(r8) | ||
293 | stw r4, 0x0064(r8) | ||
294 | stw r4, 0x006c(r8) | ||
295 | |||
296 | /* Rev 1 of the 8313 has problems with wakeup events that are | ||
297 | * pending during the transition to deep sleep state (such as if | ||
298 | * the PCI host sets the state to D3 and then D0 in rapid | ||
299 | * succession). This check shrinks the race window somewhat. | ||
300 | * | ||
301 | * See erratum PCI23, though the problem is not limited | ||
302 | * to PCI. | ||
303 | */ | ||
304 | |||
305 | lwz r3, 0x0b04(r8) | ||
306 | andi. r3, r3, 1 | ||
307 | bne- mpc83xx_deep_resume | ||
308 | |||
309 | /* Move IMMR back to the default location, following the | ||
310 | * procedure specified in the MPC8313 manual. | ||
311 | */ | ||
312 | lwz r4, IMMRBAR_BASE(r8) | ||
313 | isync | ||
314 | lis r4, DEFAULT_IMMR_VALUE@h | ||
315 | stw r4, IMMRBAR_BASE(r8) | ||
316 | lis r4, KERNELBASE@h | ||
317 | lwz r4, 0(r4) | ||
318 | isync | ||
319 | lwz r4, IMMRBAR_BASE(r9) | ||
320 | mr r8, r9 | ||
321 | isync | ||
322 | |||
323 | /* Check the Reset Configuration Word to see whether flash needs | ||
324 | * to be mapped at a low address or a high address. | ||
325 | */ | ||
326 | |||
327 | lwz r4, 0x0904(r8) | ||
328 | andis. r4, r4, 0x0400 | ||
329 | li r4, 0 | ||
330 | beq boot_low | ||
331 | lis r4, 0xff80 | ||
332 | boot_low: | ||
333 | stw r4, 0x0020(r8) | ||
334 | lis r7, 0x8000 | ||
335 | ori r7, r7, 0x0016 | ||
336 | |||
337 | mfspr r5, SPRN_HID0 | ||
338 | rlwinm r5, r5, 0, ~(HID0_DOZE | HID0_NAP) | ||
339 | oris r5, r5, HID0_SLEEP@h | ||
340 | mtspr SPRN_HID0, r5 | ||
341 | isync | ||
342 | |||
343 | mfmsr r5 | ||
344 | oris r5, r5, MSR_POW@h | ||
345 | |||
346 | /* Enable the flash mapping at the appropriate address. This | ||
347 | * mapping will override the RAM mapping if booting low, so there's | ||
348 | * no need to disable the latter. This must be done inside the same | ||
349 | * cache line as setting MSR_POW, so that no instruction fetches | ||
350 | * from RAM happen after the flash mapping is turned on. | ||
351 | */ | ||
352 | |||
353 | .align 5 | ||
354 | stw r7, 0x0024(r8) | ||
355 | sync | ||
356 | isync | ||
357 | mtmsr r5 | ||
358 | isync | ||
359 | 1: b 1b | ||
360 | |||
361 | mpc83xx_deep_resume: | ||
362 | lis r4, 1f@h | ||
363 | ori r4, r4, 1f@l | ||
364 | tophys(r4, r4) | ||
365 | mtsrr0 r4 | ||
366 | |||
367 | mfmsr r4 | ||
368 | rlwinm r4, r4, 0, ~(MSR_IR | MSR_DR) | ||
369 | mtsrr1 r4 | ||
370 | |||
371 | rfi | ||
372 | |||
373 | 1: tlbia | ||
374 | bl __inval_enable_L1 | ||
375 | |||
376 | lis r3, mpc83xx_sleep_save_area@h | ||
377 | ori r3, r3, mpc83xx_sleep_save_area@l | ||
378 | tophys(r3, r3) | ||
379 | |||
380 | lwz r5, SS_MEMSAVE+0(r3) | ||
381 | lwz r6, SS_MEMSAVE+4(r3) | ||
382 | |||
383 | stw r5, 0(0) | ||
384 | stw r6, 4(0) | ||
385 | |||
386 | lwz r5, SS_HID+0(r3) | ||
387 | lwz r6, SS_HID+4(r3) | ||
388 | lwz r7, SS_HID+8(r3) | ||
389 | |||
390 | mtspr SPRN_HID0, r5 | ||
391 | mtspr SPRN_HID1, r6 | ||
392 | mtspr SPRN_HID2, r7 | ||
393 | |||
394 | lwz r4, SS_IABR+0(r3) | ||
395 | lwz r5, SS_IABR+4(r3) | ||
396 | lwz r6, SS_IBCR(r3) | ||
397 | lwz r7, SS_DABR+0(r3) | ||
398 | lwz r8, SS_DABR+4(r3) | ||
399 | lwz r9, SS_DBCR(r3) | ||
400 | |||
401 | mtspr SPRN_IABR, r4 | ||
402 | mtspr SPRN_IABR2, r5 | ||
403 | mtspr SPRN_IBCR, r6 | ||
404 | mtspr SPRN_DABR, r7 | ||
405 | mtspr SPRN_DABR2, r8 | ||
406 | mtspr SPRN_DBCR, r9 | ||
407 | |||
408 | li r4, 0 | ||
409 | addi r6, r3, SS_SR-4 | ||
410 | 1: lwzu r5, 4(r6) | ||
411 | mtsrin r5, r4 | ||
412 | addis r4, r4, 0x1000 | ||
413 | cmpwi r4, 0 | ||
414 | bne 1b | ||
415 | |||
416 | lwz r4, SS_DBAT+0x00(r3) | ||
417 | lwz r5, SS_DBAT+0x04(r3) | ||
418 | lwz r6, SS_DBAT+0x08(r3) | ||
419 | lwz r7, SS_DBAT+0x0c(r3) | ||
420 | |||
421 | mtspr SPRN_DBAT0U, r4 | ||
422 | mtspr SPRN_DBAT0L, r5 | ||
423 | mtspr SPRN_DBAT1U, r6 | ||
424 | mtspr SPRN_DBAT1L, r7 | ||
425 | |||
426 | lwz r4, SS_DBAT+0x10(r3) | ||
427 | lwz r5, SS_DBAT+0x14(r3) | ||
428 | lwz r6, SS_DBAT+0x18(r3) | ||
429 | lwz r7, SS_DBAT+0x1c(r3) | ||
430 | |||
431 | mtspr SPRN_DBAT2U, r4 | ||
432 | mtspr SPRN_DBAT2L, r5 | ||
433 | mtspr SPRN_DBAT3U, r6 | ||
434 | mtspr SPRN_DBAT3L, r7 | ||
435 | |||
436 | lwz r4, SS_DBAT+0x20(r3) | ||
437 | lwz r5, SS_DBAT+0x24(r3) | ||
438 | lwz r6, SS_DBAT+0x28(r3) | ||
439 | lwz r7, SS_DBAT+0x2c(r3) | ||
440 | |||
441 | mtspr SPRN_DBAT4U, r4 | ||
442 | mtspr SPRN_DBAT4L, r5 | ||
443 | mtspr SPRN_DBAT5U, r6 | ||
444 | mtspr SPRN_DBAT5L, r7 | ||
445 | |||
446 | lwz r4, SS_DBAT+0x30(r3) | ||
447 | lwz r5, SS_DBAT+0x34(r3) | ||
448 | lwz r6, SS_DBAT+0x38(r3) | ||
449 | lwz r7, SS_DBAT+0x3c(r3) | ||
450 | |||
451 | mtspr SPRN_DBAT6U, r4 | ||
452 | mtspr SPRN_DBAT6L, r5 | ||
453 | mtspr SPRN_DBAT7U, r6 | ||
454 | mtspr SPRN_DBAT7L, r7 | ||
455 | |||
456 | lwz r4, SS_IBAT+0x00(r3) | ||
457 | lwz r5, SS_IBAT+0x04(r3) | ||
458 | lwz r6, SS_IBAT+0x08(r3) | ||
459 | lwz r7, SS_IBAT+0x0c(r3) | ||
460 | |||
461 | mtspr SPRN_IBAT0U, r4 | ||
462 | mtspr SPRN_IBAT0L, r5 | ||
463 | mtspr SPRN_IBAT1U, r6 | ||
464 | mtspr SPRN_IBAT1L, r7 | ||
465 | |||
466 | lwz r4, SS_IBAT+0x10(r3) | ||
467 | lwz r5, SS_IBAT+0x14(r3) | ||
468 | lwz r6, SS_IBAT+0x18(r3) | ||
469 | lwz r7, SS_IBAT+0x1c(r3) | ||
470 | |||
471 | mtspr SPRN_IBAT2U, r4 | ||
472 | mtspr SPRN_IBAT2L, r5 | ||
473 | mtspr SPRN_IBAT3U, r6 | ||
474 | mtspr SPRN_IBAT3L, r7 | ||
475 | |||
476 | lwz r4, SS_IBAT+0x20(r3) | ||
477 | lwz r5, SS_IBAT+0x24(r3) | ||
478 | lwz r6, SS_IBAT+0x28(r3) | ||
479 | lwz r7, SS_IBAT+0x2c(r3) | ||
480 | |||
481 | mtspr SPRN_IBAT4U, r4 | ||
482 | mtspr SPRN_IBAT4L, r5 | ||
483 | mtspr SPRN_IBAT5U, r6 | ||
484 | mtspr SPRN_IBAT5L, r7 | ||
485 | |||
486 | lwz r4, SS_IBAT+0x30(r3) | ||
487 | lwz r5, SS_IBAT+0x34(r3) | ||
488 | lwz r6, SS_IBAT+0x38(r3) | ||
489 | lwz r7, SS_IBAT+0x3c(r3) | ||
490 | |||
491 | mtspr SPRN_IBAT6U, r4 | ||
492 | mtspr SPRN_IBAT6L, r5 | ||
493 | mtspr SPRN_IBAT7U, r6 | ||
494 | mtspr SPRN_IBAT7L, r7 | ||
495 | |||
496 | lwz r4, SS_SPRG+0(r3) | ||
497 | lwz r5, SS_SPRG+4(r3) | ||
498 | lwz r6, SS_SPRG+8(r3) | ||
499 | lwz r7, SS_SPRG+12(r3) | ||
500 | lwz r8, SS_SDR1(r3) | ||
501 | |||
502 | mtspr SPRN_SPRG0, r4 | ||
503 | mtspr SPRN_SPRG1, r5 | ||
504 | mtspr SPRN_SPRG2, r6 | ||
505 | mtspr SPRN_SPRG3, r7 | ||
506 | mtsdr1 r8 | ||
507 | |||
508 | lwz r4, SS_MSR(r3) | ||
509 | lwz r5, SS_LR(r3) | ||
510 | lwz r6, SS_CR(r3) | ||
511 | lwz r1, SS_SP(r3) | ||
512 | lwz r2, SS_R2(r3) | ||
513 | |||
514 | mtsrr1 r4 | ||
515 | mtsrr0 r5 | ||
516 | mtcr r6 | ||
517 | |||
518 | li r4, 0 | ||
519 | mtspr SPRN_TBWL, r4 | ||
520 | |||
521 | lwz r4, SS_TB+0(r3) | ||
522 | lwz r5, SS_TB+4(r3) | ||
523 | |||
524 | mtspr SPRN_TBWU, r4 | ||
525 | mtspr SPRN_TBWL, r5 | ||
526 | |||
527 | lmw r12, SS_GPREG(r3) | ||
528 | |||
529 | /* Kick decrementer */ | ||
530 | li r0, 1 | ||
531 | mtdec r0 | ||
532 | |||
533 | rfi | ||
diff --git a/arch/powerpc/platforms/83xx/suspend.c b/arch/powerpc/platforms/83xx/suspend.c new file mode 100644 index 000000000000..08e65fc8b98c --- /dev/null +++ b/arch/powerpc/platforms/83xx/suspend.c | |||
@@ -0,0 +1,388 @@ | |||
1 | /* | ||
2 | * MPC83xx suspend support | ||
3 | * | ||
4 | * Author: Scott Wood <scottwood@freescale.com> | ||
5 | * | ||
6 | * Copyright (c) 2006-2007 Freescale Semiconductor, Inc. | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify it | ||
9 | * under the terms of the GNU General Public License version 2 as published | ||
10 | * by the Free Software Foundation. | ||
11 | */ | ||
12 | |||
13 | #include <linux/init.h> | ||
14 | #include <linux/pm.h> | ||
15 | #include <linux/types.h> | ||
16 | #include <linux/ioport.h> | ||
17 | #include <linux/interrupt.h> | ||
18 | #include <linux/wait.h> | ||
19 | #include <linux/kthread.h> | ||
20 | #include <linux/freezer.h> | ||
21 | #include <linux/suspend.h> | ||
22 | #include <linux/fsl_devices.h> | ||
23 | #include <linux/of_platform.h> | ||
24 | |||
25 | #include <asm/reg.h> | ||
26 | #include <asm/io.h> | ||
27 | #include <asm/time.h> | ||
28 | #include <asm/mpc6xx.h> | ||
29 | |||
30 | #include <sysdev/fsl_soc.h> | ||
31 | |||
32 | #define PMCCR1_NEXT_STATE 0x0C /* Next state for power management */ | ||
33 | #define PMCCR1_NEXT_STATE_SHIFT 2 | ||
34 | #define PMCCR1_CURR_STATE 0x03 /* Current state for power management*/ | ||
35 | #define IMMR_RCW_OFFSET 0x900 | ||
36 | #define RCW_PCI_HOST 0x80000000 | ||
37 | |||
38 | void mpc83xx_enter_deep_sleep(phys_addr_t immrbase); | ||
39 | |||
40 | struct mpc83xx_pmc { | ||
41 | u32 config; | ||
42 | #define PMCCR_DLPEN 2 /* DDR SDRAM low power enable */ | ||
43 | #define PMCCR_SLPEN 1 /* System low power enable */ | ||
44 | |||
45 | u32 event; | ||
46 | u32 mask; | ||
47 | /* All but PMCI are deep-sleep only */ | ||
48 | #define PMCER_GPIO 0x100 | ||
49 | #define PMCER_PCI 0x080 | ||
50 | #define PMCER_USB 0x040 | ||
51 | #define PMCER_ETSEC1 0x020 | ||
52 | #define PMCER_ETSEC2 0x010 | ||
53 | #define PMCER_TIMER 0x008 | ||
54 | #define PMCER_INT1 0x004 | ||
55 | #define PMCER_INT2 0x002 | ||
56 | #define PMCER_PMCI 0x001 | ||
57 | #define PMCER_ALL 0x1FF | ||
58 | |||
59 | /* deep-sleep only */ | ||
60 | u32 config1; | ||
61 | #define PMCCR1_USE_STATE 0x80000000 | ||
62 | #define PMCCR1_PME_EN 0x00000080 | ||
63 | #define PMCCR1_ASSERT_PME 0x00000040 | ||
64 | #define PMCCR1_POWER_OFF 0x00000020 | ||
65 | |||
66 | /* deep-sleep only */ | ||
67 | u32 config2; | ||
68 | }; | ||
69 | |||
70 | struct mpc83xx_rcw { | ||
71 | u32 rcwlr; | ||
72 | u32 rcwhr; | ||
73 | }; | ||
74 | |||
75 | struct mpc83xx_clock { | ||
76 | u32 spmr; | ||
77 | u32 occr; | ||
78 | u32 sccr; | ||
79 | }; | ||
80 | |||
81 | struct pmc_type { | ||
82 | int has_deep_sleep; | ||
83 | }; | ||
84 | |||
85 | static struct of_device *pmc_dev; | ||
86 | static int has_deep_sleep, deep_sleeping; | ||
87 | static int pmc_irq; | ||
88 | static struct mpc83xx_pmc __iomem *pmc_regs; | ||
89 | static struct mpc83xx_clock __iomem *clock_regs; | ||
90 | static int is_pci_agent, wake_from_pci; | ||
91 | static phys_addr_t immrbase; | ||
92 | static int pci_pm_state; | ||
93 | static DECLARE_WAIT_QUEUE_HEAD(agent_wq); | ||
94 | |||
95 | int fsl_deep_sleep(void) | ||
96 | { | ||
97 | return deep_sleeping; | ||
98 | } | ||
99 | |||
100 | static int mpc83xx_change_state(void) | ||
101 | { | ||
102 | u32 curr_state; | ||
103 | u32 reg_cfg1 = in_be32(&pmc_regs->config1); | ||
104 | |||
105 | if (is_pci_agent) { | ||
106 | pci_pm_state = (reg_cfg1 & PMCCR1_NEXT_STATE) >> | ||
107 | PMCCR1_NEXT_STATE_SHIFT; | ||
108 | curr_state = reg_cfg1 & PMCCR1_CURR_STATE; | ||
109 | |||
110 | if (curr_state != pci_pm_state) { | ||
111 | reg_cfg1 &= ~PMCCR1_CURR_STATE; | ||
112 | reg_cfg1 |= pci_pm_state; | ||
113 | out_be32(&pmc_regs->config1, reg_cfg1); | ||
114 | |||
115 | wake_up(&agent_wq); | ||
116 | return 1; | ||
117 | } | ||
118 | } | ||
119 | |||
120 | return 0; | ||
121 | } | ||
122 | |||
123 | static irqreturn_t pmc_irq_handler(int irq, void *dev_id) | ||
124 | { | ||
125 | u32 event = in_be32(&pmc_regs->event); | ||
126 | int ret = IRQ_NONE; | ||
127 | |||
128 | if (mpc83xx_change_state()) | ||
129 | ret = IRQ_HANDLED; | ||
130 | |||
131 | if (event) { | ||
132 | out_be32(&pmc_regs->event, event); | ||
133 | ret = IRQ_HANDLED; | ||
134 | } | ||
135 | |||
136 | return ret; | ||
137 | } | ||
138 | |||
139 | static int mpc83xx_suspend_enter(suspend_state_t state) | ||
140 | { | ||
141 | int ret = -EAGAIN; | ||
142 | |||
143 | /* Don't go to sleep if there's a race where pci_pm_state changes | ||
144 | * between the agent thread checking it and the PM code disabling | ||
145 | * interrupts. | ||
146 | */ | ||
147 | if (wake_from_pci) { | ||
148 | if (pci_pm_state != (deep_sleeping ? 3 : 2)) | ||
149 | goto out; | ||
150 | |||
151 | out_be32(&pmc_regs->config1, | ||
152 | in_be32(&pmc_regs->config1) | PMCCR1_PME_EN); | ||
153 | } | ||
154 | |||
155 | /* Put the system into low-power mode and the RAM | ||
156 | * into self-refresh mode once the core goes to | ||
157 | * sleep. | ||
158 | */ | ||
159 | |||
160 | out_be32(&pmc_regs->config, PMCCR_SLPEN | PMCCR_DLPEN); | ||
161 | |||
162 | /* If it has deep sleep (i.e. it's an 831x or compatible), | ||
163 | * disable power to the core upon entering sleep mode. This will | ||
164 | * require going through the boot firmware upon a wakeup event. | ||
165 | */ | ||
166 | |||
167 | if (deep_sleeping) { | ||
168 | out_be32(&pmc_regs->mask, PMCER_ALL); | ||
169 | |||
170 | out_be32(&pmc_regs->config1, | ||
171 | in_be32(&pmc_regs->config1) | PMCCR1_POWER_OFF); | ||
172 | |||
173 | enable_kernel_fp(); | ||
174 | |||
175 | mpc83xx_enter_deep_sleep(immrbase); | ||
176 | |||
177 | out_be32(&pmc_regs->config1, | ||
178 | in_be32(&pmc_regs->config1) & ~PMCCR1_POWER_OFF); | ||
179 | |||
180 | out_be32(&pmc_regs->mask, PMCER_PMCI); | ||
181 | } else { | ||
182 | out_be32(&pmc_regs->mask, PMCER_PMCI); | ||
183 | |||
184 | mpc6xx_enter_standby(); | ||
185 | } | ||
186 | |||
187 | ret = 0; | ||
188 | |||
189 | out: | ||
190 | out_be32(&pmc_regs->config1, | ||
191 | in_be32(&pmc_regs->config1) & ~PMCCR1_PME_EN); | ||
192 | |||
193 | return ret; | ||
194 | } | ||
195 | |||
196 | static void mpc83xx_suspend_finish(void) | ||
197 | { | ||
198 | deep_sleeping = 0; | ||
199 | } | ||
200 | |||
201 | static int mpc83xx_suspend_valid(suspend_state_t state) | ||
202 | { | ||
203 | return state == PM_SUSPEND_STANDBY || state == PM_SUSPEND_MEM; | ||
204 | } | ||
205 | |||
206 | static int mpc83xx_suspend_begin(suspend_state_t state) | ||
207 | { | ||
208 | switch (state) { | ||
209 | case PM_SUSPEND_STANDBY: | ||
210 | deep_sleeping = 0; | ||
211 | return 0; | ||
212 | |||
213 | case PM_SUSPEND_MEM: | ||
214 | if (has_deep_sleep) | ||
215 | deep_sleeping = 1; | ||
216 | |||
217 | return 0; | ||
218 | |||
219 | default: | ||
220 | return -EINVAL; | ||
221 | } | ||
222 | } | ||
223 | |||
224 | static int agent_thread_fn(void *data) | ||
225 | { | ||
226 | while (1) { | ||
227 | wait_event_interruptible(agent_wq, pci_pm_state >= 2); | ||
228 | try_to_freeze(); | ||
229 | |||
230 | if (signal_pending(current) || pci_pm_state < 2) | ||
231 | continue; | ||
232 | |||
233 | /* With a preemptible kernel (or SMP), this could race with | ||
234 | * a userspace-driven suspend request. It's probably best | ||
235 | * to avoid mixing the two with such a configuration (or | ||
236 | * else fix it by adding a mutex to state_store that we can | ||
237 | * synchronize with). | ||
238 | */ | ||
239 | |||
240 | wake_from_pci = 1; | ||
241 | |||
242 | pm_suspend(pci_pm_state == 3 ? PM_SUSPEND_MEM : | ||
243 | PM_SUSPEND_STANDBY); | ||
244 | |||
245 | wake_from_pci = 0; | ||
246 | } | ||
247 | |||
248 | return 0; | ||
249 | } | ||
250 | |||
251 | static void mpc83xx_set_agent(void) | ||
252 | { | ||
253 | out_be32(&pmc_regs->config1, PMCCR1_USE_STATE); | ||
254 | out_be32(&pmc_regs->mask, PMCER_PMCI); | ||
255 | |||
256 | kthread_run(agent_thread_fn, NULL, "PCI power mgt"); | ||
257 | } | ||
258 | |||
259 | static int mpc83xx_is_pci_agent(void) | ||
260 | { | ||
261 | struct mpc83xx_rcw __iomem *rcw_regs; | ||
262 | int ret; | ||
263 | |||
264 | rcw_regs = ioremap(get_immrbase() + IMMR_RCW_OFFSET, | ||
265 | sizeof(struct mpc83xx_rcw)); | ||
266 | |||
267 | if (!rcw_regs) | ||
268 | return -ENOMEM; | ||
269 | |||
270 | ret = !(in_be32(&rcw_regs->rcwhr) & RCW_PCI_HOST); | ||
271 | |||
272 | iounmap(rcw_regs); | ||
273 | return ret; | ||
274 | } | ||
275 | |||
276 | static struct platform_suspend_ops mpc83xx_suspend_ops = { | ||
277 | .valid = mpc83xx_suspend_valid, | ||
278 | .begin = mpc83xx_suspend_begin, | ||
279 | .enter = mpc83xx_suspend_enter, | ||
280 | .finish = mpc83xx_suspend_finish, | ||
281 | }; | ||
282 | |||
283 | static int pmc_probe(struct of_device *ofdev, | ||
284 | const struct of_device_id *match) | ||
285 | { | ||
286 | struct device_node *np = ofdev->node; | ||
287 | struct resource res; | ||
288 | struct pmc_type *type = match->data; | ||
289 | int ret = 0; | ||
290 | |||
291 | if (!of_device_is_available(np)) | ||
292 | return -ENODEV; | ||
293 | |||
294 | has_deep_sleep = type->has_deep_sleep; | ||
295 | immrbase = get_immrbase(); | ||
296 | pmc_dev = ofdev; | ||
297 | |||
298 | is_pci_agent = mpc83xx_is_pci_agent(); | ||
299 | if (is_pci_agent < 0) | ||
300 | return is_pci_agent; | ||
301 | |||
302 | ret = of_address_to_resource(np, 0, &res); | ||
303 | if (ret) | ||
304 | return -ENODEV; | ||
305 | |||
306 | pmc_irq = irq_of_parse_and_map(np, 0); | ||
307 | if (pmc_irq != NO_IRQ) { | ||
308 | ret = request_irq(pmc_irq, pmc_irq_handler, IRQF_SHARED, | ||
309 | "pmc", ofdev); | ||
310 | |||
311 | if (ret) | ||
312 | return -EBUSY; | ||
313 | } | ||
314 | |||
315 | pmc_regs = ioremap(res.start, sizeof(struct mpc83xx_pmc)); | ||
316 | |||
317 | if (!pmc_regs) { | ||
318 | ret = -ENOMEM; | ||
319 | goto out; | ||
320 | } | ||
321 | |||
322 | ret = of_address_to_resource(np, 1, &res); | ||
323 | if (ret) { | ||
324 | ret = -ENODEV; | ||
325 | goto out_pmc; | ||
326 | } | ||
327 | |||
328 | clock_regs = ioremap(res.start, sizeof(struct mpc83xx_pmc)); | ||
329 | |||
330 | if (!clock_regs) { | ||
331 | ret = -ENOMEM; | ||
332 | goto out_pmc; | ||
333 | } | ||
334 | |||
335 | if (is_pci_agent) | ||
336 | mpc83xx_set_agent(); | ||
337 | |||
338 | suspend_set_ops(&mpc83xx_suspend_ops); | ||
339 | return 0; | ||
340 | |||
341 | out_pmc: | ||
342 | iounmap(pmc_regs); | ||
343 | out: | ||
344 | if (pmc_irq != NO_IRQ) | ||
345 | free_irq(pmc_irq, ofdev); | ||
346 | |||
347 | return ret; | ||
348 | } | ||
349 | |||
350 | static int pmc_remove(struct of_device *ofdev) | ||
351 | { | ||
352 | return -EPERM; | ||
353 | }; | ||
354 | |||
355 | static struct pmc_type pmc_types[] = { | ||
356 | { | ||
357 | .has_deep_sleep = 1, | ||
358 | }, | ||
359 | { | ||
360 | .has_deep_sleep = 0, | ||
361 | } | ||
362 | }; | ||
363 | |||
364 | static struct of_device_id pmc_match[] = { | ||
365 | { | ||
366 | .compatible = "fsl,mpc8313-pmc", | ||
367 | .data = &pmc_types[0], | ||
368 | }, | ||
369 | { | ||
370 | .compatible = "fsl,mpc8349-pmc", | ||
371 | .data = &pmc_types[1], | ||
372 | }, | ||
373 | {} | ||
374 | }; | ||
375 | |||
376 | static struct of_platform_driver pmc_driver = { | ||
377 | .name = "mpc83xx-pmc", | ||
378 | .match_table = pmc_match, | ||
379 | .probe = pmc_probe, | ||
380 | .remove = pmc_remove | ||
381 | }; | ||
382 | |||
383 | static int pmc_init(void) | ||
384 | { | ||
385 | return of_register_platform_driver(&pmc_driver); | ||
386 | } | ||
387 | |||
388 | module_init(pmc_init); | ||
diff --git a/arch/powerpc/platforms/83xx/usb.c b/arch/powerpc/platforms/83xx/usb.c index 64bcf0a33c71..cc99c280aad9 100644 --- a/arch/powerpc/platforms/83xx/usb.c +++ b/arch/powerpc/platforms/83xx/usb.c | |||
@@ -137,15 +137,21 @@ int mpc831x_usb_cfg(void) | |||
137 | 137 | ||
138 | /* Configure pin mux for ULPI. There is no pin mux for UTMI */ | 138 | /* Configure pin mux for ULPI. There is no pin mux for UTMI */ |
139 | if (prop && !strcmp(prop, "ulpi")) { | 139 | if (prop && !strcmp(prop, "ulpi")) { |
140 | temp = in_be32(immap + MPC83XX_SICRL_OFFS); | 140 | if (of_device_is_compatible(immr_node, "fsl,mpc8315-immr")) { |
141 | temp &= ~MPC831X_SICRL_USB_MASK; | 141 | clrsetbits_be32(immap + MPC83XX_SICRL_OFFS, |
142 | temp |= MPC831X_SICRL_USB_ULPI; | 142 | MPC8315_SICRL_USB_MASK, |
143 | out_be32(immap + MPC83XX_SICRL_OFFS, temp); | 143 | MPC8315_SICRL_USB_ULPI); |
144 | 144 | clrsetbits_be32(immap + MPC83XX_SICRH_OFFS, | |
145 | temp = in_be32(immap + MPC83XX_SICRH_OFFS); | 145 | MPC8315_SICRH_USB_MASK, |
146 | temp &= ~MPC831X_SICRH_USB_MASK; | 146 | MPC8315_SICRH_USB_ULPI); |
147 | temp |= MPC831X_SICRH_USB_ULPI; | 147 | } else { |
148 | out_be32(immap + MPC83XX_SICRH_OFFS, temp); | 148 | clrsetbits_be32(immap + MPC83XX_SICRL_OFFS, |
149 | MPC831X_SICRL_USB_MASK, | ||
150 | MPC831X_SICRL_USB_ULPI); | ||
151 | clrsetbits_be32(immap + MPC83XX_SICRH_OFFS, | ||
152 | MPC831X_SICRH_USB_MASK, | ||
153 | MPC831X_SICRH_USB_ULPI); | ||
154 | } | ||
149 | } | 155 | } |
150 | 156 | ||
151 | iounmap(immap); | 157 | iounmap(immap); |
diff --git a/arch/powerpc/platforms/85xx/Kconfig b/arch/powerpc/platforms/85xx/Kconfig index cebea5cadbc1..291675b0097a 100644 --- a/arch/powerpc/platforms/85xx/Kconfig +++ b/arch/powerpc/platforms/85xx/Kconfig | |||
@@ -2,8 +2,8 @@ menuconfig MPC85xx | |||
2 | bool "Machine Type" | 2 | bool "Machine Type" |
3 | depends on PPC_85xx | 3 | depends on PPC_85xx |
4 | select PPC_UDBG_16550 | 4 | select PPC_UDBG_16550 |
5 | select PPC_INDIRECT_PCI if PCI | ||
6 | select MPIC | 5 | select MPIC |
6 | select PPC_PCI_CHOICE | ||
7 | select FSL_PCI if PCI | 7 | select FSL_PCI if PCI |
8 | select SERIAL_8250_SHARE_IRQ if SERIAL_8250 | 8 | select SERIAL_8250_SHARE_IRQ if SERIAL_8250 |
9 | default y | 9 | default y |
@@ -86,7 +86,6 @@ config TQM8548 | |||
86 | help | 86 | help |
87 | This option enables support for the TQ Components TQM8548 board. | 87 | This option enables support for the TQ Components TQM8548 board. |
88 | select DEFAULT_UIMAGE | 88 | select DEFAULT_UIMAGE |
89 | select PPC_CPM_NEW_BINDING | ||
90 | select TQM85xx | 89 | select TQM85xx |
91 | 90 | ||
92 | config TQM8555 | 91 | config TQM8555 |
diff --git a/arch/powerpc/platforms/85xx/mpc85xx_ds.c b/arch/powerpc/platforms/85xx/mpc85xx_ds.c index 25f41cd2d33a..00c535806647 100644 --- a/arch/powerpc/platforms/85xx/mpc85xx_ds.c +++ b/arch/powerpc/platforms/85xx/mpc85xx_ds.c | |||
@@ -115,7 +115,6 @@ void __init mpc85xx_ds_pic_init(void) | |||
115 | 115 | ||
116 | #ifdef CONFIG_PCI | 116 | #ifdef CONFIG_PCI |
117 | static int primary_phb_addr; | 117 | static int primary_phb_addr; |
118 | extern int uses_fsl_uli_m1575; | ||
119 | extern int uli_exclude_device(struct pci_controller *hose, | 118 | extern int uli_exclude_device(struct pci_controller *hose, |
120 | u_char bus, u_char devfn); | 119 | u_char bus, u_char devfn); |
121 | 120 | ||
@@ -161,7 +160,6 @@ static void __init mpc85xx_ds_setup_arch(void) | |||
161 | } | 160 | } |
162 | } | 161 | } |
163 | 162 | ||
164 | uses_fsl_uli_m1575 = 1; | ||
165 | ppc_md.pci_exclude_device = mpc85xx_exclude_device; | 163 | ppc_md.pci_exclude_device = mpc85xx_exclude_device; |
166 | #endif | 164 | #endif |
167 | 165 | ||
diff --git a/arch/powerpc/platforms/86xx/Kconfig b/arch/powerpc/platforms/86xx/Kconfig index 80a81e02bb55..9355a5269431 100644 --- a/arch/powerpc/platforms/86xx/Kconfig +++ b/arch/powerpc/platforms/86xx/Kconfig | |||
@@ -27,6 +27,7 @@ config SBC8641D | |||
27 | config MPC8610_HPCD | 27 | config MPC8610_HPCD |
28 | bool "Freescale MPC8610 HPCD" | 28 | bool "Freescale MPC8610 HPCD" |
29 | select DEFAULT_UIMAGE | 29 | select DEFAULT_UIMAGE |
30 | select FSL_ULI1575 | ||
30 | help | 31 | help |
31 | This option enables support for the MPC8610 HPCD board. | 32 | This option enables support for the MPC8610 HPCD board. |
32 | 33 | ||
@@ -34,6 +35,7 @@ endif | |||
34 | 35 | ||
35 | config MPC8641 | 36 | config MPC8641 |
36 | bool | 37 | bool |
38 | select PPC_PCI_CHOICE | ||
37 | select FSL_PCI if PCI | 39 | select FSL_PCI if PCI |
38 | select PPC_UDBG_16550 | 40 | select PPC_UDBG_16550 |
39 | select MPIC | 41 | select MPIC |
@@ -41,6 +43,7 @@ config MPC8641 | |||
41 | 43 | ||
42 | config MPC8610 | 44 | config MPC8610 |
43 | bool | 45 | bool |
46 | select PPC_PCI_CHOICE | ||
44 | select FSL_PCI if PCI | 47 | select FSL_PCI if PCI |
45 | select PPC_UDBG_16550 | 48 | select PPC_UDBG_16550 |
46 | select MPIC | 49 | select MPIC |
diff --git a/arch/powerpc/platforms/86xx/mpc8610_hpcd.c b/arch/powerpc/platforms/86xx/mpc8610_hpcd.c index 30725302884a..5eedb710896e 100644 --- a/arch/powerpc/platforms/86xx/mpc8610_hpcd.c +++ b/arch/powerpc/platforms/86xx/mpc8610_hpcd.c | |||
@@ -58,93 +58,6 @@ static int __init mpc8610_declare_of_platform_devices(void) | |||
58 | } | 58 | } |
59 | machine_device_initcall(mpc86xx_hpcd, mpc8610_declare_of_platform_devices); | 59 | machine_device_initcall(mpc86xx_hpcd, mpc8610_declare_of_platform_devices); |
60 | 60 | ||
61 | #ifdef CONFIG_PCI | ||
62 | static void __devinit quirk_uli1575(struct pci_dev *dev) | ||
63 | { | ||
64 | u32 temp32; | ||
65 | |||
66 | /* Disable INTx */ | ||
67 | pci_read_config_dword(dev, 0x48, &temp32); | ||
68 | pci_write_config_dword(dev, 0x48, (temp32 | 1<<26)); | ||
69 | |||
70 | /* Enable sideband interrupt */ | ||
71 | pci_read_config_dword(dev, 0x90, &temp32); | ||
72 | pci_write_config_dword(dev, 0x90, (temp32 | 1<<22)); | ||
73 | } | ||
74 | |||
75 | static void __devinit quirk_uli5288(struct pci_dev *dev) | ||
76 | { | ||
77 | unsigned char c; | ||
78 | unsigned short temp; | ||
79 | |||
80 | /* Interrupt Disable, Needed when SATA disabled */ | ||
81 | pci_read_config_word(dev, PCI_COMMAND, &temp); | ||
82 | temp |= 1<<10; | ||
83 | pci_write_config_word(dev, PCI_COMMAND, temp); | ||
84 | |||
85 | pci_read_config_byte(dev, 0x83, &c); | ||
86 | c |= 0x80; | ||
87 | pci_write_config_byte(dev, 0x83, c); | ||
88 | |||
89 | pci_write_config_byte(dev, PCI_CLASS_PROG, 0x01); | ||
90 | pci_write_config_byte(dev, PCI_CLASS_DEVICE, 0x06); | ||
91 | |||
92 | pci_read_config_byte(dev, 0x83, &c); | ||
93 | c &= 0x7f; | ||
94 | pci_write_config_byte(dev, 0x83, c); | ||
95 | } | ||
96 | |||
97 | /* | ||
98 | * Since 8259PIC was disabled on the board, the IDE device can not | ||
99 | * use the legacy IRQ, we need to let the IDE device work under | ||
100 | * native mode and use the interrupt line like other PCI devices. | ||
101 | * IRQ14 is a sideband interrupt from IDE device to CPU and we use this | ||
102 | * as the interrupt for IDE device. | ||
103 | */ | ||
104 | static void __devinit quirk_uli5229(struct pci_dev *dev) | ||
105 | { | ||
106 | unsigned char c; | ||
107 | |||
108 | pci_read_config_byte(dev, 0x4b, &c); | ||
109 | c |= 0x10; | ||
110 | pci_write_config_byte(dev, 0x4b, c); | ||
111 | } | ||
112 | |||
113 | /* | ||
114 | * SATA interrupt pin bug fix | ||
115 | * There's a chip bug for 5288, The interrupt pin should be 2, | ||
116 | * not the read only value 1, So it use INTB#, not INTA# which | ||
117 | * actually used by the IDE device 5229. | ||
118 | * As of this bug, during the PCI initialization, 5288 read the | ||
119 | * irq of IDE device from the device tree, this function fix this | ||
120 | * bug by re-assigning a correct irq to 5288. | ||
121 | * | ||
122 | */ | ||
123 | static void __devinit final_uli5288(struct pci_dev *dev) | ||
124 | { | ||
125 | struct pci_controller *hose = pci_bus_to_host(dev->bus); | ||
126 | struct device_node *hosenode = hose ? hose->dn : NULL; | ||
127 | struct of_irq oirq; | ||
128 | int virq, pin = 2; | ||
129 | u32 laddr[3]; | ||
130 | |||
131 | if (!hosenode) | ||
132 | return; | ||
133 | |||
134 | laddr[0] = (hose->first_busno << 16) | (PCI_DEVFN(31, 0) << 8); | ||
135 | laddr[1] = laddr[2] = 0; | ||
136 | of_irq_map_raw(hosenode, &pin, 1, laddr, &oirq); | ||
137 | virq = irq_create_of_mapping(oirq.controller, oirq.specifier, | ||
138 | oirq.size); | ||
139 | dev->irq = virq; | ||
140 | } | ||
141 | |||
142 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_AL, 0x1575, quirk_uli1575); | ||
143 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_AL, 0x5288, quirk_uli5288); | ||
144 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_AL, 0x5229, quirk_uli5229); | ||
145 | DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_AL, 0x5288, final_uli5288); | ||
146 | #endif /* CONFIG_PCI */ | ||
147 | |||
148 | #if defined(CONFIG_FB_FSL_DIU) || defined(CONFIG_FB_FSL_DIU_MODULE) | 61 | #if defined(CONFIG_FB_FSL_DIU) || defined(CONFIG_FB_FSL_DIU_MODULE) |
149 | 62 | ||
150 | static u32 get_busfreq(void) | 63 | static u32 get_busfreq(void) |
diff --git a/arch/powerpc/platforms/86xx/mpc86xx_hpcn.c b/arch/powerpc/platforms/86xx/mpc86xx_hpcn.c index 7916599c9126..f712d9c0991b 100644 --- a/arch/powerpc/platforms/86xx/mpc86xx_hpcn.c +++ b/arch/powerpc/platforms/86xx/mpc86xx_hpcn.c | |||
@@ -45,7 +45,6 @@ | |||
45 | #endif | 45 | #endif |
46 | 46 | ||
47 | #ifdef CONFIG_PCI | 47 | #ifdef CONFIG_PCI |
48 | extern int uses_fsl_uli_m1575; | ||
49 | extern int uli_exclude_device(struct pci_controller *hose, | 48 | extern int uli_exclude_device(struct pci_controller *hose, |
50 | u_char bus, u_char devfn); | 49 | u_char bus, u_char devfn); |
51 | 50 | ||
@@ -87,7 +86,6 @@ mpc86xx_hpcn_setup_arch(void) | |||
87 | fsl_add_bridge(np, 0); | 86 | fsl_add_bridge(np, 0); |
88 | } | 87 | } |
89 | 88 | ||
90 | uses_fsl_uli_m1575 = 1; | ||
91 | ppc_md.pci_exclude_device = mpc86xx_exclude_device; | 89 | ppc_md.pci_exclude_device = mpc86xx_exclude_device; |
92 | 90 | ||
93 | #endif | 91 | #endif |
diff --git a/arch/powerpc/platforms/Kconfig b/arch/powerpc/platforms/Kconfig index 690c1f46e698..1d0968775c0a 100644 --- a/arch/powerpc/platforms/Kconfig +++ b/arch/powerpc/platforms/Kconfig | |||
@@ -253,17 +253,13 @@ config CPM2 | |||
253 | depends on MPC85xx || 8260 | 253 | depends on MPC85xx || 8260 |
254 | select CPM | 254 | select CPM |
255 | select PPC_LIB_RHEAP | 255 | select PPC_LIB_RHEAP |
256 | select PPC_PCI_CHOICE | ||
256 | help | 257 | help |
257 | The CPM2 (Communications Processor Module) is a coprocessor on | 258 | The CPM2 (Communications Processor Module) is a coprocessor on |
258 | embedded CPUs made by Freescale. Selecting this option means that | 259 | embedded CPUs made by Freescale. Selecting this option means that |
259 | you wish to build a kernel for a machine with a CPM2 coprocessor | 260 | you wish to build a kernel for a machine with a CPM2 coprocessor |
260 | on it (826x, 827x, 8560). | 261 | on it (826x, 827x, 8560). |
261 | 262 | ||
262 | config PPC_CPM_NEW_BINDING | ||
263 | bool | ||
264 | depends on CPM1 || CPM2 | ||
265 | default y | ||
266 | |||
267 | config AXON_RAM | 263 | config AXON_RAM |
268 | tristate "Axon DDR2 memory device driver" | 264 | tristate "Axon DDR2 memory device driver" |
269 | depends on PPC_IBM_CELL_BLADE | 265 | depends on PPC_IBM_CELL_BLADE |
diff --git a/arch/powerpc/platforms/Kconfig.cputype b/arch/powerpc/platforms/Kconfig.cputype index 5bc4b611ff88..7f6512733862 100644 --- a/arch/powerpc/platforms/Kconfig.cputype +++ b/arch/powerpc/platforms/Kconfig.cputype | |||
@@ -42,12 +42,14 @@ config 40x | |||
42 | select PPC_DCR_NATIVE | 42 | select PPC_DCR_NATIVE |
43 | select PPC_UDBG_16550 | 43 | select PPC_UDBG_16550 |
44 | select 4xx_SOC | 44 | select 4xx_SOC |
45 | select PPC_PCI_CHOICE | ||
45 | 46 | ||
46 | config 44x | 47 | config 44x |
47 | bool "AMCC 44x" | 48 | bool "AMCC 44x" |
48 | select PPC_DCR_NATIVE | 49 | select PPC_DCR_NATIVE |
49 | select PPC_UDBG_16550 | 50 | select PPC_UDBG_16550 |
50 | select 4xx_SOC | 51 | select 4xx_SOC |
52 | select PPC_PCI_CHOICE | ||
51 | 53 | ||
52 | config E200 | 54 | config E200 |
53 | bool "Freescale e200" | 55 | bool "Freescale e200" |
@@ -84,9 +86,6 @@ config TUNE_CELL | |||
84 | machines. When building a kernel that is supposed to run only | 86 | machines. When building a kernel that is supposed to run only |
85 | on Cell, you should also select the POWER4_ONLY option. | 87 | on Cell, you should also select the POWER4_ONLY option. |
86 | 88 | ||
87 | config 6xx | ||
88 | bool | ||
89 | |||
90 | # this is temp to handle compat with arch=ppc | 89 | # this is temp to handle compat with arch=ppc |
91 | config 8xx | 90 | config 8xx |
92 | bool | 91 | bool |
diff --git a/arch/powerpc/platforms/cell/Kconfig b/arch/powerpc/platforms/cell/Kconfig index 3959fcfe731c..c14d7d8d96c8 100644 --- a/arch/powerpc/platforms/cell/Kconfig +++ b/arch/powerpc/platforms/cell/Kconfig | |||
@@ -83,6 +83,22 @@ config CBE_RAS | |||
83 | depends on PPC_CELL_NATIVE | 83 | depends on PPC_CELL_NATIVE |
84 | default y | 84 | default y |
85 | 85 | ||
86 | config PPC_IBM_CELL_RESETBUTTON | ||
87 | bool "IBM Cell Blade Pinhole reset button" | ||
88 | depends on CBE_RAS && PPC_IBM_CELL_BLADE | ||
89 | default y | ||
90 | help | ||
91 | Support Pinhole Resetbutton on IBM Cell blades. | ||
92 | This adds a method to trigger system reset via front panel pinhole button. | ||
93 | |||
94 | config PPC_IBM_CELL_POWERBUTTON | ||
95 | tristate "IBM Cell Blade power button" | ||
96 | depends on PPC_IBM_CELL_BLADE && PPC_PMI && INPUT_EVDEV | ||
97 | default y | ||
98 | help | ||
99 | Support Powerbutton on IBM Cell blades. | ||
100 | This will enable the powerbutton as an input device. | ||
101 | |||
86 | config CBE_THERM | 102 | config CBE_THERM |
87 | tristate "CBE thermal support" | 103 | tristate "CBE thermal support" |
88 | default m | 104 | default m |
@@ -107,6 +123,15 @@ config CBE_CPUFREQ_PMI | |||
107 | processor will not only be able to run at lower speed, | 123 | processor will not only be able to run at lower speed, |
108 | but also at lower core voltage. | 124 | but also at lower core voltage. |
109 | 125 | ||
126 | config CBE_CPUFREQ_SPU_GOVERNOR | ||
127 | tristate "CBE frequency scaling based on SPU usage" | ||
128 | depends on SPU_FS && CPU_FREQ | ||
129 | default m | ||
130 | help | ||
131 | This governor checks for spu usage to adjust the cpu frequency. | ||
132 | If no spu is running on a given cpu, that cpu will be throttled to | ||
133 | the minimal possible frequency. | ||
134 | |||
110 | endmenu | 135 | endmenu |
111 | 136 | ||
112 | config OPROFILE_CELL | 137 | config OPROFILE_CELL |
diff --git a/arch/powerpc/platforms/cell/Makefile b/arch/powerpc/platforms/cell/Makefile index c2a7e4e5ddf9..7fd830872c43 100644 --- a/arch/powerpc/platforms/cell/Makefile +++ b/arch/powerpc/platforms/cell/Makefile | |||
@@ -8,6 +8,9 @@ obj-$(CONFIG_CBE_THERM) += cbe_thermal.o | |||
8 | obj-$(CONFIG_CBE_CPUFREQ_PMI) += cbe_cpufreq_pmi.o | 8 | obj-$(CONFIG_CBE_CPUFREQ_PMI) += cbe_cpufreq_pmi.o |
9 | obj-$(CONFIG_CBE_CPUFREQ) += cbe-cpufreq.o | 9 | obj-$(CONFIG_CBE_CPUFREQ) += cbe-cpufreq.o |
10 | cbe-cpufreq-y += cbe_cpufreq_pervasive.o cbe_cpufreq.o | 10 | cbe-cpufreq-y += cbe_cpufreq_pervasive.o cbe_cpufreq.o |
11 | obj-$(CONFIG_CBE_CPUFREQ_SPU_GOVERNOR) += cpufreq_spudemand.o | ||
12 | |||
13 | obj-$(CONFIG_PPC_IBM_CELL_POWERBUTTON) += cbe_powerbutton.o | ||
11 | 14 | ||
12 | ifeq ($(CONFIG_SMP),y) | 15 | ifeq ($(CONFIG_SMP),y) |
13 | obj-$(CONFIG_PPC_CELL_NATIVE) += smp.o | 16 | obj-$(CONFIG_PPC_CELL_NATIVE) += smp.o |
diff --git a/arch/powerpc/platforms/cell/cbe_powerbutton.c b/arch/powerpc/platforms/cell/cbe_powerbutton.c new file mode 100644 index 000000000000..dcddaa5fcb66 --- /dev/null +++ b/arch/powerpc/platforms/cell/cbe_powerbutton.c | |||
@@ -0,0 +1,117 @@ | |||
1 | /* | ||
2 | * driver for powerbutton on IBM cell blades | ||
3 | * | ||
4 | * (C) Copyright IBM Corp. 2005-2008 | ||
5 | * | ||
6 | * Author: Christian Krafft <krafft@de.ibm.com> | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License as published by | ||
10 | * the Free Software Foundation; either version 2, or (at your option) | ||
11 | * any later version. | ||
12 | * | ||
13 | * This program is distributed in the hope that it will be useful, | ||
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
16 | * GNU General Public License for more details. | ||
17 | * | ||
18 | * You should have received a copy of the GNU General Public License | ||
19 | * along with this program; if not, write to the Free Software | ||
20 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | ||
21 | */ | ||
22 | |||
23 | #include <linux/input.h> | ||
24 | #include <linux/platform_device.h> | ||
25 | #include <asm/pmi.h> | ||
26 | #include <asm/prom.h> | ||
27 | |||
28 | static struct input_dev *button_dev; | ||
29 | static struct platform_device *button_pdev; | ||
30 | |||
31 | static void cbe_powerbutton_handle_pmi(pmi_message_t pmi_msg) | ||
32 | { | ||
33 | BUG_ON(pmi_msg.type != PMI_TYPE_POWER_BUTTON); | ||
34 | |||
35 | input_report_key(button_dev, KEY_POWER, 1); | ||
36 | input_sync(button_dev); | ||
37 | input_report_key(button_dev, KEY_POWER, 0); | ||
38 | input_sync(button_dev); | ||
39 | } | ||
40 | |||
41 | static struct pmi_handler cbe_pmi_handler = { | ||
42 | .type = PMI_TYPE_POWER_BUTTON, | ||
43 | .handle_pmi_message = cbe_powerbutton_handle_pmi, | ||
44 | }; | ||
45 | |||
46 | static int __init cbe_powerbutton_init(void) | ||
47 | { | ||
48 | int ret = 0; | ||
49 | struct input_dev *dev; | ||
50 | |||
51 | if (!machine_is_compatible("IBM,CBPLUS-1.0")) { | ||
52 | printk(KERN_ERR "%s: Not a cell blade.\n", __func__); | ||
53 | ret = -ENODEV; | ||
54 | goto out; | ||
55 | } | ||
56 | |||
57 | dev = input_allocate_device(); | ||
58 | if (!dev) { | ||
59 | ret = -ENOMEM; | ||
60 | printk(KERN_ERR "%s: Not enough memory.\n", __func__); | ||
61 | goto out; | ||
62 | } | ||
63 | |||
64 | set_bit(EV_KEY, dev->evbit); | ||
65 | set_bit(KEY_POWER, dev->keybit); | ||
66 | |||
67 | dev->name = "Power Button"; | ||
68 | dev->id.bustype = BUS_HOST; | ||
69 | |||
70 | /* this makes the button look like an acpi power button | ||
71 | * no clue whether anyone relies on that though */ | ||
72 | dev->id.product = 0x02; | ||
73 | dev->phys = "LNXPWRBN/button/input0"; | ||
74 | |||
75 | button_pdev = platform_device_register_simple("power_button", 0, NULL, 0); | ||
76 | if (IS_ERR(button_pdev)) { | ||
77 | ret = PTR_ERR(button_pdev); | ||
78 | goto out_free_input; | ||
79 | } | ||
80 | |||
81 | dev->dev.parent = &button_pdev->dev; | ||
82 | ret = input_register_device(dev); | ||
83 | if (ret) { | ||
84 | printk(KERN_ERR "%s: Failed to register device\n", __func__); | ||
85 | goto out_free_pdev; | ||
86 | } | ||
87 | |||
88 | button_dev = dev; | ||
89 | |||
90 | ret = pmi_register_handler(&cbe_pmi_handler); | ||
91 | if (ret) { | ||
92 | printk(KERN_ERR "%s: Failed to register with pmi.\n", __func__); | ||
93 | goto out_free_pdev; | ||
94 | } | ||
95 | |||
96 | goto out; | ||
97 | |||
98 | out_free_pdev: | ||
99 | platform_device_unregister(button_pdev); | ||
100 | out_free_input: | ||
101 | input_free_device(dev); | ||
102 | out: | ||
103 | return ret; | ||
104 | } | ||
105 | |||
106 | static void __exit cbe_powerbutton_exit(void) | ||
107 | { | ||
108 | pmi_unregister_handler(&cbe_pmi_handler); | ||
109 | platform_device_unregister(button_pdev); | ||
110 | input_free_device(button_dev); | ||
111 | } | ||
112 | |||
113 | module_init(cbe_powerbutton_init); | ||
114 | module_exit(cbe_powerbutton_exit); | ||
115 | |||
116 | MODULE_LICENSE("GPL"); | ||
117 | MODULE_AUTHOR("Christian Krafft <krafft@de.ibm.com>"); | ||
diff --git a/arch/powerpc/platforms/cell/cpufreq_spudemand.c b/arch/powerpc/platforms/cell/cpufreq_spudemand.c new file mode 100644 index 000000000000..a3c6c01bd6db --- /dev/null +++ b/arch/powerpc/platforms/cell/cpufreq_spudemand.c | |||
@@ -0,0 +1,184 @@ | |||
1 | /* | ||
2 | * spu aware cpufreq governor for the cell processor | ||
3 | * | ||
4 | * © Copyright IBM Corporation 2006-2008 | ||
5 | * | ||
6 | * Author: Christian Krafft <krafft@de.ibm.com> | ||
7 | * | ||
8 | * This program is free software; you can redistribute it and/or modify | ||
9 | * it under the terms of the GNU General Public License as published by | ||
10 | * the Free Software Foundation; either version 2, or (at your option) | ||
11 | * any later version. | ||
12 | * | ||
13 | * This program is distributed in the hope that it will be useful, | ||
14 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
15 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
16 | * GNU General Public License for more details. | ||
17 | * | ||
18 | * You should have received a copy of the GNU General Public License | ||
19 | * along with this program; if not, write to the Free Software | ||
20 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | ||
21 | */ | ||
22 | |||
23 | #include <linux/cpufreq.h> | ||
24 | #include <linux/sched.h> | ||
25 | #include <linux/timer.h> | ||
26 | #include <linux/workqueue.h> | ||
27 | #include <asm/atomic.h> | ||
28 | #include <asm/machdep.h> | ||
29 | #include <asm/spu.h> | ||
30 | |||
31 | #define POLL_TIME 100000 /* in µs */ | ||
32 | #define EXP 753 /* exp(-1) in fixed-point */ | ||
33 | |||
34 | struct spu_gov_info_struct { | ||
35 | unsigned long busy_spus; /* fixed-point */ | ||
36 | struct cpufreq_policy *policy; | ||
37 | struct delayed_work work; | ||
38 | unsigned int poll_int; /* µs */ | ||
39 | }; | ||
40 | static DEFINE_PER_CPU(struct spu_gov_info_struct, spu_gov_info); | ||
41 | |||
42 | static struct workqueue_struct *kspugov_wq; | ||
43 | |||
44 | static int calc_freq(struct spu_gov_info_struct *info) | ||
45 | { | ||
46 | int cpu; | ||
47 | int busy_spus; | ||
48 | |||
49 | cpu = info->policy->cpu; | ||
50 | busy_spus = atomic_read(&cbe_spu_info[cpu_to_node(cpu)].busy_spus); | ||
51 | |||
52 | CALC_LOAD(info->busy_spus, EXP, busy_spus * FIXED_1); | ||
53 | pr_debug("cpu %d: busy_spus=%d, info->busy_spus=%ld\n", | ||
54 | cpu, busy_spus, info->busy_spus); | ||
55 | |||
56 | return info->policy->max * info->busy_spus / FIXED_1; | ||
57 | } | ||
58 | |||
59 | static void spu_gov_work(struct work_struct *work) | ||
60 | { | ||
61 | struct spu_gov_info_struct *info; | ||
62 | int delay; | ||
63 | unsigned long target_freq; | ||
64 | |||
65 | info = container_of(work, struct spu_gov_info_struct, work.work); | ||
66 | |||
67 | /* after cancel_delayed_work_sync we unset info->policy */ | ||
68 | BUG_ON(info->policy == NULL); | ||
69 | |||
70 | target_freq = calc_freq(info); | ||
71 | __cpufreq_driver_target(info->policy, target_freq, CPUFREQ_RELATION_H); | ||
72 | |||
73 | delay = usecs_to_jiffies(info->poll_int); | ||
74 | queue_delayed_work_on(info->policy->cpu, kspugov_wq, &info->work, delay); | ||
75 | } | ||
76 | |||
77 | static void spu_gov_init_work(struct spu_gov_info_struct *info) | ||
78 | { | ||
79 | int delay = usecs_to_jiffies(info->poll_int); | ||
80 | INIT_DELAYED_WORK_DEFERRABLE(&info->work, spu_gov_work); | ||
81 | queue_delayed_work_on(info->policy->cpu, kspugov_wq, &info->work, delay); | ||
82 | } | ||
83 | |||
84 | static void spu_gov_cancel_work(struct spu_gov_info_struct *info) | ||
85 | { | ||
86 | cancel_delayed_work_sync(&info->work); | ||
87 | } | ||
88 | |||
89 | static int spu_gov_govern(struct cpufreq_policy *policy, unsigned int event) | ||
90 | { | ||
91 | unsigned int cpu = policy->cpu; | ||
92 | struct spu_gov_info_struct *info, *affected_info; | ||
93 | int i; | ||
94 | int ret = 0; | ||
95 | |||
96 | info = &per_cpu(spu_gov_info, cpu); | ||
97 | |||
98 | switch (event) { | ||
99 | case CPUFREQ_GOV_START: | ||
100 | if (!cpu_online(cpu)) { | ||
101 | printk(KERN_ERR "cpu %d is not online\n", cpu); | ||
102 | ret = -EINVAL; | ||
103 | break; | ||
104 | } | ||
105 | |||
106 | if (!policy->cur) { | ||
107 | printk(KERN_ERR "no cpu specified in policy\n"); | ||
108 | ret = -EINVAL; | ||
109 | break; | ||
110 | } | ||
111 | |||
112 | /* initialize spu_gov_info for all affected cpus */ | ||
113 | for_each_cpu_mask(i, policy->cpus) { | ||
114 | affected_info = &per_cpu(spu_gov_info, i); | ||
115 | affected_info->policy = policy; | ||
116 | } | ||
117 | |||
118 | info->poll_int = POLL_TIME; | ||
119 | |||
120 | /* setup timer */ | ||
121 | spu_gov_init_work(info); | ||
122 | |||
123 | break; | ||
124 | |||
125 | case CPUFREQ_GOV_STOP: | ||
126 | /* cancel timer */ | ||
127 | spu_gov_cancel_work(info); | ||
128 | |||
129 | /* clean spu_gov_info for all affected cpus */ | ||
130 | for_each_cpu_mask (i, policy->cpus) { | ||
131 | info = &per_cpu(spu_gov_info, i); | ||
132 | info->policy = NULL; | ||
133 | } | ||
134 | |||
135 | break; | ||
136 | } | ||
137 | |||
138 | return ret; | ||
139 | } | ||
140 | |||
141 | static struct cpufreq_governor spu_governor = { | ||
142 | .name = "spudemand", | ||
143 | .governor = spu_gov_govern, | ||
144 | .owner = THIS_MODULE, | ||
145 | }; | ||
146 | |||
147 | /* | ||
148 | * module init and destoy | ||
149 | */ | ||
150 | |||
151 | static int __init spu_gov_init(void) | ||
152 | { | ||
153 | int ret; | ||
154 | |||
155 | kspugov_wq = create_workqueue("kspugov"); | ||
156 | if (!kspugov_wq) { | ||
157 | printk(KERN_ERR "creation of kspugov failed\n"); | ||
158 | ret = -EFAULT; | ||
159 | goto out; | ||
160 | } | ||
161 | |||
162 | ret = cpufreq_register_governor(&spu_governor); | ||
163 | if (ret) { | ||
164 | printk(KERN_ERR "registration of governor failed\n"); | ||
165 | destroy_workqueue(kspugov_wq); | ||
166 | goto out; | ||
167 | } | ||
168 | out: | ||
169 | return ret; | ||
170 | } | ||
171 | |||
172 | static void __exit spu_gov_exit(void) | ||
173 | { | ||
174 | cpufreq_unregister_governor(&spu_governor); | ||
175 | destroy_workqueue(kspugov_wq); | ||
176 | } | ||
177 | |||
178 | |||
179 | module_init(spu_gov_init); | ||
180 | module_exit(spu_gov_exit); | ||
181 | |||
182 | MODULE_LICENSE("GPL"); | ||
183 | MODULE_AUTHOR("Christian Krafft <krafft@de.ibm.com>"); | ||
184 | |||
diff --git a/arch/powerpc/platforms/cell/iommu.c b/arch/powerpc/platforms/cell/iommu.c index eeacb3a52ca1..208005ca262c 100644 --- a/arch/powerpc/platforms/cell/iommu.c +++ b/arch/powerpc/platforms/cell/iommu.c | |||
@@ -173,7 +173,8 @@ static void invalidate_tce_cache(struct cbe_iommu *iommu, unsigned long *pte, | |||
173 | } | 173 | } |
174 | 174 | ||
175 | static void tce_build_cell(struct iommu_table *tbl, long index, long npages, | 175 | static void tce_build_cell(struct iommu_table *tbl, long index, long npages, |
176 | unsigned long uaddr, enum dma_data_direction direction) | 176 | unsigned long uaddr, enum dma_data_direction direction, |
177 | struct dma_attrs *attrs) | ||
177 | { | 178 | { |
178 | int i; | 179 | int i; |
179 | unsigned long *io_pte, base_pte; | 180 | unsigned long *io_pte, base_pte; |
@@ -198,6 +199,8 @@ static void tce_build_cell(struct iommu_table *tbl, long index, long npages, | |||
198 | base_pte = IOPTE_PP_W | IOPTE_PP_R | IOPTE_M | IOPTE_SO_RW | | 199 | base_pte = IOPTE_PP_W | IOPTE_PP_R | IOPTE_M | IOPTE_SO_RW | |
199 | (window->ioid & IOPTE_IOID_Mask); | 200 | (window->ioid & IOPTE_IOID_Mask); |
200 | #endif | 201 | #endif |
202 | if (unlikely(dma_get_attr(DMA_ATTR_WEAK_ORDERING, attrs))) | ||
203 | base_pte &= ~IOPTE_SO_RW; | ||
201 | 204 | ||
202 | io_pte = (unsigned long *)tbl->it_base + (index - tbl->it_offset); | 205 | io_pte = (unsigned long *)tbl->it_base + (index - tbl->it_offset); |
203 | 206 | ||
@@ -519,7 +522,7 @@ cell_iommu_setup_window(struct cbe_iommu *iommu, struct device_node *np, | |||
519 | 522 | ||
520 | __set_bit(0, window->table.it_map); | 523 | __set_bit(0, window->table.it_map); |
521 | tce_build_cell(&window->table, window->table.it_offset, 1, | 524 | tce_build_cell(&window->table, window->table.it_offset, 1, |
522 | (unsigned long)iommu->pad_page, DMA_TO_DEVICE); | 525 | (unsigned long)iommu->pad_page, DMA_TO_DEVICE, NULL); |
523 | window->table.it_hint = window->table.it_blocksize; | 526 | window->table.it_hint = window->table.it_blocksize; |
524 | 527 | ||
525 | return window; | 528 | return window; |
@@ -538,7 +541,9 @@ static struct cbe_iommu *cell_iommu_for_node(int nid) | |||
538 | static unsigned long cell_dma_direct_offset; | 541 | static unsigned long cell_dma_direct_offset; |
539 | 542 | ||
540 | static unsigned long dma_iommu_fixed_base; | 543 | static unsigned long dma_iommu_fixed_base; |
541 | struct dma_mapping_ops dma_iommu_fixed_ops; | 544 | |
545 | /* iommu_fixed_is_weak is set if booted with iommu_fixed=weak */ | ||
546 | static int iommu_fixed_is_weak; | ||
542 | 547 | ||
543 | static struct iommu_table *cell_get_iommu_table(struct device *dev) | 548 | static struct iommu_table *cell_get_iommu_table(struct device *dev) |
544 | { | 549 | { |
@@ -562,6 +567,98 @@ static struct iommu_table *cell_get_iommu_table(struct device *dev) | |||
562 | return &window->table; | 567 | return &window->table; |
563 | } | 568 | } |
564 | 569 | ||
570 | /* A coherent allocation implies strong ordering */ | ||
571 | |||
572 | static void *dma_fixed_alloc_coherent(struct device *dev, size_t size, | ||
573 | dma_addr_t *dma_handle, gfp_t flag) | ||
574 | { | ||
575 | if (iommu_fixed_is_weak) | ||
576 | return iommu_alloc_coherent(dev, cell_get_iommu_table(dev), | ||
577 | size, dma_handle, | ||
578 | device_to_mask(dev), flag, | ||
579 | dev->archdata.numa_node); | ||
580 | else | ||
581 | return dma_direct_ops.alloc_coherent(dev, size, dma_handle, | ||
582 | flag); | ||
583 | } | ||
584 | |||
585 | static void dma_fixed_free_coherent(struct device *dev, size_t size, | ||
586 | void *vaddr, dma_addr_t dma_handle) | ||
587 | { | ||
588 | if (iommu_fixed_is_weak) | ||
589 | iommu_free_coherent(cell_get_iommu_table(dev), size, vaddr, | ||
590 | dma_handle); | ||
591 | else | ||
592 | dma_direct_ops.free_coherent(dev, size, vaddr, dma_handle); | ||
593 | } | ||
594 | |||
595 | static dma_addr_t dma_fixed_map_single(struct device *dev, void *ptr, | ||
596 | size_t size, | ||
597 | enum dma_data_direction direction, | ||
598 | struct dma_attrs *attrs) | ||
599 | { | ||
600 | if (iommu_fixed_is_weak == dma_get_attr(DMA_ATTR_WEAK_ORDERING, attrs)) | ||
601 | return dma_direct_ops.map_single(dev, ptr, size, direction, | ||
602 | attrs); | ||
603 | else | ||
604 | return iommu_map_single(dev, cell_get_iommu_table(dev), ptr, | ||
605 | size, device_to_mask(dev), direction, | ||
606 | attrs); | ||
607 | } | ||
608 | |||
609 | static void dma_fixed_unmap_single(struct device *dev, dma_addr_t dma_addr, | ||
610 | size_t size, | ||
611 | enum dma_data_direction direction, | ||
612 | struct dma_attrs *attrs) | ||
613 | { | ||
614 | if (iommu_fixed_is_weak == dma_get_attr(DMA_ATTR_WEAK_ORDERING, attrs)) | ||
615 | dma_direct_ops.unmap_single(dev, dma_addr, size, direction, | ||
616 | attrs); | ||
617 | else | ||
618 | iommu_unmap_single(cell_get_iommu_table(dev), dma_addr, size, | ||
619 | direction, attrs); | ||
620 | } | ||
621 | |||
622 | static int dma_fixed_map_sg(struct device *dev, struct scatterlist *sg, | ||
623 | int nents, enum dma_data_direction direction, | ||
624 | struct dma_attrs *attrs) | ||
625 | { | ||
626 | if (iommu_fixed_is_weak == dma_get_attr(DMA_ATTR_WEAK_ORDERING, attrs)) | ||
627 | return dma_direct_ops.map_sg(dev, sg, nents, direction, attrs); | ||
628 | else | ||
629 | return iommu_map_sg(dev, cell_get_iommu_table(dev), sg, nents, | ||
630 | device_to_mask(dev), direction, attrs); | ||
631 | } | ||
632 | |||
633 | static void dma_fixed_unmap_sg(struct device *dev, struct scatterlist *sg, | ||
634 | int nents, enum dma_data_direction direction, | ||
635 | struct dma_attrs *attrs) | ||
636 | { | ||
637 | if (iommu_fixed_is_weak == dma_get_attr(DMA_ATTR_WEAK_ORDERING, attrs)) | ||
638 | dma_direct_ops.unmap_sg(dev, sg, nents, direction, attrs); | ||
639 | else | ||
640 | iommu_unmap_sg(cell_get_iommu_table(dev), sg, nents, direction, | ||
641 | attrs); | ||
642 | } | ||
643 | |||
644 | static int dma_fixed_dma_supported(struct device *dev, u64 mask) | ||
645 | { | ||
646 | return mask == DMA_64BIT_MASK; | ||
647 | } | ||
648 | |||
649 | static int dma_set_mask_and_switch(struct device *dev, u64 dma_mask); | ||
650 | |||
651 | struct dma_mapping_ops dma_iommu_fixed_ops = { | ||
652 | .alloc_coherent = dma_fixed_alloc_coherent, | ||
653 | .free_coherent = dma_fixed_free_coherent, | ||
654 | .map_single = dma_fixed_map_single, | ||
655 | .unmap_single = dma_fixed_unmap_single, | ||
656 | .map_sg = dma_fixed_map_sg, | ||
657 | .unmap_sg = dma_fixed_unmap_sg, | ||
658 | .dma_supported = dma_fixed_dma_supported, | ||
659 | .set_dma_mask = dma_set_mask_and_switch, | ||
660 | }; | ||
661 | |||
565 | static void cell_dma_dev_setup_fixed(struct device *dev); | 662 | static void cell_dma_dev_setup_fixed(struct device *dev); |
566 | 663 | ||
567 | static void cell_dma_dev_setup(struct device *dev) | 664 | static void cell_dma_dev_setup(struct device *dev) |
@@ -918,9 +1015,16 @@ static void cell_iommu_setup_fixed_ptab(struct cbe_iommu *iommu, | |||
918 | 1015 | ||
919 | pr_debug("iommu: mapping 0x%lx pages from 0x%lx\n", fsize, fbase); | 1016 | pr_debug("iommu: mapping 0x%lx pages from 0x%lx\n", fsize, fbase); |
920 | 1017 | ||
921 | base_pte = IOPTE_PP_W | IOPTE_PP_R | IOPTE_M | IOPTE_SO_RW | 1018 | base_pte = IOPTE_PP_W | IOPTE_PP_R | IOPTE_M |
922 | | (cell_iommu_get_ioid(np) & IOPTE_IOID_Mask); | 1019 | | (cell_iommu_get_ioid(np) & IOPTE_IOID_Mask); |
923 | 1020 | ||
1021 | if (iommu_fixed_is_weak) | ||
1022 | pr_info("IOMMU: Using weak ordering for fixed mapping\n"); | ||
1023 | else { | ||
1024 | pr_info("IOMMU: Using strong ordering for fixed mapping\n"); | ||
1025 | base_pte |= IOPTE_SO_RW; | ||
1026 | } | ||
1027 | |||
924 | for (uaddr = 0; uaddr < fsize; uaddr += (1 << 24)) { | 1028 | for (uaddr = 0; uaddr < fsize; uaddr += (1 << 24)) { |
925 | /* Don't touch the dynamic region */ | 1029 | /* Don't touch the dynamic region */ |
926 | ioaddr = uaddr + fbase; | 1030 | ioaddr = uaddr + fbase; |
@@ -1036,9 +1140,6 @@ static int __init cell_iommu_fixed_mapping_init(void) | |||
1036 | cell_iommu_setup_window(iommu, np, dbase, dsize, 0); | 1140 | cell_iommu_setup_window(iommu, np, dbase, dsize, 0); |
1037 | } | 1141 | } |
1038 | 1142 | ||
1039 | dma_iommu_fixed_ops = dma_direct_ops; | ||
1040 | dma_iommu_fixed_ops.set_dma_mask = dma_set_mask_and_switch; | ||
1041 | |||
1042 | dma_iommu_ops.set_dma_mask = dma_set_mask_and_switch; | 1143 | dma_iommu_ops.set_dma_mask = dma_set_mask_and_switch; |
1043 | set_pci_dma_ops(&dma_iommu_ops); | 1144 | set_pci_dma_ops(&dma_iommu_ops); |
1044 | 1145 | ||
@@ -1052,6 +1153,9 @@ static int __init setup_iommu_fixed(char *str) | |||
1052 | if (strcmp(str, "off") == 0) | 1153 | if (strcmp(str, "off") == 0) |
1053 | iommu_fixed_disabled = 1; | 1154 | iommu_fixed_disabled = 1; |
1054 | 1155 | ||
1156 | else if (strcmp(str, "weak") == 0) | ||
1157 | iommu_fixed_is_weak = 1; | ||
1158 | |||
1055 | return 1; | 1159 | return 1; |
1056 | } | 1160 | } |
1057 | __setup("iommu_fixed=", setup_iommu_fixed); | 1161 | __setup("iommu_fixed=", setup_iommu_fixed); |
diff --git a/arch/powerpc/platforms/cell/pervasive.c b/arch/powerpc/platforms/cell/pervasive.c index 8a3631ce912b..efdacc829576 100644 --- a/arch/powerpc/platforms/cell/pervasive.c +++ b/arch/powerpc/platforms/cell/pervasive.c | |||
@@ -38,8 +38,6 @@ | |||
38 | 38 | ||
39 | #include "pervasive.h" | 39 | #include "pervasive.h" |
40 | 40 | ||
41 | static int sysreset_hack; | ||
42 | |||
43 | static void cbe_power_save(void) | 41 | static void cbe_power_save(void) |
44 | { | 42 | { |
45 | unsigned long ctrl, thread_switch_control; | 43 | unsigned long ctrl, thread_switch_control; |
@@ -87,9 +85,6 @@ static void cbe_power_save(void) | |||
87 | 85 | ||
88 | static int cbe_system_reset_exception(struct pt_regs *regs) | 86 | static int cbe_system_reset_exception(struct pt_regs *regs) |
89 | { | 87 | { |
90 | int cpu; | ||
91 | struct cbe_pmd_regs __iomem *pmd; | ||
92 | |||
93 | switch (regs->msr & SRR1_WAKEMASK) { | 88 | switch (regs->msr & SRR1_WAKEMASK) { |
94 | case SRR1_WAKEEE: | 89 | case SRR1_WAKEEE: |
95 | do_IRQ(regs); | 90 | do_IRQ(regs); |
@@ -98,19 +93,7 @@ static int cbe_system_reset_exception(struct pt_regs *regs) | |||
98 | timer_interrupt(regs); | 93 | timer_interrupt(regs); |
99 | break; | 94 | break; |
100 | case SRR1_WAKEMT: | 95 | case SRR1_WAKEMT: |
101 | /* | 96 | return cbe_sysreset_hack(); |
102 | * The BMC can inject user triggered system reset exceptions, | ||
103 | * but cannot set the system reset reason in srr1, | ||
104 | * so check an extra register here. | ||
105 | */ | ||
106 | if (sysreset_hack && (cpu = smp_processor_id()) == 0) { | ||
107 | pmd = cbe_get_cpu_pmd_regs(cpu); | ||
108 | if (in_be64(&pmd->ras_esc_0) & 0xffff) { | ||
109 | out_be64(&pmd->ras_esc_0, 0); | ||
110 | return 0; | ||
111 | } | ||
112 | } | ||
113 | break; | ||
114 | #ifdef CONFIG_CBE_RAS | 97 | #ifdef CONFIG_CBE_RAS |
115 | case SRR1_WAKESYSERR: | 98 | case SRR1_WAKESYSERR: |
116 | cbe_system_error_exception(regs); | 99 | cbe_system_error_exception(regs); |
@@ -134,8 +117,6 @@ void __init cbe_pervasive_init(void) | |||
134 | if (!cpu_has_feature(CPU_FTR_PAUSE_ZERO)) | 117 | if (!cpu_has_feature(CPU_FTR_PAUSE_ZERO)) |
135 | return; | 118 | return; |
136 | 119 | ||
137 | sysreset_hack = machine_is_compatible("IBM,CBPLUS-1.0"); | ||
138 | |||
139 | for_each_possible_cpu(cpu) { | 120 | for_each_possible_cpu(cpu) { |
140 | struct cbe_pmd_regs __iomem *regs = cbe_get_cpu_pmd_regs(cpu); | 121 | struct cbe_pmd_regs __iomem *regs = cbe_get_cpu_pmd_regs(cpu); |
141 | if (!regs) | 122 | if (!regs) |
@@ -144,12 +125,6 @@ void __init cbe_pervasive_init(void) | |||
144 | /* Enable Pause(0) control bit */ | 125 | /* Enable Pause(0) control bit */ |
145 | out_be64(®s->pmcr, in_be64(®s->pmcr) | | 126 | out_be64(®s->pmcr, in_be64(®s->pmcr) | |
146 | CBE_PMD_PAUSE_ZERO_CONTROL); | 127 | CBE_PMD_PAUSE_ZERO_CONTROL); |
147 | |||
148 | /* Enable JTAG system-reset hack */ | ||
149 | if (sysreset_hack) | ||
150 | out_be32(®s->fir_mode_reg, | ||
151 | in_be32(®s->fir_mode_reg) | | ||
152 | CBE_PMD_FIR_MODE_M8); | ||
153 | } | 128 | } |
154 | 129 | ||
155 | ppc_md.power_save = cbe_power_save; | 130 | ppc_md.power_save = cbe_power_save; |
diff --git a/arch/powerpc/platforms/cell/pervasive.h b/arch/powerpc/platforms/cell/pervasive.h index 7b50947f8044..fd4d7b7092b4 100644 --- a/arch/powerpc/platforms/cell/pervasive.h +++ b/arch/powerpc/platforms/cell/pervasive.h | |||
@@ -30,4 +30,13 @@ extern void cbe_system_error_exception(struct pt_regs *regs); | |||
30 | extern void cbe_maintenance_exception(struct pt_regs *regs); | 30 | extern void cbe_maintenance_exception(struct pt_regs *regs); |
31 | extern void cbe_thermal_exception(struct pt_regs *regs); | 31 | extern void cbe_thermal_exception(struct pt_regs *regs); |
32 | 32 | ||
33 | #ifdef CONFIG_PPC_IBM_CELL_RESETBUTTON | ||
34 | extern int cbe_sysreset_hack(void); | ||
35 | #else | ||
36 | static inline int cbe_sysreset_hack(void) | ||
37 | { | ||
38 | return 1; | ||
39 | } | ||
40 | #endif /* CONFIG_PPC_IBM_CELL_RESETBUTTON */ | ||
41 | |||
33 | #endif | 42 | #endif |
diff --git a/arch/powerpc/platforms/cell/ras.c b/arch/powerpc/platforms/cell/ras.c index 505f9b9bdf0c..2a14b052abcd 100644 --- a/arch/powerpc/platforms/cell/ras.c +++ b/arch/powerpc/platforms/cell/ras.c | |||
@@ -236,6 +236,52 @@ static struct notifier_block cbe_ptcal_reboot_notifier = { | |||
236 | .notifier_call = cbe_ptcal_notify_reboot | 236 | .notifier_call = cbe_ptcal_notify_reboot |
237 | }; | 237 | }; |
238 | 238 | ||
239 | #ifdef CONFIG_PPC_IBM_CELL_RESETBUTTON | ||
240 | static int sysreset_hack; | ||
241 | |||
242 | static int __init cbe_sysreset_init(void) | ||
243 | { | ||
244 | struct cbe_pmd_regs __iomem *regs; | ||
245 | |||
246 | sysreset_hack = machine_is_compatible("IBM,CBPLUS-1.0"); | ||
247 | if (!sysreset_hack) | ||
248 | return 0; | ||
249 | |||
250 | regs = cbe_get_cpu_pmd_regs(0); | ||
251 | if (!regs) | ||
252 | return 0; | ||
253 | |||
254 | /* Enable JTAG system-reset hack */ | ||
255 | out_be32(®s->fir_mode_reg, | ||
256 | in_be32(®s->fir_mode_reg) | | ||
257 | CBE_PMD_FIR_MODE_M8); | ||
258 | |||
259 | return 0; | ||
260 | } | ||
261 | device_initcall(cbe_sysreset_init); | ||
262 | |||
263 | int cbe_sysreset_hack(void) | ||
264 | { | ||
265 | struct cbe_pmd_regs __iomem *regs; | ||
266 | |||
267 | /* | ||
268 | * The BMC can inject user triggered system reset exceptions, | ||
269 | * but cannot set the system reset reason in srr1, | ||
270 | * so check an extra register here. | ||
271 | */ | ||
272 | if (sysreset_hack && (smp_processor_id() == 0)) { | ||
273 | regs = cbe_get_cpu_pmd_regs(0); | ||
274 | if (!regs) | ||
275 | return 0; | ||
276 | if (in_be64(®s->ras_esc_0) & 0x0000ffff) { | ||
277 | out_be64(®s->ras_esc_0, 0); | ||
278 | return 0; | ||
279 | } | ||
280 | } | ||
281 | return 1; | ||
282 | } | ||
283 | #endif /* CONFIG_PPC_IBM_CELL_RESETBUTTON */ | ||
284 | |||
239 | int __init cbe_ptcal_init(void) | 285 | int __init cbe_ptcal_init(void) |
240 | { | 286 | { |
241 | int ret; | 287 | int ret; |
diff --git a/arch/powerpc/platforms/fsl_uli1575.c b/arch/powerpc/platforms/fsl_uli1575.c index afc9141be63e..ef74a0763ec1 100644 --- a/arch/powerpc/platforms/fsl_uli1575.c +++ b/arch/powerpc/platforms/fsl_uli1575.c | |||
@@ -51,15 +51,13 @@ u8 uli_pirq_to_irq[8] = { | |||
51 | ULI_8259_NONE, /* PIRQH */ | 51 | ULI_8259_NONE, /* PIRQH */ |
52 | }; | 52 | }; |
53 | 53 | ||
54 | /* set in board code if you want this quirks to do something */ | ||
55 | int uses_fsl_uli_m1575; | ||
56 | |||
57 | /* Bridge */ | 54 | /* Bridge */ |
58 | static void __devinit early_uli5249(struct pci_dev *dev) | 55 | static void __devinit early_uli5249(struct pci_dev *dev) |
59 | { | 56 | { |
60 | unsigned char temp; | 57 | unsigned char temp; |
61 | 58 | ||
62 | if (!uses_fsl_uli_m1575) | 59 | if (!machine_is(mpc86xx_hpcn) && !machine_is(mpc8544_ds) && |
60 | !machine_is(mpc8572_ds)) | ||
63 | return; | 61 | return; |
64 | 62 | ||
65 | pci_write_config_word(dev, PCI_COMMAND, PCI_COMMAND_IO | | 63 | pci_write_config_word(dev, PCI_COMMAND, PCI_COMMAND_IO | |
@@ -82,7 +80,8 @@ static void __devinit quirk_uli1575(struct pci_dev *dev) | |||
82 | { | 80 | { |
83 | int i; | 81 | int i; |
84 | 82 | ||
85 | if (!uses_fsl_uli_m1575) | 83 | if (!machine_is(mpc86xx_hpcn) && !machine_is(mpc8544_ds) && |
84 | !machine_is(mpc8572_ds)) | ||
86 | return; | 85 | return; |
87 | 86 | ||
88 | /* | 87 | /* |
@@ -150,7 +149,8 @@ static void __devinit quirk_final_uli1575(struct pci_dev *dev) | |||
150 | * IRQ 14: Edge | 149 | * IRQ 14: Edge |
151 | * IRQ 15: Edge | 150 | * IRQ 15: Edge |
152 | */ | 151 | */ |
153 | if (!uses_fsl_uli_m1575) | 152 | if (!machine_is(mpc86xx_hpcn) && !machine_is(mpc8544_ds) && |
153 | !machine_is(mpc8572_ds)) | ||
154 | return; | 154 | return; |
155 | 155 | ||
156 | outb(0xfa, 0x4d0); | 156 | outb(0xfa, 0x4d0); |
@@ -176,7 +176,8 @@ static void __devinit quirk_uli5288(struct pci_dev *dev) | |||
176 | unsigned char c; | 176 | unsigned char c; |
177 | unsigned int d; | 177 | unsigned int d; |
178 | 178 | ||
179 | if (!uses_fsl_uli_m1575) | 179 | if (!machine_is(mpc86xx_hpcn) && !machine_is(mpc8544_ds) && |
180 | !machine_is(mpc8572_ds)) | ||
180 | return; | 181 | return; |
181 | 182 | ||
182 | /* read/write lock */ | 183 | /* read/write lock */ |
@@ -200,7 +201,8 @@ static void __devinit quirk_uli5229(struct pci_dev *dev) | |||
200 | { | 201 | { |
201 | unsigned short temp; | 202 | unsigned short temp; |
202 | 203 | ||
203 | if (!uses_fsl_uli_m1575) | 204 | if (!machine_is(mpc86xx_hpcn) && !machine_is(mpc8544_ds) && |
205 | !machine_is(mpc8572_ds)) | ||
204 | return; | 206 | return; |
205 | 207 | ||
206 | pci_write_config_word(dev, PCI_COMMAND, PCI_COMMAND_INTX_DISABLE | | 208 | pci_write_config_word(dev, PCI_COMMAND, PCI_COMMAND_INTX_DISABLE | |
@@ -221,7 +223,7 @@ static void __devinit quirk_final_uli5249(struct pci_dev *dev) | |||
221 | for (i = 0; i < PCI_BUS_NUM_RESOURCES; i++) { | 223 | for (i = 0; i < PCI_BUS_NUM_RESOURCES; i++) { |
222 | if ((bus->resource[i]) && | 224 | if ((bus->resource[i]) && |
223 | (bus->resource[i]->flags & IORESOURCE_MEM)) { | 225 | (bus->resource[i]->flags & IORESOURCE_MEM)) { |
224 | dummy = ioremap(bus->resource[i]->start, 0x4); | 226 | dummy = ioremap(bus->resource[i]->end - 3, 0x4); |
225 | if (dummy) { | 227 | if (dummy) { |
226 | in_8(dummy); | 228 | in_8(dummy); |
227 | iounmap(dummy); | 229 | iounmap(dummy); |
@@ -238,6 +240,103 @@ DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_AL, 0x5229, quirk_uli5229); | |||
238 | DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_AL, 0x5249, quirk_final_uli5249); | 240 | DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_AL, 0x5249, quirk_final_uli5249); |
239 | DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_AL, 0x1575, quirk_final_uli1575); | 241 | DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_AL, 0x1575, quirk_final_uli1575); |
240 | 242 | ||
243 | static void __devinit hpcd_quirk_uli1575(struct pci_dev *dev) | ||
244 | { | ||
245 | u32 temp32; | ||
246 | |||
247 | if (!machine_is(mpc86xx_hpcd)) | ||
248 | return; | ||
249 | |||
250 | /* Disable INTx */ | ||
251 | pci_read_config_dword(dev, 0x48, &temp32); | ||
252 | pci_write_config_dword(dev, 0x48, (temp32 | 1<<26)); | ||
253 | |||
254 | /* Enable sideband interrupt */ | ||
255 | pci_read_config_dword(dev, 0x90, &temp32); | ||
256 | pci_write_config_dword(dev, 0x90, (temp32 | 1<<22)); | ||
257 | } | ||
258 | |||
259 | static void __devinit hpcd_quirk_uli5288(struct pci_dev *dev) | ||
260 | { | ||
261 | unsigned char c; | ||
262 | unsigned short temp; | ||
263 | |||
264 | if (!machine_is(mpc86xx_hpcd)) | ||
265 | return; | ||
266 | |||
267 | /* Interrupt Disable, Needed when SATA disabled */ | ||
268 | pci_read_config_word(dev, PCI_COMMAND, &temp); | ||
269 | temp |= 1<<10; | ||
270 | pci_write_config_word(dev, PCI_COMMAND, temp); | ||
271 | |||
272 | pci_read_config_byte(dev, 0x83, &c); | ||
273 | c |= 0x80; | ||
274 | pci_write_config_byte(dev, 0x83, c); | ||
275 | |||
276 | pci_write_config_byte(dev, PCI_CLASS_PROG, 0x01); | ||
277 | pci_write_config_byte(dev, PCI_CLASS_DEVICE, 0x06); | ||
278 | |||
279 | pci_read_config_byte(dev, 0x83, &c); | ||
280 | c &= 0x7f; | ||
281 | pci_write_config_byte(dev, 0x83, c); | ||
282 | } | ||
283 | |||
284 | /* | ||
285 | * Since 8259PIC was disabled on the board, the IDE device can not | ||
286 | * use the legacy IRQ, we need to let the IDE device work under | ||
287 | * native mode and use the interrupt line like other PCI devices. | ||
288 | * IRQ14 is a sideband interrupt from IDE device to CPU and we use this | ||
289 | * as the interrupt for IDE device. | ||
290 | */ | ||
291 | static void __devinit hpcd_quirk_uli5229(struct pci_dev *dev) | ||
292 | { | ||
293 | unsigned char c; | ||
294 | |||
295 | if (!machine_is(mpc86xx_hpcd)) | ||
296 | return; | ||
297 | |||
298 | pci_read_config_byte(dev, 0x4b, &c); | ||
299 | c |= 0x10; | ||
300 | pci_write_config_byte(dev, 0x4b, c); | ||
301 | } | ||
302 | |||
303 | /* | ||
304 | * SATA interrupt pin bug fix | ||
305 | * There's a chip bug for 5288, The interrupt pin should be 2, | ||
306 | * not the read only value 1, So it use INTB#, not INTA# which | ||
307 | * actually used by the IDE device 5229. | ||
308 | * As of this bug, during the PCI initialization, 5288 read the | ||
309 | * irq of IDE device from the device tree, this function fix this | ||
310 | * bug by re-assigning a correct irq to 5288. | ||
311 | * | ||
312 | */ | ||
313 | static void __devinit hpcd_final_uli5288(struct pci_dev *dev) | ||
314 | { | ||
315 | struct pci_controller *hose = pci_bus_to_host(dev->bus); | ||
316 | struct device_node *hosenode = hose ? hose->dn : NULL; | ||
317 | struct of_irq oirq; | ||
318 | int virq, pin = 2; | ||
319 | u32 laddr[3]; | ||
320 | |||
321 | if (!machine_is(mpc86xx_hpcd)) | ||
322 | return; | ||
323 | |||
324 | if (!hosenode) | ||
325 | return; | ||
326 | |||
327 | laddr[0] = (hose->first_busno << 16) | (PCI_DEVFN(31, 0) << 8); | ||
328 | laddr[1] = laddr[2] = 0; | ||
329 | of_irq_map_raw(hosenode, &pin, 1, laddr, &oirq); | ||
330 | virq = irq_create_of_mapping(oirq.controller, oirq.specifier, | ||
331 | oirq.size); | ||
332 | dev->irq = virq; | ||
333 | } | ||
334 | |||
335 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_AL, 0x1575, hpcd_quirk_uli1575); | ||
336 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_AL, 0x5288, hpcd_quirk_uli5288); | ||
337 | DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_AL, 0x5229, hpcd_quirk_uli5229); | ||
338 | DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_AL, 0x5288, hpcd_final_uli5288); | ||
339 | |||
241 | int uli_exclude_device(struct pci_controller *hose, | 340 | int uli_exclude_device(struct pci_controller *hose, |
242 | u_char bus, u_char devfn) | 341 | u_char bus, u_char devfn) |
243 | { | 342 | { |
diff --git a/arch/powerpc/platforms/iseries/Kconfig b/arch/powerpc/platforms/iseries/Kconfig index 761d9e971fc4..ea3e541ac74f 100644 --- a/arch/powerpc/platforms/iseries/Kconfig +++ b/arch/powerpc/platforms/iseries/Kconfig | |||
@@ -2,6 +2,7 @@ config PPC_ISERIES | |||
2 | bool "IBM Legacy iSeries" | 2 | bool "IBM Legacy iSeries" |
3 | depends on PPC_MULTIPLATFORM && PPC64 | 3 | depends on PPC_MULTIPLATFORM && PPC64 |
4 | select PPC_INDIRECT_IO | 4 | select PPC_INDIRECT_IO |
5 | select PPC_PCI_CHOICE if EMBEDDED | ||
5 | 6 | ||
6 | menu "iSeries device drivers" | 7 | menu "iSeries device drivers" |
7 | depends on PPC_ISERIES | 8 | depends on PPC_ISERIES |
diff --git a/arch/powerpc/platforms/iseries/iommu.c b/arch/powerpc/platforms/iseries/iommu.c index ab5d8687c3cf..bc818e4e2033 100644 --- a/arch/powerpc/platforms/iseries/iommu.c +++ b/arch/powerpc/platforms/iseries/iommu.c | |||
@@ -42,7 +42,8 @@ | |||
42 | #include <asm/iseries/iommu.h> | 42 | #include <asm/iseries/iommu.h> |
43 | 43 | ||
44 | static void tce_build_iSeries(struct iommu_table *tbl, long index, long npages, | 44 | static void tce_build_iSeries(struct iommu_table *tbl, long index, long npages, |
45 | unsigned long uaddr, enum dma_data_direction direction) | 45 | unsigned long uaddr, enum dma_data_direction direction, |
46 | struct dma_attrs *attrs) | ||
46 | { | 47 | { |
47 | u64 rc; | 48 | u64 rc; |
48 | u64 tce, rpn; | 49 | u64 tce, rpn; |
diff --git a/arch/powerpc/platforms/pasemi/iommu.c b/arch/powerpc/platforms/pasemi/iommu.c index 86967bdd8774..70541b7a5013 100644 --- a/arch/powerpc/platforms/pasemi/iommu.c +++ b/arch/powerpc/platforms/pasemi/iommu.c | |||
@@ -85,7 +85,8 @@ static int iommu_table_iobmap_inited; | |||
85 | 85 | ||
86 | static void iobmap_build(struct iommu_table *tbl, long index, | 86 | static void iobmap_build(struct iommu_table *tbl, long index, |
87 | long npages, unsigned long uaddr, | 87 | long npages, unsigned long uaddr, |
88 | enum dma_data_direction direction) | 88 | enum dma_data_direction direction, |
89 | struct dma_attrs *attrs) | ||
89 | { | 90 | { |
90 | u32 *ip; | 91 | u32 *ip; |
91 | u32 rpn; | 92 | u32 rpn; |
diff --git a/arch/powerpc/platforms/ps3/Kconfig b/arch/powerpc/platforms/ps3/Kconfig index a5f4e95dfc3d..920cf7a454b1 100644 --- a/arch/powerpc/platforms/ps3/Kconfig +++ b/arch/powerpc/platforms/ps3/Kconfig | |||
@@ -8,6 +8,7 @@ config PPC_PS3 | |||
8 | select USB_ARCH_HAS_EHCI | 8 | select USB_ARCH_HAS_EHCI |
9 | select USB_EHCI_BIG_ENDIAN_MMIO | 9 | select USB_EHCI_BIG_ENDIAN_MMIO |
10 | select MEMORY_HOTPLUG | 10 | select MEMORY_HOTPLUG |
11 | select PPC_PCI_CHOICE | ||
11 | help | 12 | help |
12 | This option enables support for the Sony PS3 game console | 13 | This option enables support for the Sony PS3 game console |
13 | and other platforms using the PS3 hypervisor. Enabling this | 14 | and other platforms using the PS3 hypervisor. Enabling this |
diff --git a/arch/powerpc/platforms/ps3/device-init.c b/arch/powerpc/platforms/ps3/device-init.c index 3866debfa3c4..ffdd8e963fbd 100644 --- a/arch/powerpc/platforms/ps3/device-init.c +++ b/arch/powerpc/platforms/ps3/device-init.c | |||
@@ -486,6 +486,7 @@ static int __init ps3_register_graphics_devices(void) | |||
486 | return -ENOMEM; | 486 | return -ENOMEM; |
487 | 487 | ||
488 | p->dev.match_id = PS3_MATCH_ID_GRAPHICS; | 488 | p->dev.match_id = PS3_MATCH_ID_GRAPHICS; |
489 | p->dev.match_sub_id = PS3_MATCH_SUB_ID_FB; | ||
489 | p->dev.dev_type = PS3_DEVICE_TYPE_IOC0; | 490 | p->dev.dev_type = PS3_DEVICE_TYPE_IOC0; |
490 | 491 | ||
491 | result = ps3_system_bus_device_register(&p->dev); | 492 | result = ps3_system_bus_device_register(&p->dev); |
diff --git a/arch/powerpc/platforms/ps3/system-bus.c b/arch/powerpc/platforms/ps3/system-bus.c index d66c3628a112..280ee88cb0b0 100644 --- a/arch/powerpc/platforms/ps3/system-bus.c +++ b/arch/powerpc/platforms/ps3/system-bus.c | |||
@@ -347,16 +347,23 @@ static int ps3_system_bus_match(struct device *_dev, | |||
347 | struct ps3_system_bus_driver *drv = ps3_drv_to_system_bus_drv(_drv); | 347 | struct ps3_system_bus_driver *drv = ps3_drv_to_system_bus_drv(_drv); |
348 | struct ps3_system_bus_device *dev = ps3_dev_to_system_bus_dev(_dev); | 348 | struct ps3_system_bus_device *dev = ps3_dev_to_system_bus_dev(_dev); |
349 | 349 | ||
350 | result = dev->match_id == drv->match_id; | 350 | if (!dev->match_sub_id) |
351 | result = dev->match_id == drv->match_id; | ||
352 | else | ||
353 | result = dev->match_sub_id == drv->match_sub_id && | ||
354 | dev->match_id == drv->match_id; | ||
351 | 355 | ||
352 | if (result) | 356 | if (result) |
353 | pr_info("%s:%d: dev=%u(%s), drv=%u(%s): match\n", __func__, | 357 | pr_info("%s:%d: dev=%u.%u(%s), drv=%u.%u(%s): match\n", |
354 | __LINE__, dev->match_id, dev->core.bus_id, | 358 | __func__, __LINE__, |
355 | drv->match_id, drv->core.name); | 359 | dev->match_id, dev->match_sub_id, dev->core.bus_id, |
360 | drv->match_id, drv->match_sub_id, drv->core.name); | ||
356 | else | 361 | else |
357 | pr_debug("%s:%d: dev=%u(%s), drv=%u(%s): miss\n", __func__, | 362 | pr_debug("%s:%d: dev=%u.%u(%s), drv=%u.%u(%s): miss\n", |
358 | __LINE__, dev->match_id, dev->core.bus_id, | 363 | __func__, __LINE__, |
359 | drv->match_id, drv->core.name); | 364 | dev->match_id, dev->match_sub_id, dev->core.bus_id, |
365 | drv->match_id, drv->match_sub_id, drv->core.name); | ||
366 | |||
360 | return result; | 367 | return result; |
361 | } | 368 | } |
362 | 369 | ||
diff --git a/arch/powerpc/platforms/pseries/Kconfig b/arch/powerpc/platforms/pseries/Kconfig index 07fe5b69b9e2..757c0296e0b8 100644 --- a/arch/powerpc/platforms/pseries/Kconfig +++ b/arch/powerpc/platforms/pseries/Kconfig | |||
@@ -7,6 +7,7 @@ config PPC_PSERIES | |||
7 | select RTAS_ERROR_LOGGING | 7 | select RTAS_ERROR_LOGGING |
8 | select PPC_UDBG_16550 | 8 | select PPC_UDBG_16550 |
9 | select PPC_NATIVE | 9 | select PPC_NATIVE |
10 | select PPC_PCI_CHOICE if EMBEDDED | ||
10 | default y | 11 | default y |
11 | 12 | ||
12 | config PPC_SPLPAR | 13 | config PPC_SPLPAR |
diff --git a/arch/powerpc/platforms/pseries/eeh.c b/arch/powerpc/platforms/pseries/eeh.c index c027f0a70a04..54816d75b578 100644 --- a/arch/powerpc/platforms/pseries/eeh.c +++ b/arch/powerpc/platforms/pseries/eeh.c | |||
@@ -75,9 +75,9 @@ | |||
75 | */ | 75 | */ |
76 | 76 | ||
77 | /* If a device driver keeps reading an MMIO register in an interrupt | 77 | /* If a device driver keeps reading an MMIO register in an interrupt |
78 | * handler after a slot isolation event has occurred, we assume it | 78 | * handler after a slot isolation event, it might be broken. |
79 | * is broken and panic. This sets the threshold for how many read | 79 | * This sets the threshold for how many read attempts we allow |
80 | * attempts we allow before panicking. | 80 | * before printing an error message. |
81 | */ | 81 | */ |
82 | #define EEH_MAX_FAILS 2100000 | 82 | #define EEH_MAX_FAILS 2100000 |
83 | 83 | ||
@@ -470,6 +470,7 @@ int eeh_dn_check_failure(struct device_node *dn, struct pci_dev *dev) | |||
470 | unsigned long flags; | 470 | unsigned long flags; |
471 | struct pci_dn *pdn; | 471 | struct pci_dn *pdn; |
472 | int rc = 0; | 472 | int rc = 0; |
473 | const char *location; | ||
473 | 474 | ||
474 | total_mmio_ffs++; | 475 | total_mmio_ffs++; |
475 | 476 | ||
@@ -509,18 +510,15 @@ int eeh_dn_check_failure(struct device_node *dn, struct pci_dev *dev) | |||
509 | rc = 1; | 510 | rc = 1; |
510 | if (pdn->eeh_mode & EEH_MODE_ISOLATED) { | 511 | if (pdn->eeh_mode & EEH_MODE_ISOLATED) { |
511 | pdn->eeh_check_count ++; | 512 | pdn->eeh_check_count ++; |
512 | if (pdn->eeh_check_count >= EEH_MAX_FAILS) { | 513 | if (pdn->eeh_check_count % EEH_MAX_FAILS == 0) { |
513 | printk (KERN_ERR "EEH: Device driver ignored %d bad reads, panicing\n", | 514 | location = of_get_property(dn, "ibm,loc-code", NULL); |
514 | pdn->eeh_check_count); | 515 | printk (KERN_ERR "EEH: %d reads ignored for recovering device at " |
516 | "location=%s driver=%s pci addr=%s\n", | ||
517 | pdn->eeh_check_count, location, | ||
518 | dev->driver->name, pci_name(dev)); | ||
519 | printk (KERN_ERR "EEH: Might be infinite loop in %s driver\n", | ||
520 | dev->driver->name); | ||
515 | dump_stack(); | 521 | dump_stack(); |
516 | msleep(5000); | ||
517 | |||
518 | /* re-read the slot reset state */ | ||
519 | if (read_slot_reset_state(pdn, rets) != 0) | ||
520 | rets[0] = -1; /* reset state unknown */ | ||
521 | |||
522 | /* If we are here, then we hit an infinite loop. Stop. */ | ||
523 | panic("EEH: MMIO halt (%d) on device:%s\n", rets[0], pci_name(dev)); | ||
524 | } | 522 | } |
525 | goto dn_unlock; | 523 | goto dn_unlock; |
526 | } | 524 | } |
diff --git a/arch/powerpc/platforms/pseries/iommu.c b/arch/powerpc/platforms/pseries/iommu.c index 9a12908510fb..5377dd4b849a 100644 --- a/arch/powerpc/platforms/pseries/iommu.c +++ b/arch/powerpc/platforms/pseries/iommu.c | |||
@@ -50,7 +50,8 @@ | |||
50 | 50 | ||
51 | static void tce_build_pSeries(struct iommu_table *tbl, long index, | 51 | static void tce_build_pSeries(struct iommu_table *tbl, long index, |
52 | long npages, unsigned long uaddr, | 52 | long npages, unsigned long uaddr, |
53 | enum dma_data_direction direction) | 53 | enum dma_data_direction direction, |
54 | struct dma_attrs *attrs) | ||
54 | { | 55 | { |
55 | u64 proto_tce; | 56 | u64 proto_tce; |
56 | u64 *tcep; | 57 | u64 *tcep; |
@@ -95,7 +96,8 @@ static unsigned long tce_get_pseries(struct iommu_table *tbl, long index) | |||
95 | 96 | ||
96 | static void tce_build_pSeriesLP(struct iommu_table *tbl, long tcenum, | 97 | static void tce_build_pSeriesLP(struct iommu_table *tbl, long tcenum, |
97 | long npages, unsigned long uaddr, | 98 | long npages, unsigned long uaddr, |
98 | enum dma_data_direction direction) | 99 | enum dma_data_direction direction, |
100 | struct dma_attrs *attrs) | ||
99 | { | 101 | { |
100 | u64 rc; | 102 | u64 rc; |
101 | u64 proto_tce, tce; | 103 | u64 proto_tce, tce; |
@@ -127,7 +129,8 @@ static DEFINE_PER_CPU(u64 *, tce_page) = NULL; | |||
127 | 129 | ||
128 | static void tce_buildmulti_pSeriesLP(struct iommu_table *tbl, long tcenum, | 130 | static void tce_buildmulti_pSeriesLP(struct iommu_table *tbl, long tcenum, |
129 | long npages, unsigned long uaddr, | 131 | long npages, unsigned long uaddr, |
130 | enum dma_data_direction direction) | 132 | enum dma_data_direction direction, |
133 | struct dma_attrs *attrs) | ||
131 | { | 134 | { |
132 | u64 rc; | 135 | u64 rc; |
133 | u64 proto_tce; | 136 | u64 proto_tce; |
@@ -136,7 +139,8 @@ static void tce_buildmulti_pSeriesLP(struct iommu_table *tbl, long tcenum, | |||
136 | long l, limit; | 139 | long l, limit; |
137 | 140 | ||
138 | if (npages == 1) { | 141 | if (npages == 1) { |
139 | tce_build_pSeriesLP(tbl, tcenum, npages, uaddr, direction); | 142 | tce_build_pSeriesLP(tbl, tcenum, npages, uaddr, |
143 | direction, attrs); | ||
140 | return; | 144 | return; |
141 | } | 145 | } |
142 | 146 | ||
@@ -150,7 +154,7 @@ static void tce_buildmulti_pSeriesLP(struct iommu_table *tbl, long tcenum, | |||
150 | /* If allocation fails, fall back to the loop implementation */ | 154 | /* If allocation fails, fall back to the loop implementation */ |
151 | if (!tcep) { | 155 | if (!tcep) { |
152 | tce_build_pSeriesLP(tbl, tcenum, npages, uaddr, | 156 | tce_build_pSeriesLP(tbl, tcenum, npages, uaddr, |
153 | direction); | 157 | direction, attrs); |
154 | return; | 158 | return; |
155 | } | 159 | } |
156 | __get_cpu_var(tce_page) = tcep; | 160 | __get_cpu_var(tce_page) = tcep; |
diff --git a/arch/powerpc/sysdev/axonram.c b/arch/powerpc/sysdev/axonram.c index 7f59188cd9a1..9e105cbc5e5f 100644 --- a/arch/powerpc/sysdev/axonram.c +++ b/arch/powerpc/sysdev/axonram.c | |||
@@ -57,6 +57,8 @@ | |||
57 | #define AXON_RAM_SECTOR_SIZE 1 << AXON_RAM_SECTOR_SHIFT | 57 | #define AXON_RAM_SECTOR_SIZE 1 << AXON_RAM_SECTOR_SHIFT |
58 | #define AXON_RAM_IRQ_FLAGS IRQF_SHARED | IRQF_TRIGGER_RISING | 58 | #define AXON_RAM_IRQ_FLAGS IRQF_SHARED | IRQF_TRIGGER_RISING |
59 | 59 | ||
60 | static int azfs_major, azfs_minor; | ||
61 | |||
60 | struct axon_ram_bank { | 62 | struct axon_ram_bank { |
61 | struct of_device *device; | 63 | struct of_device *device; |
62 | struct gendisk *disk; | 64 | struct gendisk *disk; |
@@ -148,7 +150,10 @@ axon_ram_direct_access(struct block_device *device, sector_t sector, | |||
148 | struct axon_ram_bank *bank = device->bd_disk->private_data; | 150 | struct axon_ram_bank *bank = device->bd_disk->private_data; |
149 | loff_t offset; | 151 | loff_t offset; |
150 | 152 | ||
151 | offset = sector << AXON_RAM_SECTOR_SHIFT; | 153 | offset = sector; |
154 | if (device->bd_part != NULL) | ||
155 | offset += device->bd_part->start_sect; | ||
156 | offset <<= AXON_RAM_SECTOR_SHIFT; | ||
152 | if (offset >= bank->size) { | 157 | if (offset >= bank->size) { |
153 | dev_err(&bank->device->dev, "Access outside of address space\n"); | 158 | dev_err(&bank->device->dev, "Access outside of address space\n"); |
154 | return -ERANGE; | 159 | return -ERANGE; |
@@ -227,19 +232,14 @@ axon_ram_probe(struct of_device *device, const struct of_device_id *device_id) | |||
227 | goto failed; | 232 | goto failed; |
228 | } | 233 | } |
229 | 234 | ||
230 | bank->disk->first_minor = 0; | 235 | bank->disk->major = azfs_major; |
236 | bank->disk->first_minor = azfs_minor; | ||
231 | bank->disk->fops = &axon_ram_devops; | 237 | bank->disk->fops = &axon_ram_devops; |
232 | bank->disk->private_data = bank; | 238 | bank->disk->private_data = bank; |
233 | bank->disk->driverfs_dev = &device->dev; | 239 | bank->disk->driverfs_dev = &device->dev; |
234 | 240 | ||
235 | sprintf(bank->disk->disk_name, "%s%d", | 241 | sprintf(bank->disk->disk_name, "%s%d", |
236 | AXON_RAM_DEVICE_NAME, axon_ram_bank_id); | 242 | AXON_RAM_DEVICE_NAME, axon_ram_bank_id); |
237 | bank->disk->major = register_blkdev(0, bank->disk->disk_name); | ||
238 | if (bank->disk->major < 0) { | ||
239 | dev_err(&device->dev, "Cannot register block device\n"); | ||
240 | rc = -EFAULT; | ||
241 | goto failed; | ||
242 | } | ||
243 | 243 | ||
244 | bank->disk->queue = blk_alloc_queue(GFP_KERNEL); | 244 | bank->disk->queue = blk_alloc_queue(GFP_KERNEL); |
245 | if (bank->disk->queue == NULL) { | 245 | if (bank->disk->queue == NULL) { |
@@ -276,6 +276,8 @@ axon_ram_probe(struct of_device *device, const struct of_device_id *device_id) | |||
276 | goto failed; | 276 | goto failed; |
277 | } | 277 | } |
278 | 278 | ||
279 | azfs_minor += bank->disk->minors; | ||
280 | |||
279 | return 0; | 281 | return 0; |
280 | 282 | ||
281 | failed: | 283 | failed: |
@@ -310,7 +312,6 @@ axon_ram_remove(struct of_device *device) | |||
310 | 312 | ||
311 | device_remove_file(&device->dev, &dev_attr_ecc); | 313 | device_remove_file(&device->dev, &dev_attr_ecc); |
312 | free_irq(bank->irq_id, device); | 314 | free_irq(bank->irq_id, device); |
313 | unregister_blkdev(bank->disk->major, bank->disk->disk_name); | ||
314 | del_gendisk(bank->disk); | 315 | del_gendisk(bank->disk); |
315 | iounmap((void __iomem *) bank->io_addr); | 316 | iounmap((void __iomem *) bank->io_addr); |
316 | kfree(bank); | 317 | kfree(bank); |
@@ -341,6 +342,14 @@ static struct of_platform_driver axon_ram_driver = { | |||
341 | static int __init | 342 | static int __init |
342 | axon_ram_init(void) | 343 | axon_ram_init(void) |
343 | { | 344 | { |
345 | azfs_major = register_blkdev(azfs_major, AXON_RAM_DEVICE_NAME); | ||
346 | if (azfs_major < 0) { | ||
347 | printk(KERN_ERR "%s cannot become block device major number\n", | ||
348 | AXON_RAM_MODULE_NAME); | ||
349 | return -EFAULT; | ||
350 | } | ||
351 | azfs_minor = 0; | ||
352 | |||
344 | return of_register_platform_driver(&axon_ram_driver); | 353 | return of_register_platform_driver(&axon_ram_driver); |
345 | } | 354 | } |
346 | 355 | ||
@@ -351,6 +360,7 @@ static void __exit | |||
351 | axon_ram_exit(void) | 360 | axon_ram_exit(void) |
352 | { | 361 | { |
353 | of_unregister_platform_driver(&axon_ram_driver); | 362 | of_unregister_platform_driver(&axon_ram_driver); |
363 | unregister_blkdev(azfs_major, AXON_RAM_DEVICE_NAME); | ||
354 | } | 364 | } |
355 | 365 | ||
356 | module_init(axon_ram_init); | 366 | module_init(axon_ram_init); |
diff --git a/arch/powerpc/sysdev/dart_iommu.c b/arch/powerpc/sysdev/dart_iommu.c index 005c2ecf976f..de8c8b542cfa 100644 --- a/arch/powerpc/sysdev/dart_iommu.c +++ b/arch/powerpc/sysdev/dart_iommu.c | |||
@@ -149,7 +149,8 @@ static void dart_flush(struct iommu_table *tbl) | |||
149 | 149 | ||
150 | static void dart_build(struct iommu_table *tbl, long index, | 150 | static void dart_build(struct iommu_table *tbl, long index, |
151 | long npages, unsigned long uaddr, | 151 | long npages, unsigned long uaddr, |
152 | enum dma_data_direction direction) | 152 | enum dma_data_direction direction, |
153 | struct dma_attrs *attrs) | ||
153 | { | 154 | { |
154 | unsigned int *dp; | 155 | unsigned int *dp; |
155 | unsigned int rpn; | 156 | unsigned int rpn; |
diff --git a/arch/powerpc/sysdev/fsl_pci.c b/arch/powerpc/sysdev/fsl_pci.c index 87b0aa13ab48..61e6d77efa4f 100644 --- a/arch/powerpc/sysdev/fsl_pci.c +++ b/arch/powerpc/sysdev/fsl_pci.c | |||
@@ -27,6 +27,7 @@ | |||
27 | #include <sysdev/fsl_soc.h> | 27 | #include <sysdev/fsl_soc.h> |
28 | #include <sysdev/fsl_pci.h> | 28 | #include <sysdev/fsl_pci.h> |
29 | 29 | ||
30 | #if defined(CONFIG_PPC_85xx) || defined(CONFIG_PPC_86xx) | ||
30 | /* atmu setup for fsl pci/pcie controller */ | 31 | /* atmu setup for fsl pci/pcie controller */ |
31 | void __init setup_pci_atmu(struct pci_controller *hose, struct resource *rsrc) | 32 | void __init setup_pci_atmu(struct pci_controller *hose, struct resource *rsrc) |
32 | { | 33 | { |
@@ -248,3 +249,63 @@ DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8536, quirk_fsl_pcie_header); | |||
248 | DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8641, quirk_fsl_pcie_header); | 249 | DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8641, quirk_fsl_pcie_header); |
249 | DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8641D, quirk_fsl_pcie_header); | 250 | DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8641D, quirk_fsl_pcie_header); |
250 | DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8610, quirk_fsl_pcie_header); | 251 | DECLARE_PCI_FIXUP_HEADER(0x1957, PCI_DEVICE_ID_MPC8610, quirk_fsl_pcie_header); |
252 | #endif /* CONFIG_PPC_85xx || CONFIG_PPC_86xx */ | ||
253 | |||
254 | #if defined(CONFIG_PPC_83xx) | ||
255 | int __init mpc83xx_add_bridge(struct device_node *dev) | ||
256 | { | ||
257 | int len; | ||
258 | struct pci_controller *hose; | ||
259 | struct resource rsrc; | ||
260 | const int *bus_range; | ||
261 | int primary = 1, has_address = 0; | ||
262 | phys_addr_t immr = get_immrbase(); | ||
263 | |||
264 | pr_debug("Adding PCI host bridge %s\n", dev->full_name); | ||
265 | |||
266 | /* Fetch host bridge registers address */ | ||
267 | has_address = (of_address_to_resource(dev, 0, &rsrc) == 0); | ||
268 | |||
269 | /* Get bus range if any */ | ||
270 | bus_range = of_get_property(dev, "bus-range", &len); | ||
271 | if (bus_range == NULL || len < 2 * sizeof(int)) { | ||
272 | printk(KERN_WARNING "Can't get bus-range for %s, assume" | ||
273 | " bus 0\n", dev->full_name); | ||
274 | } | ||
275 | |||
276 | ppc_pci_flags |= PPC_PCI_REASSIGN_ALL_BUS; | ||
277 | hose = pcibios_alloc_controller(dev); | ||
278 | if (!hose) | ||
279 | return -ENOMEM; | ||
280 | |||
281 | hose->first_busno = bus_range ? bus_range[0] : 0; | ||
282 | hose->last_busno = bus_range ? bus_range[1] : 0xff; | ||
283 | |||
284 | /* MPC83xx supports up to two host controllers one at 0x8500 from immrbar | ||
285 | * the other at 0x8600, we consider the 0x8500 the primary controller | ||
286 | */ | ||
287 | /* PCI 1 */ | ||
288 | if ((rsrc.start & 0xfffff) == 0x8500) { | ||
289 | setup_indirect_pci(hose, immr + 0x8300, immr + 0x8304, 0); | ||
290 | } | ||
291 | /* PCI 2 */ | ||
292 | if ((rsrc.start & 0xfffff) == 0x8600) { | ||
293 | setup_indirect_pci(hose, immr + 0x8380, immr + 0x8384, 0); | ||
294 | primary = 0; | ||
295 | } | ||
296 | |||
297 | printk(KERN_INFO "Found MPC83xx PCI host bridge at 0x%016llx. " | ||
298 | "Firmware bus number: %d->%d\n", | ||
299 | (unsigned long long)rsrc.start, hose->first_busno, | ||
300 | hose->last_busno); | ||
301 | |||
302 | pr_debug(" ->Hose at 0x%p, cfg_addr=0x%p,cfg_data=0x%p\n", | ||
303 | hose, hose->cfg_addr, hose->cfg_data); | ||
304 | |||
305 | /* Interpret the "ranges" property */ | ||
306 | /* This also maps the I/O region and sets isa_io/mem_base */ | ||
307 | pci_process_bridge_OF_ranges(hose, dev, primary); | ||
308 | |||
309 | return 0; | ||
310 | } | ||
311 | #endif /* CONFIG_PPC_83xx */ | ||
diff --git a/arch/powerpc/sysdev/fsl_pci.h b/arch/powerpc/sysdev/fsl_pci.h index 37b04ad26571..13f30c2a61e7 100644 --- a/arch/powerpc/sysdev/fsl_pci.h +++ b/arch/powerpc/sysdev/fsl_pci.h | |||
@@ -83,6 +83,7 @@ struct ccsr_pci { | |||
83 | 83 | ||
84 | extern int fsl_add_bridge(struct device_node *dev, int is_primary); | 84 | extern int fsl_add_bridge(struct device_node *dev, int is_primary); |
85 | extern void fsl_pcibios_fixup_bus(struct pci_bus *bus); | 85 | extern void fsl_pcibios_fixup_bus(struct pci_bus *bus); |
86 | extern int mpc83xx_add_bridge(struct device_node *dev); | ||
86 | 87 | ||
87 | #endif /* __POWERPC_FSL_PCI_H */ | 88 | #endif /* __POWERPC_FSL_PCI_H */ |
88 | #endif /* __KERNEL__ */ | 89 | #endif /* __KERNEL__ */ |
diff --git a/arch/powerpc/sysdev/fsl_soc.c b/arch/powerpc/sysdev/fsl_soc.c index ebcec7362f95..214388e11807 100644 --- a/arch/powerpc/sysdev/fsl_soc.c +++ b/arch/powerpc/sysdev/fsl_soc.c | |||
@@ -207,66 +207,58 @@ static int __init of_add_fixed_phys(void) | |||
207 | arch_initcall(of_add_fixed_phys); | 207 | arch_initcall(of_add_fixed_phys); |
208 | #endif /* CONFIG_FIXED_PHY */ | 208 | #endif /* CONFIG_FIXED_PHY */ |
209 | 209 | ||
210 | static int __init gfar_mdio_of_init(void) | 210 | static int gfar_mdio_of_init_one(struct device_node *np) |
211 | { | 211 | { |
212 | struct device_node *np = NULL; | 212 | int k; |
213 | struct device_node *child = NULL; | ||
214 | struct gianfar_mdio_data mdio_data; | ||
213 | struct platform_device *mdio_dev; | 215 | struct platform_device *mdio_dev; |
214 | struct resource res; | 216 | struct resource res; |
215 | int ret; | 217 | int ret; |
216 | 218 | ||
217 | np = of_find_compatible_node(np, NULL, "fsl,gianfar-mdio"); | 219 | memset(&res, 0, sizeof(res)); |
220 | memset(&mdio_data, 0, sizeof(mdio_data)); | ||
218 | 221 | ||
219 | /* try the deprecated version */ | 222 | ret = of_address_to_resource(np, 0, &res); |
220 | if (!np) | 223 | if (ret) |
221 | np = of_find_compatible_node(np, "mdio", "gianfar"); | 224 | return ret; |
222 | 225 | ||
223 | if (np) { | 226 | mdio_dev = platform_device_register_simple("fsl-gianfar_mdio", |
224 | int k; | 227 | res.start&0xfffff, &res, 1); |
225 | struct device_node *child = NULL; | 228 | if (IS_ERR(mdio_dev)) |
226 | struct gianfar_mdio_data mdio_data; | 229 | return PTR_ERR(mdio_dev); |
227 | 230 | ||
228 | memset(&res, 0, sizeof(res)); | 231 | for (k = 0; k < 32; k++) |
229 | memset(&mdio_data, 0, sizeof(mdio_data)); | 232 | mdio_data.irq[k] = PHY_POLL; |
230 | 233 | ||
231 | ret = of_address_to_resource(np, 0, &res); | 234 | while ((child = of_get_next_child(np, child)) != NULL) { |
232 | if (ret) | 235 | int irq = irq_of_parse_and_map(child, 0); |
233 | goto err; | 236 | if (irq != NO_IRQ) { |
234 | 237 | const u32 *id = of_get_property(child, "reg", NULL); | |
235 | mdio_dev = | 238 | mdio_data.irq[*id] = irq; |
236 | platform_device_register_simple("fsl-gianfar_mdio", | ||
237 | res.start, &res, 1); | ||
238 | if (IS_ERR(mdio_dev)) { | ||
239 | ret = PTR_ERR(mdio_dev); | ||
240 | goto err; | ||
241 | } | 239 | } |
240 | } | ||
242 | 241 | ||
243 | for (k = 0; k < 32; k++) | 242 | ret = platform_device_add_data(mdio_dev, &mdio_data, |
244 | mdio_data.irq[k] = PHY_POLL; | 243 | sizeof(struct gianfar_mdio_data)); |
244 | if (ret) | ||
245 | platform_device_unregister(mdio_dev); | ||
245 | 246 | ||
246 | while ((child = of_get_next_child(np, child)) != NULL) { | 247 | return ret; |
247 | int irq = irq_of_parse_and_map(child, 0); | 248 | } |
248 | if (irq != NO_IRQ) { | ||
249 | const u32 *id = of_get_property(child, | ||
250 | "reg", NULL); | ||
251 | mdio_data.irq[*id] = irq; | ||
252 | } | ||
253 | } | ||
254 | 249 | ||
255 | ret = | 250 | static int __init gfar_mdio_of_init(void) |
256 | platform_device_add_data(mdio_dev, &mdio_data, | 251 | { |
257 | sizeof(struct gianfar_mdio_data)); | 252 | struct device_node *np = NULL; |
258 | if (ret) | ||
259 | goto unreg; | ||
260 | } | ||
261 | 253 | ||
262 | of_node_put(np); | 254 | for_each_compatible_node(np, NULL, "fsl,gianfar-mdio") |
263 | return 0; | 255 | gfar_mdio_of_init_one(np); |
264 | 256 | ||
265 | unreg: | 257 | /* try the deprecated version */ |
266 | platform_device_unregister(mdio_dev); | 258 | for_each_compatible_node(np, "mdio", "gianfar"); |
267 | err: | 259 | gfar_mdio_of_init_one(np); |
268 | of_node_put(np); | 260 | |
269 | return ret; | 261 | return 0; |
270 | } | 262 | } |
271 | 263 | ||
272 | arch_initcall(gfar_mdio_of_init); | 264 | arch_initcall(gfar_mdio_of_init); |
@@ -296,6 +288,9 @@ static int __init gfar_of_init(void) | |||
296 | const phandle *ph; | 288 | const phandle *ph; |
297 | int n_res = 2; | 289 | int n_res = 2; |
298 | 290 | ||
291 | if (!of_device_is_available(np)) | ||
292 | continue; | ||
293 | |||
299 | memset(r, 0, sizeof(r)); | 294 | memset(r, 0, sizeof(r)); |
300 | memset(&gfar_data, 0, sizeof(gfar_data)); | 295 | memset(&gfar_data, 0, sizeof(gfar_data)); |
301 | 296 | ||
@@ -357,6 +352,9 @@ static int __init gfar_of_init(void) | |||
357 | else | 352 | else |
358 | gfar_data.interface = PHY_INTERFACE_MODE_MII; | 353 | gfar_data.interface = PHY_INTERFACE_MODE_MII; |
359 | 354 | ||
355 | if (of_get_property(np, "fsl,magic-packet", NULL)) | ||
356 | gfar_data.device_flags |= FSL_GIANFAR_DEV_HAS_MAGIC_PACKET; | ||
357 | |||
360 | ph = of_get_property(np, "phy-handle", NULL); | 358 | ph = of_get_property(np, "phy-handle", NULL); |
361 | if (ph == NULL) { | 359 | if (ph == NULL) { |
362 | u32 *fixed_link; | 360 | u32 *fixed_link; |
@@ -390,7 +388,7 @@ static int __init gfar_of_init(void) | |||
390 | 388 | ||
391 | gfar_data.phy_id = *id; | 389 | gfar_data.phy_id = *id; |
392 | snprintf(gfar_data.bus_id, MII_BUS_ID_SIZE, "%llx", | 390 | snprintf(gfar_data.bus_id, MII_BUS_ID_SIZE, "%llx", |
393 | (unsigned long long)res.start); | 391 | (unsigned long long)res.start&0xfffff); |
394 | 392 | ||
395 | of_node_put(phy); | 393 | of_node_put(phy); |
396 | of_node_put(mdio); | 394 | of_node_put(mdio); |
diff --git a/arch/powerpc/sysdev/fsl_soc.h b/arch/powerpc/sysdev/fsl_soc.h index 52c831fa1886..024299887352 100644 --- a/arch/powerpc/sysdev/fsl_soc.h +++ b/arch/powerpc/sysdev/fsl_soc.h | |||
@@ -10,6 +10,7 @@ extern u32 get_baudrate(void); | |||
10 | extern u32 fsl_get_sys_freq(void); | 10 | extern u32 fsl_get_sys_freq(void); |
11 | 11 | ||
12 | struct spi_board_info; | 12 | struct spi_board_info; |
13 | struct device_node; | ||
13 | 14 | ||
14 | extern int fsl_spi_init(struct spi_board_info *board_infos, | 15 | extern int fsl_spi_init(struct spi_board_info *board_infos, |
15 | unsigned int num_board_infos, | 16 | unsigned int num_board_infos, |
diff --git a/arch/powerpc/sysdev/ipic.c b/arch/powerpc/sysdev/ipic.c index caba1c0be5a7..88a983ece5c9 100644 --- a/arch/powerpc/sysdev/ipic.c +++ b/arch/powerpc/sysdev/ipic.c | |||
@@ -22,6 +22,7 @@ | |||
22 | #include <linux/device.h> | 22 | #include <linux/device.h> |
23 | #include <linux/bootmem.h> | 23 | #include <linux/bootmem.h> |
24 | #include <linux/spinlock.h> | 24 | #include <linux/spinlock.h> |
25 | #include <linux/fsl_devices.h> | ||
25 | #include <asm/irq.h> | 26 | #include <asm/irq.h> |
26 | #include <asm/io.h> | 27 | #include <asm/io.h> |
27 | #include <asm/prom.h> | 28 | #include <asm/prom.h> |
@@ -889,8 +890,78 @@ unsigned int ipic_get_irq(void) | |||
889 | return irq_linear_revmap(primary_ipic->irqhost, irq); | 890 | return irq_linear_revmap(primary_ipic->irqhost, irq); |
890 | } | 891 | } |
891 | 892 | ||
893 | #ifdef CONFIG_PM | ||
894 | static struct { | ||
895 | u32 sicfr; | ||
896 | u32 siprr[2]; | ||
897 | u32 simsr[2]; | ||
898 | u32 sicnr; | ||
899 | u32 smprr[2]; | ||
900 | u32 semsr; | ||
901 | u32 secnr; | ||
902 | u32 sermr; | ||
903 | u32 sercr; | ||
904 | } ipic_saved_state; | ||
905 | |||
906 | static int ipic_suspend(struct sys_device *sdev, pm_message_t state) | ||
907 | { | ||
908 | struct ipic *ipic = primary_ipic; | ||
909 | |||
910 | ipic_saved_state.sicfr = ipic_read(ipic->regs, IPIC_SICFR); | ||
911 | ipic_saved_state.siprr[0] = ipic_read(ipic->regs, IPIC_SIPRR_A); | ||
912 | ipic_saved_state.siprr[1] = ipic_read(ipic->regs, IPIC_SIPRR_D); | ||
913 | ipic_saved_state.simsr[0] = ipic_read(ipic->regs, IPIC_SIMSR_H); | ||
914 | ipic_saved_state.simsr[1] = ipic_read(ipic->regs, IPIC_SIMSR_L); | ||
915 | ipic_saved_state.sicnr = ipic_read(ipic->regs, IPIC_SICNR); | ||
916 | ipic_saved_state.smprr[0] = ipic_read(ipic->regs, IPIC_SMPRR_A); | ||
917 | ipic_saved_state.smprr[1] = ipic_read(ipic->regs, IPIC_SMPRR_B); | ||
918 | ipic_saved_state.semsr = ipic_read(ipic->regs, IPIC_SEMSR); | ||
919 | ipic_saved_state.secnr = ipic_read(ipic->regs, IPIC_SECNR); | ||
920 | ipic_saved_state.sermr = ipic_read(ipic->regs, IPIC_SERMR); | ||
921 | ipic_saved_state.sercr = ipic_read(ipic->regs, IPIC_SERCR); | ||
922 | |||
923 | if (fsl_deep_sleep()) { | ||
924 | /* In deep sleep, make sure there can be no | ||
925 | * pending interrupts, as this can cause | ||
926 | * problems on 831x. | ||
927 | */ | ||
928 | ipic_write(ipic->regs, IPIC_SIMSR_H, 0); | ||
929 | ipic_write(ipic->regs, IPIC_SIMSR_L, 0); | ||
930 | ipic_write(ipic->regs, IPIC_SEMSR, 0); | ||
931 | ipic_write(ipic->regs, IPIC_SERMR, 0); | ||
932 | } | ||
933 | |||
934 | return 0; | ||
935 | } | ||
936 | |||
937 | static int ipic_resume(struct sys_device *sdev) | ||
938 | { | ||
939 | struct ipic *ipic = primary_ipic; | ||
940 | |||
941 | ipic_write(ipic->regs, IPIC_SICFR, ipic_saved_state.sicfr); | ||
942 | ipic_write(ipic->regs, IPIC_SIPRR_A, ipic_saved_state.siprr[0]); | ||
943 | ipic_write(ipic->regs, IPIC_SIPRR_D, ipic_saved_state.siprr[1]); | ||
944 | ipic_write(ipic->regs, IPIC_SIMSR_H, ipic_saved_state.simsr[0]); | ||
945 | ipic_write(ipic->regs, IPIC_SIMSR_L, ipic_saved_state.simsr[1]); | ||
946 | ipic_write(ipic->regs, IPIC_SICNR, ipic_saved_state.sicnr); | ||
947 | ipic_write(ipic->regs, IPIC_SMPRR_A, ipic_saved_state.smprr[0]); | ||
948 | ipic_write(ipic->regs, IPIC_SMPRR_B, ipic_saved_state.smprr[1]); | ||
949 | ipic_write(ipic->regs, IPIC_SEMSR, ipic_saved_state.semsr); | ||
950 | ipic_write(ipic->regs, IPIC_SECNR, ipic_saved_state.secnr); | ||
951 | ipic_write(ipic->regs, IPIC_SERMR, ipic_saved_state.sermr); | ||
952 | ipic_write(ipic->regs, IPIC_SERCR, ipic_saved_state.sercr); | ||
953 | |||
954 | return 0; | ||
955 | } | ||
956 | #else | ||
957 | #define ipic_suspend NULL | ||
958 | #define ipic_resume NULL | ||
959 | #endif | ||
960 | |||
892 | static struct sysdev_class ipic_sysclass = { | 961 | static struct sysdev_class ipic_sysclass = { |
893 | .name = "ipic", | 962 | .name = "ipic", |
963 | .suspend = ipic_suspend, | ||
964 | .resume = ipic_resume, | ||
894 | }; | 965 | }; |
895 | 966 | ||
896 | static struct sys_device device_ipic = { | 967 | static struct sys_device device_ipic = { |
diff --git a/arch/powerpc/sysdev/qe_lib/qe.c b/arch/powerpc/sysdev/qe_lib/qe.c index 9e82d7e725a5..b3b73ae57d6d 100644 --- a/arch/powerpc/sysdev/qe_lib/qe.c +++ b/arch/powerpc/sysdev/qe_lib/qe.c | |||
@@ -64,7 +64,7 @@ static phys_addr_t qebase = -1; | |||
64 | phys_addr_t get_qe_base(void) | 64 | phys_addr_t get_qe_base(void) |
65 | { | 65 | { |
66 | struct device_node *qe; | 66 | struct device_node *qe; |
67 | unsigned int size; | 67 | int size; |
68 | const u32 *prop; | 68 | const u32 *prop; |
69 | 69 | ||
70 | if (qebase != -1) | 70 | if (qebase != -1) |
@@ -158,7 +158,7 @@ static unsigned int brg_clk = 0; | |||
158 | unsigned int qe_get_brg_clk(void) | 158 | unsigned int qe_get_brg_clk(void) |
159 | { | 159 | { |
160 | struct device_node *qe; | 160 | struct device_node *qe; |
161 | unsigned int size; | 161 | int size; |
162 | const u32 *prop; | 162 | const u32 *prop; |
163 | 163 | ||
164 | if (brg_clk) | 164 | if (brg_clk) |
@@ -305,7 +305,7 @@ EXPORT_SYMBOL(qe_put_snum); | |||
305 | 305 | ||
306 | static int qe_sdma_init(void) | 306 | static int qe_sdma_init(void) |
307 | { | 307 | { |
308 | struct sdma *sdma = &qe_immr->sdma; | 308 | struct sdma __iomem *sdma = &qe_immr->sdma; |
309 | unsigned long sdma_buf_offset; | 309 | unsigned long sdma_buf_offset; |
310 | 310 | ||
311 | if (!sdma) | 311 | if (!sdma) |
diff --git a/arch/powerpc/sysdev/qe_lib/ucc.c b/arch/powerpc/sysdev/qe_lib/ucc.c index d3c7f5af9bc8..1d78071aad7d 100644 --- a/arch/powerpc/sysdev/qe_lib/ucc.c +++ b/arch/powerpc/sysdev/qe_lib/ucc.c | |||
@@ -88,7 +88,7 @@ int ucc_set_type(unsigned int ucc_num, enum ucc_speed_type speed) | |||
88 | return 0; | 88 | return 0; |
89 | } | 89 | } |
90 | 90 | ||
91 | static void get_cmxucr_reg(unsigned int ucc_num, __be32 **cmxucr, | 91 | static void get_cmxucr_reg(unsigned int ucc_num, __be32 __iomem **cmxucr, |
92 | unsigned int *reg_num, unsigned int *shift) | 92 | unsigned int *reg_num, unsigned int *shift) |
93 | { | 93 | { |
94 | unsigned int cmx = ((ucc_num & 1) << 1) + (ucc_num > 3); | 94 | unsigned int cmx = ((ucc_num & 1) << 1) + (ucc_num > 3); |
@@ -100,7 +100,7 @@ static void get_cmxucr_reg(unsigned int ucc_num, __be32 **cmxucr, | |||
100 | 100 | ||
101 | int ucc_mux_set_grant_tsa_bkpt(unsigned int ucc_num, int set, u32 mask) | 101 | int ucc_mux_set_grant_tsa_bkpt(unsigned int ucc_num, int set, u32 mask) |
102 | { | 102 | { |
103 | __be32 *cmxucr; | 103 | __be32 __iomem *cmxucr; |
104 | unsigned int reg_num; | 104 | unsigned int reg_num; |
105 | unsigned int shift; | 105 | unsigned int shift; |
106 | 106 | ||
@@ -121,7 +121,7 @@ int ucc_mux_set_grant_tsa_bkpt(unsigned int ucc_num, int set, u32 mask) | |||
121 | int ucc_set_qe_mux_rxtx(unsigned int ucc_num, enum qe_clock clock, | 121 | int ucc_set_qe_mux_rxtx(unsigned int ucc_num, enum qe_clock clock, |
122 | enum comm_dir mode) | 122 | enum comm_dir mode) |
123 | { | 123 | { |
124 | __be32 *cmxucr; | 124 | __be32 __iomem *cmxucr; |
125 | unsigned int reg_num; | 125 | unsigned int reg_num; |
126 | unsigned int shift; | 126 | unsigned int shift; |
127 | u32 clock_bits = 0; | 127 | u32 clock_bits = 0; |
diff --git a/arch/powerpc/sysdev/qe_lib/ucc_fast.c b/arch/powerpc/sysdev/qe_lib/ucc_fast.c index bcf88e6ce962..1aecb075a72e 100644 --- a/arch/powerpc/sysdev/qe_lib/ucc_fast.c +++ b/arch/powerpc/sysdev/qe_lib/ucc_fast.c | |||
@@ -46,7 +46,7 @@ void ucc_fast_dump_regs(struct ucc_fast_private * uccf) | |||
46 | printk(KERN_INFO "uccm : addr=0x%p, val=0x%08x\n", | 46 | printk(KERN_INFO "uccm : addr=0x%p, val=0x%08x\n", |
47 | &uccf->uf_regs->uccm, in_be32(&uccf->uf_regs->uccm)); | 47 | &uccf->uf_regs->uccm, in_be32(&uccf->uf_regs->uccm)); |
48 | printk(KERN_INFO "uccs : addr=0x%p, val=0x%02x\n", | 48 | printk(KERN_INFO "uccs : addr=0x%p, val=0x%02x\n", |
49 | &uccf->uf_regs->uccs, uccf->uf_regs->uccs); | 49 | &uccf->uf_regs->uccs, in_8(&uccf->uf_regs->uccs)); |
50 | printk(KERN_INFO "urfb : addr=0x%p, val=0x%08x\n", | 50 | printk(KERN_INFO "urfb : addr=0x%p, val=0x%08x\n", |
51 | &uccf->uf_regs->urfb, in_be32(&uccf->uf_regs->urfb)); | 51 | &uccf->uf_regs->urfb, in_be32(&uccf->uf_regs->urfb)); |
52 | printk(KERN_INFO "urfs : addr=0x%p, val=0x%04x\n", | 52 | printk(KERN_INFO "urfs : addr=0x%p, val=0x%04x\n", |
@@ -68,7 +68,7 @@ void ucc_fast_dump_regs(struct ucc_fast_private * uccf) | |||
68 | printk(KERN_INFO "urtry : addr=0x%p, val=0x%08x\n", | 68 | printk(KERN_INFO "urtry : addr=0x%p, val=0x%08x\n", |
69 | &uccf->uf_regs->urtry, in_be32(&uccf->uf_regs->urtry)); | 69 | &uccf->uf_regs->urtry, in_be32(&uccf->uf_regs->urtry)); |
70 | printk(KERN_INFO "guemr : addr=0x%p, val=0x%02x\n", | 70 | printk(KERN_INFO "guemr : addr=0x%p, val=0x%02x\n", |
71 | &uccf->uf_regs->guemr, uccf->uf_regs->guemr); | 71 | &uccf->uf_regs->guemr, in_8(&uccf->uf_regs->guemr)); |
72 | } | 72 | } |
73 | EXPORT_SYMBOL(ucc_fast_dump_regs); | 73 | EXPORT_SYMBOL(ucc_fast_dump_regs); |
74 | 74 | ||
@@ -96,7 +96,7 @@ EXPORT_SYMBOL(ucc_fast_transmit_on_demand); | |||
96 | 96 | ||
97 | void ucc_fast_enable(struct ucc_fast_private * uccf, enum comm_dir mode) | 97 | void ucc_fast_enable(struct ucc_fast_private * uccf, enum comm_dir mode) |
98 | { | 98 | { |
99 | struct ucc_fast *uf_regs; | 99 | struct ucc_fast __iomem *uf_regs; |
100 | u32 gumr; | 100 | u32 gumr; |
101 | 101 | ||
102 | uf_regs = uccf->uf_regs; | 102 | uf_regs = uccf->uf_regs; |
@@ -117,7 +117,7 @@ EXPORT_SYMBOL(ucc_fast_enable); | |||
117 | 117 | ||
118 | void ucc_fast_disable(struct ucc_fast_private * uccf, enum comm_dir mode) | 118 | void ucc_fast_disable(struct ucc_fast_private * uccf, enum comm_dir mode) |
119 | { | 119 | { |
120 | struct ucc_fast *uf_regs; | 120 | struct ucc_fast __iomem *uf_regs; |
121 | u32 gumr; | 121 | u32 gumr; |
122 | 122 | ||
123 | uf_regs = uccf->uf_regs; | 123 | uf_regs = uccf->uf_regs; |
@@ -139,7 +139,7 @@ EXPORT_SYMBOL(ucc_fast_disable); | |||
139 | int ucc_fast_init(struct ucc_fast_info * uf_info, struct ucc_fast_private ** uccf_ret) | 139 | int ucc_fast_init(struct ucc_fast_info * uf_info, struct ucc_fast_private ** uccf_ret) |
140 | { | 140 | { |
141 | struct ucc_fast_private *uccf; | 141 | struct ucc_fast_private *uccf; |
142 | struct ucc_fast *uf_regs; | 142 | struct ucc_fast __iomem *uf_regs; |
143 | u32 gumr; | 143 | u32 gumr; |
144 | int ret; | 144 | int ret; |
145 | 145 | ||
@@ -216,10 +216,10 @@ int ucc_fast_init(struct ucc_fast_info * uf_info, struct ucc_fast_private ** ucc | |||
216 | uccf->stopped_tx = 0; | 216 | uccf->stopped_tx = 0; |
217 | uccf->stopped_rx = 0; | 217 | uccf->stopped_rx = 0; |
218 | uf_regs = uccf->uf_regs; | 218 | uf_regs = uccf->uf_regs; |
219 | uccf->p_ucce = (u32 *) & (uf_regs->ucce); | 219 | uccf->p_ucce = &uf_regs->ucce; |
220 | uccf->p_uccm = (u32 *) & (uf_regs->uccm); | 220 | uccf->p_uccm = &uf_regs->uccm; |
221 | #ifdef CONFIG_UGETH_TX_ON_DEMAND | 221 | #ifdef CONFIG_UGETH_TX_ON_DEMAND |
222 | uccf->p_utodr = (u16 *) & (uf_regs->utodr); | 222 | uccf->p_utodr = &uf_regs->utodr; |
223 | #endif | 223 | #endif |
224 | #ifdef STATISTICS | 224 | #ifdef STATISTICS |
225 | uccf->tx_frames = 0; | 225 | uccf->tx_frames = 0; |
diff --git a/drivers/edac/cell_edac.c b/drivers/edac/cell_edac.c index b54112ffd282..0e024fe2d8c4 100644 --- a/drivers/edac/cell_edac.c +++ b/drivers/edac/cell_edac.c | |||
@@ -33,7 +33,7 @@ static void cell_edac_count_ce(struct mem_ctl_info *mci, int chan, u64 ar) | |||
33 | { | 33 | { |
34 | struct cell_edac_priv *priv = mci->pvt_info; | 34 | struct cell_edac_priv *priv = mci->pvt_info; |
35 | struct csrow_info *csrow = &mci->csrows[0]; | 35 | struct csrow_info *csrow = &mci->csrows[0]; |
36 | unsigned long address, pfn, offset; | 36 | unsigned long address, pfn, offset, syndrome; |
37 | 37 | ||
38 | dev_dbg(mci->dev, "ECC CE err on node %d, channel %d, ar = 0x%016lx\n", | 38 | dev_dbg(mci->dev, "ECC CE err on node %d, channel %d, ar = 0x%016lx\n", |
39 | priv->node, chan, ar); | 39 | priv->node, chan, ar); |
@@ -44,10 +44,11 @@ static void cell_edac_count_ce(struct mem_ctl_info *mci, int chan, u64 ar) | |||
44 | address = (address << 1) | chan; | 44 | address = (address << 1) | chan; |
45 | pfn = address >> PAGE_SHIFT; | 45 | pfn = address >> PAGE_SHIFT; |
46 | offset = address & ~PAGE_MASK; | 46 | offset = address & ~PAGE_MASK; |
47 | syndrome = (ar & 0x000000001fe00000ul) >> 21; | ||
47 | 48 | ||
48 | /* TODO: Decoding of the error addresss */ | 49 | /* TODO: Decoding of the error addresss */ |
49 | edac_mc_handle_ce(mci, csrow->first_page + pfn, offset, | 50 | edac_mc_handle_ce(mci, csrow->first_page + pfn, offset, |
50 | 0, 0, chan, ""); | 51 | syndrome, 0, chan, ""); |
51 | } | 52 | } |
52 | 53 | ||
53 | static void cell_edac_count_ue(struct mem_ctl_info *mci, int chan, u64 ar) | 54 | static void cell_edac_count_ue(struct mem_ctl_info *mci, int chan, u64 ar) |
diff --git a/drivers/net/fs_enet/Makefile b/drivers/net/fs_enet/Makefile index 1ffbe0756a0c..d4a305ee3455 100644 --- a/drivers/net/fs_enet/Makefile +++ b/drivers/net/fs_enet/Makefile | |||
@@ -8,12 +8,7 @@ fs_enet-$(CONFIG_FS_ENET_HAS_SCC) += mac-scc.o | |||
8 | fs_enet-$(CONFIG_FS_ENET_HAS_FEC) += mac-fec.o | 8 | fs_enet-$(CONFIG_FS_ENET_HAS_FEC) += mac-fec.o |
9 | fs_enet-$(CONFIG_FS_ENET_HAS_FCC) += mac-fcc.o | 9 | fs_enet-$(CONFIG_FS_ENET_HAS_FCC) += mac-fcc.o |
10 | 10 | ||
11 | ifeq ($(CONFIG_PPC_CPM_NEW_BINDING),y) | ||
12 | obj-$(CONFIG_FS_ENET_MDIO_FEC) += mii-fec.o | 11 | obj-$(CONFIG_FS_ENET_MDIO_FEC) += mii-fec.o |
13 | obj-$(CONFIG_FS_ENET_MDIO_FCC) += mii-bitbang.o | 12 | obj-$(CONFIG_FS_ENET_MDIO_FCC) += mii-bitbang.o |
14 | else | ||
15 | fs_enet-$(CONFIG_FS_ENET_MDIO_FEC) += mii-fec.o | ||
16 | fs_enet-$(CONFIG_FS_ENET_MDIO_FCC) += mii-bitbang.o | ||
17 | endif | ||
18 | 13 | ||
19 | fs_enet-objs := fs_enet-main.o $(fs_enet-m) | 14 | fs_enet-objs := fs_enet-main.o $(fs_enet-m) |
diff --git a/drivers/net/fs_enet/fs_enet-main.c b/drivers/net/fs_enet/fs_enet-main.c index 445763e5648e..92591384afa5 100644 --- a/drivers/net/fs_enet/fs_enet-main.c +++ b/drivers/net/fs_enet/fs_enet-main.c | |||
@@ -36,26 +36,18 @@ | |||
36 | #include <linux/fs.h> | 36 | #include <linux/fs.h> |
37 | #include <linux/platform_device.h> | 37 | #include <linux/platform_device.h> |
38 | #include <linux/phy.h> | 38 | #include <linux/phy.h> |
39 | #include <linux/of_platform.h> | ||
40 | #include <linux/of_gpio.h> | ||
39 | 41 | ||
40 | #include <linux/vmalloc.h> | 42 | #include <linux/vmalloc.h> |
41 | #include <asm/pgtable.h> | 43 | #include <asm/pgtable.h> |
42 | #include <asm/irq.h> | 44 | #include <asm/irq.h> |
43 | #include <asm/uaccess.h> | 45 | #include <asm/uaccess.h> |
44 | 46 | ||
45 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
46 | #include <linux/of_gpio.h> | ||
47 | #include <linux/of_platform.h> | ||
48 | #endif | ||
49 | |||
50 | #include "fs_enet.h" | 47 | #include "fs_enet.h" |
51 | 48 | ||
52 | /*************************************************/ | 49 | /*************************************************/ |
53 | 50 | ||
54 | #ifndef CONFIG_PPC_CPM_NEW_BINDING | ||
55 | static char version[] __devinitdata = | ||
56 | DRV_MODULE_NAME ".c:v" DRV_MODULE_VERSION " (" DRV_MODULE_RELDATE ")" "\n"; | ||
57 | #endif | ||
58 | |||
59 | MODULE_AUTHOR("Pantelis Antoniou <panto@intracom.gr>"); | 51 | MODULE_AUTHOR("Pantelis Antoniou <panto@intracom.gr>"); |
60 | MODULE_DESCRIPTION("Freescale Ethernet Driver"); | 52 | MODULE_DESCRIPTION("Freescale Ethernet Driver"); |
61 | MODULE_LICENSE("GPL"); | 53 | MODULE_LICENSE("GPL"); |
@@ -958,190 +950,6 @@ static int fs_ioctl(struct net_device *dev, struct ifreq *rq, int cmd) | |||
958 | extern int fs_mii_connect(struct net_device *dev); | 950 | extern int fs_mii_connect(struct net_device *dev); |
959 | extern void fs_mii_disconnect(struct net_device *dev); | 951 | extern void fs_mii_disconnect(struct net_device *dev); |
960 | 952 | ||
961 | #ifndef CONFIG_PPC_CPM_NEW_BINDING | ||
962 | static struct net_device *fs_init_instance(struct device *dev, | ||
963 | struct fs_platform_info *fpi) | ||
964 | { | ||
965 | struct net_device *ndev = NULL; | ||
966 | struct fs_enet_private *fep = NULL; | ||
967 | int privsize, i, r, err = 0, registered = 0; | ||
968 | |||
969 | fpi->fs_no = fs_get_id(fpi); | ||
970 | /* guard */ | ||
971 | if ((unsigned int)fpi->fs_no >= FS_MAX_INDEX) | ||
972 | return ERR_PTR(-EINVAL); | ||
973 | |||
974 | privsize = sizeof(*fep) + (sizeof(struct sk_buff **) * | ||
975 | (fpi->rx_ring + fpi->tx_ring)); | ||
976 | |||
977 | ndev = alloc_etherdev(privsize); | ||
978 | if (!ndev) { | ||
979 | err = -ENOMEM; | ||
980 | goto err; | ||
981 | } | ||
982 | |||
983 | fep = netdev_priv(ndev); | ||
984 | |||
985 | fep->dev = dev; | ||
986 | dev_set_drvdata(dev, ndev); | ||
987 | fep->fpi = fpi; | ||
988 | if (fpi->init_ioports) | ||
989 | fpi->init_ioports((struct fs_platform_info *)fpi); | ||
990 | |||
991 | #ifdef CONFIG_FS_ENET_HAS_FEC | ||
992 | if (fs_get_fec_index(fpi->fs_no) >= 0) | ||
993 | fep->ops = &fs_fec_ops; | ||
994 | #endif | ||
995 | |||
996 | #ifdef CONFIG_FS_ENET_HAS_SCC | ||
997 | if (fs_get_scc_index(fpi->fs_no) >=0) | ||
998 | fep->ops = &fs_scc_ops; | ||
999 | #endif | ||
1000 | |||
1001 | #ifdef CONFIG_FS_ENET_HAS_FCC | ||
1002 | if (fs_get_fcc_index(fpi->fs_no) >= 0) | ||
1003 | fep->ops = &fs_fcc_ops; | ||
1004 | #endif | ||
1005 | |||
1006 | if (fep->ops == NULL) { | ||
1007 | printk(KERN_ERR DRV_MODULE_NAME | ||
1008 | ": %s No matching ops found (%d).\n", | ||
1009 | ndev->name, fpi->fs_no); | ||
1010 | err = -EINVAL; | ||
1011 | goto err; | ||
1012 | } | ||
1013 | |||
1014 | r = (*fep->ops->setup_data)(ndev); | ||
1015 | if (r != 0) { | ||
1016 | printk(KERN_ERR DRV_MODULE_NAME | ||
1017 | ": %s setup_data failed\n", | ||
1018 | ndev->name); | ||
1019 | err = r; | ||
1020 | goto err; | ||
1021 | } | ||
1022 | |||
1023 | /* point rx_skbuff, tx_skbuff */ | ||
1024 | fep->rx_skbuff = (struct sk_buff **)&fep[1]; | ||
1025 | fep->tx_skbuff = fep->rx_skbuff + fpi->rx_ring; | ||
1026 | |||
1027 | /* init locks */ | ||
1028 | spin_lock_init(&fep->lock); | ||
1029 | spin_lock_init(&fep->tx_lock); | ||
1030 | |||
1031 | /* | ||
1032 | * Set the Ethernet address. | ||
1033 | */ | ||
1034 | for (i = 0; i < 6; i++) | ||
1035 | ndev->dev_addr[i] = fpi->macaddr[i]; | ||
1036 | |||
1037 | r = (*fep->ops->allocate_bd)(ndev); | ||
1038 | |||
1039 | if (fep->ring_base == NULL) { | ||
1040 | printk(KERN_ERR DRV_MODULE_NAME | ||
1041 | ": %s buffer descriptor alloc failed (%d).\n", ndev->name, r); | ||
1042 | err = r; | ||
1043 | goto err; | ||
1044 | } | ||
1045 | |||
1046 | /* | ||
1047 | * Set receive and transmit descriptor base. | ||
1048 | */ | ||
1049 | fep->rx_bd_base = fep->ring_base; | ||
1050 | fep->tx_bd_base = fep->rx_bd_base + fpi->rx_ring; | ||
1051 | |||
1052 | /* initialize ring size variables */ | ||
1053 | fep->tx_ring = fpi->tx_ring; | ||
1054 | fep->rx_ring = fpi->rx_ring; | ||
1055 | |||
1056 | /* | ||
1057 | * The FEC Ethernet specific entries in the device structure. | ||
1058 | */ | ||
1059 | ndev->open = fs_enet_open; | ||
1060 | ndev->hard_start_xmit = fs_enet_start_xmit; | ||
1061 | ndev->tx_timeout = fs_timeout; | ||
1062 | ndev->watchdog_timeo = 2 * HZ; | ||
1063 | ndev->stop = fs_enet_close; | ||
1064 | ndev->get_stats = fs_enet_get_stats; | ||
1065 | ndev->set_multicast_list = fs_set_multicast_list; | ||
1066 | |||
1067 | #ifdef CONFIG_NET_POLL_CONTROLLER | ||
1068 | ndev->poll_controller = fs_enet_netpoll; | ||
1069 | #endif | ||
1070 | |||
1071 | netif_napi_add(ndev, &fep->napi, | ||
1072 | fs_enet_rx_napi, fpi->napi_weight); | ||
1073 | |||
1074 | ndev->ethtool_ops = &fs_ethtool_ops; | ||
1075 | ndev->do_ioctl = fs_ioctl; | ||
1076 | |||
1077 | init_timer(&fep->phy_timer_list); | ||
1078 | |||
1079 | netif_carrier_off(ndev); | ||
1080 | |||
1081 | err = register_netdev(ndev); | ||
1082 | if (err != 0) { | ||
1083 | printk(KERN_ERR DRV_MODULE_NAME | ||
1084 | ": %s register_netdev failed.\n", ndev->name); | ||
1085 | goto err; | ||
1086 | } | ||
1087 | registered = 1; | ||
1088 | |||
1089 | |||
1090 | return ndev; | ||
1091 | |||
1092 | err: | ||
1093 | if (ndev != NULL) { | ||
1094 | if (registered) | ||
1095 | unregister_netdev(ndev); | ||
1096 | |||
1097 | if (fep && fep->ops) { | ||
1098 | (*fep->ops->free_bd)(ndev); | ||
1099 | (*fep->ops->cleanup_data)(ndev); | ||
1100 | } | ||
1101 | |||
1102 | free_netdev(ndev); | ||
1103 | } | ||
1104 | |||
1105 | dev_set_drvdata(dev, NULL); | ||
1106 | |||
1107 | return ERR_PTR(err); | ||
1108 | } | ||
1109 | |||
1110 | static int fs_cleanup_instance(struct net_device *ndev) | ||
1111 | { | ||
1112 | struct fs_enet_private *fep; | ||
1113 | const struct fs_platform_info *fpi; | ||
1114 | struct device *dev; | ||
1115 | |||
1116 | if (ndev == NULL) | ||
1117 | return -EINVAL; | ||
1118 | |||
1119 | fep = netdev_priv(ndev); | ||
1120 | if (fep == NULL) | ||
1121 | return -EINVAL; | ||
1122 | |||
1123 | fpi = fep->fpi; | ||
1124 | |||
1125 | unregister_netdev(ndev); | ||
1126 | |||
1127 | dma_free_coherent(fep->dev, (fpi->tx_ring + fpi->rx_ring) * sizeof(cbd_t), | ||
1128 | (void __force *)fep->ring_base, fep->ring_mem_addr); | ||
1129 | |||
1130 | /* reset it */ | ||
1131 | (*fep->ops->cleanup_data)(ndev); | ||
1132 | |||
1133 | dev = fep->dev; | ||
1134 | if (dev != NULL) { | ||
1135 | dev_set_drvdata(dev, NULL); | ||
1136 | fep->dev = NULL; | ||
1137 | } | ||
1138 | |||
1139 | free_netdev(ndev); | ||
1140 | |||
1141 | return 0; | ||
1142 | } | ||
1143 | #endif | ||
1144 | |||
1145 | /**************************************************************************************/ | 953 | /**************************************************************************************/ |
1146 | 954 | ||
1147 | /* handy pointer to the immap */ | 955 | /* handy pointer to the immap */ |
@@ -1168,7 +976,6 @@ static void cleanup_immap(void) | |||
1168 | 976 | ||
1169 | /**************************************************************************************/ | 977 | /**************************************************************************************/ |
1170 | 978 | ||
1171 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
1172 | static int __devinit find_phy(struct device_node *np, | 979 | static int __devinit find_phy(struct device_node *np, |
1173 | struct fs_platform_info *fpi) | 980 | struct fs_platform_info *fpi) |
1174 | { | 981 | { |
@@ -1408,121 +1215,6 @@ static void __exit fs_cleanup(void) | |||
1408 | of_unregister_platform_driver(&fs_enet_driver); | 1215 | of_unregister_platform_driver(&fs_enet_driver); |
1409 | cleanup_immap(); | 1216 | cleanup_immap(); |
1410 | } | 1217 | } |
1411 | #else | ||
1412 | static int __devinit fs_enet_probe(struct device *dev) | ||
1413 | { | ||
1414 | struct net_device *ndev; | ||
1415 | |||
1416 | /* no fixup - no device */ | ||
1417 | if (dev->platform_data == NULL) { | ||
1418 | printk(KERN_INFO "fs_enet: " | ||
1419 | "probe called with no platform data; " | ||
1420 | "remove unused devices\n"); | ||
1421 | return -ENODEV; | ||
1422 | } | ||
1423 | |||
1424 | ndev = fs_init_instance(dev, dev->platform_data); | ||
1425 | if (IS_ERR(ndev)) | ||
1426 | return PTR_ERR(ndev); | ||
1427 | return 0; | ||
1428 | } | ||
1429 | |||
1430 | static int fs_enet_remove(struct device *dev) | ||
1431 | { | ||
1432 | return fs_cleanup_instance(dev_get_drvdata(dev)); | ||
1433 | } | ||
1434 | |||
1435 | static struct device_driver fs_enet_fec_driver = { | ||
1436 | .name = "fsl-cpm-fec", | ||
1437 | .bus = &platform_bus_type, | ||
1438 | .probe = fs_enet_probe, | ||
1439 | .remove = fs_enet_remove, | ||
1440 | #ifdef CONFIG_PM | ||
1441 | /* .suspend = fs_enet_suspend, TODO */ | ||
1442 | /* .resume = fs_enet_resume, TODO */ | ||
1443 | #endif | ||
1444 | }; | ||
1445 | |||
1446 | static struct device_driver fs_enet_scc_driver = { | ||
1447 | .name = "fsl-cpm-scc", | ||
1448 | .bus = &platform_bus_type, | ||
1449 | .probe = fs_enet_probe, | ||
1450 | .remove = fs_enet_remove, | ||
1451 | #ifdef CONFIG_PM | ||
1452 | /* .suspend = fs_enet_suspend, TODO */ | ||
1453 | /* .resume = fs_enet_resume, TODO */ | ||
1454 | #endif | ||
1455 | }; | ||
1456 | |||
1457 | static struct device_driver fs_enet_fcc_driver = { | ||
1458 | .name = "fsl-cpm-fcc", | ||
1459 | .bus = &platform_bus_type, | ||
1460 | .probe = fs_enet_probe, | ||
1461 | .remove = fs_enet_remove, | ||
1462 | #ifdef CONFIG_PM | ||
1463 | /* .suspend = fs_enet_suspend, TODO */ | ||
1464 | /* .resume = fs_enet_resume, TODO */ | ||
1465 | #endif | ||
1466 | }; | ||
1467 | |||
1468 | static int __init fs_init(void) | ||
1469 | { | ||
1470 | int r; | ||
1471 | |||
1472 | printk(KERN_INFO | ||
1473 | "%s", version); | ||
1474 | |||
1475 | r = setup_immap(); | ||
1476 | if (r != 0) | ||
1477 | return r; | ||
1478 | |||
1479 | #ifdef CONFIG_FS_ENET_HAS_FCC | ||
1480 | /* let's insert mii stuff */ | ||
1481 | r = fs_enet_mdio_bb_init(); | ||
1482 | |||
1483 | if (r != 0) { | ||
1484 | printk(KERN_ERR DRV_MODULE_NAME | ||
1485 | "BB PHY init failed.\n"); | ||
1486 | return r; | ||
1487 | } | ||
1488 | r = driver_register(&fs_enet_fcc_driver); | ||
1489 | if (r != 0) | ||
1490 | goto err; | ||
1491 | #endif | ||
1492 | |||
1493 | #ifdef CONFIG_FS_ENET_HAS_FEC | ||
1494 | r = fs_enet_mdio_fec_init(); | ||
1495 | if (r != 0) { | ||
1496 | printk(KERN_ERR DRV_MODULE_NAME | ||
1497 | "FEC PHY init failed.\n"); | ||
1498 | return r; | ||
1499 | } | ||
1500 | |||
1501 | r = driver_register(&fs_enet_fec_driver); | ||
1502 | if (r != 0) | ||
1503 | goto err; | ||
1504 | #endif | ||
1505 | |||
1506 | #ifdef CONFIG_FS_ENET_HAS_SCC | ||
1507 | r = driver_register(&fs_enet_scc_driver); | ||
1508 | if (r != 0) | ||
1509 | goto err; | ||
1510 | #endif | ||
1511 | |||
1512 | return 0; | ||
1513 | err: | ||
1514 | cleanup_immap(); | ||
1515 | return r; | ||
1516 | } | ||
1517 | |||
1518 | static void __exit fs_cleanup(void) | ||
1519 | { | ||
1520 | driver_unregister(&fs_enet_fec_driver); | ||
1521 | driver_unregister(&fs_enet_fcc_driver); | ||
1522 | driver_unregister(&fs_enet_scc_driver); | ||
1523 | cleanup_immap(); | ||
1524 | } | ||
1525 | #endif | ||
1526 | 1218 | ||
1527 | #ifdef CONFIG_NET_POLL_CONTROLLER | 1219 | #ifdef CONFIG_NET_POLL_CONTROLLER |
1528 | static void fs_enet_netpoll(struct net_device *dev) | 1220 | static void fs_enet_netpoll(struct net_device *dev) |
diff --git a/drivers/net/fs_enet/fs_enet.h b/drivers/net/fs_enet/fs_enet.h index e05389c49bbb..db46d2e72329 100644 --- a/drivers/net/fs_enet/fs_enet.h +++ b/drivers/net/fs_enet/fs_enet.h | |||
@@ -138,10 +138,6 @@ struct fs_enet_private { | |||
138 | }; | 138 | }; |
139 | 139 | ||
140 | /***************************************************************************/ | 140 | /***************************************************************************/ |
141 | #ifndef CONFIG_PPC_CPM_NEW_BINDING | ||
142 | int fs_enet_mdio_bb_init(void); | ||
143 | int fs_enet_mdio_fec_init(void); | ||
144 | #endif | ||
145 | 141 | ||
146 | void fs_init_bds(struct net_device *dev); | 142 | void fs_init_bds(struct net_device *dev); |
147 | void fs_cleanup_bds(struct net_device *dev); | 143 | void fs_cleanup_bds(struct net_device *dev); |
diff --git a/drivers/net/fs_enet/mac-fcc.c b/drivers/net/fs_enet/mac-fcc.c index 8268b3535b30..0a97fc2d97ec 100644 --- a/drivers/net/fs_enet/mac-fcc.c +++ b/drivers/net/fs_enet/mac-fcc.c | |||
@@ -33,6 +33,7 @@ | |||
33 | #include <linux/fs.h> | 33 | #include <linux/fs.h> |
34 | #include <linux/platform_device.h> | 34 | #include <linux/platform_device.h> |
35 | #include <linux/phy.h> | 35 | #include <linux/phy.h> |
36 | #include <linux/of_device.h> | ||
36 | 37 | ||
37 | #include <asm/immap_cpm2.h> | 38 | #include <asm/immap_cpm2.h> |
38 | #include <asm/mpc8260.h> | 39 | #include <asm/mpc8260.h> |
@@ -42,10 +43,6 @@ | |||
42 | #include <asm/irq.h> | 43 | #include <asm/irq.h> |
43 | #include <asm/uaccess.h> | 44 | #include <asm/uaccess.h> |
44 | 45 | ||
45 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
46 | #include <asm/of_device.h> | ||
47 | #endif | ||
48 | |||
49 | #include "fs_enet.h" | 46 | #include "fs_enet.h" |
50 | 47 | ||
51 | /*************************************************/ | 48 | /*************************************************/ |
@@ -87,7 +84,6 @@ static inline int fcc_cr_cmd(struct fs_enet_private *fep, u32 op) | |||
87 | 84 | ||
88 | static int do_pd_setup(struct fs_enet_private *fep) | 85 | static int do_pd_setup(struct fs_enet_private *fep) |
89 | { | 86 | { |
90 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
91 | struct of_device *ofdev = to_of_device(fep->dev); | 87 | struct of_device *ofdev = to_of_device(fep->dev); |
92 | struct fs_platform_info *fpi = fep->fpi; | 88 | struct fs_platform_info *fpi = fep->fpi; |
93 | int ret = -EINVAL; | 89 | int ret = -EINVAL; |
@@ -125,44 +121,6 @@ out_fccp: | |||
125 | iounmap(fep->fcc.fccp); | 121 | iounmap(fep->fcc.fccp); |
126 | out: | 122 | out: |
127 | return ret; | 123 | return ret; |
128 | #else | ||
129 | struct platform_device *pdev = to_platform_device(fep->dev); | ||
130 | struct resource *r; | ||
131 | |||
132 | /* Fill out IRQ field */ | ||
133 | fep->interrupt = platform_get_irq(pdev, 0); | ||
134 | if (fep->interrupt < 0) | ||
135 | return -EINVAL; | ||
136 | |||
137 | /* Attach the memory for the FCC Parameter RAM */ | ||
138 | r = platform_get_resource_byname(pdev, IORESOURCE_MEM, "fcc_pram"); | ||
139 | fep->fcc.ep = ioremap(r->start, r->end - r->start + 1); | ||
140 | if (fep->fcc.ep == NULL) | ||
141 | return -EINVAL; | ||
142 | |||
143 | r = platform_get_resource_byname(pdev, IORESOURCE_MEM, "fcc_regs"); | ||
144 | fep->fcc.fccp = ioremap(r->start, r->end - r->start + 1); | ||
145 | if (fep->fcc.fccp == NULL) | ||
146 | return -EINVAL; | ||
147 | |||
148 | if (fep->fpi->fcc_regs_c) { | ||
149 | fep->fcc.fcccp = (void __iomem *)fep->fpi->fcc_regs_c; | ||
150 | } else { | ||
151 | r = platform_get_resource_byname(pdev, IORESOURCE_MEM, | ||
152 | "fcc_regs_c"); | ||
153 | fep->fcc.fcccp = ioremap(r->start, | ||
154 | r->end - r->start + 1); | ||
155 | } | ||
156 | |||
157 | if (fep->fcc.fcccp == NULL) | ||
158 | return -EINVAL; | ||
159 | |||
160 | fep->fcc.mem = (void __iomem *)fep->fpi->mem_offset; | ||
161 | if (fep->fcc.mem == NULL) | ||
162 | return -EINVAL; | ||
163 | |||
164 | return 0; | ||
165 | #endif | ||
166 | } | 124 | } |
167 | 125 | ||
168 | #define FCC_NAPI_RX_EVENT_MSK (FCC_ENET_RXF | FCC_ENET_RXB) | 126 | #define FCC_NAPI_RX_EVENT_MSK (FCC_ENET_RXF | FCC_ENET_RXB) |
@@ -173,17 +131,6 @@ out: | |||
173 | static int setup_data(struct net_device *dev) | 131 | static int setup_data(struct net_device *dev) |
174 | { | 132 | { |
175 | struct fs_enet_private *fep = netdev_priv(dev); | 133 | struct fs_enet_private *fep = netdev_priv(dev); |
176 | #ifndef CONFIG_PPC_CPM_NEW_BINDING | ||
177 | struct fs_platform_info *fpi = fep->fpi; | ||
178 | |||
179 | fpi->cp_command = (fpi->cp_page << 26) | | ||
180 | (fpi->cp_block << 21) | | ||
181 | (12 << 6); | ||
182 | |||
183 | fep->fcc.idx = fs_get_fcc_index(fpi->fs_no); | ||
184 | if ((unsigned int)fep->fcc.idx >= 3) /* max 3 FCCs */ | ||
185 | return -EINVAL; | ||
186 | #endif | ||
187 | 134 | ||
188 | if (do_pd_setup(fep) != 0) | 135 | if (do_pd_setup(fep) != 0) |
189 | return -EINVAL; | 136 | return -EINVAL; |
@@ -304,9 +251,6 @@ static void restart(struct net_device *dev) | |||
304 | fcc_enet_t __iomem *ep = fep->fcc.ep; | 251 | fcc_enet_t __iomem *ep = fep->fcc.ep; |
305 | dma_addr_t rx_bd_base_phys, tx_bd_base_phys; | 252 | dma_addr_t rx_bd_base_phys, tx_bd_base_phys; |
306 | u16 paddrh, paddrm, paddrl; | 253 | u16 paddrh, paddrm, paddrl; |
307 | #ifndef CONFIG_PPC_CPM_NEW_BINDING | ||
308 | u16 mem_addr; | ||
309 | #endif | ||
310 | const unsigned char *mac; | 254 | const unsigned char *mac; |
311 | int i; | 255 | int i; |
312 | 256 | ||
@@ -338,19 +282,10 @@ static void restart(struct net_device *dev) | |||
338 | * this area. | 282 | * this area. |
339 | */ | 283 | */ |
340 | 284 | ||
341 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
342 | W16(ep, fen_genfcc.fcc_riptr, fpi->dpram_offset); | 285 | W16(ep, fen_genfcc.fcc_riptr, fpi->dpram_offset); |
343 | W16(ep, fen_genfcc.fcc_tiptr, fpi->dpram_offset + 32); | 286 | W16(ep, fen_genfcc.fcc_tiptr, fpi->dpram_offset + 32); |
344 | 287 | ||
345 | W16(ep, fen_padptr, fpi->dpram_offset + 64); | 288 | W16(ep, fen_padptr, fpi->dpram_offset + 64); |
346 | #else | ||
347 | mem_addr = (u32) fep->fcc.mem; /* de-fixup dpram offset */ | ||
348 | |||
349 | W16(ep, fen_genfcc.fcc_riptr, (mem_addr & 0xffff)); | ||
350 | W16(ep, fen_genfcc.fcc_tiptr, ((mem_addr + 32) & 0xffff)); | ||
351 | |||
352 | W16(ep, fen_padptr, mem_addr + 64); | ||
353 | #endif | ||
354 | 289 | ||
355 | /* fill with special symbol... */ | 290 | /* fill with special symbol... */ |
356 | memset_io(fep->fcc.mem + fpi->dpram_offset + 64, 0x88, 32); | 291 | memset_io(fep->fcc.mem + fpi->dpram_offset + 64, 0x88, 32); |
diff --git a/drivers/net/fs_enet/mac-fec.c b/drivers/net/fs_enet/mac-fec.c index 8a311d1e435b..0a7d1c5c6524 100644 --- a/drivers/net/fs_enet/mac-fec.c +++ b/drivers/net/fs_enet/mac-fec.c | |||
@@ -32,6 +32,7 @@ | |||
32 | #include <linux/bitops.h> | 32 | #include <linux/bitops.h> |
33 | #include <linux/fs.h> | 33 | #include <linux/fs.h> |
34 | #include <linux/platform_device.h> | 34 | #include <linux/platform_device.h> |
35 | #include <linux/of_device.h> | ||
35 | 36 | ||
36 | #include <asm/irq.h> | 37 | #include <asm/irq.h> |
37 | #include <asm/uaccess.h> | 38 | #include <asm/uaccess.h> |
@@ -43,10 +44,6 @@ | |||
43 | #include <asm/cpm1.h> | 44 | #include <asm/cpm1.h> |
44 | #endif | 45 | #endif |
45 | 46 | ||
46 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
47 | #include <asm/of_device.h> | ||
48 | #endif | ||
49 | |||
50 | #include "fs_enet.h" | 47 | #include "fs_enet.h" |
51 | #include "fec.h" | 48 | #include "fec.h" |
52 | 49 | ||
@@ -99,7 +96,6 @@ static int whack_reset(fec_t __iomem *fecp) | |||
99 | 96 | ||
100 | static int do_pd_setup(struct fs_enet_private *fep) | 97 | static int do_pd_setup(struct fs_enet_private *fep) |
101 | { | 98 | { |
102 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
103 | struct of_device *ofdev = to_of_device(fep->dev); | 99 | struct of_device *ofdev = to_of_device(fep->dev); |
104 | 100 | ||
105 | fep->interrupt = of_irq_to_resource(ofdev->node, 0, NULL); | 101 | fep->interrupt = of_irq_to_resource(ofdev->node, 0, NULL); |
@@ -111,23 +107,6 @@ static int do_pd_setup(struct fs_enet_private *fep) | |||
111 | return -EINVAL; | 107 | return -EINVAL; |
112 | 108 | ||
113 | return 0; | 109 | return 0; |
114 | #else | ||
115 | struct platform_device *pdev = to_platform_device(fep->dev); | ||
116 | struct resource *r; | ||
117 | |||
118 | /* Fill out IRQ field */ | ||
119 | fep->interrupt = platform_get_irq_byname(pdev,"interrupt"); | ||
120 | if (fep->interrupt < 0) | ||
121 | return -EINVAL; | ||
122 | |||
123 | r = platform_get_resource_byname(pdev, IORESOURCE_MEM, "regs"); | ||
124 | fep->fec.fecp = ioremap(r->start, r->end - r->start + 1); | ||
125 | |||
126 | if(fep->fec.fecp == NULL) | ||
127 | return -EINVAL; | ||
128 | |||
129 | return 0; | ||
130 | #endif | ||
131 | } | 110 | } |
132 | 111 | ||
133 | #define FEC_NAPI_RX_EVENT_MSK (FEC_ENET_RXF | FEC_ENET_RXB) | 112 | #define FEC_NAPI_RX_EVENT_MSK (FEC_ENET_RXF | FEC_ENET_RXB) |
diff --git a/drivers/net/fs_enet/mac-scc.c b/drivers/net/fs_enet/mac-scc.c index e3557eca7b6d..029b3c7ef29c 100644 --- a/drivers/net/fs_enet/mac-scc.c +++ b/drivers/net/fs_enet/mac-scc.c | |||
@@ -32,6 +32,7 @@ | |||
32 | #include <linux/bitops.h> | 32 | #include <linux/bitops.h> |
33 | #include <linux/fs.h> | 33 | #include <linux/fs.h> |
34 | #include <linux/platform_device.h> | 34 | #include <linux/platform_device.h> |
35 | #include <linux/of_platform.h> | ||
35 | 36 | ||
36 | #include <asm/irq.h> | 37 | #include <asm/irq.h> |
37 | #include <asm/uaccess.h> | 38 | #include <asm/uaccess.h> |
@@ -43,10 +44,6 @@ | |||
43 | #include <asm/cpm1.h> | 44 | #include <asm/cpm1.h> |
44 | #endif | 45 | #endif |
45 | 46 | ||
46 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
47 | #include <linux/of_platform.h> | ||
48 | #endif | ||
49 | |||
50 | #include "fs_enet.h" | 47 | #include "fs_enet.h" |
51 | 48 | ||
52 | /*************************************************/ | 49 | /*************************************************/ |
@@ -99,7 +96,6 @@ static inline int scc_cr_cmd(struct fs_enet_private *fep, u32 op) | |||
99 | 96 | ||
100 | static int do_pd_setup(struct fs_enet_private *fep) | 97 | static int do_pd_setup(struct fs_enet_private *fep) |
101 | { | 98 | { |
102 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
103 | struct of_device *ofdev = to_of_device(fep->dev); | 99 | struct of_device *ofdev = to_of_device(fep->dev); |
104 | 100 | ||
105 | fep->interrupt = of_irq_to_resource(ofdev->node, 0, NULL); | 101 | fep->interrupt = of_irq_to_resource(ofdev->node, 0, NULL); |
@@ -115,27 +111,6 @@ static int do_pd_setup(struct fs_enet_private *fep) | |||
115 | iounmap(fep->scc.sccp); | 111 | iounmap(fep->scc.sccp); |
116 | return -EINVAL; | 112 | return -EINVAL; |
117 | } | 113 | } |
118 | #else | ||
119 | struct platform_device *pdev = to_platform_device(fep->dev); | ||
120 | struct resource *r; | ||
121 | |||
122 | /* Fill out IRQ field */ | ||
123 | fep->interrupt = platform_get_irq_byname(pdev, "interrupt"); | ||
124 | if (fep->interrupt < 0) | ||
125 | return -EINVAL; | ||
126 | |||
127 | r = platform_get_resource_byname(pdev, IORESOURCE_MEM, "regs"); | ||
128 | fep->scc.sccp = ioremap(r->start, r->end - r->start + 1); | ||
129 | |||
130 | if (fep->scc.sccp == NULL) | ||
131 | return -EINVAL; | ||
132 | |||
133 | r = platform_get_resource_byname(pdev, IORESOURCE_MEM, "pram"); | ||
134 | fep->scc.ep = ioremap(r->start, r->end - r->start + 1); | ||
135 | |||
136 | if (fep->scc.ep == NULL) | ||
137 | return -EINVAL; | ||
138 | #endif | ||
139 | 114 | ||
140 | return 0; | 115 | return 0; |
141 | } | 116 | } |
@@ -149,16 +124,6 @@ static int setup_data(struct net_device *dev) | |||
149 | { | 124 | { |
150 | struct fs_enet_private *fep = netdev_priv(dev); | 125 | struct fs_enet_private *fep = netdev_priv(dev); |
151 | 126 | ||
152 | #ifndef CONFIG_PPC_CPM_NEW_BINDING | ||
153 | struct fs_platform_info *fpi = fep->fpi; | ||
154 | |||
155 | fep->scc.idx = fs_get_scc_index(fpi->fs_no); | ||
156 | if ((unsigned int)fep->fcc.idx >= 4) /* max 4 SCCs */ | ||
157 | return -EINVAL; | ||
158 | |||
159 | fpi->cp_command = fep->fcc.idx << 6; | ||
160 | #endif | ||
161 | |||
162 | do_pd_setup(fep); | 127 | do_pd_setup(fep); |
163 | 128 | ||
164 | fep->scc.hthi = 0; | 129 | fep->scc.hthi = 0; |
diff --git a/drivers/net/fs_enet/mii-bitbang.c b/drivers/net/fs_enet/mii-bitbang.c index 1620030cd33c..be4b72f4f49a 100644 --- a/drivers/net/fs_enet/mii-bitbang.c +++ b/drivers/net/fs_enet/mii-bitbang.c | |||
@@ -22,10 +22,7 @@ | |||
22 | #include <linux/mii.h> | 22 | #include <linux/mii.h> |
23 | #include <linux/platform_device.h> | 23 | #include <linux/platform_device.h> |
24 | #include <linux/mdio-bitbang.h> | 24 | #include <linux/mdio-bitbang.h> |
25 | |||
26 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
27 | #include <linux/of_platform.h> | 25 | #include <linux/of_platform.h> |
28 | #endif | ||
29 | 26 | ||
30 | #include "fs_enet.h" | 27 | #include "fs_enet.h" |
31 | 28 | ||
@@ -110,7 +107,6 @@ static struct mdiobb_ops bb_ops = { | |||
110 | .get_mdio_data = mdio_read, | 107 | .get_mdio_data = mdio_read, |
111 | }; | 108 | }; |
112 | 109 | ||
113 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
114 | static int __devinit fs_mii_bitbang_init(struct mii_bus *bus, | 110 | static int __devinit fs_mii_bitbang_init(struct mii_bus *bus, |
115 | struct device_node *np) | 111 | struct device_node *np) |
116 | { | 112 | { |
@@ -271,106 +267,3 @@ static void fs_enet_mdio_bb_exit(void) | |||
271 | 267 | ||
272 | module_init(fs_enet_mdio_bb_init); | 268 | module_init(fs_enet_mdio_bb_init); |
273 | module_exit(fs_enet_mdio_bb_exit); | 269 | module_exit(fs_enet_mdio_bb_exit); |
274 | #else | ||
275 | static int __devinit fs_mii_bitbang_init(struct bb_info *bitbang, | ||
276 | struct fs_mii_bb_platform_info *fmpi) | ||
277 | { | ||
278 | bitbang->dir = (u32 __iomem *)fmpi->mdio_dir.offset; | ||
279 | bitbang->dat = (u32 __iomem *)fmpi->mdio_dat.offset; | ||
280 | bitbang->mdio_msk = 1U << (31 - fmpi->mdio_dat.bit); | ||
281 | bitbang->mdc_msk = 1U << (31 - fmpi->mdc_dat.bit); | ||
282 | |||
283 | return 0; | ||
284 | } | ||
285 | |||
286 | static int __devinit fs_enet_mdio_probe(struct device *dev) | ||
287 | { | ||
288 | struct platform_device *pdev = to_platform_device(dev); | ||
289 | struct fs_mii_bb_platform_info *pdata; | ||
290 | struct mii_bus *new_bus; | ||
291 | struct bb_info *bitbang; | ||
292 | int err = 0; | ||
293 | |||
294 | if (NULL == dev) | ||
295 | return -EINVAL; | ||
296 | |||
297 | bitbang = kzalloc(sizeof(struct bb_info), GFP_KERNEL); | ||
298 | |||
299 | if (NULL == bitbang) | ||
300 | return -ENOMEM; | ||
301 | |||
302 | bitbang->ctrl.ops = &bb_ops; | ||
303 | |||
304 | new_bus = alloc_mdio_bitbang(&bitbang->ctrl); | ||
305 | |||
306 | if (NULL == new_bus) | ||
307 | return -ENOMEM; | ||
308 | |||
309 | new_bus->name = "BB MII Bus", | ||
310 | snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", pdev->id); | ||
311 | |||
312 | new_bus->phy_mask = ~0x9; | ||
313 | pdata = (struct fs_mii_bb_platform_info *)pdev->dev.platform_data; | ||
314 | |||
315 | if (NULL == pdata) { | ||
316 | printk(KERN_ERR "gfar mdio %d: Missing platform data!\n", pdev->id); | ||
317 | return -ENODEV; | ||
318 | } | ||
319 | |||
320 | /*set up workspace*/ | ||
321 | fs_mii_bitbang_init(bitbang, pdata); | ||
322 | |||
323 | new_bus->priv = bitbang; | ||
324 | |||
325 | new_bus->irq = pdata->irq; | ||
326 | |||
327 | new_bus->dev = dev; | ||
328 | dev_set_drvdata(dev, new_bus); | ||
329 | |||
330 | err = mdiobus_register(new_bus); | ||
331 | |||
332 | if (0 != err) { | ||
333 | printk (KERN_ERR "%s: Cannot register as MDIO bus\n", | ||
334 | new_bus->name); | ||
335 | goto bus_register_fail; | ||
336 | } | ||
337 | |||
338 | return 0; | ||
339 | |||
340 | bus_register_fail: | ||
341 | free_mdio_bitbang(new_bus); | ||
342 | kfree(bitbang); | ||
343 | |||
344 | return err; | ||
345 | } | ||
346 | |||
347 | static int fs_enet_mdio_remove(struct device *dev) | ||
348 | { | ||
349 | struct mii_bus *bus = dev_get_drvdata(dev); | ||
350 | |||
351 | mdiobus_unregister(bus); | ||
352 | |||
353 | dev_set_drvdata(dev, NULL); | ||
354 | |||
355 | free_mdio_bitbang(bus); | ||
356 | |||
357 | return 0; | ||
358 | } | ||
359 | |||
360 | static struct device_driver fs_enet_bb_mdio_driver = { | ||
361 | .name = "fsl-bb-mdio", | ||
362 | .bus = &platform_bus_type, | ||
363 | .probe = fs_enet_mdio_probe, | ||
364 | .remove = fs_enet_mdio_remove, | ||
365 | }; | ||
366 | |||
367 | int fs_enet_mdio_bb_init(void) | ||
368 | { | ||
369 | return driver_register(&fs_enet_bb_mdio_driver); | ||
370 | } | ||
371 | |||
372 | void fs_enet_mdio_bb_exit(void) | ||
373 | { | ||
374 | driver_unregister(&fs_enet_bb_mdio_driver); | ||
375 | } | ||
376 | #endif | ||
diff --git a/drivers/net/fs_enet/mii-fec.c b/drivers/net/fs_enet/mii-fec.c index 8f6a43b0e0ff..695f74cc4398 100644 --- a/drivers/net/fs_enet/mii-fec.c +++ b/drivers/net/fs_enet/mii-fec.c | |||
@@ -31,15 +31,12 @@ | |||
31 | #include <linux/ethtool.h> | 31 | #include <linux/ethtool.h> |
32 | #include <linux/bitops.h> | 32 | #include <linux/bitops.h> |
33 | #include <linux/platform_device.h> | 33 | #include <linux/platform_device.h> |
34 | #include <linux/of_platform.h> | ||
34 | 35 | ||
35 | #include <asm/pgtable.h> | 36 | #include <asm/pgtable.h> |
36 | #include <asm/irq.h> | 37 | #include <asm/irq.h> |
37 | #include <asm/uaccess.h> | 38 | #include <asm/uaccess.h> |
38 | 39 | ||
39 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
40 | #include <linux/of_platform.h> | ||
41 | #endif | ||
42 | |||
43 | #include "fs_enet.h" | 40 | #include "fs_enet.h" |
44 | #include "fec.h" | 41 | #include "fec.h" |
45 | 42 | ||
@@ -51,52 +48,6 @@ | |||
51 | 48 | ||
52 | #define FEC_MII_LOOPS 10000 | 49 | #define FEC_MII_LOOPS 10000 |
53 | 50 | ||
54 | #ifndef CONFIG_PPC_CPM_NEW_BINDING | ||
55 | static int match_has_phy (struct device *dev, void* data) | ||
56 | { | ||
57 | struct platform_device* pdev = container_of(dev, struct platform_device, dev); | ||
58 | struct fs_platform_info* fpi; | ||
59 | if(strcmp(pdev->name, (char*)data)) | ||
60 | { | ||
61 | return 0; | ||
62 | } | ||
63 | |||
64 | fpi = pdev->dev.platform_data; | ||
65 | if((fpi)&&(fpi->has_phy)) | ||
66 | return 1; | ||
67 | return 0; | ||
68 | } | ||
69 | |||
70 | static int fs_mii_fec_init(struct fec_info* fec, struct fs_mii_fec_platform_info *fmpi) | ||
71 | { | ||
72 | struct resource *r; | ||
73 | fec_t __iomem *fecp; | ||
74 | char* name = "fsl-cpm-fec"; | ||
75 | |||
76 | /* we need fec in order to be useful */ | ||
77 | struct platform_device *fec_pdev = | ||
78 | container_of(bus_find_device(&platform_bus_type, NULL, name, match_has_phy), | ||
79 | struct platform_device, dev); | ||
80 | |||
81 | if(fec_pdev == NULL) { | ||
82 | printk(KERN_ERR"Unable to find PHY for %s", name); | ||
83 | return -ENODEV; | ||
84 | } | ||
85 | |||
86 | r = platform_get_resource_byname(fec_pdev, IORESOURCE_MEM, "regs"); | ||
87 | |||
88 | fec->fecp = fecp = ioremap(r->start,sizeof(fec_t)); | ||
89 | fec->mii_speed = fmpi->mii_speed; | ||
90 | |||
91 | setbits32(&fecp->fec_r_cntrl, FEC_RCNTRL_MII_MODE); /* MII enable */ | ||
92 | setbits32(&fecp->fec_ecntrl, FEC_ECNTRL_PINMUX | FEC_ECNTRL_ETHER_EN); | ||
93 | out_be32(&fecp->fec_ievent, FEC_ENET_MII); | ||
94 | out_be32(&fecp->fec_mii_speed, fec->mii_speed); | ||
95 | |||
96 | return 0; | ||
97 | } | ||
98 | #endif | ||
99 | |||
100 | static int fs_enet_fec_mii_read(struct mii_bus *bus , int phy_id, int location) | 51 | static int fs_enet_fec_mii_read(struct mii_bus *bus , int phy_id, int location) |
101 | { | 52 | { |
102 | struct fec_info* fec = bus->priv; | 53 | struct fec_info* fec = bus->priv; |
@@ -151,7 +102,6 @@ static int fs_enet_fec_mii_reset(struct mii_bus *bus) | |||
151 | return 0; | 102 | return 0; |
152 | } | 103 | } |
153 | 104 | ||
154 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
155 | static void __devinit add_phy(struct mii_bus *bus, struct device_node *np) | 105 | static void __devinit add_phy(struct mii_bus *bus, struct device_node *np) |
156 | { | 106 | { |
157 | const u32 *data; | 107 | const u32 *data; |
@@ -286,95 +236,3 @@ static void fs_enet_mdio_fec_exit(void) | |||
286 | 236 | ||
287 | module_init(fs_enet_mdio_fec_init); | 237 | module_init(fs_enet_mdio_fec_init); |
288 | module_exit(fs_enet_mdio_fec_exit); | 238 | module_exit(fs_enet_mdio_fec_exit); |
289 | #else | ||
290 | static int __devinit fs_enet_fec_mdio_probe(struct device *dev) | ||
291 | { | ||
292 | struct platform_device *pdev = to_platform_device(dev); | ||
293 | struct fs_mii_fec_platform_info *pdata; | ||
294 | struct mii_bus *new_bus; | ||
295 | struct fec_info *fec; | ||
296 | int err = 0; | ||
297 | if (NULL == dev) | ||
298 | return -EINVAL; | ||
299 | new_bus = kzalloc(sizeof(struct mii_bus), GFP_KERNEL); | ||
300 | |||
301 | if (NULL == new_bus) | ||
302 | return -ENOMEM; | ||
303 | |||
304 | fec = kzalloc(sizeof(struct fec_info), GFP_KERNEL); | ||
305 | |||
306 | if (NULL == fec) | ||
307 | return -ENOMEM; | ||
308 | |||
309 | new_bus->name = "FEC MII Bus", | ||
310 | new_bus->read = &fs_enet_fec_mii_read, | ||
311 | new_bus->write = &fs_enet_fec_mii_write, | ||
312 | new_bus->reset = &fs_enet_fec_mii_reset, | ||
313 | snprintf(new_bus->id, MII_BUS_ID_SIZE, "%x", pdev->id); | ||
314 | |||
315 | pdata = (struct fs_mii_fec_platform_info *)pdev->dev.platform_data; | ||
316 | |||
317 | if (NULL == pdata) { | ||
318 | printk(KERN_ERR "fs_enet FEC mdio %d: Missing platform data!\n", pdev->id); | ||
319 | return -ENODEV; | ||
320 | } | ||
321 | |||
322 | /*set up workspace*/ | ||
323 | |||
324 | fs_mii_fec_init(fec, pdata); | ||
325 | new_bus->priv = fec; | ||
326 | |||
327 | new_bus->irq = pdata->irq; | ||
328 | |||
329 | new_bus->dev = dev; | ||
330 | dev_set_drvdata(dev, new_bus); | ||
331 | |||
332 | err = mdiobus_register(new_bus); | ||
333 | |||
334 | if (0 != err) { | ||
335 | printk (KERN_ERR "%s: Cannot register as MDIO bus\n", | ||
336 | new_bus->name); | ||
337 | goto bus_register_fail; | ||
338 | } | ||
339 | |||
340 | return 0; | ||
341 | |||
342 | bus_register_fail: | ||
343 | kfree(new_bus); | ||
344 | |||
345 | return err; | ||
346 | } | ||
347 | |||
348 | |||
349 | static int fs_enet_fec_mdio_remove(struct device *dev) | ||
350 | { | ||
351 | struct mii_bus *bus = dev_get_drvdata(dev); | ||
352 | |||
353 | mdiobus_unregister(bus); | ||
354 | |||
355 | dev_set_drvdata(dev, NULL); | ||
356 | kfree(bus->priv); | ||
357 | |||
358 | bus->priv = NULL; | ||
359 | kfree(bus); | ||
360 | |||
361 | return 0; | ||
362 | } | ||
363 | |||
364 | static struct device_driver fs_enet_fec_mdio_driver = { | ||
365 | .name = "fsl-cpm-fec-mdio", | ||
366 | .bus = &platform_bus_type, | ||
367 | .probe = fs_enet_fec_mdio_probe, | ||
368 | .remove = fs_enet_fec_mdio_remove, | ||
369 | }; | ||
370 | |||
371 | int fs_enet_mdio_fec_init(void) | ||
372 | { | ||
373 | return driver_register(&fs_enet_fec_mdio_driver); | ||
374 | } | ||
375 | |||
376 | void fs_enet_mdio_fec_exit(void) | ||
377 | { | ||
378 | driver_unregister(&fs_enet_fec_mdio_driver); | ||
379 | } | ||
380 | #endif | ||
diff --git a/drivers/net/gianfar.c b/drivers/net/gianfar.c index 39b45e901be6..b8394cf134e8 100644 --- a/drivers/net/gianfar.c +++ b/drivers/net/gianfar.c | |||
@@ -134,6 +134,9 @@ static int gfar_process_frame(struct net_device *dev, struct sk_buff *skb, int l | |||
134 | static void gfar_vlan_rx_register(struct net_device *netdev, | 134 | static void gfar_vlan_rx_register(struct net_device *netdev, |
135 | struct vlan_group *grp); | 135 | struct vlan_group *grp); |
136 | void gfar_halt(struct net_device *dev); | 136 | void gfar_halt(struct net_device *dev); |
137 | #ifdef CONFIG_PM | ||
138 | static void gfar_halt_nodisable(struct net_device *dev); | ||
139 | #endif | ||
137 | void gfar_start(struct net_device *dev); | 140 | void gfar_start(struct net_device *dev); |
138 | static void gfar_clear_exact_match(struct net_device *dev); | 141 | static void gfar_clear_exact_match(struct net_device *dev); |
139 | static void gfar_set_mac_for_addr(struct net_device *dev, int num, u8 *addr); | 142 | static void gfar_set_mac_for_addr(struct net_device *dev, int num, u8 *addr); |
@@ -207,6 +210,7 @@ static int gfar_probe(struct platform_device *pdev) | |||
207 | 210 | ||
208 | spin_lock_init(&priv->txlock); | 211 | spin_lock_init(&priv->txlock); |
209 | spin_lock_init(&priv->rxlock); | 212 | spin_lock_init(&priv->rxlock); |
213 | spin_lock_init(&priv->bflock); | ||
210 | 214 | ||
211 | platform_set_drvdata(pdev, dev); | 215 | platform_set_drvdata(pdev, dev); |
212 | 216 | ||
@@ -378,6 +382,103 @@ static int gfar_remove(struct platform_device *pdev) | |||
378 | return 0; | 382 | return 0; |
379 | } | 383 | } |
380 | 384 | ||
385 | #ifdef CONFIG_PM | ||
386 | static int gfar_suspend(struct platform_device *pdev, pm_message_t state) | ||
387 | { | ||
388 | struct net_device *dev = platform_get_drvdata(pdev); | ||
389 | struct gfar_private *priv = netdev_priv(dev); | ||
390 | unsigned long flags; | ||
391 | u32 tempval; | ||
392 | |||
393 | int magic_packet = priv->wol_en && | ||
394 | (priv->einfo->device_flags & FSL_GIANFAR_DEV_HAS_MAGIC_PACKET); | ||
395 | |||
396 | netif_device_detach(dev); | ||
397 | |||
398 | if (netif_running(dev)) { | ||
399 | spin_lock_irqsave(&priv->txlock, flags); | ||
400 | spin_lock(&priv->rxlock); | ||
401 | |||
402 | gfar_halt_nodisable(dev); | ||
403 | |||
404 | /* Disable Tx, and Rx if wake-on-LAN is disabled. */ | ||
405 | tempval = gfar_read(&priv->regs->maccfg1); | ||
406 | |||
407 | tempval &= ~MACCFG1_TX_EN; | ||
408 | |||
409 | if (!magic_packet) | ||
410 | tempval &= ~MACCFG1_RX_EN; | ||
411 | |||
412 | gfar_write(&priv->regs->maccfg1, tempval); | ||
413 | |||
414 | spin_unlock(&priv->rxlock); | ||
415 | spin_unlock_irqrestore(&priv->txlock, flags); | ||
416 | |||
417 | #ifdef CONFIG_GFAR_NAPI | ||
418 | napi_disable(&priv->napi); | ||
419 | #endif | ||
420 | |||
421 | if (magic_packet) { | ||
422 | /* Enable interrupt on Magic Packet */ | ||
423 | gfar_write(&priv->regs->imask, IMASK_MAG); | ||
424 | |||
425 | /* Enable Magic Packet mode */ | ||
426 | tempval = gfar_read(&priv->regs->maccfg2); | ||
427 | tempval |= MACCFG2_MPEN; | ||
428 | gfar_write(&priv->regs->maccfg2, tempval); | ||
429 | } else { | ||
430 | phy_stop(priv->phydev); | ||
431 | } | ||
432 | } | ||
433 | |||
434 | return 0; | ||
435 | } | ||
436 | |||
437 | static int gfar_resume(struct platform_device *pdev) | ||
438 | { | ||
439 | struct net_device *dev = platform_get_drvdata(pdev); | ||
440 | struct gfar_private *priv = netdev_priv(dev); | ||
441 | unsigned long flags; | ||
442 | u32 tempval; | ||
443 | int magic_packet = priv->wol_en && | ||
444 | (priv->einfo->device_flags & FSL_GIANFAR_DEV_HAS_MAGIC_PACKET); | ||
445 | |||
446 | if (!netif_running(dev)) { | ||
447 | netif_device_attach(dev); | ||
448 | return 0; | ||
449 | } | ||
450 | |||
451 | if (!magic_packet && priv->phydev) | ||
452 | phy_start(priv->phydev); | ||
453 | |||
454 | /* Disable Magic Packet mode, in case something | ||
455 | * else woke us up. | ||
456 | */ | ||
457 | |||
458 | spin_lock_irqsave(&priv->txlock, flags); | ||
459 | spin_lock(&priv->rxlock); | ||
460 | |||
461 | tempval = gfar_read(&priv->regs->maccfg2); | ||
462 | tempval &= ~MACCFG2_MPEN; | ||
463 | gfar_write(&priv->regs->maccfg2, tempval); | ||
464 | |||
465 | gfar_start(dev); | ||
466 | |||
467 | spin_unlock(&priv->rxlock); | ||
468 | spin_unlock_irqrestore(&priv->txlock, flags); | ||
469 | |||
470 | netif_device_attach(dev); | ||
471 | |||
472 | #ifdef CONFIG_GFAR_NAPI | ||
473 | napi_enable(&priv->napi); | ||
474 | #endif | ||
475 | |||
476 | return 0; | ||
477 | } | ||
478 | #else | ||
479 | #define gfar_suspend NULL | ||
480 | #define gfar_resume NULL | ||
481 | #endif | ||
381 | 482 | ||
382 | /* Reads the controller's registers to determine what interface | 483 | /* Reads the controller's registers to determine what interface |
383 | * connects it to the PHY. | 484 | * connects it to the PHY. |
@@ -534,8 +635,9 @@ static void init_registers(struct net_device *dev) | |||
534 | } | 635 | } |
535 | 636 | ||
536 | 637 | ||
638 | #ifdef CONFIG_PM | ||
537 | /* Halt the receive and transmit queues */ | 639 | /* Halt the receive and transmit queues */ |
538 | void gfar_halt(struct net_device *dev) | 640 | static void gfar_halt_nodisable(struct net_device *dev) |
539 | { | 641 | { |
540 | struct gfar_private *priv = netdev_priv(dev); | 642 | struct gfar_private *priv = netdev_priv(dev); |
541 | struct gfar __iomem *regs = priv->regs; | 643 | struct gfar __iomem *regs = priv->regs; |
@@ -558,6 +660,15 @@ void gfar_halt(struct net_device *dev) | |||
558 | (IEVENT_GRSC | IEVENT_GTSC))) | 660 | (IEVENT_GRSC | IEVENT_GTSC))) |
559 | cpu_relax(); | 661 | cpu_relax(); |
560 | } | 662 | } |
663 | } | ||
664 | #endif | ||
665 | |||
666 | /* Halt the receive and transmit queues */ | ||
667 | void gfar_halt(struct net_device *dev) | ||
668 | { | ||
669 | struct gfar_private *priv = netdev_priv(dev); | ||
670 | struct gfar __iomem *regs = priv->regs; | ||
671 | u32 tempval; | ||
561 | 672 | ||
562 | /* Disable Rx and Tx */ | 673 | /* Disable Rx and Tx */ |
563 | tempval = gfar_read(®s->maccfg1); | 674 | tempval = gfar_read(®s->maccfg1); |
@@ -1909,7 +2020,12 @@ static irqreturn_t gfar_error(int irq, void *dev_id) | |||
1909 | u32 events = gfar_read(&priv->regs->ievent); | 2020 | u32 events = gfar_read(&priv->regs->ievent); |
1910 | 2021 | ||
1911 | /* Clear IEVENT */ | 2022 | /* Clear IEVENT */ |
1912 | gfar_write(&priv->regs->ievent, IEVENT_ERR_MASK); | 2023 | gfar_write(&priv->regs->ievent, events & IEVENT_ERR_MASK); |
2024 | |||
2025 | /* Magic Packet is not an error. */ | ||
2026 | if ((priv->einfo->device_flags & FSL_GIANFAR_DEV_HAS_MAGIC_PACKET) && | ||
2027 | (events & IEVENT_MAG)) | ||
2028 | events &= ~IEVENT_MAG; | ||
1913 | 2029 | ||
1914 | /* Hmm... */ | 2030 | /* Hmm... */ |
1915 | if (netif_msg_rx_err(priv) || netif_msg_tx_err(priv)) | 2031 | if (netif_msg_rx_err(priv) || netif_msg_tx_err(priv)) |
@@ -1977,6 +2093,8 @@ MODULE_ALIAS("platform:fsl-gianfar"); | |||
1977 | static struct platform_driver gfar_driver = { | 2093 | static struct platform_driver gfar_driver = { |
1978 | .probe = gfar_probe, | 2094 | .probe = gfar_probe, |
1979 | .remove = gfar_remove, | 2095 | .remove = gfar_remove, |
2096 | .suspend = gfar_suspend, | ||
2097 | .resume = gfar_resume, | ||
1980 | .driver = { | 2098 | .driver = { |
1981 | .name = "fsl-gianfar", | 2099 | .name = "fsl-gianfar", |
1982 | .owner = THIS_MODULE, | 2100 | .owner = THIS_MODULE, |
diff --git a/drivers/net/gianfar.h b/drivers/net/gianfar.h index bead71cb2b16..d59df98bd636 100644 --- a/drivers/net/gianfar.h +++ b/drivers/net/gianfar.h | |||
@@ -157,6 +157,7 @@ extern const char gfar_driver_version[]; | |||
157 | #define MACCFG2_GMII 0x00000200 | 157 | #define MACCFG2_GMII 0x00000200 |
158 | #define MACCFG2_HUGEFRAME 0x00000020 | 158 | #define MACCFG2_HUGEFRAME 0x00000020 |
159 | #define MACCFG2_LENGTHCHECK 0x00000010 | 159 | #define MACCFG2_LENGTHCHECK 0x00000010 |
160 | #define MACCFG2_MPEN 0x00000008 | ||
160 | 161 | ||
161 | #define ECNTRL_INIT_SETTINGS 0x00001000 | 162 | #define ECNTRL_INIT_SETTINGS 0x00001000 |
162 | #define ECNTRL_TBI_MODE 0x00000020 | 163 | #define ECNTRL_TBI_MODE 0x00000020 |
@@ -229,6 +230,7 @@ extern const char gfar_driver_version[]; | |||
229 | #define IEVENT_CRL 0x00020000 | 230 | #define IEVENT_CRL 0x00020000 |
230 | #define IEVENT_XFUN 0x00010000 | 231 | #define IEVENT_XFUN 0x00010000 |
231 | #define IEVENT_RXB0 0x00008000 | 232 | #define IEVENT_RXB0 0x00008000 |
233 | #define IEVENT_MAG 0x00000800 | ||
232 | #define IEVENT_GRSC 0x00000100 | 234 | #define IEVENT_GRSC 0x00000100 |
233 | #define IEVENT_RXF0 0x00000080 | 235 | #define IEVENT_RXF0 0x00000080 |
234 | #define IEVENT_FIR 0x00000008 | 236 | #define IEVENT_FIR 0x00000008 |
@@ -241,7 +243,8 @@ extern const char gfar_driver_version[]; | |||
241 | #define IEVENT_ERR_MASK \ | 243 | #define IEVENT_ERR_MASK \ |
242 | (IEVENT_RXC | IEVENT_BSY | IEVENT_EBERR | IEVENT_MSRO | \ | 244 | (IEVENT_RXC | IEVENT_BSY | IEVENT_EBERR | IEVENT_MSRO | \ |
243 | IEVENT_BABT | IEVENT_TXC | IEVENT_TXE | IEVENT_LC \ | 245 | IEVENT_BABT | IEVENT_TXC | IEVENT_TXE | IEVENT_LC \ |
244 | | IEVENT_CRL | IEVENT_XFUN | IEVENT_DPE | IEVENT_PERR) | 246 | | IEVENT_CRL | IEVENT_XFUN | IEVENT_DPE | IEVENT_PERR \ |
247 | | IEVENT_MAG) | ||
245 | 248 | ||
246 | #define IMASK_INIT_CLEAR 0x00000000 | 249 | #define IMASK_INIT_CLEAR 0x00000000 |
247 | #define IMASK_BABR 0x80000000 | 250 | #define IMASK_BABR 0x80000000 |
@@ -259,6 +262,7 @@ extern const char gfar_driver_version[]; | |||
259 | #define IMASK_CRL 0x00020000 | 262 | #define IMASK_CRL 0x00020000 |
260 | #define IMASK_XFUN 0x00010000 | 263 | #define IMASK_XFUN 0x00010000 |
261 | #define IMASK_RXB0 0x00008000 | 264 | #define IMASK_RXB0 0x00008000 |
265 | #define IMASK_MAG 0x00000800 | ||
262 | #define IMASK_GTSC 0x00000100 | 266 | #define IMASK_GTSC 0x00000100 |
263 | #define IMASK_RXFEN0 0x00000080 | 267 | #define IMASK_RXFEN0 0x00000080 |
264 | #define IMASK_FIR 0x00000008 | 268 | #define IMASK_FIR 0x00000008 |
@@ -726,10 +730,14 @@ struct gfar_private { | |||
726 | unsigned int fifo_starve; | 730 | unsigned int fifo_starve; |
727 | unsigned int fifo_starve_off; | 731 | unsigned int fifo_starve_off; |
728 | 732 | ||
733 | /* Bitfield update lock */ | ||
734 | spinlock_t bflock; | ||
735 | |||
729 | unsigned char vlan_enable:1, | 736 | unsigned char vlan_enable:1, |
730 | rx_csum_enable:1, | 737 | rx_csum_enable:1, |
731 | extended_hash:1, | 738 | extended_hash:1, |
732 | bd_stash_en:1; | 739 | bd_stash_en:1, |
740 | wol_en:1; /* Wake-on-LAN enabled */ | ||
733 | unsigned short padding; | 741 | unsigned short padding; |
734 | 742 | ||
735 | unsigned int interruptTransmit; | 743 | unsigned int interruptTransmit; |
diff --git a/drivers/net/gianfar_ethtool.c b/drivers/net/gianfar_ethtool.c index 6007147cc1e9..fb7d3ccc0fdc 100644 --- a/drivers/net/gianfar_ethtool.c +++ b/drivers/net/gianfar_ethtool.c | |||
@@ -479,14 +479,13 @@ static int gfar_sringparam(struct net_device *dev, struct ethtool_ringparam *rva | |||
479 | static int gfar_set_rx_csum(struct net_device *dev, uint32_t data) | 479 | static int gfar_set_rx_csum(struct net_device *dev, uint32_t data) |
480 | { | 480 | { |
481 | struct gfar_private *priv = netdev_priv(dev); | 481 | struct gfar_private *priv = netdev_priv(dev); |
482 | unsigned long flags; | ||
482 | int err = 0; | 483 | int err = 0; |
483 | 484 | ||
484 | if (!(priv->einfo->device_flags & FSL_GIANFAR_DEV_HAS_CSUM)) | 485 | if (!(priv->einfo->device_flags & FSL_GIANFAR_DEV_HAS_CSUM)) |
485 | return -EOPNOTSUPP; | 486 | return -EOPNOTSUPP; |
486 | 487 | ||
487 | if (dev->flags & IFF_UP) { | 488 | if (dev->flags & IFF_UP) { |
488 | unsigned long flags; | ||
489 | |||
490 | /* Halt TX and RX, and process the frames which | 489 | /* Halt TX and RX, and process the frames which |
491 | * have already been received */ | 490 | * have already been received */ |
492 | spin_lock_irqsave(&priv->txlock, flags); | 491 | spin_lock_irqsave(&priv->txlock, flags); |
@@ -502,7 +501,9 @@ static int gfar_set_rx_csum(struct net_device *dev, uint32_t data) | |||
502 | stop_gfar(dev); | 501 | stop_gfar(dev); |
503 | } | 502 | } |
504 | 503 | ||
504 | spin_lock_irqsave(&priv->bflock, flags); | ||
505 | priv->rx_csum_enable = data; | 505 | priv->rx_csum_enable = data; |
506 | spin_unlock_irqrestore(&priv->bflock, flags); | ||
506 | 507 | ||
507 | if (dev->flags & IFF_UP) | 508 | if (dev->flags & IFF_UP) |
508 | err = startup_gfar(dev); | 509 | err = startup_gfar(dev); |
@@ -564,6 +565,38 @@ static void gfar_set_msglevel(struct net_device *dev, uint32_t data) | |||
564 | priv->msg_enable = data; | 565 | priv->msg_enable = data; |
565 | } | 566 | } |
566 | 567 | ||
568 | #ifdef CONFIG_PM | ||
569 | static void gfar_get_wol(struct net_device *dev, struct ethtool_wolinfo *wol) | ||
570 | { | ||
571 | struct gfar_private *priv = netdev_priv(dev); | ||
572 | |||
573 | if (priv->einfo->device_flags & FSL_GIANFAR_DEV_HAS_MAGIC_PACKET) { | ||
574 | wol->supported = WAKE_MAGIC; | ||
575 | wol->wolopts = priv->wol_en ? WAKE_MAGIC : 0; | ||
576 | } else { | ||
577 | wol->supported = wol->wolopts = 0; | ||
578 | } | ||
579 | } | ||
580 | |||
581 | static int gfar_set_wol(struct net_device *dev, struct ethtool_wolinfo *wol) | ||
582 | { | ||
583 | struct gfar_private *priv = netdev_priv(dev); | ||
584 | unsigned long flags; | ||
585 | |||
586 | if (!(priv->einfo->device_flags & FSL_GIANFAR_DEV_HAS_MAGIC_PACKET) && | ||
587 | wol->wolopts != 0) | ||
588 | return -EINVAL; | ||
589 | |||
590 | if (wol->wolopts & ~WAKE_MAGIC) | ||
591 | return -EINVAL; | ||
592 | |||
593 | spin_lock_irqsave(&priv->bflock, flags); | ||
594 | priv->wol_en = wol->wolopts & WAKE_MAGIC ? 1 : 0; | ||
595 | spin_unlock_irqrestore(&priv->bflock, flags); | ||
596 | |||
597 | return 0; | ||
598 | } | ||
599 | #endif | ||
567 | 600 | ||
568 | const struct ethtool_ops gfar_ethtool_ops = { | 601 | const struct ethtool_ops gfar_ethtool_ops = { |
569 | .get_settings = gfar_gsettings, | 602 | .get_settings = gfar_gsettings, |
@@ -585,4 +618,8 @@ const struct ethtool_ops gfar_ethtool_ops = { | |||
585 | .set_tx_csum = gfar_set_tx_csum, | 618 | .set_tx_csum = gfar_set_tx_csum, |
586 | .get_msglevel = gfar_get_msglevel, | 619 | .get_msglevel = gfar_get_msglevel, |
587 | .set_msglevel = gfar_set_msglevel, | 620 | .set_msglevel = gfar_set_msglevel, |
621 | #ifdef CONFIG_PM | ||
622 | .get_wol = gfar_get_wol, | ||
623 | .set_wol = gfar_set_wol, | ||
624 | #endif | ||
588 | }; | 625 | }; |
diff --git a/drivers/video/offb.c b/drivers/video/offb.c index d7b3dcc0dc43..e1d9eeb1aeaf 100644 --- a/drivers/video/offb.c +++ b/drivers/video/offb.c | |||
@@ -47,6 +47,7 @@ enum { | |||
47 | cmap_M3B, /* ATI Rage Mobility M3 Head B */ | 47 | cmap_M3B, /* ATI Rage Mobility M3 Head B */ |
48 | cmap_radeon, /* ATI Radeon */ | 48 | cmap_radeon, /* ATI Radeon */ |
49 | cmap_gxt2000, /* IBM GXT2000 */ | 49 | cmap_gxt2000, /* IBM GXT2000 */ |
50 | cmap_avivo, /* ATI R5xx */ | ||
50 | }; | 51 | }; |
51 | 52 | ||
52 | struct offb_par { | 53 | struct offb_par { |
@@ -58,26 +59,36 @@ struct offb_par { | |||
58 | 59 | ||
59 | struct offb_par default_par; | 60 | struct offb_par default_par; |
60 | 61 | ||
61 | /* | ||
62 | * Interface used by the world | ||
63 | */ | ||
64 | |||
65 | static int offb_setcolreg(u_int regno, u_int red, u_int green, u_int blue, | ||
66 | u_int transp, struct fb_info *info); | ||
67 | static int offb_blank(int blank, struct fb_info *info); | ||
68 | |||
69 | #ifdef CONFIG_PPC32 | 62 | #ifdef CONFIG_PPC32 |
70 | extern boot_infos_t *boot_infos; | 63 | extern boot_infos_t *boot_infos; |
71 | #endif | 64 | #endif |
72 | 65 | ||
73 | static struct fb_ops offb_ops = { | 66 | /* Definitions used by the Avivo palette hack */ |
74 | .owner = THIS_MODULE, | 67 | #define AVIVO_DC_LUT_RW_SELECT 0x6480 |
75 | .fb_setcolreg = offb_setcolreg, | 68 | #define AVIVO_DC_LUT_RW_MODE 0x6484 |
76 | .fb_blank = offb_blank, | 69 | #define AVIVO_DC_LUT_RW_INDEX 0x6488 |
77 | .fb_fillrect = cfb_fillrect, | 70 | #define AVIVO_DC_LUT_SEQ_COLOR 0x648c |
78 | .fb_copyarea = cfb_copyarea, | 71 | #define AVIVO_DC_LUT_PWL_DATA 0x6490 |
79 | .fb_imageblit = cfb_imageblit, | 72 | #define AVIVO_DC_LUT_30_COLOR 0x6494 |
80 | }; | 73 | #define AVIVO_DC_LUT_READ_PIPE_SELECT 0x6498 |
74 | #define AVIVO_DC_LUT_WRITE_EN_MASK 0x649c | ||
75 | #define AVIVO_DC_LUT_AUTOFILL 0x64a0 | ||
76 | |||
77 | #define AVIVO_DC_LUTA_CONTROL 0x64c0 | ||
78 | #define AVIVO_DC_LUTA_BLACK_OFFSET_BLUE 0x64c4 | ||
79 | #define AVIVO_DC_LUTA_BLACK_OFFSET_GREEN 0x64c8 | ||
80 | #define AVIVO_DC_LUTA_BLACK_OFFSET_RED 0x64cc | ||
81 | #define AVIVO_DC_LUTA_WHITE_OFFSET_BLUE 0x64d0 | ||
82 | #define AVIVO_DC_LUTA_WHITE_OFFSET_GREEN 0x64d4 | ||
83 | #define AVIVO_DC_LUTA_WHITE_OFFSET_RED 0x64d8 | ||
84 | |||
85 | #define AVIVO_DC_LUTB_CONTROL 0x6cc0 | ||
86 | #define AVIVO_DC_LUTB_BLACK_OFFSET_BLUE 0x6cc4 | ||
87 | #define AVIVO_DC_LUTB_BLACK_OFFSET_GREEN 0x6cc8 | ||
88 | #define AVIVO_DC_LUTB_BLACK_OFFSET_RED 0x6ccc | ||
89 | #define AVIVO_DC_LUTB_WHITE_OFFSET_BLUE 0x6cd0 | ||
90 | #define AVIVO_DC_LUTB_WHITE_OFFSET_GREEN 0x6cd4 | ||
91 | #define AVIVO_DC_LUTB_WHITE_OFFSET_RED 0x6cd8 | ||
81 | 92 | ||
82 | /* | 93 | /* |
83 | * Set a single color register. The values supplied are already | 94 | * Set a single color register. The values supplied are already |
@@ -160,6 +171,17 @@ static int offb_setcolreg(u_int regno, u_int red, u_int green, u_int blue, | |||
160 | out_le32(((unsigned __iomem *) par->cmap_adr) + regno, | 171 | out_le32(((unsigned __iomem *) par->cmap_adr) + regno, |
161 | (red << 16 | green << 8 | blue)); | 172 | (red << 16 | green << 8 | blue)); |
162 | break; | 173 | break; |
174 | case cmap_avivo: | ||
175 | /* Write to both LUTs for now */ | ||
176 | writel(1, par->cmap_adr + AVIVO_DC_LUT_RW_SELECT); | ||
177 | writeb(regno, par->cmap_adr + AVIVO_DC_LUT_RW_INDEX); | ||
178 | writel(((red) << 22) | ((green) << 12) | ((blue) << 2), | ||
179 | par->cmap_adr + AVIVO_DC_LUT_30_COLOR); | ||
180 | writel(0, par->cmap_adr + AVIVO_DC_LUT_RW_SELECT); | ||
181 | writeb(regno, par->cmap_adr + AVIVO_DC_LUT_RW_INDEX); | ||
182 | writel(((red) << 22) | ((green) << 12) | ((blue) << 2), | ||
183 | par->cmap_adr + AVIVO_DC_LUT_30_COLOR); | ||
184 | break; | ||
163 | } | 185 | } |
164 | 186 | ||
165 | return 0; | 187 | return 0; |
@@ -216,12 +238,59 @@ static int offb_blank(int blank, struct fb_info *info) | |||
216 | out_le32(((unsigned __iomem *) par->cmap_adr) + i, | 238 | out_le32(((unsigned __iomem *) par->cmap_adr) + i, |
217 | 0); | 239 | 0); |
218 | break; | 240 | break; |
241 | case cmap_avivo: | ||
242 | writel(1, par->cmap_adr + AVIVO_DC_LUT_RW_SELECT); | ||
243 | writeb(i, par->cmap_adr + AVIVO_DC_LUT_RW_INDEX); | ||
244 | writel(0, par->cmap_adr + AVIVO_DC_LUT_30_COLOR); | ||
245 | writel(0, par->cmap_adr + AVIVO_DC_LUT_RW_SELECT); | ||
246 | writeb(i, par->cmap_adr + AVIVO_DC_LUT_RW_INDEX); | ||
247 | writel(0, par->cmap_adr + AVIVO_DC_LUT_30_COLOR); | ||
248 | break; | ||
219 | } | 249 | } |
220 | } else | 250 | } else |
221 | fb_set_cmap(&info->cmap, info); | 251 | fb_set_cmap(&info->cmap, info); |
222 | return 0; | 252 | return 0; |
223 | } | 253 | } |
224 | 254 | ||
255 | static int offb_set_par(struct fb_info *info) | ||
256 | { | ||
257 | struct offb_par *par = (struct offb_par *) info->par; | ||
258 | |||
259 | /* On avivo, initialize palette control */ | ||
260 | if (par->cmap_type == cmap_avivo) { | ||
261 | writel(0, par->cmap_adr + AVIVO_DC_LUTA_CONTROL); | ||
262 | writel(0, par->cmap_adr + AVIVO_DC_LUTA_BLACK_OFFSET_BLUE); | ||
263 | writel(0, par->cmap_adr + AVIVO_DC_LUTA_BLACK_OFFSET_GREEN); | ||
264 | writel(0, par->cmap_adr + AVIVO_DC_LUTA_BLACK_OFFSET_RED); | ||
265 | writel(0x0000ffff, par->cmap_adr + AVIVO_DC_LUTA_WHITE_OFFSET_BLUE); | ||
266 | writel(0x0000ffff, par->cmap_adr + AVIVO_DC_LUTA_WHITE_OFFSET_GREEN); | ||
267 | writel(0x0000ffff, par->cmap_adr + AVIVO_DC_LUTA_WHITE_OFFSET_RED); | ||
268 | writel(0, par->cmap_adr + AVIVO_DC_LUTB_CONTROL); | ||
269 | writel(0, par->cmap_adr + AVIVO_DC_LUTB_BLACK_OFFSET_BLUE); | ||
270 | writel(0, par->cmap_adr + AVIVO_DC_LUTB_BLACK_OFFSET_GREEN); | ||
271 | writel(0, par->cmap_adr + AVIVO_DC_LUTB_BLACK_OFFSET_RED); | ||
272 | writel(0x0000ffff, par->cmap_adr + AVIVO_DC_LUTB_WHITE_OFFSET_BLUE); | ||
273 | writel(0x0000ffff, par->cmap_adr + AVIVO_DC_LUTB_WHITE_OFFSET_GREEN); | ||
274 | writel(0x0000ffff, par->cmap_adr + AVIVO_DC_LUTB_WHITE_OFFSET_RED); | ||
275 | writel(1, par->cmap_adr + AVIVO_DC_LUT_RW_SELECT); | ||
276 | writel(0, par->cmap_adr + AVIVO_DC_LUT_RW_MODE); | ||
277 | writel(0x0000003f, par->cmap_adr + AVIVO_DC_LUT_WRITE_EN_MASK); | ||
278 | writel(0, par->cmap_adr + AVIVO_DC_LUT_RW_SELECT); | ||
279 | writel(0, par->cmap_adr + AVIVO_DC_LUT_RW_MODE); | ||
280 | writel(0x0000003f, par->cmap_adr + AVIVO_DC_LUT_WRITE_EN_MASK); | ||
281 | } | ||
282 | return 0; | ||
283 | } | ||
284 | |||
285 | static struct fb_ops offb_ops = { | ||
286 | .owner = THIS_MODULE, | ||
287 | .fb_setcolreg = offb_setcolreg, | ||
288 | .fb_set_par = offb_set_par, | ||
289 | .fb_blank = offb_blank, | ||
290 | .fb_fillrect = cfb_fillrect, | ||
291 | .fb_copyarea = cfb_copyarea, | ||
292 | .fb_imageblit = cfb_imageblit, | ||
293 | }; | ||
225 | 294 | ||
226 | static void __iomem *offb_map_reg(struct device_node *np, int index, | 295 | static void __iomem *offb_map_reg(struct device_node *np, int index, |
227 | unsigned long offset, unsigned long size) | 296 | unsigned long offset, unsigned long size) |
@@ -245,6 +314,59 @@ static void __iomem *offb_map_reg(struct device_node *np, int index, | |||
245 | return ioremap(taddr + offset, size); | 314 | return ioremap(taddr + offset, size); |
246 | } | 315 | } |
247 | 316 | ||
317 | static void offb_init_palette_hacks(struct fb_info *info, struct device_node *dp, | ||
318 | const char *name, unsigned long address) | ||
319 | { | ||
320 | struct offb_par *par = (struct offb_par *) info->par; | ||
321 | |||
322 | if (dp && !strncmp(name, "ATY,Rage128", 11)) { | ||
323 | par->cmap_adr = offb_map_reg(dp, 2, 0, 0x1fff); | ||
324 | if (par->cmap_adr) | ||
325 | par->cmap_type = cmap_r128; | ||
326 | } else if (dp && (!strncmp(name, "ATY,RageM3pA", 12) | ||
327 | || !strncmp(name, "ATY,RageM3p12A", 14))) { | ||
328 | par->cmap_adr = offb_map_reg(dp, 2, 0, 0x1fff); | ||
329 | if (par->cmap_adr) | ||
330 | par->cmap_type = cmap_M3A; | ||
331 | } else if (dp && !strncmp(name, "ATY,RageM3pB", 12)) { | ||
332 | par->cmap_adr = offb_map_reg(dp, 2, 0, 0x1fff); | ||
333 | if (par->cmap_adr) | ||
334 | par->cmap_type = cmap_M3B; | ||
335 | } else if (dp && !strncmp(name, "ATY,Rage6", 9)) { | ||
336 | par->cmap_adr = offb_map_reg(dp, 1, 0, 0x1fff); | ||
337 | if (par->cmap_adr) | ||
338 | par->cmap_type = cmap_radeon; | ||
339 | } else if (!strncmp(name, "ATY,", 4)) { | ||
340 | unsigned long base = address & 0xff000000UL; | ||
341 | par->cmap_adr = | ||
342 | ioremap(base + 0x7ff000, 0x1000) + 0xcc0; | ||
343 | par->cmap_data = par->cmap_adr + 1; | ||
344 | par->cmap_type = cmap_m64; | ||
345 | } else if (dp && (of_device_is_compatible(dp, "pci1014,b7") || | ||
346 | of_device_is_compatible(dp, "pci1014,21c"))) { | ||
347 | par->cmap_adr = offb_map_reg(dp, 0, 0x6000, 0x1000); | ||
348 | if (par->cmap_adr) | ||
349 | par->cmap_type = cmap_gxt2000; | ||
350 | } else if (dp && !strncmp(name, "vga,Display-", 12)) { | ||
351 | /* Look for AVIVO initialized by SLOF */ | ||
352 | struct device_node *pciparent = of_get_parent(dp); | ||
353 | const u32 *vid, *did; | ||
354 | vid = of_get_property(pciparent, "vendor-id", NULL); | ||
355 | did = of_get_property(pciparent, "device-id", NULL); | ||
356 | /* This will match most R5xx */ | ||
357 | if (vid && did && *vid == 0x1002 && | ||
358 | ((*did >= 0x7100 && *did < 0x7800) || | ||
359 | (*did >= 0x9400))) { | ||
360 | par->cmap_adr = offb_map_reg(pciparent, 2, 0, 0x10000); | ||
361 | if (par->cmap_adr) | ||
362 | par->cmap_type = cmap_avivo; | ||
363 | } | ||
364 | of_node_put(pciparent); | ||
365 | } | ||
366 | info->fix.visual = (par->cmap_type != cmap_unknown) ? | ||
367 | FB_VISUAL_PSEUDOCOLOR : FB_VISUAL_STATIC_PSEUDOCOLOR; | ||
368 | } | ||
369 | |||
248 | static void __init offb_init_fb(const char *name, const char *full_name, | 370 | static void __init offb_init_fb(const char *name, const char *full_name, |
249 | int width, int height, int depth, | 371 | int width, int height, int depth, |
250 | int pitch, unsigned long address, | 372 | int pitch, unsigned long address, |
@@ -283,6 +405,7 @@ static void __init offb_init_fb(const char *name, const char *full_name, | |||
283 | 405 | ||
284 | fix = &info->fix; | 406 | fix = &info->fix; |
285 | var = &info->var; | 407 | var = &info->var; |
408 | info->par = par; | ||
286 | 409 | ||
287 | strcpy(fix->id, "OFfb "); | 410 | strcpy(fix->id, "OFfb "); |
288 | strncat(fix->id, name, sizeof(fix->id) - sizeof("OFfb ")); | 411 | strncat(fix->id, name, sizeof(fix->id) - sizeof("OFfb ")); |
@@ -298,39 +421,9 @@ static void __init offb_init_fb(const char *name, const char *full_name, | |||
298 | fix->type_aux = 0; | 421 | fix->type_aux = 0; |
299 | 422 | ||
300 | par->cmap_type = cmap_unknown; | 423 | par->cmap_type = cmap_unknown; |
301 | if (depth == 8) { | 424 | if (depth == 8) |
302 | if (dp && !strncmp(name, "ATY,Rage128", 11)) { | 425 | offb_init_palette_hacks(info, dp, name, address); |
303 | par->cmap_adr = offb_map_reg(dp, 2, 0, 0x1fff); | 426 | else |
304 | if (par->cmap_adr) | ||
305 | par->cmap_type = cmap_r128; | ||
306 | } else if (dp && (!strncmp(name, "ATY,RageM3pA", 12) | ||
307 | || !strncmp(name, "ATY,RageM3p12A", 14))) { | ||
308 | par->cmap_adr = offb_map_reg(dp, 2, 0, 0x1fff); | ||
309 | if (par->cmap_adr) | ||
310 | par->cmap_type = cmap_M3A; | ||
311 | } else if (dp && !strncmp(name, "ATY,RageM3pB", 12)) { | ||
312 | par->cmap_adr = offb_map_reg(dp, 2, 0, 0x1fff); | ||
313 | if (par->cmap_adr) | ||
314 | par->cmap_type = cmap_M3B; | ||
315 | } else if (dp && !strncmp(name, "ATY,Rage6", 9)) { | ||
316 | par->cmap_adr = offb_map_reg(dp, 1, 0, 0x1fff); | ||
317 | if (par->cmap_adr) | ||
318 | par->cmap_type = cmap_radeon; | ||
319 | } else if (!strncmp(name, "ATY,", 4)) { | ||
320 | unsigned long base = address & 0xff000000UL; | ||
321 | par->cmap_adr = | ||
322 | ioremap(base + 0x7ff000, 0x1000) + 0xcc0; | ||
323 | par->cmap_data = par->cmap_adr + 1; | ||
324 | par->cmap_type = cmap_m64; | ||
325 | } else if (dp && (of_device_is_compatible(dp, "pci1014,b7") || | ||
326 | of_device_is_compatible(dp, "pci1014,21c"))) { | ||
327 | par->cmap_adr = offb_map_reg(dp, 0, 0x6000, 0x1000); | ||
328 | if (par->cmap_adr) | ||
329 | par->cmap_type = cmap_gxt2000; | ||
330 | } | ||
331 | fix->visual = (par->cmap_type != cmap_unknown) ? | ||
332 | FB_VISUAL_PSEUDOCOLOR : FB_VISUAL_STATIC_PSEUDOCOLOR; | ||
333 | } else | ||
334 | fix->visual = FB_VISUAL_TRUECOLOR; | 427 | fix->visual = FB_VISUAL_TRUECOLOR; |
335 | 428 | ||
336 | var->xoffset = var->yoffset = 0; | 429 | var->xoffset = var->yoffset = 0; |
@@ -395,7 +488,6 @@ static void __init offb_init_fb(const char *name, const char *full_name, | |||
395 | 488 | ||
396 | info->fbops = &offb_ops; | 489 | info->fbops = &offb_ops; |
397 | info->screen_base = ioremap(address, fix->smem_len); | 490 | info->screen_base = ioremap(address, fix->smem_len); |
398 | info->par = par; | ||
399 | info->pseudo_palette = (void *) (info + 1); | 491 | info->pseudo_palette = (void *) (info + 1); |
400 | info->flags = FBINFO_DEFAULT | foreign_endian; | 492 | info->flags = FBINFO_DEFAULT | foreign_endian; |
401 | 493 | ||
diff --git a/drivers/video/ps3fb.c b/drivers/video/ps3fb.c index dc3af1c78c56..4b5d80771904 100644 --- a/drivers/video/ps3fb.c +++ b/drivers/video/ps3fb.c | |||
@@ -1297,6 +1297,7 @@ static int ps3fb_shutdown(struct ps3_system_bus_device *dev) | |||
1297 | 1297 | ||
1298 | static struct ps3_system_bus_driver ps3fb_driver = { | 1298 | static struct ps3_system_bus_driver ps3fb_driver = { |
1299 | .match_id = PS3_MATCH_ID_GRAPHICS, | 1299 | .match_id = PS3_MATCH_ID_GRAPHICS, |
1300 | .match_sub_id = PS3_MATCH_SUB_ID_FB, | ||
1300 | .core.name = DEVICE_NAME, | 1301 | .core.name = DEVICE_NAME, |
1301 | .core.owner = THIS_MODULE, | 1302 | .core.owner = THIS_MODULE, |
1302 | .probe = ps3fb_probe, | 1303 | .probe = ps3fb_probe, |
diff --git a/include/asm-powerpc/asm-compat.h b/include/asm-powerpc/asm-compat.h index 8ec2e1da68bf..8f0fe7971949 100644 --- a/include/asm-powerpc/asm-compat.h +++ b/include/asm-powerpc/asm-compat.h | |||
@@ -22,6 +22,7 @@ | |||
22 | #define PPC_STL stringify_in_c(std) | 22 | #define PPC_STL stringify_in_c(std) |
23 | #define PPC_LCMPI stringify_in_c(cmpdi) | 23 | #define PPC_LCMPI stringify_in_c(cmpdi) |
24 | #define PPC_LONG stringify_in_c(.llong) | 24 | #define PPC_LONG stringify_in_c(.llong) |
25 | #define PPC_LONG_ALIGN stringify_in_c(.balign 8) | ||
25 | #define PPC_TLNEI stringify_in_c(tdnei) | 26 | #define PPC_TLNEI stringify_in_c(tdnei) |
26 | #define PPC_LLARX stringify_in_c(ldarx) | 27 | #define PPC_LLARX stringify_in_c(ldarx) |
27 | #define PPC_STLCX stringify_in_c(stdcx.) | 28 | #define PPC_STLCX stringify_in_c(stdcx.) |
@@ -43,6 +44,7 @@ | |||
43 | #define PPC_STL stringify_in_c(stw) | 44 | #define PPC_STL stringify_in_c(stw) |
44 | #define PPC_LCMPI stringify_in_c(cmpwi) | 45 | #define PPC_LCMPI stringify_in_c(cmpwi) |
45 | #define PPC_LONG stringify_in_c(.long) | 46 | #define PPC_LONG stringify_in_c(.long) |
47 | #define PPC_LONG_ALIGN stringify_in_c(.balign 4) | ||
46 | #define PPC_TLNEI stringify_in_c(twnei) | 48 | #define PPC_TLNEI stringify_in_c(twnei) |
47 | #define PPC_LLARX stringify_in_c(lwarx) | 49 | #define PPC_LLARX stringify_in_c(lwarx) |
48 | #define PPC_STLCX stringify_in_c(stwcx.) | 50 | #define PPC_STLCX stringify_in_c(stwcx.) |
diff --git a/include/asm-powerpc/machdep.h b/include/asm-powerpc/machdep.h index 989922621e35..1233d735fd28 100644 --- a/include/asm-powerpc/machdep.h +++ b/include/asm-powerpc/machdep.h | |||
@@ -80,7 +80,8 @@ struct machdep_calls { | |||
80 | long index, | 80 | long index, |
81 | long npages, | 81 | long npages, |
82 | unsigned long uaddr, | 82 | unsigned long uaddr, |
83 | enum dma_data_direction direction); | 83 | enum dma_data_direction direction, |
84 | struct dma_attrs *attrs); | ||
84 | void (*tce_free)(struct iommu_table *tbl, | 85 | void (*tce_free)(struct iommu_table *tbl, |
85 | long index, | 86 | long index, |
86 | long npages); | 87 | long npages); |
diff --git a/include/asm-powerpc/pgtable-ppc32.h b/include/asm-powerpc/pgtable-ppc32.h index 73015f0139de..3a96d001cb75 100644 --- a/include/asm-powerpc/pgtable-ppc32.h +++ b/include/asm-powerpc/pgtable-ppc32.h | |||
@@ -295,10 +295,10 @@ extern int icache_44x_need_flush; | |||
295 | #define _PAGE_PRESENT 0x00001 /* S: PTE contains a translation */ | 295 | #define _PAGE_PRESENT 0x00001 /* S: PTE contains a translation */ |
296 | #define _PAGE_USER 0x00002 /* S: User page (maps to UR) */ | 296 | #define _PAGE_USER 0x00002 /* S: User page (maps to UR) */ |
297 | #define _PAGE_FILE 0x00002 /* S: when !present: nonlinear file mapping */ | 297 | #define _PAGE_FILE 0x00002 /* S: when !present: nonlinear file mapping */ |
298 | #define _PAGE_ACCESSED 0x00004 /* S: Page referenced */ | 298 | #define _PAGE_RW 0x00004 /* S: Write permission (SW) */ |
299 | #define _PAGE_HWWRITE 0x00008 /* H: Dirty & RW, set in exception */ | 299 | #define _PAGE_DIRTY 0x00008 /* S: Page dirty */ |
300 | #define _PAGE_RW 0x00010 /* S: Write permission */ | 300 | #define _PAGE_HWEXEC 0x00010 /* H: SX permission */ |
301 | #define _PAGE_HWEXEC 0x00020 /* H: UX permission */ | 301 | #define _PAGE_ACCESSED 0x00020 /* S: Page referenced */ |
302 | 302 | ||
303 | #define _PAGE_ENDIAN 0x00040 /* H: E bit */ | 303 | #define _PAGE_ENDIAN 0x00040 /* H: E bit */ |
304 | #define _PAGE_GUARDED 0x00080 /* H: G bit */ | 304 | #define _PAGE_GUARDED 0x00080 /* H: G bit */ |
@@ -307,21 +307,14 @@ extern int icache_44x_need_flush; | |||
307 | #define _PAGE_WRITETHRU 0x00400 /* H: W bit */ | 307 | #define _PAGE_WRITETHRU 0x00400 /* H: W bit */ |
308 | 308 | ||
309 | #ifdef CONFIG_PTE_64BIT | 309 | #ifdef CONFIG_PTE_64BIT |
310 | #define _PAGE_DIRTY 0x08000 /* S: Page dirty */ | ||
311 | |||
312 | /* ERPN in a PTE never gets cleared, ignore it */ | 310 | /* ERPN in a PTE never gets cleared, ignore it */ |
313 | #define _PTE_NONE_MASK 0xffffffffffff0000ULL | 311 | #define _PTE_NONE_MASK 0xffffffffffff0000ULL |
314 | #else | ||
315 | #define _PAGE_DIRTY 0x00800 /* S: Page dirty */ | ||
316 | #endif | 312 | #endif |
317 | 313 | ||
318 | #define _PMD_PRESENT 0 | 314 | #define _PMD_PRESENT 0 |
319 | #define _PMD_PRESENT_MASK (PAGE_MASK) | 315 | #define _PMD_PRESENT_MASK (PAGE_MASK) |
320 | #define _PMD_BAD (~PAGE_MASK) | 316 | #define _PMD_BAD (~PAGE_MASK) |
321 | 317 | ||
322 | /* Until my rework is finished, FSL BookE still needs atomic PTE updates */ | ||
323 | #define PTE_ATOMIC_UPDATES 1 | ||
324 | |||
325 | #elif defined(CONFIG_8xx) | 318 | #elif defined(CONFIG_8xx) |
326 | /* Definitions for 8xx embedded chips. */ | 319 | /* Definitions for 8xx embedded chips. */ |
327 | #define _PAGE_PRESENT 0x0001 /* Page is valid */ | 320 | #define _PAGE_PRESENT 0x0001 /* Page is valid */ |
diff --git a/include/asm-powerpc/pmi.h b/include/asm-powerpc/pmi.h index e1dc090748df..b4e91fbf5081 100644 --- a/include/asm-powerpc/pmi.h +++ b/include/asm-powerpc/pmi.h | |||
@@ -30,6 +30,7 @@ | |||
30 | #ifdef __KERNEL__ | 30 | #ifdef __KERNEL__ |
31 | 31 | ||
32 | #define PMI_TYPE_FREQ_CHANGE 0x01 | 32 | #define PMI_TYPE_FREQ_CHANGE 0x01 |
33 | #define PMI_TYPE_POWER_BUTTON 0x02 | ||
33 | #define PMI_READ_TYPE 0 | 34 | #define PMI_READ_TYPE 0 |
34 | #define PMI_READ_DATA0 1 | 35 | #define PMI_READ_DATA0 1 |
35 | #define PMI_READ_DATA1 2 | 36 | #define PMI_READ_DATA1 2 |
diff --git a/include/asm-powerpc/ps3.h b/include/asm-powerpc/ps3.h index 81ffe3b3c1ce..f9e34c493cbb 100644 --- a/include/asm-powerpc/ps3.h +++ b/include/asm-powerpc/ps3.h | |||
@@ -337,12 +337,18 @@ enum ps3_system_bus_device_type { | |||
337 | PS3_DEVICE_TYPE_LPM, | 337 | PS3_DEVICE_TYPE_LPM, |
338 | }; | 338 | }; |
339 | 339 | ||
340 | enum ps3_match_sub_id { | ||
341 | /* for PS3_MATCH_ID_GRAPHICS */ | ||
342 | PS3_MATCH_SUB_ID_FB = 1, | ||
343 | }; | ||
344 | |||
340 | /** | 345 | /** |
341 | * struct ps3_system_bus_device - a device on the system bus | 346 | * struct ps3_system_bus_device - a device on the system bus |
342 | */ | 347 | */ |
343 | 348 | ||
344 | struct ps3_system_bus_device { | 349 | struct ps3_system_bus_device { |
345 | enum ps3_match_id match_id; | 350 | enum ps3_match_id match_id; |
351 | enum ps3_match_sub_id match_sub_id; | ||
346 | enum ps3_system_bus_device_type dev_type; | 352 | enum ps3_system_bus_device_type dev_type; |
347 | 353 | ||
348 | u64 bus_id; /* SB */ | 354 | u64 bus_id; /* SB */ |
@@ -371,6 +377,7 @@ int ps3_close_hv_device(struct ps3_system_bus_device *dev); | |||
371 | 377 | ||
372 | struct ps3_system_bus_driver { | 378 | struct ps3_system_bus_driver { |
373 | enum ps3_match_id match_id; | 379 | enum ps3_match_id match_id; |
380 | enum ps3_match_sub_id match_sub_id; | ||
374 | struct device_driver core; | 381 | struct device_driver core; |
375 | int (*probe)(struct ps3_system_bus_device *); | 382 | int (*probe)(struct ps3_system_bus_device *); |
376 | int (*remove)(struct ps3_system_bus_device *); | 383 | int (*remove)(struct ps3_system_bus_device *); |
diff --git a/include/asm-powerpc/reg.h b/include/asm-powerpc/reg.h index bbccadfee0d6..c6d1ab650778 100644 --- a/include/asm-powerpc/reg.h +++ b/include/asm-powerpc/reg.h | |||
@@ -155,10 +155,12 @@ | |||
155 | #define CTRL_RUNLATCH 0x1 | 155 | #define CTRL_RUNLATCH 0x1 |
156 | #define SPRN_DABR 0x3F5 /* Data Address Breakpoint Register */ | 156 | #define SPRN_DABR 0x3F5 /* Data Address Breakpoint Register */ |
157 | #define DABR_TRANSLATION (1UL << 2) | 157 | #define DABR_TRANSLATION (1UL << 2) |
158 | #define SPRN_DABR2 0x13D /* e300 */ | ||
158 | #define SPRN_DABRX 0x3F7 /* Data Address Breakpoint Register Extension */ | 159 | #define SPRN_DABRX 0x3F7 /* Data Address Breakpoint Register Extension */ |
159 | #define DABRX_USER (1UL << 0) | 160 | #define DABRX_USER (1UL << 0) |
160 | #define DABRX_KERNEL (1UL << 1) | 161 | #define DABRX_KERNEL (1UL << 1) |
161 | #define SPRN_DAR 0x013 /* Data Address Register */ | 162 | #define SPRN_DAR 0x013 /* Data Address Register */ |
163 | #define SPRN_DBCR 0x136 /* e300 Data Breakpoint Control Reg */ | ||
162 | #define SPRN_DSISR 0x012 /* Data Storage Interrupt Status Register */ | 164 | #define SPRN_DSISR 0x012 /* Data Storage Interrupt Status Register */ |
163 | #define DSISR_NOHPTE 0x40000000 /* no translation found */ | 165 | #define DSISR_NOHPTE 0x40000000 /* no translation found */ |
164 | #define DSISR_PROTFAULT 0x08000000 /* protection fault */ | 166 | #define DSISR_PROTFAULT 0x08000000 /* protection fault */ |
@@ -264,6 +266,8 @@ | |||
264 | #define HID1_PS (1<<16) /* 750FX PLL selection */ | 266 | #define HID1_PS (1<<16) /* 750FX PLL selection */ |
265 | #define SPRN_HID2 0x3F8 /* Hardware Implementation Register 2 */ | 267 | #define SPRN_HID2 0x3F8 /* Hardware Implementation Register 2 */ |
266 | #define SPRN_IABR 0x3F2 /* Instruction Address Breakpoint Register */ | 268 | #define SPRN_IABR 0x3F2 /* Instruction Address Breakpoint Register */ |
269 | #define SPRN_IABR2 0x3FA /* 83xx */ | ||
270 | #define SPRN_IBCR 0x135 /* 83xx Insn Breakpoint Control Reg */ | ||
267 | #define SPRN_HID4 0x3F4 /* 970 HID4 */ | 271 | #define SPRN_HID4 0x3F4 /* 970 HID4 */ |
268 | #define SPRN_HID5 0x3F6 /* 970 HID5 */ | 272 | #define SPRN_HID5 0x3F6 /* 970 HID5 */ |
269 | #define SPRN_HID6 0x3F9 /* BE HID 6 */ | 273 | #define SPRN_HID6 0x3F9 /* BE HID 6 */ |
diff --git a/include/asm-powerpc/uaccess.h b/include/asm-powerpc/uaccess.h index 1a0736f8803f..bd0fb8495154 100644 --- a/include/asm-powerpc/uaccess.h +++ b/include/asm-powerpc/uaccess.h | |||
@@ -6,6 +6,7 @@ | |||
6 | 6 | ||
7 | #include <linux/sched.h> | 7 | #include <linux/sched.h> |
8 | #include <linux/errno.h> | 8 | #include <linux/errno.h> |
9 | #include <asm/asm-compat.h> | ||
9 | #include <asm/processor.h> | 10 | #include <asm/processor.h> |
10 | #include <asm/page.h> | 11 | #include <asm/page.h> |
11 | 12 | ||
@@ -141,12 +142,11 @@ extern long __put_user_bad(void); | |||
141 | " b 2b\n" \ | 142 | " b 2b\n" \ |
142 | ".previous\n" \ | 143 | ".previous\n" \ |
143 | ".section __ex_table,\"a\"\n" \ | 144 | ".section __ex_table,\"a\"\n" \ |
144 | " .balign %5\n" \ | 145 | PPC_LONG_ALIGN "\n" \ |
145 | PPC_LONG "1b,3b\n" \ | 146 | PPC_LONG "1b,3b\n" \ |
146 | ".previous" \ | 147 | ".previous" \ |
147 | : "=r" (err) \ | 148 | : "=r" (err) \ |
148 | : "r" (x), "b" (addr), "i" (-EFAULT), "0" (err),\ | 149 | : "r" (x), "b" (addr), "i" (-EFAULT), "0" (err)) |
149 | "i"(sizeof(unsigned long))) | ||
150 | 150 | ||
151 | #ifdef __powerpc64__ | 151 | #ifdef __powerpc64__ |
152 | #define __put_user_asm2(x, ptr, retval) \ | 152 | #define __put_user_asm2(x, ptr, retval) \ |
@@ -162,13 +162,12 @@ extern long __put_user_bad(void); | |||
162 | " b 3b\n" \ | 162 | " b 3b\n" \ |
163 | ".previous\n" \ | 163 | ".previous\n" \ |
164 | ".section __ex_table,\"a\"\n" \ | 164 | ".section __ex_table,\"a\"\n" \ |
165 | " .balign %5\n" \ | 165 | PPC_LONG_ALIGN "\n" \ |
166 | PPC_LONG "1b,4b\n" \ | 166 | PPC_LONG "1b,4b\n" \ |
167 | PPC_LONG "2b,4b\n" \ | 167 | PPC_LONG "2b,4b\n" \ |
168 | ".previous" \ | 168 | ".previous" \ |
169 | : "=r" (err) \ | 169 | : "=r" (err) \ |
170 | : "r" (x), "b" (addr), "i" (-EFAULT), "0" (err),\ | 170 | : "r" (x), "b" (addr), "i" (-EFAULT), "0" (err)) |
171 | "i"(sizeof(unsigned long))) | ||
172 | #endif /* __powerpc64__ */ | 171 | #endif /* __powerpc64__ */ |
173 | 172 | ||
174 | #define __put_user_size(x, ptr, size, retval) \ | 173 | #define __put_user_size(x, ptr, size, retval) \ |
@@ -226,12 +225,11 @@ extern long __get_user_bad(void); | |||
226 | " b 2b\n" \ | 225 | " b 2b\n" \ |
227 | ".previous\n" \ | 226 | ".previous\n" \ |
228 | ".section __ex_table,\"a\"\n" \ | 227 | ".section __ex_table,\"a\"\n" \ |
229 | " .balign %5\n" \ | 228 | PPC_LONG_ALIGN "\n" \ |
230 | PPC_LONG "1b,3b\n" \ | 229 | PPC_LONG "1b,3b\n" \ |
231 | ".previous" \ | 230 | ".previous" \ |
232 | : "=r" (err), "=r" (x) \ | 231 | : "=r" (err), "=r" (x) \ |
233 | : "b" (addr), "i" (-EFAULT), "0" (err), \ | 232 | : "b" (addr), "i" (-EFAULT), "0" (err)) |
234 | "i"(sizeof(unsigned long))) | ||
235 | 233 | ||
236 | #ifdef __powerpc64__ | 234 | #ifdef __powerpc64__ |
237 | #define __get_user_asm2(x, addr, err) \ | 235 | #define __get_user_asm2(x, addr, err) \ |
@@ -249,13 +247,12 @@ extern long __get_user_bad(void); | |||
249 | " b 3b\n" \ | 247 | " b 3b\n" \ |
250 | ".previous\n" \ | 248 | ".previous\n" \ |
251 | ".section __ex_table,\"a\"\n" \ | 249 | ".section __ex_table,\"a\"\n" \ |
252 | " .balign %5\n" \ | 250 | PPC_LONG_ALIGN "\n" \ |
253 | PPC_LONG "1b,4b\n" \ | 251 | PPC_LONG "1b,4b\n" \ |
254 | PPC_LONG "2b,4b\n" \ | 252 | PPC_LONG "2b,4b\n" \ |
255 | ".previous" \ | 253 | ".previous" \ |
256 | : "=r" (err), "=&r" (x) \ | 254 | : "=r" (err), "=&r" (x) \ |
257 | : "b" (addr), "i" (-EFAULT), "0" (err), \ | 255 | : "b" (addr), "i" (-EFAULT), "0" (err)) |
258 | "i"(sizeof(unsigned long))) | ||
259 | #endif /* __powerpc64__ */ | 256 | #endif /* __powerpc64__ */ |
260 | 257 | ||
261 | #define __get_user_size(x, ptr, size, retval) \ | 258 | #define __get_user_size(x, ptr, size, retval) \ |
diff --git a/include/asm-powerpc/ucc_fast.h b/include/asm-powerpc/ucc_fast.h index f529f70b1d82..fce16abe7ee1 100644 --- a/include/asm-powerpc/ucc_fast.h +++ b/include/asm-powerpc/ucc_fast.h | |||
@@ -156,11 +156,11 @@ struct ucc_fast_info { | |||
156 | 156 | ||
157 | struct ucc_fast_private { | 157 | struct ucc_fast_private { |
158 | struct ucc_fast_info *uf_info; | 158 | struct ucc_fast_info *uf_info; |
159 | struct ucc_fast *uf_regs; /* a pointer to memory map of UCC regs. */ | 159 | struct ucc_fast __iomem *uf_regs; /* a pointer to the UCC regs. */ |
160 | u32 *p_ucce; /* a pointer to the event register in memory. */ | 160 | u32 __iomem *p_ucce; /* a pointer to the event register in memory. */ |
161 | u32 *p_uccm; /* a pointer to the mask register in memory. */ | 161 | u32 __iomem *p_uccm; /* a pointer to the mask register in memory. */ |
162 | #ifdef CONFIG_UGETH_TX_ON_DEMAND | 162 | #ifdef CONFIG_UGETH_TX_ON_DEMAND |
163 | u16 *p_utodr; /* pointer to the transmit on demand register */ | 163 | u16 __iomem *p_utodr; /* pointer to the transmit on demand register */ |
164 | #endif | 164 | #endif |
165 | int enabled_tx; /* Whether channel is enabled for Tx (ENT) */ | 165 | int enabled_tx; /* Whether channel is enabled for Tx (ENT) */ |
166 | int enabled_rx; /* Whether channel is enabled for Rx (ENR) */ | 166 | int enabled_rx; /* Whether channel is enabled for Rx (ENR) */ |
diff --git a/include/linux/dma-attrs.h b/include/linux/dma-attrs.h index 1677e2bfa00c..71ad34eca6e3 100644 --- a/include/linux/dma-attrs.h +++ b/include/linux/dma-attrs.h | |||
@@ -12,6 +12,7 @@ | |||
12 | */ | 12 | */ |
13 | enum dma_attr { | 13 | enum dma_attr { |
14 | DMA_ATTR_WRITE_BARRIER, | 14 | DMA_ATTR_WRITE_BARRIER, |
15 | DMA_ATTR_WEAK_ORDERING, | ||
15 | DMA_ATTR_MAX, | 16 | DMA_ATTR_MAX, |
16 | }; | 17 | }; |
17 | 18 | ||
diff --git a/include/linux/fs_enet_pd.h b/include/linux/fs_enet_pd.h index 9bc045b8c478..0ba21ee0f58c 100644 --- a/include/linux/fs_enet_pd.h +++ b/include/linux/fs_enet_pd.h | |||
@@ -135,11 +135,7 @@ struct fs_platform_info { | |||
135 | u32 device_flags; | 135 | u32 device_flags; |
136 | 136 | ||
137 | int phy_addr; /* the phy address (-1 no phy) */ | 137 | int phy_addr; /* the phy address (-1 no phy) */ |
138 | #ifdef CONFIG_PPC_CPM_NEW_BINDING | ||
139 | char bus_id[16]; | 138 | char bus_id[16]; |
140 | #else | ||
141 | const char* bus_id; | ||
142 | #endif | ||
143 | int phy_irq; /* the phy irq (if it exists) */ | 139 | int phy_irq; /* the phy irq (if it exists) */ |
144 | 140 | ||
145 | const struct fs_mii_bus_info *bus_info; | 141 | const struct fs_mii_bus_info *bus_info; |
diff --git a/include/linux/fsl_devices.h b/include/linux/fsl_devices.h index c415a496de3a..4e625e0094c8 100644 --- a/include/linux/fsl_devices.h +++ b/include/linux/fsl_devices.h | |||
@@ -69,6 +69,7 @@ struct gianfar_mdio_data { | |||
69 | #define FSL_GIANFAR_DEV_HAS_VLAN 0x00000020 | 69 | #define FSL_GIANFAR_DEV_HAS_VLAN 0x00000020 |
70 | #define FSL_GIANFAR_DEV_HAS_EXTENDED_HASH 0x00000040 | 70 | #define FSL_GIANFAR_DEV_HAS_EXTENDED_HASH 0x00000040 |
71 | #define FSL_GIANFAR_DEV_HAS_PADDING 0x00000080 | 71 | #define FSL_GIANFAR_DEV_HAS_PADDING 0x00000080 |
72 | #define FSL_GIANFAR_DEV_HAS_MAGIC_PACKET 0x00000100 | ||
72 | 73 | ||
73 | /* Flags in gianfar_platform_data */ | 74 | /* Flags in gianfar_platform_data */ |
74 | #define FSL_GIANFAR_BRD_HAS_PHY_INTR 0x00000001 /* set or use a timer */ | 75 | #define FSL_GIANFAR_BRD_HAS_PHY_INTR 0x00000001 /* set or use a timer */ |
@@ -125,4 +126,10 @@ struct mpc8xx_pcmcia_ops { | |||
125 | int(*voltage_set)(int slot, int vcc, int vpp); | 126 | int(*voltage_set)(int slot, int vcc, int vpp); |
126 | }; | 127 | }; |
127 | 128 | ||
129 | /* Returns non-zero if the current suspend operation would | ||
130 | * lead to a deep sleep (i.e. power removed from the core, | ||
131 | * instead of just the clock). | ||
132 | */ | ||
133 | int fsl_deep_sleep(void); | ||
134 | |||
128 | #endif /* _FSL_DEVICE_H_ */ | 135 | #endif /* _FSL_DEVICE_H_ */ |
diff --git a/include/linux/of_gpio.h b/include/linux/of_gpio.h index 2ee97e9877a7..67db101d0eb8 100644 --- a/include/linux/of_gpio.h +++ b/include/linux/of_gpio.h | |||
@@ -15,7 +15,7 @@ | |||
15 | #define __LINUX_OF_GPIO_H | 15 | #define __LINUX_OF_GPIO_H |
16 | 16 | ||
17 | #include <linux/errno.h> | 17 | #include <linux/errno.h> |
18 | #include <asm/gpio.h> | 18 | #include <linux/gpio.h> |
19 | 19 | ||
20 | #ifdef CONFIG_OF_GPIO | 20 | #ifdef CONFIG_OF_GPIO |
21 | 21 | ||