|
@@ -838,3 +838,150 @@ do { \
|
|
|
#define write_c0_entrylo0(val) __write_ulong_c0_register($2, 0, val)
|
|
|
|
|
|
#define read_c0_entrylo1() __read_ulong_c0_register($3, 0)
|
|
|
+#define write_c0_entrylo1(val) __write_ulong_c0_register($3, 0, val)
|
|
|
+
|
|
|
+#define read_c0_conf() __read_32bit_c0_register($3, 0)
|
|
|
+#define write_c0_conf(val) __write_32bit_c0_register($3, 0, val)
|
|
|
+
|
|
|
+#define read_c0_context() __read_ulong_c0_register($4, 0)
|
|
|
+#define write_c0_context(val) __write_ulong_c0_register($4, 0, val)
|
|
|
+
|
|
|
+#define read_c0_userlocal() __read_ulong_c0_register($4, 2)
|
|
|
+#define write_c0_userlocal(val) __write_ulong_c0_register($4, 2, val)
|
|
|
+
|
|
|
+#define read_c0_pagemask() __read_32bit_c0_register($5, 0)
|
|
|
+#define write_c0_pagemask(val) __write_32bit_c0_register($5, 0, val)
|
|
|
+
|
|
|
+#define read_c0_pagegrain() __read_32bit_c0_register($5, 1)
|
|
|
+#define write_c0_pagegrain(val) __write_32bit_c0_register($5, 1, val)
|
|
|
+
|
|
|
+#define read_c0_wired() __read_32bit_c0_register($6, 0)
|
|
|
+#define write_c0_wired(val) __write_32bit_c0_register($6, 0, val)
|
|
|
+
|
|
|
+#define read_c0_info() __read_32bit_c0_register($7, 0)
|
|
|
+
|
|
|
+#define read_c0_cache() __read_32bit_c0_register($7, 0) /* TX39xx */
|
|
|
+#define write_c0_cache(val) __write_32bit_c0_register($7, 0, val)
|
|
|
+
|
|
|
+#define read_c0_badvaddr() __read_ulong_c0_register($8, 0)
|
|
|
+#define write_c0_badvaddr(val) __write_ulong_c0_register($8, 0, val)
|
|
|
+
|
|
|
+#define read_c0_count() __read_32bit_c0_register($9, 0)
|
|
|
+#define write_c0_count(val) __write_32bit_c0_register($9, 0, val)
|
|
|
+
|
|
|
+#define read_c0_count2() __read_32bit_c0_register($9, 6) /* pnx8550 */
|
|
|
+#define write_c0_count2(val) __write_32bit_c0_register($9, 6, val)
|
|
|
+
|
|
|
+#define read_c0_count3() __read_32bit_c0_register($9, 7) /* pnx8550 */
|
|
|
+#define write_c0_count3(val) __write_32bit_c0_register($9, 7, val)
|
|
|
+
|
|
|
+#define read_c0_entryhi() __read_ulong_c0_register($10, 0)
|
|
|
+#define write_c0_entryhi(val) __write_ulong_c0_register($10, 0, val)
|
|
|
+
|
|
|
+#define read_c0_compare() __read_32bit_c0_register($11, 0)
|
|
|
+#define write_c0_compare(val) __write_32bit_c0_register($11, 0, val)
|
|
|
+
|
|
|
+#define read_c0_compare2() __read_32bit_c0_register($11, 6) /* pnx8550 */
|
|
|
+#define write_c0_compare2(val) __write_32bit_c0_register($11, 6, val)
|
|
|
+
|
|
|
+#define read_c0_compare3() __read_32bit_c0_register($11, 7) /* pnx8550 */
|
|
|
+#define write_c0_compare3(val) __write_32bit_c0_register($11, 7, val)
|
|
|
+
|
|
|
+#define read_c0_status() __read_32bit_c0_register($12, 0)
|
|
|
+#ifdef CONFIG_MIPS_MT_SMTC
|
|
|
+#define write_c0_status(val) \
|
|
|
+do { \
|
|
|
+ __write_32bit_c0_register($12, 0, val); \
|
|
|
+ __ehb(); \
|
|
|
+} while (0)
|
|
|
+#else
|
|
|
+/*
|
|
|
+ * Legacy non-SMTC code, which may be hazardous
|
|
|
+ * but which might not support EHB
|
|
|
+ */
|
|
|
+#define write_c0_status(val) __write_32bit_c0_register($12, 0, val)
|
|
|
+#endif /* CONFIG_MIPS_MT_SMTC */
|
|
|
+
|
|
|
+#define read_c0_cause() __read_32bit_c0_register($13, 0)
|
|
|
+#define write_c0_cause(val) __write_32bit_c0_register($13, 0, val)
|
|
|
+
|
|
|
+#define read_c0_epc() __read_ulong_c0_register($14, 0)
|
|
|
+#define write_c0_epc(val) __write_ulong_c0_register($14, 0, val)
|
|
|
+
|
|
|
+#define read_c0_prid() __read_32bit_c0_register($15, 0)
|
|
|
+
|
|
|
+#define read_c0_config() __read_32bit_c0_register($16, 0)
|
|
|
+#define read_c0_config1() __read_32bit_c0_register($16, 1)
|
|
|
+#define read_c0_config2() __read_32bit_c0_register($16, 2)
|
|
|
+#define read_c0_config3() __read_32bit_c0_register($16, 3)
|
|
|
+#define read_c0_config4() __read_32bit_c0_register($16, 4)
|
|
|
+#define read_c0_config5() __read_32bit_c0_register($16, 5)
|
|
|
+#define read_c0_config6() __read_32bit_c0_register($16, 6)
|
|
|
+#define read_c0_config7() __read_32bit_c0_register($16, 7)
|
|
|
+#define write_c0_config(val) __write_32bit_c0_register($16, 0, val)
|
|
|
+#define write_c0_config1(val) __write_32bit_c0_register($16, 1, val)
|
|
|
+#define write_c0_config2(val) __write_32bit_c0_register($16, 2, val)
|
|
|
+#define write_c0_config3(val) __write_32bit_c0_register($16, 3, val)
|
|
|
+#define write_c0_config4(val) __write_32bit_c0_register($16, 4, val)
|
|
|
+#define write_c0_config5(val) __write_32bit_c0_register($16, 5, val)
|
|
|
+#define write_c0_config6(val) __write_32bit_c0_register($16, 6, val)
|
|
|
+#define write_c0_config7(val) __write_32bit_c0_register($16, 7, val)
|
|
|
+
|
|
|
+/*
|
|
|
+ * The WatchLo register. There may be up to 8 of them.
|
|
|
+ */
|
|
|
+#define read_c0_watchlo0() __read_ulong_c0_register($18, 0)
|
|
|
+#define read_c0_watchlo1() __read_ulong_c0_register($18, 1)
|
|
|
+#define read_c0_watchlo2() __read_ulong_c0_register($18, 2)
|
|
|
+#define read_c0_watchlo3() __read_ulong_c0_register($18, 3)
|
|
|
+#define read_c0_watchlo4() __read_ulong_c0_register($18, 4)
|
|
|
+#define read_c0_watchlo5() __read_ulong_c0_register($18, 5)
|
|
|
+#define read_c0_watchlo6() __read_ulong_c0_register($18, 6)
|
|
|
+#define read_c0_watchlo7() __read_ulong_c0_register($18, 7)
|
|
|
+#define write_c0_watchlo0(val) __write_ulong_c0_register($18, 0, val)
|
|
|
+#define write_c0_watchlo1(val) __write_ulong_c0_register($18, 1, val)
|
|
|
+#define write_c0_watchlo2(val) __write_ulong_c0_register($18, 2, val)
|
|
|
+#define write_c0_watchlo3(val) __write_ulong_c0_register($18, 3, val)
|
|
|
+#define write_c0_watchlo4(val) __write_ulong_c0_register($18, 4, val)
|
|
|
+#define write_c0_watchlo5(val) __write_ulong_c0_register($18, 5, val)
|
|
|
+#define write_c0_watchlo6(val) __write_ulong_c0_register($18, 6, val)
|
|
|
+#define write_c0_watchlo7(val) __write_ulong_c0_register($18, 7, val)
|
|
|
+
|
|
|
+/*
|
|
|
+ * The WatchHi register. There may be up to 8 of them.
|
|
|
+ */
|
|
|
+#define read_c0_watchhi0() __read_32bit_c0_register($19, 0)
|
|
|
+#define read_c0_watchhi1() __read_32bit_c0_register($19, 1)
|
|
|
+#define read_c0_watchhi2() __read_32bit_c0_register($19, 2)
|
|
|
+#define read_c0_watchhi3() __read_32bit_c0_register($19, 3)
|
|
|
+#define read_c0_watchhi4() __read_32bit_c0_register($19, 4)
|
|
|
+#define read_c0_watchhi5() __read_32bit_c0_register($19, 5)
|
|
|
+#define read_c0_watchhi6() __read_32bit_c0_register($19, 6)
|
|
|
+#define read_c0_watchhi7() __read_32bit_c0_register($19, 7)
|
|
|
+
|
|
|
+#define write_c0_watchhi0(val) __write_32bit_c0_register($19, 0, val)
|
|
|
+#define write_c0_watchhi1(val) __write_32bit_c0_register($19, 1, val)
|
|
|
+#define write_c0_watchhi2(val) __write_32bit_c0_register($19, 2, val)
|
|
|
+#define write_c0_watchhi3(val) __write_32bit_c0_register($19, 3, val)
|
|
|
+#define write_c0_watchhi4(val) __write_32bit_c0_register($19, 4, val)
|
|
|
+#define write_c0_watchhi5(val) __write_32bit_c0_register($19, 5, val)
|
|
|
+#define write_c0_watchhi6(val) __write_32bit_c0_register($19, 6, val)
|
|
|
+#define write_c0_watchhi7(val) __write_32bit_c0_register($19, 7, val)
|
|
|
+
|
|
|
+#define read_c0_xcontext() __read_ulong_c0_register($20, 0)
|
|
|
+#define write_c0_xcontext(val) __write_ulong_c0_register($20, 0, val)
|
|
|
+
|
|
|
+#define read_c0_intcontrol() __read_32bit_c0_ctrl_register($20)
|
|
|
+#define write_c0_intcontrol(val) __write_32bit_c0_ctrl_register($20, val)
|
|
|
+
|
|
|
+#define read_c0_framemask() __read_32bit_c0_register($21, 0)
|
|
|
+#define write_c0_framemask(val) __write_32bit_c0_register($21, 0, val)
|
|
|
+
|
|
|
+#define read_c0_diag() __read_32bit_c0_register($22, 0)
|
|
|
+#define write_c0_diag(val) __write_32bit_c0_register($22, 0, val)
|
|
|
+
|
|
|
+#define read_c0_diag1() __read_32bit_c0_register($22, 1)
|
|
|
+#define write_c0_diag1(val) __write_32bit_c0_register($22, 1, val)
|
|
|
+
|
|
|
+#define read_c0_diag2() __read_32bit_c0_register($22, 2)
|
|
|
+#define write_c0_diag2(val) __write_32bit_c0_register($22, 2, val)
|