aboutsummaryrefslogtreecommitdiff
path: root/tests/multilabel_merge.dts
blob: a27d856f80dda39906558a412e0d3e9af2822a4d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/dts-v1/;

m1: mq: /memreserve/ 0 0x1000;

/ {
	p0: pw: prop = "foo";

	/* Explicit phandles */
	n1: node1 {
		linux,phandle = <0x2000>;
		ref = <&{/node2}>; /* reference precedes target */
		p1: lref;
	};
	node2 {
		phandle = <0x1>;
		ref = <&{/node1}>; /* reference after target */
		lref = <&nx>;
	};

	/* Implicit phandles */
	n3: node3 {
		p3: ref = <&{/node4}>;
		lref = <&n4>;
	};
	n4: node4 {
		p4: prop = "foo";
	};

	/* Explicit phandle with implicit value */
	/* This self-reference is the standard way to tag a node as requiring
	 * a phandle (perhaps for reference by nodes that will be dynamically
	 * added) without explicitly allocating it a phandle.
	 * The self-reference requires some special internal handling, though
	 * so check it actually works */
	n5: nz: node5 {
		linux,phandle = <&n5>;
		phandle = <&nz>;
		n1 = &n1;
		n2 = &n2;
		n3 = &n3;
	};

	node6 {
		linux,phandle = <0xfffffffe>;
		phandle = <0xfffffffe>;
	};
};

/ {
	/* Append labels (also changes property content) */
	nx: node1 {
		px: lref = <&ny>;
	};

	/* Add multiple labels */
	ny: n2: node2 {
		/* Add a label to a property */
		p2: py: phandle = <0x1>;
	};

	/* Reassigning the same label should be a no-op */
	n3: node3 {
		p3: ref = <&{/node4}>;
	};

	/* Redefining a node/property should not remove labels */
	node4 {
		prop;
	};

};

/ {
	rref = <&{/}>;
};