Porting MIPS IRQ handler to ARM

Mason slash.tmp at free.fr
Fri Sep 4 09:13:46 PDT 2015


On 02/09/2015 20:01, Mason wrote:

> On 02/09/2015 19:17, Måns Rullgård wrote:
> 
>> Use the latest DT from my tree.  It looks like you're missing some
>> changes.
> 
> Indeed, my repo is not up-to-date. (I was vaguely worried that you'd
> have made further changes that I'd have to revert when back-porting
> to 3.14)
> 
> I'll try upgrading and report back.
> 
> By the way, did you write the DT from scratch?
> 
> Are there people walking this earth that can write device tree like C?

No cigar :-(

There's just too much DT syntax that flies light-years over my head.
#address-cells, #size-cells, #interrupt-cells, ranges, aliases, etc.
Basically, all I understand is /dts-v1/;
(Anyone have links to good tutorials?)

I've attached the current version I'm playing with (I tried to make it
as small as possible). If some charitable soul spots an obvious problem...
(Commented blocks have been tested uncommented, of course.)

Regards

-------------- next part --------------
/dts-v1/;

/ {
	compatible = "sigma,tango4-soc";

	#address-cells = <1>;
	#size-cells = <1>;

	gic: interrupt-controller at 20001000 {
		compatible = "arm,cortex-a9-gic";
		interrupt-controller;
		#interrupt-cells = <3>;
		reg = <0x20001000 0x1000>,
		      <0x20000100 0x0100>;
	};

	soc {
		compatible = "simple-bus";
/*		interrupt-parent = <&irqintc>;	*/
		#address-cells = <1>;
		#size-cells = <1>;
		ranges;

		uart0: uart at 10700 {
			compatible = "ns16550a";
			reg = <0x10700 0x100>;
			clock-frequency = <7372800>;
			reg-shift = <2>;
			no-loopback-test;
		};
	};

	cpublock: cpublock {
		compatible = "simple-bus";
		reg = <0x60000 0x10000>;
		ranges = <0x0 0x60000 0x10000>;
/*		interrupt-parent = <&irqintc>;	*/
		#address-cells = <1>;
		#size-cells = <1>;

		intc: intc at e000 {
			compatible = "sigma,tango-intc";
			reg = <0xe000 0x1000>;
			ranges = <0x0 0xe000 0x1000>;
			interrupt-parent = <&gic>;
			interrupt-controller;
			#address-cells = <1>;
			#size-cells = <1>;

			irqintc: irq at 000 {
				reg = <0x000 0x100>;
				interrupt-controller;
				#interrupt-cells = <2>;
				interrupts = <2>;
				label = "IRQ";
			};

/*
			fiqintc: fiq at 100 {
				reg = <0x100 0x100>;
				interrupt-controller;
				#interrupt-cells = <2>;
				interrupts = <3>;
				label = "FIQ";
			};

			iiqintc: iiq at 300 {
				reg = <0x300 0x100>;
				interrupt-controller;
				#interrupt-cells = <2>;
				interrupts = <4>;
				label = "IIQ";
			};
*/
		};
	};

};


More information about the linux-arm-kernel mailing list