mirror of https://github.com/hak5/openwrt-owl.git
150 lines
3.8 KiB
Diff
150 lines
3.8 KiB
Diff
From c02c17b2d2bd9663ded7e9f59d6ef24fba239b33 Mon Sep 17 00:00:00 2001
|
|
From: John Crispin <blogic@openwrt.org>
|
|
Date: Mon, 12 Mar 2012 15:23:39 +0100
|
|
Subject: [PATCH 34/70] MIPS: lantiq: add additional soc ids
|
|
|
|
---
|
|
.../mips/include/asm/mach-lantiq/xway/lantiq_soc.h | 38 +++++++++++++++----
|
|
arch/mips/lantiq/xway/prom.c | 35 ++++++++++++++++--
|
|
2 files changed, 61 insertions(+), 12 deletions(-)
|
|
|
|
--- a/arch/mips/include/asm/mach-lantiq/xway/lantiq_soc.h
|
|
+++ b/arch/mips/include/asm/mach-lantiq/xway/lantiq_soc.h
|
|
@@ -17,20 +17,32 @@
|
|
#define SOC_ID_DANUBE1 0x129
|
|
#define SOC_ID_DANUBE2 0x12B
|
|
#define SOC_ID_TWINPASS 0x12D
|
|
-#define SOC_ID_AMAZON_SE 0x152
|
|
+#define SOC_ID_AMAZON_SE_1 0x152 /* 50601 */
|
|
+#define SOC_ID_AMAZON_SE_2 0x153 /* 50600 */
|
|
#define SOC_ID_ARX188 0x16C
|
|
-#define SOC_ID_ARX168 0x16D
|
|
+#define SOC_ID_ARX168_1 0x16D
|
|
+#define SOC_ID_ARX168_2 0x16E
|
|
#define SOC_ID_ARX182 0x16F
|
|
-#define SOC_ID_VRX288 0x1C0 /* VRX288 v1.1 */
|
|
-#define SOC_ID_VRX268 0x1C2 /* VRX268 v1.1 */
|
|
-#define SOC_ID_GRX288 0x1C9 /* GRX288 v1.1 */
|
|
+#define SOC_ID_GRX188 0x170
|
|
+#define SOC_ID_GRX168 0x171
|
|
+
|
|
+#define SOC_ID_VRX288 0x1C0 /* v1.1 */
|
|
+#define SOC_ID_VRX282 0x1C1 /* v1.1 */
|
|
+#define SOC_ID_VRX268 0x1C2 /* v1.1 */
|
|
+#define SOC_ID_GRX268 0x1C8 /* v1.1 */
|
|
+#define SOC_ID_GRX288 0x1C9 /* v1.1 */
|
|
+#define SOC_ID_VRX288_2 0x00B /* v1.2 */
|
|
+#define SOC_ID_VRX268_2 0x00C /* v1.2 */
|
|
+#define SOC_ID_GRX288_2 0x00D /* v1.2 */
|
|
+#define SOC_ID_GRX282_2 0x00E /* v1.2 */
|
|
|
|
/* SoC Types */
|
|
#define SOC_TYPE_DANUBE 0x01
|
|
#define SOC_TYPE_TWINPASS 0x02
|
|
#define SOC_TYPE_AR9 0x03
|
|
-#define SOC_TYPE_VR9 0x04
|
|
-#define SOC_TYPE_AMAZON_SE 0x05
|
|
+#define SOC_TYPE_VR9_1 0x04 /* v1.1 */
|
|
+#define SOC_TYPE_VR9_2 0x05 /* v1.2 */
|
|
+#define SOC_TYPE_AMAZON_SE 0x06
|
|
|
|
/* ASC0/1 - serial port */
|
|
#define LTQ_ASC0_BASE_ADDR 0x1E100400
|
|
@@ -149,9 +161,19 @@ static inline int ltq_is_ar9(void)
|
|
return (ltq_get_soc_type() == SOC_TYPE_AR9);
|
|
}
|
|
|
|
+static inline int ltq_is_vr9_1(void)
|
|
+{
|
|
+ return (ltq_get_soc_type() == SOC_TYPE_VR9_1);
|
|
+}
|
|
+
|
|
+static inline int ltq_is_vr9_2(void)
|
|
+{
|
|
+ return (ltq_get_soc_type() == SOC_TYPE_VR9_2);
|
|
+}
|
|
+
|
|
static inline int ltq_is_vr9(void)
|
|
{
|
|
- return (ltq_get_soc_type() == SOC_TYPE_VR9);
|
|
+ return (ltq_is_vr9_1() || ltq_is_vr9_2());
|
|
}
|
|
|
|
static inline int ltq_is_falcon(void)
|
|
--- a/arch/mips/lantiq/xway/prom.c
|
|
+++ b/arch/mips/lantiq/xway/prom.c
|
|
@@ -18,7 +18,9 @@
|
|
|
|
#define SOC_DANUBE "Danube"
|
|
#define SOC_TWINPASS "Twinpass"
|
|
+#define SOC_AMAZON_SE "Amazon_SE"
|
|
#define SOC_AR9 "AR9"
|
|
+#define SOC_GR9 "GR9"
|
|
#define SOC_VR9 "VR9"
|
|
|
|
#define PART_SHIFT 12
|
|
@@ -26,7 +28,6 @@
|
|
#define REV_SHIFT 28
|
|
#define REV_MASK 0xF0000000
|
|
|
|
-#define SOC_AMAZON_SE "Amazon_SE"
|
|
|
|
void __init ltq_soc_detect(struct ltq_soc_info *i)
|
|
{
|
|
@@ -46,13 +47,21 @@ void __init ltq_soc_detect(struct ltq_so
|
|
break;
|
|
|
|
case SOC_ID_ARX188:
|
|
- case SOC_ID_ARX168:
|
|
+ case SOC_ID_ARX168_1:
|
|
+ case SOC_ID_ARX168_2:
|
|
case SOC_ID_ARX182:
|
|
i->name = SOC_AR9;
|
|
i->type = SOC_TYPE_AR9;
|
|
break;
|
|
|
|
- case SOC_ID_AMAZON_SE:
|
|
+ case SOC_ID_GRX188:
|
|
+ case SOC_ID_GRX168:
|
|
+ i->name = SOC_GR9;
|
|
+ i->type = SOC_TYPE_AR9;
|
|
+ break;
|
|
+
|
|
+ case SOC_ID_AMAZON_SE_1:
|
|
+ case SOC_ID_AMAZON_SE_2:
|
|
i->name = SOC_AMAZON_SE;
|
|
i->type = SOC_TYPE_AMAZON_SE;
|
|
#ifdef CONFIG_PCI
|
|
@@ -60,12 +69,30 @@ void __init ltq_soc_detect(struct ltq_so
|
|
#endif
|
|
break;
|
|
|
|
+ case SOC_ID_VRX282:
|
|
case SOC_ID_VRX268:
|
|
case SOC_ID_VRX288:
|
|
i->name = SOC_VR9;
|
|
- i->type = SOC_TYPE_VR9;
|
|
+ i->type = SOC_TYPE_VR9_1;
|
|
break;
|
|
|
|
+ case SOC_ID_GRX268:
|
|
+ case SOC_ID_GRX288:
|
|
+ i->name = SOC_GR9;
|
|
+ i->type = SOC_TYPE_VR9_1;
|
|
+ break;
|
|
+
|
|
+ case SOC_ID_VRX268_2:
|
|
+ case SOC_ID_VRX288_2:
|
|
+ i->name = SOC_VR9;
|
|
+ i->type = SOC_TYPE_VR9_2;
|
|
+ break;
|
|
+
|
|
+ case SOC_ID_GRX282_2:
|
|
+ case SOC_ID_GRX288_2:
|
|
+ i->name = SOC_GR9;
|
|
+ i->type = SOC_TYPE_VR9_2;
|
|
+
|
|
default:
|
|
unreachable();
|
|
break;
|