mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-25 16:31:13 +00:00
e9b6602a84
this is a backport of a series posted on the lmo mailing list Signed-off-by: Jonathan Thibault <jonathan@navigue.com> SVN-Revision: 44901
106 lines
4.5 KiB
Diff
106 lines
4.5 KiB
Diff
diff --git a/arch/mips/include/asm/octeon/octeon-model.h b/arch/mips/include/asm/octeon/octeon-model.h
|
|
index e2c122c..35d7cbd 100644
|
|
--- a/arch/mips/include/asm/octeon/octeon-model.h
|
|
+++ b/arch/mips/include/asm/octeon/octeon-model.h
|
|
@@ -45,6 +45,7 @@
|
|
*/
|
|
|
|
#define OCTEON_FAMILY_MASK 0x00ffff00
|
|
+#define OCTEON_PRID_MASK 0x00ffffff
|
|
|
|
/* Flag bits in top byte */
|
|
/* Ignores revision in model checks */
|
|
@@ -63,6 +64,46 @@
|
|
#define OM_MATCH_6XXX_FAMILY_MODELS 0x40000000
|
|
/* Match all cnf7XXX Octeon models. */
|
|
#define OM_MATCH_F7XXX_FAMILY_MODELS 0x80000000
|
|
+/* Match all cn7XXX Octeon models. */
|
|
+#define OM_MATCH_7XXX_FAMILY_MODELS 0x10000000
|
|
+#define OM_MATCH_FAMILY_MODELS (OM_MATCH_5XXX_FAMILY_MODELS | \
|
|
+ OM_MATCH_6XXX_FAMILY_MODELS | \
|
|
+ OM_MATCH_F7XXX_FAMILY_MODELS | \
|
|
+ OM_MATCH_7XXX_FAMILY_MODELS)
|
|
+/*
|
|
+ * CN7XXX models with new revision encoding
|
|
+ */
|
|
+
|
|
+#define OCTEON_CN73XX_PASS1_0 0x000d9700
|
|
+#define OCTEON_CN73XX (OCTEON_CN73XX_PASS1_0 | OM_IGNORE_REVISION)
|
|
+#define OCTEON_CN73XX_PASS1_X (OCTEON_CN73XX_PASS1_0 | \
|
|
+ OM_IGNORE_MINOR_REVISION)
|
|
+
|
|
+#define OCTEON_CN70XX_PASS1_0 0x000d9600
|
|
+#define OCTEON_CN70XX_PASS1_1 0x000d9601
|
|
+#define OCTEON_CN70XX_PASS1_2 0x000d9602
|
|
+
|
|
+#define OCTEON_CN70XX_PASS2_0 0x000d9608
|
|
+
|
|
+#define OCTEON_CN70XX (OCTEON_CN70XX_PASS1_0 | OM_IGNORE_REVISION)
|
|
+#define OCTEON_CN70XX_PASS1_X (OCTEON_CN70XX_PASS1_0 | \
|
|
+ OM_IGNORE_MINOR_REVISION)
|
|
+#define OCTEON_CN70XX_PASS2_X (OCTEON_CN70XX_PASS2_0 | \
|
|
+ OM_IGNORE_MINOR_REVISION)
|
|
+
|
|
+#define OCTEON_CN71XX OCTEON_CN70XX
|
|
+
|
|
+#define OCTEON_CN78XX_PASS1_0 0x000d9500
|
|
+#define OCTEON_CN78XX_PASS1_1 0x000d9501
|
|
+#define OCTEON_CN78XX_PASS2_0 0x000d9508
|
|
+
|
|
+#define OCTEON_CN78XX (OCTEON_CN78XX_PASS1_0 | OM_IGNORE_REVISION)
|
|
+#define OCTEON_CN78XX_PASS1_X (OCTEON_CN78XX_PASS1_0 | \
|
|
+ OM_IGNORE_MINOR_REVISION)
|
|
+#define OCTEON_CN78XX_PASS2_X (OCTEON_CN78XX_PASS2_0 | \
|
|
+ OM_IGNORE_MINOR_REVISION)
|
|
+
|
|
+#define OCTEON_CN76XX (0x000d9540 | OM_CHECK_SUBMODEL)
|
|
|
|
/*
|
|
* CNF7XXX models with new revision encoding
|
|
@@ -217,6 +258,10 @@
|
|
#define OCTEON_CN3XXX (OCTEON_CN58XX_PASS1_0 | OM_MATCH_PREVIOUS_MODELS | OM_IGNORE_REVISION)
|
|
#define OCTEON_CN5XXX (OCTEON_CN58XX_PASS1_0 | OM_MATCH_5XXX_FAMILY_MODELS)
|
|
#define OCTEON_CN6XXX (OCTEON_CN63XX_PASS1_0 | OM_MATCH_6XXX_FAMILY_MODELS)
|
|
+#define OCTEON_CNF7XXX (OCTEON_CNF71XX_PASS1_0 | \
|
|
+ OM_MATCH_F7XXX_FAMILY_MODELS)
|
|
+#define OCTEON_CN7XXX (OCTEON_CN78XX_PASS1_0 | \
|
|
+ OM_MATCH_7XXX_FAMILY_MODELS)
|
|
|
|
/* These are used to cover entire families of OCTEON processors */
|
|
#define OCTEON_FAM_1 (OCTEON_CN3XXX)
|
|
@@ -288,9 +333,16 @@ static inline uint64_t cvmx_read_csr(uint64_t csr_addr);
|
|
((((arg_model) & (OM_FLAG_MASK)) == OM_CHECK_SUBMODEL) \
|
|
&& __OCTEON_MATCH_MASK__((chip_model), (arg_model), OCTEON_58XX_MODEL_REV_MASK)) || \
|
|
((((arg_model) & (OM_MATCH_5XXX_FAMILY_MODELS)) == OM_MATCH_5XXX_FAMILY_MODELS) \
|
|
- && ((chip_model) >= OCTEON_CN58XX_PASS1_0) && ((chip_model) < OCTEON_CN63XX_PASS1_0)) || \
|
|
+ && ((chip_model & OCTEON_PRID_MASK) >= OCTEON_CN58XX_PASS1_0) \
|
|
+ && ((chip_model & OCTEON_PRID_MASK) < OCTEON_CN63XX_PASS1_0)) || \
|
|
((((arg_model) & (OM_MATCH_6XXX_FAMILY_MODELS)) == OM_MATCH_6XXX_FAMILY_MODELS) \
|
|
- && ((chip_model) >= OCTEON_CN63XX_PASS1_0)) || \
|
|
+ && ((chip_model & OCTEON_PRID_MASK) >= OCTEON_CN63XX_PASS1_0) \
|
|
+ && ((chip_model & OCTEON_PRID_MASK) < OCTEON_CNF71XX_PASS1_0)) || \
|
|
+ ((((arg_model) & (OM_MATCH_F7XXX_FAMILY_MODELS)) == OM_MATCH_F7XXX_FAMILY_MODELS) \
|
|
+ && ((chip_model & OCTEON_PRID_MASK) >= OCTEON_CNF71XX_PASS1_0) \
|
|
+ && ((chip_model & OCTEON_PRID_MASK) < OCTEON_CN78XX_PASS1_0)) || \
|
|
+ ((((arg_model) & (OM_MATCH_7XXX_FAMILY_MODELS)) == OM_MATCH_7XXX_FAMILY_MODELS) \
|
|
+ && ((chip_model & OCTEON_PRID_MASK) >= OCTEON_CN78XX_PASS1_0)) || \
|
|
((((arg_model) & (OM_MATCH_PREVIOUS_MODELS)) == OM_MATCH_PREVIOUS_MODELS) \
|
|
&& (((chip_model) & OCTEON_58XX_MODEL_MASK) < ((arg_model) & OCTEON_58XX_MODEL_MASK))) \
|
|
)))
|
|
@@ -326,6 +378,15 @@ static inline int __octeon_is_model_runtime__(uint32_t model)
|
|
#define OCTEON_IS_COMMON_BINARY() 1
|
|
#undef OCTEON_MODEL
|
|
|
|
+#define OCTEON_IS_OCTEON1() OCTEON_IS_MODEL(OCTEON_CN3XXX)
|
|
+#define OCTEON_IS_OCTEONPLUS() OCTEON_IS_MODEL(OCTEON_CN5XXX)
|
|
+#define OCTEON_IS_OCTEON2() \
|
|
+ (OCTEON_IS_MODEL(OCTEON_CN6XXX) || OCTEON_IS_MODEL(OCTEON_CNF71XX))
|
|
+
|
|
+#define OCTEON_IS_OCTEON3() OCTEON_IS_MODEL(OCTEON_CN7XXX)
|
|
+
|
|
+#define OCTEON_IS_OCTEON1PLUS() (OCTEON_IS_OCTEON1() || OCTEON_IS_OCTEONPLUS())
|
|
+
|
|
const char *octeon_model_get_string(uint32_t chip_id);
|
|
const char *octeon_model_get_string_buffer(uint32_t chip_id, char *buffer);
|
|
|