#ifndef XC_BITOPS_H #define XC_BITOPS_H 1 /* bitmap operations for single threaded access */ #include #include #define BITS_PER_LONG (sizeof(unsigned long) * 8) #define ORDER_LONG (sizeof(unsigned long) == 4 ? 5 : 6) #define BITMAP_ENTRY(_nr,_bmap) ((_bmap))[(_nr)/BITS_PER_LONG] #define BITMAP_SHIFT(_nr) ((_nr) % BITS_PER_LONG) /* calculate required space for number of longs needed to hold nr_bits */ static inline int bitmap_size(int nr_bits) { int nr_long, nr_bytes; nr_long = (nr_bits + BITS_PER_LONG - 1) >> ORDER_LONG; nr_bytes = nr_long * sizeof(unsigned long); return nr_bytes; } static inline unsigned long *bitmap_alloc(int nr_bits) { return calloc(1, bitmap_size(nr_bits)); } static inline void bitmap_clear(unsigned long *addr, int nr_bits) { memset(addr, 0, bitmap_size(nr_bits)); } static inline int test_bit(int nr, unsigned long *addr) { return (BITMAP_ENTRY(nr, addr) >> BITMAP_SHIFT(nr)) & 1; } static inline void clear_bit(int nr, unsigned long *addr) { BITMAP_ENTRY(nr, addr) &= ~(1UL << BITMAP_SHIFT(nr)); } static inline void set_bit(int nr, unsigned long *addr) { BITMAP_ENTRY(nr, addr) |= (1UL << BITMAP_SHIFT(nr)); } static inline int test_and_clear_bit(int nr, unsigned long *addr) { int oldbit = test_bit(nr, addr); clear_bit(nr, addr); return oldbit; } static inline int test_and_set_bit(int nr, unsigned long *addr) { int oldbit = test_bit(nr, addr); set_bit(nr, addr); return oldbit; } #endif /* XC_BITOPS_H */ 07'>openwrt-19.07 upstream openwrtJames
aboutsummaryrefslogtreecommitdiffstats
blob: 00ef4ffdd50910f57a5d06545bf780ee63e815d8 (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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
--- a/arch/mips/bcm63xx/boards/board_bcm963xx.c
+++ b/arch/mips/bcm63xx/boards/board_bcm963xx.c
@@ -139,6 +139,79 @@ static struct board_info __initdata boar
 	},
 };
 
+static struct sprom_fixup __initdata ar5387un_fixups[] = {
+	{ .offset = 2, .value = 0x05bb },
+	{ .offset = 65, .value = 0x1204 },
+	{ .offset = 78, .value = 0x0303 },
+	{ .offset = 79, .value = 0x0202 },
+	{ .offset = 80, .value = 0xff02 },
+	{ .offset = 87, .value = 0x0315 },
+	{ .offset = 88, .value = 0x0315 },
+	{ .offset = 96, .value = 0x2048 },
+	{ .offset = 97, .value = 0xff11 },
+	{ .offset = 98, .value = 0x1567 },
+	{ .offset = 99, .value = 0xfb24 },
+	{ .offset = 100, .value = 0x3e3c },
+	{ .offset = 101, .value = 0x4038 },
+	{ .offset = 102, .value = 0xfe7f },
+	{ .offset = 103, .value = 0x1279 },
+	{ .offset = 112, .value = 0x2048 },
+	{ .offset = 113, .value = 0xff03 },
+	{ .offset = 114, .value = 0x154c },
+	{ .offset = 115, .value = 0xfb27 },
+	{ .offset = 116, .value = 0x3e3c },
+	{ .offset = 117, .value = 0x4038 },
+	{ .offset = 118, .value = 0xfe87 },
+	{ .offset = 119, .value = 0x1233 },
+	{ .offset = 203, .value = 0x2226 },
+};
+
+static struct board_info __initdata board_AR5387un = {
+	.name					= "96328A-1441N1",
+	.expected_cpu_id			= 0x6328,
+
+	.has_uart0				= 1,
+	.has_pci				= 1,
+	.use_fallback_sprom		= 1,
+	.has_ohci0				= 1,
+	.has_ehci0				= 1,
+	.num_usbh_ports				= 1,
+	.has_enetsw				= 1,
+
+	.enetsw = {
+		.used_ports = {
+			[0] = {
+				.used		= 1,
+				.phy_id		= 1,
+				.name		= "Port 1",
+			},
+			[1] = {
+				.used		= 1,
+				.phy_id		= 2,
+				.name		= "Port 2",
+			},
+			[2] = {
+				.used		= 1,
+				.phy_id		= 3,
+				.name		= "Port 3",
+			},
+			[3] = {
+				.used		= 1,
+				.phy_id		= 4,
+				.name		= "Port 4",
+			},
+		},
+	},
+
+	.fallback_sprom = {
+		.type 				= SPROM_BCM43225,
+		.pci_bus			= 1,
+		.pci_dev			= 0,
+		.board_fixups			= ar5387un_fixups,
+		.num_board_fixups		= ARRAY_SIZE(ar5387un_fixups),
+	},
+};
+
 static struct board_info __initdata board_963281TAN = {
 	.name				= "963281TAN",
 	.expected_cpu_id		= 0x6328,
@@ -1545,6 +1618,7 @@ static const struct board_info __initcon
 #endif
 #ifdef CONFIG_BCM63XX_CPU_6328
 	&board_96328avng,
+	&board_AR5387un,
 	&board_963281TAN,
 	&board_A4001N1,
 	&board_dsl_274xb_f1,
@@ -1615,6 +1689,7 @@ static struct of_device_id const bcm963x
 	{ .compatible = "adb,a4001n1", .data = &board_A4001N1, },
 	{ .compatible = "brcm,bcm963281TAN", .data = &board_963281TAN, },
 	{ .compatible = "brcm,bcm96328avng", .data = &board_96328avng, },
+	{ .compatible = "comtrend,ar-5387un", .data = &board_AR5387un, },
 	{ .compatible = "d-link,dsl-274xb-f", .data = &board_dsl_274xb_f1, },
 #endif
 #ifdef CONFIG_BCM63XX_CPU_6338