Thor Thayer | d31e2e8 | 2016-02-10 13:26:22 -0600 | [diff] [blame] | 1 | Altera SoCFPGA ECC Manager |
| 2 | This driver uses the EDAC framework to implement the SOCFPGA ECC Manager. |
| 3 | The ECC Manager counts and corrects single bit errors and counts/handles |
| 4 | double bit errors which are uncorrectable. |
| 5 | |
Thor Thayer | 8b39ab7 | 2016-03-21 11:01:43 -0500 | [diff] [blame] | 6 | Cyclone5 and Arria5 ECC Manager |
Thor Thayer | d31e2e8 | 2016-02-10 13:26:22 -0600 | [diff] [blame] | 7 | Required Properties: |
| 8 | - compatible : Should be "altr,socfpga-ecc-manager" |
| 9 | - #address-cells: must be 1 |
| 10 | - #size-cells: must be 1 |
| 11 | - ranges : standard definition, should translate from local addresses |
| 12 | |
| 13 | Subcomponents: |
| 14 | |
| 15 | L2 Cache ECC |
| 16 | Required Properties: |
| 17 | - compatible : Should be "altr,socfpga-l2-ecc" |
| 18 | - reg : Address and size for ECC error interrupt clear registers. |
| 19 | - interrupts : Should be single bit error interrupt, then double bit error |
| 20 | interrupt. Note the rising edge type. |
| 21 | |
| 22 | On Chip RAM ECC |
| 23 | Required Properties: |
| 24 | - compatible : Should be "altr,socfpga-ocram-ecc" |
| 25 | - reg : Address and size for ECC error interrupt clear registers. |
| 26 | - iram : phandle to On-Chip RAM definition. |
| 27 | - interrupts : Should be single bit error interrupt, then double bit error |
| 28 | interrupt. Note the rising edge type. |
| 29 | |
| 30 | Example: |
| 31 | |
| 32 | eccmgr: eccmgr@ffd08140 { |
| 33 | compatible = "altr,socfpga-ecc-manager"; |
| 34 | #address-cells = <1>; |
| 35 | #size-cells = <1>; |
| 36 | ranges; |
| 37 | |
| 38 | l2-ecc@ffd08140 { |
| 39 | compatible = "altr,socfpga-l2-ecc"; |
| 40 | reg = <0xffd08140 0x4>; |
| 41 | interrupts = <0 36 1>, <0 37 1>; |
| 42 | }; |
| 43 | |
| 44 | ocram-ecc@ffd08144 { |
| 45 | compatible = "altr,socfpga-ocram-ecc"; |
| 46 | reg = <0xffd08144 0x4>; |
| 47 | iram = <&ocram>; |
| 48 | interrupts = <0 178 1>, <0 179 1>; |
| 49 | }; |
| 50 | }; |
Thor Thayer | 8b39ab7 | 2016-03-21 11:01:43 -0500 | [diff] [blame] | 51 | |
| 52 | Arria10 SoCFPGA ECC Manager |
| 53 | The Arria10 SoC ECC Manager handles the IRQs for each peripheral |
| 54 | in a shared register instead of individual IRQs like the Cyclone5 |
| 55 | and Arria5. Therefore the device tree is different as well. |
| 56 | |
| 57 | Required Properties: |
| 58 | - compatible : Should be "altr,socfpga-a10-ecc-manager" |
| 59 | - altr,sysgr-syscon : phandle to Arria10 System Manager Block |
| 60 | containing the ECC manager registers. |
| 61 | - #address-cells: must be 1 |
| 62 | - #size-cells: must be 1 |
| 63 | - interrupts : Should be single bit error interrupt, then double bit error |
Thor Thayer | 47d7800 | 2016-05-25 11:29:39 -0500 | [diff] [blame] | 64 | interrupt. |
| 65 | - interrupt-controller : boolean indicator that ECC Manager is an interrupt controller |
| 66 | - #interrupt-cells : must be set to 2. |
Thor Thayer | 8b39ab7 | 2016-03-21 11:01:43 -0500 | [diff] [blame] | 67 | - ranges : standard definition, should translate from local addresses |
| 68 | |
| 69 | Subcomponents: |
| 70 | |
| 71 | L2 Cache ECC |
| 72 | Required Properties: |
| 73 | - compatible : Should be "altr,socfpga-a10-l2-ecc" |
| 74 | - reg : Address and size for ECC error interrupt clear registers. |
Thor Thayer | 47d7800 | 2016-05-25 11:29:39 -0500 | [diff] [blame] | 75 | - interrupts : Should be single bit error interrupt, then double bit error |
| 76 | interrupt, in this order. |
Thor Thayer | 8b39ab7 | 2016-03-21 11:01:43 -0500 | [diff] [blame] | 77 | |
Thor Thayer | abd56b3 | 2016-03-31 13:48:04 -0500 | [diff] [blame] | 78 | On-Chip RAM ECC |
| 79 | Required Properties: |
| 80 | - compatible : Should be "altr,socfpga-a10-ocram-ecc" |
| 81 | - reg : Address and size for ECC block registers. |
Thor Thayer | 47d7800 | 2016-05-25 11:29:39 -0500 | [diff] [blame] | 82 | - interrupts : Should be single bit error interrupt, then double bit error |
| 83 | interrupt, in this order. |
Thor Thayer | abd56b3 | 2016-03-31 13:48:04 -0500 | [diff] [blame] | 84 | |
Thor Thayer | f103ad1 | 2016-06-22 08:58:56 -0500 | [diff] [blame] | 85 | Ethernet FIFO ECC |
| 86 | Required Properties: |
| 87 | - compatible : Should be "altr,socfpga-eth-mac-ecc" |
| 88 | - reg : Address and size for ECC block registers. |
| 89 | - altr,ecc-parent : phandle to parent Ethernet node. |
| 90 | - interrupts : Should be single bit error interrupt, then double bit error |
| 91 | interrupt, in this order. |
| 92 | |
Thor Thayer | 8b39ab7 | 2016-03-21 11:01:43 -0500 | [diff] [blame] | 93 | Example: |
| 94 | |
| 95 | eccmgr: eccmgr@ffd06000 { |
| 96 | compatible = "altr,socfpga-a10-ecc-manager"; |
| 97 | altr,sysmgr-syscon = <&sysmgr>; |
| 98 | #address-cells = <1>; |
| 99 | #size-cells = <1>; |
| 100 | interrupts = <0 2 IRQ_TYPE_LEVEL_HIGH>, |
| 101 | <0 0 IRQ_TYPE_LEVEL_HIGH>; |
Thor Thayer | 47d7800 | 2016-05-25 11:29:39 -0500 | [diff] [blame] | 102 | interrupt-controller; |
| 103 | #interrupt-cells = <2>; |
Thor Thayer | 8b39ab7 | 2016-03-21 11:01:43 -0500 | [diff] [blame] | 104 | ranges; |
| 105 | |
| 106 | l2-ecc@ffd06010 { |
| 107 | compatible = "altr,socfpga-a10-l2-ecc"; |
| 108 | reg = <0xffd06010 0x4>; |
Thor Thayer | 47d7800 | 2016-05-25 11:29:39 -0500 | [diff] [blame] | 109 | interrupts = <0 IRQ_TYPE_LEVEL_HIGH>, |
| 110 | <32 IRQ_TYPE_LEVEL_HIGH>; |
Thor Thayer | 8b39ab7 | 2016-03-21 11:01:43 -0500 | [diff] [blame] | 111 | }; |
Thor Thayer | abd56b3 | 2016-03-31 13:48:04 -0500 | [diff] [blame] | 112 | |
| 113 | ocram-ecc@ff8c3000 { |
| 114 | compatible = "altr,socfpga-a10-ocram-ecc"; |
| 115 | reg = <0xff8c3000 0x90>; |
Thor Thayer | 47d7800 | 2016-05-25 11:29:39 -0500 | [diff] [blame] | 116 | interrupts = <1 IRQ_TYPE_LEVEL_HIGH>, |
| 117 | <33 IRQ_TYPE_LEVEL_HIGH> ; |
Thor Thayer | abd56b3 | 2016-03-31 13:48:04 -0500 | [diff] [blame] | 118 | }; |
Thor Thayer | f103ad1 | 2016-06-22 08:58:56 -0500 | [diff] [blame] | 119 | |
| 120 | emac0-rx-ecc@ff8c0800 { |
| 121 | compatible = "altr,socfpga-eth-mac-ecc"; |
| 122 | reg = <0xff8c0800 0x400>; |
| 123 | altr,ecc-parent = <&gmac0>; |
| 124 | interrupts = <4 IRQ_TYPE_LEVEL_HIGH>, |
| 125 | <36 IRQ_TYPE_LEVEL_HIGH>; |
| 126 | }; |
| 127 | |
| 128 | emac0-tx-ecc@ff8c0c00 { |
| 129 | compatible = "altr,socfpga-eth-mac-ecc"; |
| 130 | reg = <0xff8c0c00 0x400>; |
| 131 | altr,ecc-parent = <&gmac0>; |
| 132 | interrupts = <5 IRQ_TYPE_LEVEL_HIGH>, |
| 133 | <37 IRQ_TYPE_LEVEL_HIGH>; |
| 134 | }; |
Thor Thayer | 8b39ab7 | 2016-03-21 11:01:43 -0500 | [diff] [blame] | 135 | }; |