80 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
SAMSUNG Exynos SoCs SROM Controller driver.
 | 
						|
 | 
						|
Required properties:
 | 
						|
- compatible : Should contain "samsung,exynos4210-srom".
 | 
						|
 | 
						|
- reg: offset and length of the register set
 | 
						|
 | 
						|
Optional properties:
 | 
						|
The SROM controller can be used to attach external peripherals. In this case
 | 
						|
extra properties, describing the bus behind it, should be specified as below:
 | 
						|
 | 
						|
- #address-cells: Must be set to 2 to allow device address translation.
 | 
						|
		  Address is specified as (bank#, offset).
 | 
						|
 | 
						|
- #size-cells: Must be set to 1 to allow device size passing
 | 
						|
 | 
						|
- ranges: Must be set up to reflect the memory layout with four integer values
 | 
						|
	  per bank:
 | 
						|
		<bank-number> 0 <parent address of bank> <size>
 | 
						|
 | 
						|
Sub-nodes:
 | 
						|
The actual device nodes should be added as subnodes to the SROMc node. These
 | 
						|
subnodes, in addition to regular device specification, should contain the following
 | 
						|
properties, describing configuration of the relevant SROM bank:
 | 
						|
 | 
						|
Required properties:
 | 
						|
- reg: bank number, base address (relative to start of the bank) and size of
 | 
						|
       the memory mapped for the device. Note that base address will be
 | 
						|
       typically 0 as this is the start of the bank.
 | 
						|
 | 
						|
- samsung,srom-timing : array of 6 integers, specifying bank timings in the
 | 
						|
                        following order: Tacp, Tcah, Tcoh, Tacc, Tcos, Tacs.
 | 
						|
                        Each value is specified in cycles and has the following
 | 
						|
                        meaning and valid range:
 | 
						|
                        Tacp : Page mode access cycle at Page mode (0 - 15)
 | 
						|
                        Tcah : Address holding time after CSn (0 - 15)
 | 
						|
                        Tcoh : Chip selection hold on OEn (0 - 15)
 | 
						|
                        Tacc : Access cycle (0 - 31, the actual time is N + 1)
 | 
						|
                        Tcos : Chip selection set-up before OEn (0 - 15)
 | 
						|
                        Tacs : Address set-up before CSn (0 - 15)
 | 
						|
 | 
						|
Optional properties:
 | 
						|
- reg-io-width : data width in bytes (1 or 2). If omitted, default of 1 is used.
 | 
						|
 | 
						|
- samsung,srom-page-mode : if page mode is set, 4 data page mode will be configured,
 | 
						|
			   else normal (1 data) page mode will be set.
 | 
						|
 | 
						|
Example: basic definition, no banks are configured
 | 
						|
	memory-controller@12570000 {
 | 
						|
		compatible = "samsung,exynos4210-srom";
 | 
						|
		reg = <0x12570000 0x14>;
 | 
						|
	};
 | 
						|
 | 
						|
Example: SROMc with SMSC911x ethernet chip on bank 3
 | 
						|
	memory-controller@12570000 {
 | 
						|
		#address-cells = <2>;
 | 
						|
		#size-cells = <1>;
 | 
						|
		ranges = <0 0 0x04000000 0x20000   // Bank0
 | 
						|
			  1 0 0x05000000 0x20000   // Bank1
 | 
						|
			  2 0 0x06000000 0x20000   // Bank2
 | 
						|
			  3 0 0x07000000 0x20000>; // Bank3
 | 
						|
 | 
						|
		compatible = "samsung,exynos4210-srom";
 | 
						|
		reg = <0x12570000 0x14>;
 | 
						|
 | 
						|
		ethernet@3,0 {
 | 
						|
			compatible = "smsc,lan9115";
 | 
						|
			reg = <3 0 0x10000>;	   // Bank 3, offset = 0
 | 
						|
			phy-mode = "mii";
 | 
						|
			interrupt-parent = <&gpx0>;
 | 
						|
			interrupts = <5 8>;
 | 
						|
			reg-io-width = <2>;
 | 
						|
			smsc,irq-push-pull;
 | 
						|
			smsc,force-internal-phy;
 | 
						|
 | 
						|
			samsung,srom-page-mode;
 | 
						|
			samsung,srom-timing = <9 12 1 9 1 1>;
 | 
						|
		};
 | 
						|
	};
 |