ARM: mvebu: Relocate Armada 370/XP PCIe device tree nodes
Now that mbus has been added to the device tree, it's possible to move the PCIe nodes out of internal registers, placing it directly below the mbus. This is a more accurate representation of the hardware. Moving the PCIe nodes, we now need to introduce an extra cell to encode the window target ID and attribute. Since this depends on the PCIe port, we split the ranges translation entries, to correspond to each MBus window. Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> Signed-off-by: Ezequiel Garcia <ezequiel.garcia@free-electrons.com> Tested-by: Andrew Lunn <andrew@lunn.ch> Tested-by: Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com> Signed-off-by: Jason Cooper <jason@lakedaemon.net>
This commit is contained in:
		
					parent
					
						
							
								de1af8d486
							
						
					
				
			
			
				commit
				
					
						14fd8ed0a7
					
				
			
		
					 9 changed files with 612 additions and 542 deletions
				
			
		|  | @ -28,6 +28,22 @@ | ||||||
| 		ranges = <MBUS_ID(0xf0, 0x01) 0 0xd0000000 0x100000 | 		ranges = <MBUS_ID(0xf0, 0x01) 0 0xd0000000 0x100000 | ||||||
| 			  MBUS_ID(0x01, 0xe0) 0 0xfff00000 0x100000>; | 			  MBUS_ID(0x01, 0xe0) 0 0xfff00000 0x100000>; | ||||||
| 
 | 
 | ||||||
|  | 		pcie-controller { | ||||||
|  | 			status = "okay"; | ||||||
|  | 
 | ||||||
|  | 			/* Internal mini-PCIe connector */ | ||||||
|  | 			pcie@1,0 { | ||||||
|  | 				/* Port 0, Lane 0 */ | ||||||
|  | 				status = "okay"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			/* Connected on the PCB to a USB 3.0 XHCI controller */ | ||||||
|  | 			pcie@2,0 { | ||||||
|  | 				/* Port 1, Lane 0 */ | ||||||
|  | 				status = "okay"; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 
 | ||||||
| 		internal-regs { | 		internal-regs { | ||||||
| 			serial@12000 { | 			serial@12000 { | ||||||
| 				clock-frequency = <200000000>; | 				clock-frequency = <200000000>; | ||||||
|  | @ -123,22 +139,6 @@ | ||||||
| 					reg = <0x25>; | 					reg = <0x25>; | ||||||
| 				}; | 				}; | ||||||
| 			}; | 			}; | ||||||
| 
 |  | ||||||
| 			pcie-controller { |  | ||||||
| 				status = "okay"; |  | ||||||
| 
 |  | ||||||
| 				/* Internal mini-PCIe connector */ |  | ||||||
| 				pcie@1,0 { |  | ||||||
| 					/* Port 0, Lane 0 */ |  | ||||||
| 					status = "okay"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				/* Connected on the PCB to a USB 3.0 XHCI controller */ |  | ||||||
| 				pcie@2,0 { |  | ||||||
| 					/* Port 1, Lane 0 */ |  | ||||||
| 					status = "okay"; |  | ||||||
| 				}; |  | ||||||
| 			}; |  | ||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -44,6 +44,8 @@ | ||||||
| 		#size-cells = <1>; | 		#size-cells = <1>; | ||||||
| 		controller = <&mbusc>; | 		controller = <&mbusc>; | ||||||
| 		interrupt-parent = <&mpic>; | 		interrupt-parent = <&mpic>; | ||||||
|  | 		pcie-mem-aperture = <0xe0000000 0x8000000>; | ||||||
|  | 		pcie-io-aperture  = <0xe8000000 0x100000>; | ||||||
| 
 | 
 | ||||||
| 		devbus-bootcs { | 		devbus-bootcs { | ||||||
| 			compatible = "marvell,mvebu-devbus"; | 			compatible = "marvell,mvebu-devbus"; | ||||||
|  |  | ||||||
|  | @ -36,6 +36,59 @@ | ||||||
| 			reg = <MBUS_ID(0x01, 0xe0) 0 0x100000>; | 			reg = <MBUS_ID(0x01, 0xe0) 0 0x100000>; | ||||||
| 		}; | 		}; | ||||||
| 
 | 
 | ||||||
|  | 		pcie-controller { | ||||||
|  | 			compatible = "marvell,armada-370-pcie"; | ||||||
|  | 			status = "disabled"; | ||||||
|  | 			device_type = "pci"; | ||||||
|  | 
 | ||||||
|  | 			#address-cells = <3>; | ||||||
|  | 			#size-cells = <2>; | ||||||
|  | 
 | ||||||
|  | 			bus-range = <0x00 0xff>; | ||||||
|  | 
 | ||||||
|  | 			ranges = | ||||||
|  | 			       <0x82000000 0 0x40000 MBUS_ID(0xf0, 0x01) 0x40000 0 0x00002000 | ||||||
|  | 				0x82000000 0 0x80000 MBUS_ID(0xf0, 0x01) 0x80000 0 0x00002000 | ||||||
|  | 				0x82000000 0x1 0     MBUS_ID(0x04, 0xe8) 0       1 0 /* Port 0.0 MEM */ | ||||||
|  | 				0x81000000 0x1 0     MBUS_ID(0x04, 0xe0) 0       1 0 /* Port 0.0 IO  */ | ||||||
|  | 				0x82000000 0x2 0     MBUS_ID(0x08, 0xe8) 0       1 0 /* Port 1.0 MEM */ | ||||||
|  | 				0x81000000 0x2 0     MBUS_ID(0x08, 0xe0) 0       1 0 /* Port 1.0 IO  */>; | ||||||
|  | 
 | ||||||
|  | 			pcie@1,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82000800 0 0x40000 0 0x2000>; | ||||||
|  | 				reg = <0x0800 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  |                                 ranges = <0x82000000 0 0 0x82000000 0x1 0 1 0 | ||||||
|  |                                           0x81000000 0 0 0x81000000 0x1 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 58>; | ||||||
|  | 				marvell,pcie-port = <0>; | ||||||
|  | 				marvell,pcie-lane = <0>; | ||||||
|  | 				clocks = <&gateclk 5>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@2,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82002800 0 0x80000 0 0x2000>; | ||||||
|  | 				reg = <0x1000 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  |                                 ranges = <0x82000000 0 0 0x82000000 0x2 0 1 0 | ||||||
|  |                                           0x81000000 0 0 0x81000000 0x2 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 62>; | ||||||
|  | 				marvell,pcie-port = <1>; | ||||||
|  | 				marvell,pcie-lane = <0>; | ||||||
|  | 				clocks = <&gateclk 9>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 
 | ||||||
| 		internal-regs { | 		internal-regs { | ||||||
| 			system-controller@18200 { | 			system-controller@18200 { | ||||||
| 				compatible = "marvell,armada-370-xp-system-controller"; | 				compatible = "marvell,armada-370-xp-system-controller"; | ||||||
|  | @ -174,54 +227,6 @@ | ||||||
| 					0x18304 0x4>; | 					0x18304 0x4>; | ||||||
| 				status = "okay"; | 				status = "okay"; | ||||||
| 			}; | 			}; | ||||||
| 
 |  | ||||||
| 			pcie-controller { |  | ||||||
| 				compatible = "marvell,armada-370-pcie"; |  | ||||||
| 				status = "disabled"; |  | ||||||
| 				device_type = "pci"; |  | ||||||
| 
 |  | ||||||
| 				#address-cells = <3>; |  | ||||||
| 				#size-cells = <2>; |  | ||||||
| 
 |  | ||||||
| 				bus-range = <0x00 0xff>; |  | ||||||
| 
 |  | ||||||
| 				ranges = <0x82000000 0 0x40000 0x40000 0 0x00002000   /* Port 0.0 registers */ |  | ||||||
| 					0x82000000 0 0x80000 0x80000 0 0x00002000   /* Port 1.0 registers */ |  | ||||||
| 					0x82000000 0 0xe0000000 0xe0000000 0 0x08000000   /* non-prefetchable memory */ |  | ||||||
| 					0x81000000 0 0          0xe8000000 0 0x00100000>; /* downstream I/O */ |  | ||||||
| 
 |  | ||||||
| 				pcie@1,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82000800 0 0x40000 0 0x2000>; |  | ||||||
| 					reg = <0x0800 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 58>; |  | ||||||
| 					marvell,pcie-port = <0>; |  | ||||||
| 					marvell,pcie-lane = <0>; |  | ||||||
| 					clocks = <&gateclk 5>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@2,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82002800 0 0x80000 0 0x2000>; |  | ||||||
| 					reg = <0x1000 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 62>; |  | ||||||
| 					marvell,pcie-port = <1>; |  | ||||||
| 					marvell,pcie-lane = <0>; |  | ||||||
| 					clocks = <&gateclk 9>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 			}; |  | ||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -62,6 +62,39 @@ | ||||||
| 			}; | 			}; | ||||||
| 		}; | 		}; | ||||||
| 
 | 
 | ||||||
|  | 		pcie-controller { | ||||||
|  | 			status = "okay"; | ||||||
|  | 
 | ||||||
|  | 			/* | ||||||
|  | 			 * All 6 slots are physically present as | ||||||
|  | 			 * standard PCIe slots on the board. | ||||||
|  | 			 */ | ||||||
|  | 			pcie@1,0 { | ||||||
|  | 				/* Port 0, Lane 0 */ | ||||||
|  | 				status = "okay"; | ||||||
|  | 			}; | ||||||
|  | 			pcie@2,0 { | ||||||
|  | 				/* Port 0, Lane 1 */ | ||||||
|  | 				status = "okay"; | ||||||
|  | 			}; | ||||||
|  | 			pcie@3,0 { | ||||||
|  | 				/* Port 0, Lane 2 */ | ||||||
|  | 				status = "okay"; | ||||||
|  | 			}; | ||||||
|  | 			pcie@4,0 { | ||||||
|  | 				/* Port 0, Lane 3 */ | ||||||
|  | 				status = "okay"; | ||||||
|  | 			}; | ||||||
|  | 			pcie@9,0 { | ||||||
|  | 				/* Port 2, Lane 0 */ | ||||||
|  | 				status = "okay"; | ||||||
|  | 			}; | ||||||
|  | 			pcie@10,0 { | ||||||
|  | 				/* Port 3, Lane 0 */ | ||||||
|  | 				status = "okay"; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 
 | ||||||
| 		internal-regs { | 		internal-regs { | ||||||
| 			serial@12000 { | 			serial@12000 { | ||||||
| 				clock-frequency = <250000000>; | 				clock-frequency = <250000000>; | ||||||
|  | @ -155,40 +188,6 @@ | ||||||
| 					spi-max-frequency = <20000000>; | 					spi-max-frequency = <20000000>; | ||||||
| 				}; | 				}; | ||||||
| 			}; | 			}; | ||||||
| 
 |  | ||||||
| 			pcie-controller { |  | ||||||
| 				status = "okay"; |  | ||||||
| 
 |  | ||||||
| 				/* |  | ||||||
| 				 * All 6 slots are physically present as |  | ||||||
| 				 * standard PCIe slots on the board. |  | ||||||
| 				 */ |  | ||||||
| 				pcie@1,0 { |  | ||||||
| 					/* Port 0, Lane 0 */ |  | ||||||
| 					status = "okay"; |  | ||||||
| 				}; |  | ||||||
| 				pcie@2,0 { |  | ||||||
| 					/* Port 0, Lane 1 */ |  | ||||||
| 					status = "okay"; |  | ||||||
| 				}; |  | ||||||
| 				pcie@3,0 { |  | ||||||
| 					/* Port 0, Lane 2 */ |  | ||||||
| 					status = "okay"; |  | ||||||
| 				}; |  | ||||||
| 				pcie@4,0 { |  | ||||||
| 					/* Port 0, Lane 3 */ |  | ||||||
| 					status = "okay"; |  | ||||||
| 				}; |  | ||||||
| 				pcie@9,0 { |  | ||||||
| 					/* Port 2, Lane 0 */ |  | ||||||
| 					status = "okay"; |  | ||||||
| 				}; |  | ||||||
| 				pcie@10,0 { |  | ||||||
| 					/* Port 3, Lane 0 */ |  | ||||||
| 					status = "okay"; |  | ||||||
| 				}; |  | ||||||
| 			}; |  | ||||||
| 
 |  | ||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -71,6 +71,27 @@ | ||||||
| 			}; | 			}; | ||||||
| 		}; | 		}; | ||||||
| 
 | 
 | ||||||
|  | 		pcie-controller { | ||||||
|  | 			status = "okay"; | ||||||
|  | 
 | ||||||
|  | 			/* | ||||||
|  | 			 * The 3 slots are physically present as | ||||||
|  | 			 * standard PCIe slots on the board. | ||||||
|  | 			 */ | ||||||
|  | 			pcie@1,0 { | ||||||
|  | 				/* Port 0, Lane 0 */ | ||||||
|  | 				status = "okay"; | ||||||
|  | 			}; | ||||||
|  | 			pcie@9,0 { | ||||||
|  | 				/* Port 2, Lane 0 */ | ||||||
|  | 				status = "okay"; | ||||||
|  | 			}; | ||||||
|  | 			pcie@10,0 { | ||||||
|  | 				/* Port 3, Lane 0 */ | ||||||
|  | 				status = "okay"; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 
 | ||||||
| 		internal-regs { | 		internal-regs { | ||||||
| 			serial@12000 { | 			serial@12000 { | ||||||
| 				clock-frequency = <250000000>; | 				clock-frequency = <250000000>; | ||||||
|  | @ -154,27 +175,6 @@ | ||||||
| 					spi-max-frequency = <108000000>; | 					spi-max-frequency = <108000000>; | ||||||
| 				}; | 				}; | ||||||
| 			}; | 			}; | ||||||
| 
 |  | ||||||
| 			pcie-controller { |  | ||||||
| 				status = "okay"; |  | ||||||
| 
 |  | ||||||
| 				/* |  | ||||||
| 				 * The 3 slots are physically present as |  | ||||||
| 				 * standard PCIe slots on the board. |  | ||||||
| 				 */ |  | ||||||
| 				pcie@1,0 { |  | ||||||
| 					/* Port 0, Lane 0 */ |  | ||||||
| 					status = "okay"; |  | ||||||
| 				}; |  | ||||||
| 				pcie@9,0 { |  | ||||||
| 					/* Port 2, Lane 0 */ |  | ||||||
| 					status = "okay"; |  | ||||||
| 				}; |  | ||||||
| 				pcie@10,0 { |  | ||||||
| 					/* Port 3, Lane 0 */ |  | ||||||
| 					status = "okay"; |  | ||||||
| 				}; |  | ||||||
| 			}; |  | ||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -44,6 +44,124 @@ | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
| 	soc { | 	soc { | ||||||
|  | 		/* | ||||||
|  | 		 * MV78230 has 2 PCIe units Gen2.0: One unit can be | ||||||
|  | 		 * configured as x4 or quad x1 lanes. One unit is | ||||||
|  | 		 * x4/x1. | ||||||
|  | 		 */ | ||||||
|  | 		pcie-controller { | ||||||
|  | 			compatible = "marvell,armada-xp-pcie"; | ||||||
|  | 			status = "disabled"; | ||||||
|  | 			device_type = "pci"; | ||||||
|  | 
 | ||||||
|  | 			#address-cells = <3>; | ||||||
|  | 			#size-cells = <2>; | ||||||
|  | 
 | ||||||
|  | 			bus-range = <0x00 0xff>; | ||||||
|  | 
 | ||||||
|  | 			ranges = | ||||||
|  | 			       <0x82000000 0 0x40000 MBUS_ID(0xf0, 0x01) 0x40000 0 0x00002000   /* Port 0.0 registers */ | ||||||
|  | 				0x82000000 0 0x42000 MBUS_ID(0xf0, 0x01) 0x42000 0 0x00002000   /* Port 2.0 registers */ | ||||||
|  | 				0x82000000 0 0x44000 MBUS_ID(0xf0, 0x01) 0x44000 0 0x00002000   /* Port 0.1 registers */ | ||||||
|  | 				0x82000000 0 0x48000 MBUS_ID(0xf0, 0x01) 0x48000 0 0x00002000   /* Port 0.2 registers */ | ||||||
|  | 				0x82000000 0 0x4c000 MBUS_ID(0xf0, 0x01) 0x4c000 0 0x00002000   /* Port 0.3 registers */ | ||||||
|  | 				0x82000000 0x1 0       MBUS_ID(0x04, 0xe8) 0 1 0 /* Port 0.0 MEM */ | ||||||
|  | 				0x81000000 0x1 0       MBUS_ID(0x04, 0xe0) 0 1 0 /* Port 0.0 IO  */ | ||||||
|  | 				0x82000000 0x2 0       MBUS_ID(0x04, 0xd8) 0 1 0 /* Port 0.1 MEM */ | ||||||
|  | 				0x81000000 0x2 0       MBUS_ID(0x04, 0xd0) 0 1 0 /* Port 0.1 IO  */ | ||||||
|  | 				0x82000000 0x3 0       MBUS_ID(0x04, 0xb8) 0 1 0 /* Port 0.2 MEM */ | ||||||
|  | 				0x81000000 0x3 0       MBUS_ID(0x04, 0xb0) 0 1 0 /* Port 0.2 IO  */ | ||||||
|  | 				0x82000000 0x4 0       MBUS_ID(0x04, 0x78) 0 1 0 /* Port 0.3 MEM */ | ||||||
|  | 				0x81000000 0x4 0       MBUS_ID(0x04, 0x70) 0 1 0 /* Port 0.3 IO  */ | ||||||
|  | 				0x82000000 0x9 0       MBUS_ID(0x04, 0xf8) 0 1 0 /* Port 2.0 MEM */ | ||||||
|  | 				0x81000000 0x9 0       MBUS_ID(0x04, 0xf0) 0 1 0 /* Port 2.0 IO  */>; | ||||||
|  | 
 | ||||||
|  | 			pcie@1,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82000800 0 0x40000 0 0x2000>; | ||||||
|  | 				reg = <0x0800 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x1 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x1 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 58>; | ||||||
|  | 				marvell,pcie-port = <0>; | ||||||
|  | 				marvell,pcie-lane = <0>; | ||||||
|  | 				clocks = <&gateclk 5>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@2,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82000800 0 0x44000 0 0x2000>; | ||||||
|  | 				reg = <0x1000 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x2 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x2 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 59>; | ||||||
|  | 				marvell,pcie-port = <0>; | ||||||
|  | 				marvell,pcie-lane = <1>; | ||||||
|  | 				clocks = <&gateclk 6>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@3,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82000800 0 0x48000 0 0x2000>; | ||||||
|  | 				reg = <0x1800 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x3 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x3 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 60>; | ||||||
|  | 				marvell,pcie-port = <0>; | ||||||
|  | 				marvell,pcie-lane = <2>; | ||||||
|  | 				clocks = <&gateclk 7>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@4,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82000800 0 0x4c000 0 0x2000>; | ||||||
|  | 				reg = <0x2000 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x4 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x4 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 61>; | ||||||
|  | 				marvell,pcie-port = <0>; | ||||||
|  | 				marvell,pcie-lane = <3>; | ||||||
|  | 				clocks = <&gateclk 8>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@9,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82000800 0 0x42000 0 0x2000>; | ||||||
|  | 				reg = <0x4800 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x9 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x9 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 99>; | ||||||
|  | 				marvell,pcie-port = <2>; | ||||||
|  | 				marvell,pcie-lane = <0>; | ||||||
|  | 				clocks = <&gateclk 26>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 
 | ||||||
| 		internal-regs { | 		internal-regs { | ||||||
| 			pinctrl { | 			pinctrl { | ||||||
| 				compatible = "marvell,mv78230-pinctrl"; | 				compatible = "marvell,mv78230-pinctrl"; | ||||||
|  | @ -77,110 +195,6 @@ | ||||||
| 				#interrupts-cells = <2>; | 				#interrupts-cells = <2>; | ||||||
| 				interrupts = <87>, <88>, <89>; | 				interrupts = <87>, <88>, <89>; | ||||||
| 			}; | 			}; | ||||||
| 
 |  | ||||||
| 			/* |  | ||||||
| 			 * MV78230 has 2 PCIe units Gen2.0: One unit can be |  | ||||||
| 			 * configured as x4 or quad x1 lanes. One unit is |  | ||||||
| 			 * x4/x1. |  | ||||||
| 			 */ |  | ||||||
| 			pcie-controller { |  | ||||||
| 				compatible = "marvell,armada-xp-pcie"; |  | ||||||
| 				status = "disabled"; |  | ||||||
| 				device_type = "pci"; |  | ||||||
| 
 |  | ||||||
| #address-cells = <3>; |  | ||||||
| #size-cells = <2>; |  | ||||||
| 
 |  | ||||||
| 				bus-range = <0x00 0xff>; |  | ||||||
| 
 |  | ||||||
| 				ranges = <0x82000000 0 0x40000 0x40000 0 0x00002000   /* Port 0.0 registers */ |  | ||||||
| 					0x82000000 0 0x42000 0x42000 0 0x00002000   /* Port 2.0 registers */ |  | ||||||
| 					0x82000000 0 0x44000 0x44000 0 0x00002000   /* Port 0.1 registers */ |  | ||||||
| 					0x82000000 0 0x48000 0x48000 0 0x00002000   /* Port 0.2 registers */ |  | ||||||
| 					0x82000000 0 0x4c000 0x4c000 0 0x00002000   /* Port 0.3 registers */ |  | ||||||
| 					0x82000000 0 0xe0000000 0xe0000000 0 0x08000000   /* non-prefetchable memory */ |  | ||||||
| 					0x81000000 0 0	  0xe8000000 0 0x00100000>; /* downstream I/O */ |  | ||||||
| 
 |  | ||||||
| 				pcie@1,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82000800 0 0x40000 0 0x2000>; |  | ||||||
| 					reg = <0x0800 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 58>; |  | ||||||
| 					marvell,pcie-port = <0>; |  | ||||||
| 					marvell,pcie-lane = <0>; |  | ||||||
| 					clocks = <&gateclk 5>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@2,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82000800 0 0x44000 0 0x2000>; |  | ||||||
| 					reg = <0x1000 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 59>; |  | ||||||
| 					marvell,pcie-port = <0>; |  | ||||||
| 					marvell,pcie-lane = <1>; |  | ||||||
| 					clocks = <&gateclk 6>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@3,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82000800 0 0x48000 0 0x2000>; |  | ||||||
| 					reg = <0x1800 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 60>; |  | ||||||
| 					marvell,pcie-port = <0>; |  | ||||||
| 					marvell,pcie-lane = <2>; |  | ||||||
| 					clocks = <&gateclk 7>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@4,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82000800 0 0x4c000 0 0x2000>; |  | ||||||
| 					reg = <0x2000 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 61>; |  | ||||||
| 					marvell,pcie-port = <0>; |  | ||||||
| 					marvell,pcie-lane = <3>; |  | ||||||
| 					clocks = <&gateclk 8>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@9,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82000800 0 0x42000 0 0x2000>; |  | ||||||
| 					reg = <0x4800 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 99>; |  | ||||||
| 					marvell,pcie-port = <2>; |  | ||||||
| 					marvell,pcie-lane = <0>; |  | ||||||
| 					clocks = <&gateclk 26>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 			}; |  | ||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -45,6 +45,145 @@ | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
| 	soc { | 	soc { | ||||||
|  | 		/* | ||||||
|  | 		 * MV78260 has 3 PCIe units Gen2.0: Two units can be | ||||||
|  | 		 * configured as x4 or quad x1 lanes. One unit is | ||||||
|  | 		 * x4/x1. | ||||||
|  | 		 */ | ||||||
|  | 		pcie-controller { | ||||||
|  | 			compatible = "marvell,armada-xp-pcie"; | ||||||
|  | 			status = "disabled"; | ||||||
|  | 			device_type = "pci"; | ||||||
|  | 
 | ||||||
|  | 			#address-cells = <3>; | ||||||
|  | 			#size-cells = <2>; | ||||||
|  | 
 | ||||||
|  | 			bus-range = <0x00 0xff>; | ||||||
|  | 
 | ||||||
|  | 			ranges = | ||||||
|  | 			       <0x82000000 0 0x40000 MBUS_ID(0xf0, 0x01) 0x40000 0 0x00002000   /* Port 0.0 registers */ | ||||||
|  | 				0x82000000 0 0x42000 MBUS_ID(0xf0, 0x01) 0x42000 0 0x00002000   /* Port 2.0 registers */ | ||||||
|  | 				0x82000000 0 0x44000 MBUS_ID(0xf0, 0x01) 0x44000 0 0x00002000   /* Port 0.1 registers */ | ||||||
|  | 				0x82000000 0 0x48000 MBUS_ID(0xf0, 0x01) 0x48000 0 0x00002000   /* Port 0.2 registers */ | ||||||
|  | 				0x82000000 0 0x4c000 MBUS_ID(0xf0, 0x01) 0x4c000 0 0x00002000   /* Port 0.3 registers */ | ||||||
|  | 				0x82000000 0 0x80000 MBUS_ID(0xf0, 0x01) 0x80000 0 0x00002000   /* Port 1.0 registers */ | ||||||
|  | 				0x82000000 0 0x82000 MBUS_ID(0xf0, 0x01) 0x82000 0 0x00002000   /* Port 3.0 registers */ | ||||||
|  | 				0x82000000 0x1 0     MBUS_ID(0x04, 0xe8) 0 1 0 /* Port 0.0 MEM */ | ||||||
|  | 				0x81000000 0x1 0     MBUS_ID(0x04, 0xe0) 0 1 0 /* Port 0.0 IO  */ | ||||||
|  | 				0x82000000 0x2 0     MBUS_ID(0x04, 0xd8) 0 1 0 /* Port 0.1 MEM */ | ||||||
|  | 				0x81000000 0x2 0     MBUS_ID(0x04, 0xd0) 0 1 0 /* Port 0.1 IO  */ | ||||||
|  | 				0x82000000 0x3 0     MBUS_ID(0x04, 0xb8) 0 1 0 /* Port 0.2 MEM */ | ||||||
|  | 				0x81000000 0x3 0     MBUS_ID(0x04, 0xb0) 0 1 0 /* Port 0.2 IO  */ | ||||||
|  | 				0x82000000 0x4 0     MBUS_ID(0x04, 0x78) 0 1 0 /* Port 0.3 MEM */ | ||||||
|  | 				0x81000000 0x4 0     MBUS_ID(0x04, 0x70) 0 1 0 /* Port 0.3 IO  */ | ||||||
|  | 				0x82000000 0x9 0     MBUS_ID(0x08, 0xe8) 0 1 0 /* Port 1.0 MEM */ | ||||||
|  | 				0x81000000 0x9 0     MBUS_ID(0x08, 0xe0) 0 1 0 /* Port 1.0 IO  */ | ||||||
|  | 				0x82000000 0xa 0     MBUS_ID(0x08, 0xf8) 0 1 0 /* Port 3.0 MEM */ | ||||||
|  | 				0x81000000 0xa 0     MBUS_ID(0x08, 0xf0) 0 1 0 /* Port 3.0 IO  */>; | ||||||
|  | 
 | ||||||
|  | 			pcie@1,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82000800 0 0x40000 0 0x2000>; | ||||||
|  | 				reg = <0x0800 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x1 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x1 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 58>; | ||||||
|  | 				marvell,pcie-port = <0>; | ||||||
|  | 				marvell,pcie-lane = <0>; | ||||||
|  | 				clocks = <&gateclk 5>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@2,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82000800 0 0x44000 0 0x2000>; | ||||||
|  | 				reg = <0x1000 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  |                                 ranges = <0x82000000 0 0 0x82000000 0x2 0 1 0 | ||||||
|  |                                           0x81000000 0 0 0x81000000 0x2 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 59>; | ||||||
|  | 				marvell,pcie-port = <0>; | ||||||
|  | 				marvell,pcie-lane = <1>; | ||||||
|  | 				clocks = <&gateclk 6>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@3,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82000800 0 0x48000 0 0x2000>; | ||||||
|  | 				reg = <0x1800 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x3 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x3 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 60>; | ||||||
|  | 				marvell,pcie-port = <0>; | ||||||
|  | 				marvell,pcie-lane = <2>; | ||||||
|  | 				clocks = <&gateclk 7>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@4,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82000800 0 0x4c000 0 0x2000>; | ||||||
|  | 				reg = <0x2000 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x4 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x4 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 61>; | ||||||
|  | 				marvell,pcie-port = <0>; | ||||||
|  | 				marvell,pcie-lane = <3>; | ||||||
|  | 				clocks = <&gateclk 8>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@9,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82000800 0 0x42000 0 0x2000>; | ||||||
|  | 				reg = <0x4800 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x9 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x9 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 99>; | ||||||
|  | 				marvell,pcie-port = <2>; | ||||||
|  | 				marvell,pcie-lane = <0>; | ||||||
|  | 				clocks = <&gateclk 26>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@10,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82000800 0 0x82000 0 0x2000>; | ||||||
|  | 				reg = <0x5000 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0xa 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0xa 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 103>; | ||||||
|  | 				marvell,pcie-port = <3>; | ||||||
|  | 				marvell,pcie-lane = <0>; | ||||||
|  | 				clocks = <&gateclk 27>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 
 | ||||||
| 		internal-regs { | 		internal-regs { | ||||||
| 			pinctrl { | 			pinctrl { | ||||||
| 				compatible = "marvell,mv78260-pinctrl"; | 				compatible = "marvell,mv78260-pinctrl"; | ||||||
|  | @ -97,128 +236,6 @@ | ||||||
| 				clocks = <&gateclk 1>; | 				clocks = <&gateclk 1>; | ||||||
| 				status = "disabled"; | 				status = "disabled"; | ||||||
| 			}; | 			}; | ||||||
| 
 |  | ||||||
| 			/* |  | ||||||
| 			 * MV78260 has 3 PCIe units Gen2.0: Two units can be |  | ||||||
| 			 * configured as x4 or quad x1 lanes. One unit is |  | ||||||
| 			 * x4/x1. |  | ||||||
| 			 */ |  | ||||||
| 			pcie-controller { |  | ||||||
| 				compatible = "marvell,armada-xp-pcie"; |  | ||||||
| 				status = "disabled"; |  | ||||||
| 				device_type = "pci"; |  | ||||||
| 
 |  | ||||||
| 				#address-cells = <3>; |  | ||||||
| 				#size-cells = <2>; |  | ||||||
| 
 |  | ||||||
| 				bus-range = <0x00 0xff>; |  | ||||||
| 
 |  | ||||||
| 				ranges = <0x82000000 0 0x40000 0x40000 0 0x00002000   /* Port 0.0 registers */ |  | ||||||
| 					0x82000000 0 0x42000 0x42000 0 0x00002000   /* Port 2.0 registers */ |  | ||||||
| 					0x82000000 0 0x44000 0x44000 0 0x00002000   /* Port 0.1 registers */ |  | ||||||
| 					0x82000000 0 0x48000 0x48000 0 0x00002000   /* Port 0.2 registers */ |  | ||||||
| 					0x82000000 0 0x4c000 0x4c000 0 0x00002000   /* Port 0.3 registers */ |  | ||||||
| 					0x82000000 0 0x80000 0x80000 0 0x00002000   /* Port 1.0 registers */ |  | ||||||
| 					0x82000000 0 0x82000 0x82000 0 0x00002000   /* Port 3.0 registers */ |  | ||||||
| 					0x82000000 0 0xe0000000 0xe0000000 0 0x08000000   /* non-prefetchable memory */ |  | ||||||
| 					0x81000000 0 0	  0xe8000000 0 0x00100000>; /* downstream I/O */ |  | ||||||
| 
 |  | ||||||
| 				pcie@1,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82000800 0 0x40000 0 0x2000>; |  | ||||||
| 					reg = <0x0800 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 58>; |  | ||||||
| 					marvell,pcie-port = <0>; |  | ||||||
| 					marvell,pcie-lane = <0>; |  | ||||||
| 					clocks = <&gateclk 5>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@2,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82000800 0 0x44000 0 0x2000>; |  | ||||||
| 					reg = <0x1000 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 59>; |  | ||||||
| 					marvell,pcie-port = <0>; |  | ||||||
| 					marvell,pcie-lane = <1>; |  | ||||||
| 					clocks = <&gateclk 6>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@3,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82000800 0 0x48000 0 0x2000>; |  | ||||||
| 					reg = <0x1800 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 60>; |  | ||||||
| 					marvell,pcie-port = <0>; |  | ||||||
| 					marvell,pcie-lane = <2>; |  | ||||||
| 					clocks = <&gateclk 7>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@4,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82000800 0 0x4c000 0 0x2000>; |  | ||||||
| 					reg = <0x2000 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 61>; |  | ||||||
| 					marvell,pcie-port = <0>; |  | ||||||
| 					marvell,pcie-lane = <3>; |  | ||||||
| 					clocks = <&gateclk 8>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@9,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82000800 0 0x42000 0 0x2000>; |  | ||||||
| 					reg = <0x4800 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 99>; |  | ||||||
| 					marvell,pcie-port = <2>; |  | ||||||
| 					marvell,pcie-lane = <0>; |  | ||||||
| 					clocks = <&gateclk 26>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@10,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82000800 0 0x82000 0 0x2000>; |  | ||||||
| 					reg = <0x5000 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 103>; |  | ||||||
| 					marvell,pcie-port = <3>; |  | ||||||
| 					marvell,pcie-lane = <0>; |  | ||||||
| 					clocks = <&gateclk 27>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 			}; |  | ||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -61,6 +61,227 @@ | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
| 	soc { | 	soc { | ||||||
|  | 		/* | ||||||
|  | 		 * MV78460 has 4 PCIe units Gen2.0: Two units can be | ||||||
|  | 		 * configured as x4 or quad x1 lanes. Two units are | ||||||
|  | 		 * x4/x1. | ||||||
|  | 		 */ | ||||||
|  | 		pcie-controller { | ||||||
|  | 			compatible = "marvell,armada-xp-pcie"; | ||||||
|  | 			status = "disabled"; | ||||||
|  | 			device_type = "pci"; | ||||||
|  | 
 | ||||||
|  | 			#address-cells = <3>; | ||||||
|  | 			#size-cells = <2>; | ||||||
|  | 
 | ||||||
|  | 			bus-range = <0x00 0xff>; | ||||||
|  | 
 | ||||||
|  | 			ranges = | ||||||
|  | 			       <0x82000000 0 0x40000 MBUS_ID(0xf0, 0x01) 0x40000 0 0x00002000   /* Port 0.0 registers */ | ||||||
|  | 				0x82000000 0 0x42000 MBUS_ID(0xf0, 0x01) 0x42000 0 0x00002000   /* Port 2.0 registers */ | ||||||
|  | 				0x82000000 0 0x44000 MBUS_ID(0xf0, 0x01) 0x44000 0 0x00002000   /* Port 0.1 registers */ | ||||||
|  | 				0x82000000 0 0x48000 MBUS_ID(0xf0, 0x01) 0x48000 0 0x00002000   /* Port 0.2 registers */ | ||||||
|  | 				0x82000000 0 0x4c000 MBUS_ID(0xf0, 0x01) 0x4c000 0 0x00002000   /* Port 0.3 registers */ | ||||||
|  | 				0x82000000 0 0x80000 MBUS_ID(0xf0, 0x01) 0x80000 0 0x00002000   /* Port 1.0 registers */ | ||||||
|  | 				0x82000000 0 0x82000 MBUS_ID(0xf0, 0x01) 0x82000 0 0x00002000   /* Port 3.0 registers */ | ||||||
|  | 				0x82000000 0 0x84000 MBUS_ID(0xf0, 0x01) 0x84000 0 0x00002000   /* Port 1.1 registers */ | ||||||
|  | 				0x82000000 0 0x88000 MBUS_ID(0xf0, 0x01) 0x88000 0 0x00002000   /* Port 1.2 registers */ | ||||||
|  | 				0x82000000 0 0x8c000 MBUS_ID(0xf0, 0x01) 0x8c000 0 0x00002000   /* Port 1.3 registers */ | ||||||
|  | 				0x82000000 0x1 0     MBUS_ID(0x04, 0xe8) 0 1 0 /* Port 0.0 MEM */ | ||||||
|  | 				0x81000000 0x1 0     MBUS_ID(0x04, 0xe0) 0 1 0 /* Port 0.0 IO  */ | ||||||
|  | 				0x82000000 0x2 0     MBUS_ID(0x04, 0xd8) 0 1 0 /* Port 0.1 MEM */ | ||||||
|  | 				0x81000000 0x2 0     MBUS_ID(0x04, 0xd0) 0 1 0 /* Port 0.1 IO  */ | ||||||
|  | 				0x82000000 0x3 0     MBUS_ID(0x04, 0xb8) 0 1 0 /* Port 0.2 MEM */ | ||||||
|  | 				0x81000000 0x3 0     MBUS_ID(0x04, 0xb0) 0 1 0 /* Port 0.2 IO  */ | ||||||
|  | 				0x82000000 0x4 0     MBUS_ID(0x04, 0x78) 0 1 0 /* Port 0.3 MEM */ | ||||||
|  | 				0x81000000 0x4 0     MBUS_ID(0x04, 0x70) 0 1 0 /* Port 0.3 IO  */ | ||||||
|  | 
 | ||||||
|  | 				0x82000000 0x5 0     MBUS_ID(0x08, 0xe8) 0 1 0 /* Port 1.0 MEM */ | ||||||
|  | 				0x81000000 0x5 0     MBUS_ID(0x08, 0xe0) 0 1 0 /* Port 1.0 IO  */ | ||||||
|  | 				0x82000000 0x6 0     MBUS_ID(0x08, 0xd8) 0 1 0 /* Port 1.1 MEM */ | ||||||
|  | 				0x81000000 0x6 0     MBUS_ID(0x08, 0xd0) 0 1 0 /* Port 1.1 IO  */ | ||||||
|  | 				0x82000000 0x7 0     MBUS_ID(0x08, 0xb8) 0 1 0 /* Port 1.2 MEM */ | ||||||
|  | 				0x81000000 0x7 0     MBUS_ID(0x08, 0xb0) 0 1 0 /* Port 1.2 IO  */ | ||||||
|  | 				0x82000000 0x8 0     MBUS_ID(0x08, 0x78) 0 1 0 /* Port 1.3 MEM */ | ||||||
|  | 				0x81000000 0x8 0     MBUS_ID(0x08, 0x70) 0 1 0 /* Port 1.3 IO  */ | ||||||
|  | 
 | ||||||
|  | 				0x82000000 0x9 0     MBUS_ID(0x04, 0xf8) 0 1 0 /* Port 2.0 MEM */ | ||||||
|  | 				0x81000000 0x9 0     MBUS_ID(0x04, 0xf0) 0 1 0 /* Port 2.0 IO  */ | ||||||
|  | 
 | ||||||
|  | 				0x82000000 0xa 0     MBUS_ID(0x08, 0xf8) 0 1 0 /* Port 3.0 MEM */ | ||||||
|  | 				0x81000000 0xa 0     MBUS_ID(0x08, 0xf0) 0 1 0 /* Port 3.0 IO  */>; | ||||||
|  | 
 | ||||||
|  | 			pcie@1,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82000800 0 0x40000 0 0x2000>; | ||||||
|  | 				reg = <0x0800 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x1 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x1 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 58>; | ||||||
|  | 				marvell,pcie-port = <0>; | ||||||
|  | 				marvell,pcie-lane = <0>; | ||||||
|  | 				clocks = <&gateclk 5>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@2,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82001000 0 0x44000 0 0x2000>; | ||||||
|  | 				reg = <0x1000 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x2 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x2 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 59>; | ||||||
|  | 				marvell,pcie-port = <0>; | ||||||
|  | 				marvell,pcie-lane = <1>; | ||||||
|  | 				clocks = <&gateclk 6>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@3,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82001800 0 0x48000 0 0x2000>; | ||||||
|  | 				reg = <0x1800 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x3 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x3 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 60>; | ||||||
|  | 				marvell,pcie-port = <0>; | ||||||
|  | 				marvell,pcie-lane = <2>; | ||||||
|  | 				clocks = <&gateclk 7>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@4,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82002000 0 0x4c000 0 0x2000>; | ||||||
|  | 				reg = <0x2000 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x4 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x4 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 61>; | ||||||
|  | 				marvell,pcie-port = <0>; | ||||||
|  | 				marvell,pcie-lane = <3>; | ||||||
|  | 				clocks = <&gateclk 8>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@5,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82002800 0 0x80000 0 0x2000>; | ||||||
|  | 				reg = <0x2800 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x5 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x5 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 62>; | ||||||
|  | 				marvell,pcie-port = <1>; | ||||||
|  | 				marvell,pcie-lane = <0>; | ||||||
|  | 				clocks = <&gateclk 9>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@6,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82003000 0 0x84000 0 0x2000>; | ||||||
|  | 				reg = <0x3000 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x6 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x6 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 63>; | ||||||
|  | 				marvell,pcie-port = <1>; | ||||||
|  | 				marvell,pcie-lane = <1>; | ||||||
|  | 				clocks = <&gateclk 10>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@7,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82003800 0 0x88000 0 0x2000>; | ||||||
|  | 				reg = <0x3800 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x7 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x7 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 64>; | ||||||
|  | 				marvell,pcie-port = <1>; | ||||||
|  | 				marvell,pcie-lane = <2>; | ||||||
|  | 				clocks = <&gateclk 11>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@8,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82004000 0 0x8c000 0 0x2000>; | ||||||
|  | 				reg = <0x4000 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x8 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x8 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 65>; | ||||||
|  | 				marvell,pcie-port = <1>; | ||||||
|  | 				marvell,pcie-lane = <3>; | ||||||
|  | 				clocks = <&gateclk 12>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@9,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82004800 0 0x42000 0 0x2000>; | ||||||
|  | 				reg = <0x4800 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0x9 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0x9 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 99>; | ||||||
|  | 				marvell,pcie-port = <2>; | ||||||
|  | 				marvell,pcie-lane = <0>; | ||||||
|  | 				clocks = <&gateclk 26>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 
 | ||||||
|  | 			pcie@10,0 { | ||||||
|  | 				device_type = "pci"; | ||||||
|  | 				assigned-addresses = <0x82005000 0 0x82000 0 0x2000>; | ||||||
|  | 				reg = <0x5000 0 0 0 0>; | ||||||
|  | 				#address-cells = <3>; | ||||||
|  | 				#size-cells = <2>; | ||||||
|  | 				#interrupt-cells = <1>; | ||||||
|  | 				ranges = <0x82000000 0 0 0x82000000 0xa 0 1 0 | ||||||
|  | 					  0x81000000 0 0 0x81000000 0xa 0 1 0>; | ||||||
|  | 				interrupt-map-mask = <0 0 0 0>; | ||||||
|  | 				interrupt-map = <0 0 0 0 &mpic 103>; | ||||||
|  | 				marvell,pcie-port = <3>; | ||||||
|  | 				marvell,pcie-lane = <0>; | ||||||
|  | 				clocks = <&gateclk 27>; | ||||||
|  | 				status = "disabled"; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 
 | ||||||
| 		internal-regs { | 		internal-regs { | ||||||
| 			pinctrl { | 			pinctrl { | ||||||
| 				compatible = "marvell,mv78460-pinctrl"; | 				compatible = "marvell,mv78460-pinctrl"; | ||||||
|  | @ -113,194 +334,6 @@ | ||||||
| 				clocks = <&gateclk 1>; | 				clocks = <&gateclk 1>; | ||||||
| 				status = "disabled"; | 				status = "disabled"; | ||||||
| 			}; | 			}; | ||||||
| 
 |  | ||||||
| 			/* |  | ||||||
| 			 * MV78460 has 4 PCIe units Gen2.0: Two units can be |  | ||||||
| 			 * configured as x4 or quad x1 lanes. Two units are |  | ||||||
| 			 * x4/x1. |  | ||||||
| 			 */ |  | ||||||
| 			pcie-controller { |  | ||||||
| 				compatible = "marvell,armada-xp-pcie"; |  | ||||||
| 				status = "disabled"; |  | ||||||
| 				device_type = "pci"; |  | ||||||
| 
 |  | ||||||
| 				#address-cells = <3>; |  | ||||||
| 				#size-cells = <2>; |  | ||||||
| 
 |  | ||||||
| 				bus-range = <0x00 0xff>; |  | ||||||
| 
 |  | ||||||
| 				ranges = <0x82000000 0 0x40000 0x40000 0 0x00002000   /* Port 0.0 registers */ |  | ||||||
| 					0x82000000 0 0x42000 0x42000 0 0x00002000   /* Port 2.0 registers */ |  | ||||||
| 					0x82000000 0 0x44000 0x44000 0 0x00002000   /* Port 0.1 registers */ |  | ||||||
| 					0x82000000 0 0x48000 0x48000 0 0x00002000   /* Port 0.2 registers */ |  | ||||||
| 					0x82000000 0 0x4c000 0x4c000 0 0x00002000   /* Port 0.3 registers */ |  | ||||||
| 					0x82000000 0 0x80000 0x80000 0 0x00002000   /* Port 1.0 registers */ |  | ||||||
| 					0x82000000 0 0x82000 0x82000 0 0x00002000   /* Port 3.0 registers */ |  | ||||||
| 					0x82000000 0 0x84000 0x84000 0 0x00002000   /* Port 1.1 registers */ |  | ||||||
| 					0x82000000 0 0x88000 0x88000 0 0x00002000   /* Port 1.2 registers */ |  | ||||||
| 					0x82000000 0 0x8c000 0x8c000 0 0x00002000   /* Port 1.3 registers */ |  | ||||||
| 					0x82000000 0 0xe0000000 0xe0000000 0 0x08000000   /* non-prefetchable memory */ |  | ||||||
| 					0x81000000 0 0	  0xe8000000 0 0x00100000>; /* downstream I/O */ |  | ||||||
| 
 |  | ||||||
| 				pcie@1,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82000800 0 0x40000 0 0x2000>; |  | ||||||
| 					reg = <0x0800 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 58>; |  | ||||||
| 					marvell,pcie-port = <0>; |  | ||||||
| 					marvell,pcie-lane = <0>; |  | ||||||
| 					clocks = <&gateclk 5>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@2,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82001000 0 0x44000 0 0x2000>; |  | ||||||
| 					reg = <0x1000 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 59>; |  | ||||||
| 					marvell,pcie-port = <0>; |  | ||||||
| 					marvell,pcie-lane = <1>; |  | ||||||
| 					clocks = <&gateclk 6>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@3,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82001800 0 0x48000 0 0x2000>; |  | ||||||
| 					reg = <0x1800 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 60>; |  | ||||||
| 					marvell,pcie-port = <0>; |  | ||||||
| 					marvell,pcie-lane = <2>; |  | ||||||
| 					clocks = <&gateclk 7>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@4,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82002000 0 0x4c000 0 0x2000>; |  | ||||||
| 					reg = <0x2000 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 61>; |  | ||||||
| 					marvell,pcie-port = <0>; |  | ||||||
| 					marvell,pcie-lane = <3>; |  | ||||||
| 					clocks = <&gateclk 8>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@5,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82002800 0 0x80000 0 0x2000>; |  | ||||||
| 					reg = <0x2800 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 62>; |  | ||||||
| 					marvell,pcie-port = <1>; |  | ||||||
| 					marvell,pcie-lane = <0>; |  | ||||||
| 					clocks = <&gateclk 9>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@6,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82003000 0 0x84000 0 0x2000>; |  | ||||||
| 					reg = <0x3000 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 63>; |  | ||||||
| 					marvell,pcie-port = <1>; |  | ||||||
| 					marvell,pcie-lane = <1>; |  | ||||||
| 					clocks = <&gateclk 10>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@7,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82003800 0 0x88000 0 0x2000>; |  | ||||||
| 					reg = <0x3800 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 64>; |  | ||||||
| 					marvell,pcie-port = <1>; |  | ||||||
| 					marvell,pcie-lane = <2>; |  | ||||||
| 					clocks = <&gateclk 11>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@8,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82004000 0 0x8c000 0 0x2000>; |  | ||||||
| 					reg = <0x4000 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 65>; |  | ||||||
| 					marvell,pcie-port = <1>; |  | ||||||
| 					marvell,pcie-lane = <3>; |  | ||||||
| 					clocks = <&gateclk 12>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 				pcie@9,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82004800 0 0x42000 0 0x2000>; |  | ||||||
| 					reg = <0x4800 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 99>; |  | ||||||
| 					marvell,pcie-port = <2>; |  | ||||||
| 					marvell,pcie-lane = <0>; |  | ||||||
| 					clocks = <&gateclk 26>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 
 |  | ||||||
| 				pcie@10,0 { |  | ||||||
| 					device_type = "pci"; |  | ||||||
| 					assigned-addresses = <0x82005000 0 0x82000 0 0x2000>; |  | ||||||
| 					reg = <0x5000 0 0 0 0>; |  | ||||||
| 					#address-cells = <3>; |  | ||||||
| 					#size-cells = <2>; |  | ||||||
| 					#interrupt-cells = <1>; |  | ||||||
| 					ranges; |  | ||||||
| 					interrupt-map-mask = <0 0 0 0>; |  | ||||||
| 					interrupt-map = <0 0 0 0 &mpic 103>; |  | ||||||
| 					marvell,pcie-port = <3>; |  | ||||||
| 					marvell,pcie-lane = <0>; |  | ||||||
| 					clocks = <&gateclk 27>; |  | ||||||
| 					status = "disabled"; |  | ||||||
| 				}; |  | ||||||
| 			}; |  | ||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -59,6 +59,15 @@ | ||||||
| 			}; | 			}; | ||||||
| 		}; | 		}; | ||||||
| 
 | 
 | ||||||
|  | 		pcie-controller { | ||||||
|  | 			status = "okay"; | ||||||
|  | 			/* Internal mini-PCIe connector */ | ||||||
|  | 			pcie@1,0 { | ||||||
|  | 				/* Port 0, Lane 0 */ | ||||||
|  | 				status = "okay"; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 
 | ||||||
| 		internal-regs { | 		internal-regs { | ||||||
| 			serial@12000 { | 			serial@12000 { | ||||||
| 				clock-frequency = <250000000>; | 				clock-frequency = <250000000>; | ||||||
|  | @ -176,15 +185,6 @@ | ||||||
| 			usb@51000 { | 			usb@51000 { | ||||||
| 				status = "okay"; | 				status = "okay"; | ||||||
| 			}; | 			}; | ||||||
| 
 |  | ||||||
| 			pcie-controller { |  | ||||||
| 				status = "okay"; |  | ||||||
| 				/* Internal mini-PCIe connector */ |  | ||||||
| 				pcie@1,0 { |  | ||||||
| 					/* Port 0, Lane 0 */ |  | ||||||
| 					status = "okay"; |  | ||||||
| 				}; |  | ||||||
| 			}; |  | ||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
| }; | }; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Ezequiel Garcia
				Ezequiel Garcia