Browse Source

xtensa: update configuration overlay for esp32s3

From LX7_ESP32_S3_MP_linux_redist.tgz with SHA256:
63f305a982b2ee94cc78e5c20e3e3eb8bf0edeeaf703af0227a418bc34f7b848
copied from xtensa-elf/arch/include/xtensa/config/ with changes:
1) pre-commit fixes applied
2) re-added CONFIGID0 and CONFIGID1 in specreg.h
Ivan Grokhotkov 4 years ago
parent
commit
ca5ed172a5

+ 500 - 490
components/xtensa/esp32s3/include/xtensa/config/core-isa.h

@@ -1,13 +1,13 @@
 /*
 /*
  * xtensa/config/core-isa.h -- HAL definitions that are dependent on Xtensa
  * xtensa/config/core-isa.h -- HAL definitions that are dependent on Xtensa
- *              processor CORE configuration
+ *				processor CORE configuration
  *
  *
  *  See <xtensa/config/core.h>, which includes this file, for more details.
  *  See <xtensa/config/core.h>, which includes this file, for more details.
  */
  */
 
 
 /* Xtensa processor core configuration information.
 /* Xtensa processor core configuration information.
 
 
-   Copyright (c) 1999-2020 Tensilica Inc.
+   Customer ID=15128; Build=0x90f1f; Copyright (c) 1999-2021 Tensilica Inc.
 
 
    Permission is hereby granted, free of charge, to any person obtaining
    Permission is hereby granted, free of charge, to any person obtaining
    a copy of this software and associated documentation files (the
    a copy of this software and associated documentation files (the
@@ -33,7 +33,7 @@
 
 
 
 
 /****************************************************************************
 /****************************************************************************
-        Parameters Useful for Any Code, USER or PRIVILEGED
+	    Parameters Useful for Any Code, USER or PRIVILEGED
  ****************************************************************************/
  ****************************************************************************/
 
 
 /*
 /*
@@ -43,140 +43,140 @@
 
 
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-                ISA
+				ISA
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
-#define XCHAL_HAVE_BE           0   /* big-endian byte ordering */
-#define XCHAL_HAVE_WINDOWED     1   /* windowed registers option */
-#define XCHAL_NUM_AREGS         64  /* num of physical addr regs */
-#define XCHAL_NUM_AREGS_LOG2        6   /* log2(XCHAL_NUM_AREGS) */
-#define XCHAL_MAX_INSTRUCTION_SIZE  4   /* max instr bytes (3..8) */
-#define XCHAL_HAVE_DEBUG        1   /* debug option */
-#define XCHAL_HAVE_DENSITY      1   /* 16-bit instructions */
-#define XCHAL_HAVE_LOOPS        1   /* zero-overhead loops */
-#define XCHAL_LOOP_BUFFER_SIZE      256 /* zero-ov. loop instr buffer size */
-#define XCHAL_HAVE_NSA          1   /* NSA/NSAU instructions */
-#define XCHAL_HAVE_MINMAX       1   /* MIN/MAX instructions */
-#define XCHAL_HAVE_SEXT         1   /* SEXT instruction */
-#define XCHAL_HAVE_DEPBITS      0   /* DEPBITS instruction */
-#define XCHAL_HAVE_CLAMPS       1   /* CLAMPS instruction */
-#define XCHAL_HAVE_MUL16        1   /* MUL16S/MUL16U instructions */
-#define XCHAL_HAVE_MUL32        1   /* MULL instruction */
-#define XCHAL_HAVE_MUL32_HIGH       1   /* MULUH/MULSH instructions */
-#define XCHAL_HAVE_DIV32        1   /* QUOS/QUOU/REMS/REMU instructions */
-#define XCHAL_HAVE_L32R         1   /* L32R instruction */
-#define XCHAL_HAVE_ABSOLUTE_LITERALS    0   /* non-PC-rel (extended) L32R */
-#define XCHAL_HAVE_CONST16      0   /* CONST16 instruction */
-#define XCHAL_HAVE_ADDX         1   /* ADDX#/SUBX# instructions */
-#define XCHAL_HAVE_EXCLUSIVE            0   /* L32EX/S32EX instructions */
-#define XCHAL_HAVE_WIDE_BRANCHES    0   /* B*.W18 or B*.W15 instr's */
-#define XCHAL_HAVE_PREDICTED_BRANCHES   0   /* B[EQ/EQZ/NE/NEZ]T instr's */
-#define XCHAL_HAVE_CALL4AND12       1   /* (obsolete option) */
-#define XCHAL_HAVE_ABS          1   /* ABS instruction */
-/*#define XCHAL_HAVE_POPC       0*/ /* POPC instruction */
-/*#define XCHAL_HAVE_CRC        0*/ /* CRC instruction */
-#define XCHAL_HAVE_RELEASE_SYNC     1   /* L32AI/S32RI instructions */
-#define XCHAL_HAVE_S32C1I       1   /* S32C1I instruction */
-#define XCHAL_HAVE_SPECULATION      0   /* speculation */
-#define XCHAL_HAVE_FULL_RESET       1   /* all regs/state reset */
-#define XCHAL_NUM_CONTEXTS      1   /* */
-#define XCHAL_NUM_MISC_REGS     4   /* num of scratch regs (0..4) */
-#define XCHAL_HAVE_TAP_MASTER       0   /* JTAG TAP control instr's */
-#define XCHAL_HAVE_PRID         1   /* processor ID register */
-#define XCHAL_HAVE_EXTERN_REGS      1   /* WER/RER instructions */
-#define XCHAL_HAVE_MX           0   /* MX core (Tensilica internal) */
-#define XCHAL_HAVE_MP_INTERRUPTS    0   /* interrupt distributor port */
-#define XCHAL_HAVE_MP_RUNSTALL      0   /* core RunStall control port */
-#define XCHAL_HAVE_PSO          0   /* Power Shut-Off */
-#define XCHAL_HAVE_PSO_CDM      0   /* core/debug/mem pwr domains */
-#define XCHAL_HAVE_PSO_FULL_RETENTION   0   /* all regs preserved on PSO */
-#define XCHAL_HAVE_THREADPTR        1   /* THREADPTR register */
-#define XCHAL_HAVE_BOOLEANS     1   /* boolean registers */
-#define XCHAL_HAVE_CP           1   /* CPENABLE reg (coprocessor) */
-#define XCHAL_CP_MAXCFG         8   /* max allowed cp id plus one */
-#define XCHAL_HAVE_MAC16        1   /* MAC16 package */
-
-#define XCHAL_HAVE_FUSION       0   /* Fusion*/
-#define XCHAL_HAVE_FUSION_FP        0   /* Fusion FP option */
-#define XCHAL_HAVE_FUSION_LOW_POWER 0   /* Fusion Low Power option */
-#define XCHAL_HAVE_FUSION_AES       0   /* Fusion BLE/Wifi AES-128 CCM option */
-#define XCHAL_HAVE_FUSION_CONVENC   0   /* Fusion Conv Encode option */
-#define XCHAL_HAVE_FUSION_LFSR_CRC  0   /* Fusion LFSR-CRC option */
-#define XCHAL_HAVE_FUSION_BITOPS    0   /* Fusion Bit Operations Support option */
-#define XCHAL_HAVE_FUSION_AVS       0   /* Fusion AVS option */
-#define XCHAL_HAVE_FUSION_16BIT_BASEBAND 0  /* Fusion 16-bit Baseband option */
-#define XCHAL_HAVE_FUSION_VITERBI   0   /* Fusion Viterbi option */
-#define XCHAL_HAVE_FUSION_SOFTDEMAP 0   /* Fusion Soft Bit Demap option */
-#define XCHAL_HAVE_HIFIPRO      0   /* HiFiPro Audio Engine pkg */
-#define XCHAL_HAVE_HIFI5        0   /* HiFi5 Audio Engine pkg */
-#define XCHAL_HAVE_HIFI5_NN_MAC     0   /* HiFi5 Audio Engine NN-MAC option */
-#define XCHAL_HAVE_HIFI5_VFPU       0   /* HiFi5 Audio Engine Single-Precision VFPU option */
-#define XCHAL_HAVE_HIFI5_HP_VFPU    0   /* HiFi5 Audio Engine Half-Precision VFPU option */
-#define XCHAL_HAVE_HIFI4        0   /* HiFi4 Audio Engine pkg */
-#define XCHAL_HAVE_HIFI4_VFPU       0   /* HiFi4 Audio Engine VFPU option */
-#define XCHAL_HAVE_HIFI3        0   /* HiFi3 Audio Engine pkg */
-#define XCHAL_HAVE_HIFI3_VFPU       0   /* HiFi3 Audio Engine VFPU option */
-#define XCHAL_HAVE_HIFI3Z       0   /* HiFi3Z Audio Engine pkg */
-#define XCHAL_HAVE_HIFI3Z_VFPU  0   /* HiFi3Z Audio Engine VFPU option */
-#define XCHAL_HAVE_HIFI2        0   /* HiFi2 Audio Engine pkg */
-#define XCHAL_HAVE_HIFI2EP      0   /* HiFi2EP */
-#define XCHAL_HAVE_HIFI_MINI        0
-
-
-
-#define XCHAL_HAVE_VECTORFPU2005    0   /* vector floating-point pkg */
-#define XCHAL_HAVE_USER_DPFPU       0       /* user DP floating-point pkg */
-#define XCHAL_HAVE_USER_SPFPU       0       /* user SP floating-point pkg */
-#define XCHAL_HAVE_FP           1   /* single prec floating point */
-#define XCHAL_HAVE_FP_DIV       1   /* FP with DIV instructions */
-#define XCHAL_HAVE_FP_RECIP     1   /* FP with RECIP instructions */
-#define XCHAL_HAVE_FP_SQRT      1   /* FP with SQRT instructions */
-#define XCHAL_HAVE_FP_RSQRT     1   /* FP with RSQRT instructions */
-#define XCHAL_HAVE_DFP          0   /* double precision FP pkg */
-#define XCHAL_HAVE_DFP_DIV      0   /* DFP with DIV instructions */
-#define XCHAL_HAVE_DFP_RECIP        0   /* DFP with RECIP instructions*/
-#define XCHAL_HAVE_DFP_SQRT     0   /* DFP with SQRT instructions */
-#define XCHAL_HAVE_DFP_RSQRT        0   /* DFP with RSQRT instructions*/
-#define XCHAL_HAVE_DFP_ACCEL        0   /* double precision FP acceleration pkg */
-#define XCHAL_HAVE_DFP_accel        XCHAL_HAVE_DFP_ACCEL    /* for backward compatibility */
-
-#define XCHAL_HAVE_DFPU_SINGLE_ONLY 1   /* DFPU Coprocessor, single precision only */
-#define XCHAL_HAVE_DFPU_SINGLE_DOUBLE   0   /* DFPU Coprocessor, single and double precision */
-#define XCHAL_HAVE_VECTRA1      0   /* Vectra I  pkg */
-#define XCHAL_HAVE_VECTRALX     0   /* Vectra LX pkg */
-
-#define XCHAL_HAVE_FUSIONG      0    /* FusionG */
-#define XCHAL_HAVE_FUSIONG3     0    /* FusionG3 */
-#define XCHAL_HAVE_FUSIONG6     0    /* FusionG6 */
-#define XCHAL_HAVE_FUSIONG_SP_VFPU  0    /* sp_vfpu option on FusionG */
-#define XCHAL_HAVE_FUSIONG_DP_VFPU  0    /* dp_vfpu option on FusionG */
-#define XCHAL_FUSIONG_SIMD32        0    /* simd32 for FusionG */
-
-#define XCHAL_HAVE_PDX          0    /* PDX */
-#define XCHAL_PDX_SIMD32        0    /* simd32 for PDX */
-#define XCHAL_HAVE_PDX4         0    /* PDX4 */
-#define XCHAL_HAVE_PDX8         0    /* PDX8 */
-#define XCHAL_HAVE_PDX16        0    /* PDX16 */
-
-#define XCHAL_HAVE_CONNXD2      0   /* ConnX D2 pkg */
-#define XCHAL_HAVE_CONNXD2_DUALLSFLIX   0   /* ConnX D2 & Dual LoadStore Flix */
-#define XCHAL_HAVE_BBE16        0   /* ConnX BBE16 pkg */
-#define XCHAL_HAVE_BBE16_RSQRT      0   /* BBE16 & vector recip sqrt */
-#define XCHAL_HAVE_BBE16_VECDIV     0   /* BBE16 & vector divide */
-#define XCHAL_HAVE_BBE16_DESPREAD   0   /* BBE16 & despread */
-#define XCHAL_HAVE_BBENEP       0   /* ConnX BBENEP pkgs */
-#define XCHAL_HAVE_BBENEP_SP_VFPU   0      /* sp_vfpu option on BBE-EP */
-#define XCHAL_HAVE_BSP3         0   /* ConnX BSP3 pkg */
-#define XCHAL_HAVE_BSP3_TRANSPOSE   0   /* BSP3 & transpose32x32 */
-#define XCHAL_HAVE_SSP16        0   /* ConnX SSP16 pkg */
-#define XCHAL_HAVE_SSP16_VITERBI    0   /* SSP16 & viterbi */
-#define XCHAL_HAVE_TURBO16      0   /* ConnX Turbo16 pkg */
-#define XCHAL_HAVE_BBP16        0   /* ConnX BBP16 pkg */
-#define XCHAL_HAVE_FLIX3        0   /* basic 3-way FLIX option */
-#define XCHAL_HAVE_GRIVPEP      0   /* General Release of IVPEP */
-#define XCHAL_HAVE_GRIVPEP_HISTOGRAM    0       /* Histogram option on GRIVPEP */
-
-#define XCHAL_HAVE_VISION           0     /* Vision P5/P6 */
+#define XCHAL_HAVE_BE			0	/* big-endian byte ordering */
+#define XCHAL_HAVE_WINDOWED		1	/* windowed registers option */
+#define XCHAL_NUM_AREGS			64	/* num of physical addr regs */
+#define XCHAL_NUM_AREGS_LOG2		6	/* log2(XCHAL_NUM_AREGS) */
+#define XCHAL_MAX_INSTRUCTION_SIZE	4	/* max instr bytes (3..8) */
+#define XCHAL_HAVE_DEBUG		1	/* debug option */
+#define XCHAL_HAVE_DENSITY		1	/* 16-bit instructions */
+#define XCHAL_HAVE_LOOPS		1	/* zero-overhead loops */
+#define XCHAL_LOOP_BUFFER_SIZE		256	/* zero-ov. loop instr buffer size */
+#define XCHAL_HAVE_NSA			1	/* NSA/NSAU instructions */
+#define XCHAL_HAVE_MINMAX		1	/* MIN/MAX instructions */
+#define XCHAL_HAVE_SEXT			1	/* SEXT instruction */
+#define XCHAL_HAVE_DEPBITS		0	/* DEPBITS instruction */
+#define XCHAL_HAVE_CLAMPS		1	/* CLAMPS instruction */
+#define XCHAL_HAVE_MUL16		1	/* MUL16S/MUL16U instructions */
+#define XCHAL_HAVE_MUL32		1	/* MULL instruction */
+#define XCHAL_HAVE_MUL32_HIGH		1	/* MULUH/MULSH instructions */
+#define XCHAL_HAVE_DIV32		1	/* QUOS/QUOU/REMS/REMU instructions */
+#define XCHAL_HAVE_L32R			1	/* L32R instruction */
+#define XCHAL_HAVE_ABSOLUTE_LITERALS	0	/* non-PC-rel (extended) L32R */
+#define XCHAL_HAVE_CONST16		0	/* CONST16 instruction */
+#define XCHAL_HAVE_ADDX			1	/* ADDX#/SUBX# instructions */
+#define XCHAL_HAVE_EXCLUSIVE            0	/* L32EX/S32EX instructions */
+#define XCHAL_HAVE_WIDE_BRANCHES	0	/* B*.W18 or B*.W15 instr's */
+#define XCHAL_HAVE_PREDICTED_BRANCHES	0	/* B[EQ/EQZ/NE/NEZ]T instr's */
+#define XCHAL_HAVE_CALL4AND12		1	/* (obsolete option) */
+#define XCHAL_HAVE_ABS			1	/* ABS instruction */
+/*#define XCHAL_HAVE_POPC		0*/	/* POPC instruction */
+/*#define XCHAL_HAVE_CRC		0*/	/* CRC instruction */
+#define XCHAL_HAVE_RELEASE_SYNC		1	/* L32AI/S32RI instructions */
+#define XCHAL_HAVE_S32C1I		1	/* S32C1I instruction */
+#define XCHAL_HAVE_SPECULATION		0	/* speculation */
+#define XCHAL_HAVE_FULL_RESET		1	/* all regs/state reset */
+#define XCHAL_NUM_CONTEXTS		1	/* */
+#define XCHAL_NUM_MISC_REGS		4	/* num of scratch regs (0..4) */
+#define XCHAL_HAVE_TAP_MASTER		0	/* JTAG TAP control instr's */
+#define XCHAL_HAVE_PRID			1	/* processor ID register */
+#define XCHAL_HAVE_EXTERN_REGS		1	/* WER/RER instructions */
+#define XCHAL_HAVE_MX			0	/* MX core (Tensilica internal) */
+#define XCHAL_HAVE_MP_INTERRUPTS	0	/* interrupt distributor port */
+#define XCHAL_HAVE_MP_RUNSTALL		0	/* core RunStall control port */
+#define XCHAL_HAVE_PSO			0	/* Power Shut-Off */
+#define XCHAL_HAVE_PSO_CDM		0	/* core/debug/mem pwr domains */
+#define XCHAL_HAVE_PSO_FULL_RETENTION	0	/* all regs preserved on PSO */
+#define XCHAL_HAVE_THREADPTR		1	/* THREADPTR register */
+#define XCHAL_HAVE_BOOLEANS		1	/* boolean registers */
+#define XCHAL_HAVE_CP			1	/* CPENABLE reg (coprocessor) */
+#define XCHAL_CP_MAXCFG			8	/* max allowed cp id plus one */
+#define XCHAL_HAVE_MAC16		1	/* MAC16 package */
+
+#define XCHAL_HAVE_FUSION		0	/* Fusion*/
+#define XCHAL_HAVE_FUSION_FP		0	/* Fusion FP option */
+#define XCHAL_HAVE_FUSION_LOW_POWER	0	/* Fusion Low Power option */
+#define XCHAL_HAVE_FUSION_AES		0	/* Fusion BLE/Wifi AES-128 CCM option */
+#define XCHAL_HAVE_FUSION_CONVENC	0	/* Fusion Conv Encode option */
+#define XCHAL_HAVE_FUSION_LFSR_CRC	0	/* Fusion LFSR-CRC option */
+#define XCHAL_HAVE_FUSION_BITOPS	0	/* Fusion Bit Operations Support option */
+#define XCHAL_HAVE_FUSION_AVS		0	/* Fusion AVS option */
+#define XCHAL_HAVE_FUSION_16BIT_BASEBAND 0	/* Fusion 16-bit Baseband option */
+#define XCHAL_HAVE_FUSION_VITERBI	0	/* Fusion Viterbi option */
+#define XCHAL_HAVE_FUSION_SOFTDEMAP	0	/* Fusion Soft Bit Demap option */
+#define XCHAL_HAVE_HIFIPRO		0	/* HiFiPro Audio Engine pkg */
+#define XCHAL_HAVE_HIFI5		0	/* HiFi5 Audio Engine pkg */
+#define XCHAL_HAVE_HIFI5_NN_MAC		0	/* HiFi5 Audio Engine NN-MAC option */
+#define XCHAL_HAVE_HIFI5_VFPU		0	/* HiFi5 Audio Engine Single-Precision VFPU option */
+#define XCHAL_HAVE_HIFI5_HP_VFPU	0	/* HiFi5 Audio Engine Half-Precision VFPU option */
+#define XCHAL_HAVE_HIFI4		0	/* HiFi4 Audio Engine pkg */
+#define XCHAL_HAVE_HIFI4_VFPU		0	/* HiFi4 Audio Engine VFPU option */
+#define XCHAL_HAVE_HIFI3		0	/* HiFi3 Audio Engine pkg */
+#define XCHAL_HAVE_HIFI3_VFPU		0	/* HiFi3 Audio Engine VFPU option */
+#define XCHAL_HAVE_HIFI3Z		0	/* HiFi3Z Audio Engine pkg */
+#define XCHAL_HAVE_HIFI3Z_VFPU	0	/* HiFi3Z Audio Engine VFPU option */
+#define XCHAL_HAVE_HIFI2		0	/* HiFi2 Audio Engine pkg */
+#define XCHAL_HAVE_HIFI2EP		0	/* HiFi2EP */
+#define XCHAL_HAVE_HIFI_MINI		0
+
+
+
+#define XCHAL_HAVE_VECTORFPU2005	0	/* vector floating-point pkg */
+#define XCHAL_HAVE_USER_DPFPU		0       /* user DP floating-point pkg */
+#define XCHAL_HAVE_USER_SPFPU		0       /* user SP floating-point pkg */
+#define XCHAL_HAVE_FP			1	/* single prec floating point */
+#define XCHAL_HAVE_FP_DIV		1	/* FP with DIV instructions */
+#define XCHAL_HAVE_FP_RECIP		1	/* FP with RECIP instructions */
+#define XCHAL_HAVE_FP_SQRT		1	/* FP with SQRT instructions */
+#define XCHAL_HAVE_FP_RSQRT		1	/* FP with RSQRT instructions */
+#define XCHAL_HAVE_DFP			0	/* double precision FP pkg */
+#define XCHAL_HAVE_DFP_DIV		0	/* DFP with DIV instructions */
+#define XCHAL_HAVE_DFP_RECIP		0	/* DFP with RECIP instructions*/
+#define XCHAL_HAVE_DFP_SQRT		0	/* DFP with SQRT instructions */
+#define XCHAL_HAVE_DFP_RSQRT		0	/* DFP with RSQRT instructions*/
+#define XCHAL_HAVE_DFP_ACCEL		0	/* double precision FP acceleration pkg */
+#define XCHAL_HAVE_DFP_accel		XCHAL_HAVE_DFP_ACCEL	/* for backward compatibility */
+
+#define XCHAL_HAVE_DFPU_SINGLE_ONLY	1	/* DFPU Coprocessor, single precision only */
+#define XCHAL_HAVE_DFPU_SINGLE_DOUBLE	0	/* DFPU Coprocessor, single and double precision */
+#define XCHAL_HAVE_VECTRA1		0	/* Vectra I  pkg */
+#define XCHAL_HAVE_VECTRALX		0	/* Vectra LX pkg */
+
+#define XCHAL_HAVE_FUSIONG		0    /* FusionG */
+#define XCHAL_HAVE_FUSIONG3		0    /* FusionG3 */
+#define XCHAL_HAVE_FUSIONG6		0    /* FusionG6 */
+#define XCHAL_HAVE_FUSIONG_SP_VFPU	0    /* sp_vfpu option on FusionG */
+#define XCHAL_HAVE_FUSIONG_DP_VFPU	0    /* dp_vfpu option on FusionG */
+#define XCHAL_FUSIONG_SIMD32		0    /* simd32 for FusionG */
+
+#define XCHAL_HAVE_PDX			0    /* PDX */
+#define XCHAL_PDX_SIMD32		0    /* simd32 for PDX */
+#define XCHAL_HAVE_PDX4			0    /* PDX4 */
+#define XCHAL_HAVE_PDX8			0    /* PDX8 */
+#define XCHAL_HAVE_PDX16		0    /* PDX16 */
+
+#define XCHAL_HAVE_CONNXD2		0	/* ConnX D2 pkg */
+#define XCHAL_HAVE_CONNXD2_DUALLSFLIX   0	/* ConnX D2 & Dual LoadStore Flix */
+#define XCHAL_HAVE_BBE16		0	/* ConnX BBE16 pkg */
+#define XCHAL_HAVE_BBE16_RSQRT		0	/* BBE16 & vector recip sqrt */
+#define XCHAL_HAVE_BBE16_VECDIV		0	/* BBE16 & vector divide */
+#define XCHAL_HAVE_BBE16_DESPREAD	0	/* BBE16 & despread */
+#define XCHAL_HAVE_BBENEP		0	/* ConnX BBENEP pkgs */
+#define XCHAL_HAVE_BBENEP_SP_VFPU	0      /* sp_vfpu option on BBE-EP */
+#define XCHAL_HAVE_BSP3			0	/* ConnX BSP3 pkg */
+#define XCHAL_HAVE_BSP3_TRANSPOSE	0	/* BSP3 & transpose32x32 */
+#define XCHAL_HAVE_SSP16		0	/* ConnX SSP16 pkg */
+#define XCHAL_HAVE_SSP16_VITERBI	0	/* SSP16 & viterbi */
+#define XCHAL_HAVE_TURBO16		0	/* ConnX Turbo16 pkg */
+#define XCHAL_HAVE_BBP16		0	/* ConnX BBP16 pkg */
+#define XCHAL_HAVE_FLIX3		0	/* basic 3-way FLIX option */
+#define XCHAL_HAVE_GRIVPEP		0	/* General Release of IVPEP */
+#define XCHAL_HAVE_GRIVPEP_HISTOGRAM	0       /* Histogram option on GRIVPEP */
+
+#define XCHAL_HAVE_VISION	        0     /* Vision P5/P6 */
 #define XCHAL_VISION_SIMD16             0     /* simd16 for Vision P5/P6 */
 #define XCHAL_VISION_SIMD16             0     /* simd16 for Vision P5/P6 */
 #define XCHAL_VISION_TYPE               0     /* Vision P5, P6, or P3 */
 #define XCHAL_VISION_TYPE               0     /* Vision P5, P6, or P3 */
 #define XCHAL_VISION_QUAD_MAC_TYPE      0     /* quad_mac option on Vision P6 */
 #define XCHAL_VISION_QUAD_MAC_TYPE      0     /* quad_mac option on Vision P6 */
@@ -184,78 +184,81 @@
 #define XCHAL_HAVE_VISION_SP_VFPU       0     /* sp_vfpu option on Vision P5/P6 */
 #define XCHAL_HAVE_VISION_SP_VFPU       0     /* sp_vfpu option on Vision P5/P6 */
 #define XCHAL_HAVE_VISION_HP_VFPU       0     /* hp_vfpu option on Vision P6 */
 #define XCHAL_HAVE_VISION_HP_VFPU       0     /* hp_vfpu option on Vision P6 */
 
 
-#define XCHAL_HAVE_VISIONC          0     /* Vision C */
+#define XCHAL_HAVE_VISIONC	        0     /* Vision C */
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-                MISC
+				MISC
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
-#define XCHAL_NUM_LOADSTORE_UNITS   1   /* load/store units */
-#define XCHAL_NUM_WRITEBUFFER_ENTRIES   4   /* size of write buffer */
-#define XCHAL_INST_FETCH_WIDTH      4   /* instr-fetch width in bytes */
-#define XCHAL_DATA_WIDTH            16  /* data width in bytes */
-#define XCHAL_DATA_PIPE_DELAY       1   /* d-side pipeline delay (1 = 5-stage, 2 = 7-stage) */
-#define XCHAL_CLOCK_GATING_GLOBAL   1   /* global clock gating */
-#define XCHAL_CLOCK_GATING_FUNCUNIT 1   /* funct. unit clock gating */
+#define XCHAL_NUM_LOADSTORE_UNITS	1	/* load/store units */
+#define XCHAL_NUM_WRITEBUFFER_ENTRIES	4	/* size of write buffer */
+#define XCHAL_INST_FETCH_WIDTH		4	/* instr-fetch width in bytes */
+#define XCHAL_DATA_WIDTH		16	/* data width in bytes */
+#define XCHAL_DATA_PIPE_DELAY		1	/* d-side pipeline delay
+						   (1 = 5-stage, 2 = 7-stage) */
+#define XCHAL_CLOCK_GATING_GLOBAL	1	/* global clock gating */
+#define XCHAL_CLOCK_GATING_FUNCUNIT	1	/* funct. unit clock gating */
 /*  In T1050, applies to selected core load and store instructions (see ISA): */
 /*  In T1050, applies to selected core load and store instructions (see ISA): */
-#define XCHAL_UNALIGNED_LOAD_EXCEPTION  0   /* unaligned loads cause exc. */
-#define XCHAL_UNALIGNED_STORE_EXCEPTION 0   /* unaligned stores cause exc.*/
-#define XCHAL_UNALIGNED_LOAD_HW     1   /* unaligned loads work in hw */
-#define XCHAL_UNALIGNED_STORE_HW    1   /* unaligned stores work in hw*/
+#define XCHAL_UNALIGNED_LOAD_EXCEPTION	0	/* unaligned loads cause exc. */
+#define XCHAL_UNALIGNED_STORE_EXCEPTION	0	/* unaligned stores cause exc.*/
+#define XCHAL_UNALIGNED_LOAD_HW		1	/* unaligned loads work in hw */
+#define XCHAL_UNALIGNED_STORE_HW	1	/* unaligned stores work in hw*/
 
 
-#define XCHAL_SW_VERSION        1200012 /* sw version of this header */
+#define XCHAL_SW_VERSION		1200012	/* sw version of this header */
 
 
-#define XCHAL_CORE_ID           "LX7_ESP32_S3"  /* alphanum core name (CoreID) set in the Xtensa Processor Generator */
+#define XCHAL_CORE_ID			"LX7_ESP32_S3_MP"	/* alphanum core name
+						   (CoreID) set in the Xtensa
+						   Processor Generator */
 
 
-#define XCHAL_BUILD_UNIQUE_ID       0x00088EF1  /* 22-bit sw build ID */
+#define XCHAL_BUILD_UNIQUE_ID		0x00090F1F	/* 22-bit sw build ID */
 
 
 /*
 /*
  *  These definitions describe the hardware targeted by this software.
  *  These definitions describe the hardware targeted by this software.
  */
  */
-#define XCHAL_HW_CONFIGID0      0xC2F0FFFE  /* ConfigID hi 32 bits*/
-#define XCHAL_HW_CONFIGID1      0x23088EF1  /* ConfigID lo 32 bits*/
-#define XCHAL_HW_VERSION_NAME       "LX7.0.12"  /* full version name */
-#define XCHAL_HW_VERSION_MAJOR      2700    /* major ver# of targeted hw */
-#define XCHAL_HW_VERSION_MINOR      12  /* minor ver# of targeted hw */
-#define XCHAL_HW_VERSION        270012  /* major*100+minor */
-#define XCHAL_HW_REL_LX7        1
-#define XCHAL_HW_REL_LX7_0      1
-#define XCHAL_HW_REL_LX7_0_12       1
-#define XCHAL_HW_CONFIGID_RELIABLE  1
+#define XCHAL_HW_CONFIGID0		0xC2F0FFFE	/* ConfigID hi 32 bits*/
+#define XCHAL_HW_CONFIGID1		0x23090F1F	/* ConfigID lo 32 bits*/
+#define XCHAL_HW_VERSION_NAME		"LX7.0.12"	/* full version name */
+#define XCHAL_HW_VERSION_MAJOR		2700	/* major ver# of targeted hw */
+#define XCHAL_HW_VERSION_MINOR		12	/* minor ver# of targeted hw */
+#define XCHAL_HW_VERSION		270012	/* major*100+minor */
+#define XCHAL_HW_REL_LX7		1
+#define XCHAL_HW_REL_LX7_0		1
+#define XCHAL_HW_REL_LX7_0_12		1
+#define XCHAL_HW_CONFIGID_RELIABLE	1
 /*  If software targets a *range* of hardware versions, these are the bounds: */
 /*  If software targets a *range* of hardware versions, these are the bounds: */
-#define XCHAL_HW_MIN_VERSION_MAJOR  2700    /* major v of earliest tgt hw */
-#define XCHAL_HW_MIN_VERSION_MINOR  12  /* minor v of earliest tgt hw */
-#define XCHAL_HW_MIN_VERSION        270012  /* earliest targeted hw */
-#define XCHAL_HW_MAX_VERSION_MAJOR  2700    /* major v of latest tgt hw */
-#define XCHAL_HW_MAX_VERSION_MINOR  12  /* minor v of latest tgt hw */
-#define XCHAL_HW_MAX_VERSION        270012  /* latest targeted hw */
+#define XCHAL_HW_MIN_VERSION_MAJOR	2700	/* major v of earliest tgt hw */
+#define XCHAL_HW_MIN_VERSION_MINOR	12	/* minor v of earliest tgt hw */
+#define XCHAL_HW_MIN_VERSION		270012	/* earliest targeted hw */
+#define XCHAL_HW_MAX_VERSION_MAJOR	2700	/* major v of latest tgt hw */
+#define XCHAL_HW_MAX_VERSION_MINOR	12	/* minor v of latest tgt hw */
+#define XCHAL_HW_MAX_VERSION		270012	/* latest targeted hw */
 
 
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-                CACHE
+				CACHE
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
-#define XCHAL_ICACHE_LINESIZE       4   /* I-cache line size in bytes */
-#define XCHAL_DCACHE_LINESIZE       16  /* D-cache line size in bytes */
-#define XCHAL_ICACHE_LINEWIDTH      2   /* log2(I line size in bytes) */
-#define XCHAL_DCACHE_LINEWIDTH      4   /* log2(D line size in bytes) */
+#define XCHAL_ICACHE_LINESIZE		4	/* I-cache line size in bytes */
+#define XCHAL_DCACHE_LINESIZE		16	/* D-cache line size in bytes */
+#define XCHAL_ICACHE_LINEWIDTH		2	/* log2(I line size in bytes) */
+#define XCHAL_DCACHE_LINEWIDTH		4	/* log2(D line size in bytes) */
 
 
-#define XCHAL_ICACHE_SIZE       0   /* I-cache size in bytes or 0 */
-#define XCHAL_DCACHE_SIZE       0   /* D-cache size in bytes or 0 */
+#define XCHAL_ICACHE_SIZE		0	/* I-cache size in bytes or 0 */
+#define XCHAL_DCACHE_SIZE		0	/* D-cache size in bytes or 0 */
 
 
-#define XCHAL_DCACHE_IS_WRITEBACK   0   /* writeback feature */
-#define XCHAL_DCACHE_IS_COHERENT    0   /* MP coherence feature */
+#define XCHAL_DCACHE_IS_WRITEBACK	0	/* writeback feature */
+#define XCHAL_DCACHE_IS_COHERENT	0	/* MP coherence feature */
 
 
-#define XCHAL_HAVE_PREFETCH     0   /* PREFCTL register */
-#define XCHAL_HAVE_PREFETCH_L1      0   /* prefetch to L1 dcache */
-#define XCHAL_PREFETCH_CASTOUT_LINES    0   /* dcache pref. castout bufsz */
-#define XCHAL_PREFETCH_ENTRIES      0   /* cache prefetch entries */
-#define XCHAL_PREFETCH_BLOCK_ENTRIES    0   /* prefetch block streams */
-#define XCHAL_HAVE_CACHE_BLOCKOPS   0   /* block prefetch for caches */
-#define XCHAL_HAVE_ICACHE_TEST      0   /* Icache test instructions */
-#define XCHAL_HAVE_DCACHE_TEST      0   /* Dcache test instructions */
-#define XCHAL_HAVE_ICACHE_DYN_WAYS  0   /* Icache dynamic way support */
-#define XCHAL_HAVE_DCACHE_DYN_WAYS  0   /* Dcache dynamic way support */
+#define XCHAL_HAVE_PREFETCH		0	/* PREFCTL register */
+#define XCHAL_HAVE_PREFETCH_L1		0	/* prefetch to L1 dcache */
+#define XCHAL_PREFETCH_CASTOUT_LINES	0	/* dcache pref. castout bufsz */
+#define XCHAL_PREFETCH_ENTRIES		0	/* cache prefetch entries */
+#define XCHAL_PREFETCH_BLOCK_ENTRIES	0	/* prefetch block streams */
+#define XCHAL_HAVE_CACHE_BLOCKOPS	0	/* block prefetch for caches */
+#define XCHAL_HAVE_ICACHE_TEST		0	/* Icache test instructions */
+#define XCHAL_HAVE_DCACHE_TEST		0	/* Dcache test instructions */
+#define XCHAL_HAVE_ICACHE_DYN_WAYS	0	/* Icache dynamic way support */
+#define XCHAL_HAVE_DCACHE_DYN_WAYS	0	/* Dcache dynamic way support */
 
 
 
 
 
 
@@ -268,207 +271,209 @@
 #ifndef XTENSA_HAL_NON_PRIVILEGED_ONLY
 #ifndef XTENSA_HAL_NON_PRIVILEGED_ONLY
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-                CACHE
+				CACHE
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
-#define XCHAL_HAVE_PIF          1   /* any outbound bus present */
+#define XCHAL_HAVE_PIF			1	/* any outbound bus present */
 
 
-#define XCHAL_HAVE_AXI          0   /* AXI bus */
-#define XCHAL_HAVE_AXI_ECC      0   /* ECC on AXI bus */
-#define XCHAL_HAVE_ACELITE      0   /* ACELite bus */
+#define XCHAL_HAVE_AXI			0	/* AXI bus */
+#define XCHAL_HAVE_AXI_ECC		0	/* ECC on AXI bus */
+#define XCHAL_HAVE_ACELITE		0	/* ACELite bus */
 
 
-#define XCHAL_HAVE_PIF_WR_RESP          0   /* pif write response */
-#define XCHAL_HAVE_PIF_REQ_ATTR         1   /* pif attribute */
+#define XCHAL_HAVE_PIF_WR_RESP			0	/* pif write response */
+#define XCHAL_HAVE_PIF_REQ_ATTR			1	/* pif attribute */
 
 
 /*  If present, cache size in bytes == (ways * 2^(linewidth + setwidth)).  */
 /*  If present, cache size in bytes == (ways * 2^(linewidth + setwidth)).  */
 
 
 /*  Number of cache sets in log2(lines per way):  */
 /*  Number of cache sets in log2(lines per way):  */
-#define XCHAL_ICACHE_SETWIDTH       0
-#define XCHAL_DCACHE_SETWIDTH       0
+#define XCHAL_ICACHE_SETWIDTH		0
+#define XCHAL_DCACHE_SETWIDTH		0
 
 
 /*  Cache set associativity (number of ways):  */
 /*  Cache set associativity (number of ways):  */
-#define XCHAL_ICACHE_WAYS       1
-#define XCHAL_DCACHE_WAYS       1
+#define XCHAL_ICACHE_WAYS		1
+#define XCHAL_DCACHE_WAYS		1
 
 
 /*  Cache features:  */
 /*  Cache features:  */
-#define XCHAL_ICACHE_LINE_LOCKABLE  0
-#define XCHAL_DCACHE_LINE_LOCKABLE  0
-#define XCHAL_ICACHE_ECC_PARITY     0
-#define XCHAL_DCACHE_ECC_PARITY     0
-#define XCHAL_ICACHE_ECC_WIDTH      1
-#define XCHAL_DCACHE_ECC_WIDTH      1
+#define XCHAL_ICACHE_LINE_LOCKABLE	0
+#define XCHAL_DCACHE_LINE_LOCKABLE	0
+#define XCHAL_ICACHE_ECC_PARITY		0
+#define XCHAL_DCACHE_ECC_PARITY		0
+#define XCHAL_ICACHE_ECC_WIDTH		1
+#define XCHAL_DCACHE_ECC_WIDTH		1
 
 
 /*  Cache access size in bytes (affects operation of SICW instruction):  */
 /*  Cache access size in bytes (affects operation of SICW instruction):  */
-#define XCHAL_ICACHE_ACCESS_SIZE    1
-#define XCHAL_DCACHE_ACCESS_SIZE    1
+#define XCHAL_ICACHE_ACCESS_SIZE	1
+#define XCHAL_DCACHE_ACCESS_SIZE	1
 
 
-#define XCHAL_DCACHE_BANKS      0   /* number of banks */
+#define XCHAL_DCACHE_BANKS		0	/* number of banks */
 
 
 /*  Number of encoded cache attr bits (see <xtensa/hal.h> for decoded bits):  */
 /*  Number of encoded cache attr bits (see <xtensa/hal.h> for decoded bits):  */
-#define XCHAL_CA_BITS           4
+#define XCHAL_CA_BITS			4
 
 
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-            INTERNAL I/D RAM/ROMs and XLMI
+			INTERNAL I/D RAM/ROMs and XLMI
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
-#define XCHAL_NUM_INSTROM       0   /* number of core instr. ROMs */
-#define XCHAL_NUM_INSTRAM       1   /* number of core instr. RAMs */
-#define XCHAL_NUM_DATAROM       0   /* number of core data ROMs */
-#define XCHAL_NUM_DATARAM       1   /* number of core data RAMs */
-#define XCHAL_NUM_URAM          0   /* number of core unified RAMs*/
-#define XCHAL_NUM_XLMI          0   /* number of core XLMI ports */
+#define XCHAL_NUM_INSTROM		0	/* number of core instr. ROMs */
+#define XCHAL_NUM_INSTRAM		1	/* number of core instr. RAMs */
+#define XCHAL_NUM_DATAROM		0	/* number of core data ROMs */
+#define XCHAL_NUM_DATARAM		1	/* number of core data RAMs */
+#define XCHAL_NUM_URAM			0	/* number of core unified RAMs*/
+#define XCHAL_NUM_XLMI			0	/* number of core XLMI ports */
 
 
 /*  Instruction RAM 0:  */
 /*  Instruction RAM 0:  */
-#define XCHAL_INSTRAM0_VADDR        0x40000000  /* virtual address */
-#define XCHAL_INSTRAM0_PADDR        0x40000000  /* physical address */
-#define XCHAL_INSTRAM0_SIZE         67108864    /* size in bytes */
-#define XCHAL_INSTRAM0_ECC_PARITY   0   /* ECC/parity type, 0=none */
-#define XCHAL_HAVE_INSTRAM0         1
-#define XCHAL_INSTRAM0_HAVE_IDMA    0   /* idma supported by this local memory */
+#define XCHAL_INSTRAM0_VADDR		0x40000000	/* virtual address */
+#define XCHAL_INSTRAM0_PADDR		0x40000000	/* physical address */
+#define XCHAL_INSTRAM0_SIZE		67108864	/* size in bytes */
+#define XCHAL_INSTRAM0_ECC_PARITY	0	/* ECC/parity type, 0=none */
+#define XCHAL_HAVE_INSTRAM0		1
+#define XCHAL_INSTRAM0_HAVE_IDMA	0	/* idma supported by this local memory */
 
 
 /*  Data RAM 0:  */
 /*  Data RAM 0:  */
-#define XCHAL_DATARAM0_VADDR        0x3C000000  /* virtual address */
-#define XCHAL_DATARAM0_PADDR        0x3C000000  /* physical address */
-#define XCHAL_DATARAM0_SIZE         67108864    /* size in bytes */
-#define XCHAL_DATARAM0_ECC_PARITY   0   /* ECC/parity type, 0=none */
-#define XCHAL_DATARAM0_BANKS        1   /* number of banks */
-#define XCHAL_HAVE_DATARAM0         1
-#define XCHAL_DATARAM0_HAVE_IDMA    0   /* idma supported by this local memory */
+#define XCHAL_DATARAM0_VADDR		0x3C000000	/* virtual address */
+#define XCHAL_DATARAM0_PADDR		0x3C000000	/* physical address */
+#define XCHAL_DATARAM0_SIZE		67108864	/* size in bytes */
+#define XCHAL_DATARAM0_ECC_PARITY	0	/* ECC/parity type, 0=none */
+#define XCHAL_DATARAM0_BANKS		1	/* number of banks */
+#define XCHAL_HAVE_DATARAM0		1
+#define XCHAL_DATARAM0_HAVE_IDMA	0	/* idma supported by this local memory */
 
 
-#define XCHAL_HAVE_IDMA             0
-#define XCHAL_HAVE_IDMA_TRANSPOSE   0
+#define XCHAL_HAVE_IDMA			0
+#define XCHAL_HAVE_IDMA_TRANSPOSE	0
 
 
-#define XCHAL_HAVE_IMEM_LOADSTORE   1   /* can load/store to IROM/IRAM*/
+#define XCHAL_HAVE_IMEM_LOADSTORE	1	/* can load/store to IROM/IRAM*/
 
 
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-            INTERRUPTS and TIMERS
+			INTERRUPTS and TIMERS
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
-#define XCHAL_HAVE_INTERRUPTS       1   /* interrupt option */
-#define XCHAL_HAVE_HIGHPRI_INTERRUPTS   1   /* med/high-pri. interrupts */
-#define XCHAL_HAVE_NMI          1   /* non-maskable interrupt */
-#define XCHAL_HAVE_CCOUNT       1   /* CCOUNT reg. (timer option) */
-#define XCHAL_NUM_TIMERS        3   /* number of CCOMPAREn regs */
-#define XCHAL_NUM_INTERRUPTS        32  /* number of interrupts */
-#define XCHAL_NUM_INTERRUPTS_LOG2   5   /* ceil(log2(NUM_INTERRUPTS)) */
-#define XCHAL_NUM_EXTINTERRUPTS     26  /* num of external interrupts */
-#define XCHAL_NUM_INTLEVELS     6   /* number of interrupt levels (not including level zero) */
-#define XCHAL_EXCM_LEVEL        3   /* level masked by PS.EXCM */
-/* (always 1 in XEA1; levels 2 .. EXCM_LEVEL are "medium priority") */
+#define XCHAL_HAVE_INTERRUPTS		1	/* interrupt option */
+#define XCHAL_HAVE_HIGHPRI_INTERRUPTS	1	/* med/high-pri. interrupts */
+#define XCHAL_HAVE_NMI			1	/* non-maskable interrupt */
+#define XCHAL_HAVE_CCOUNT		1	/* CCOUNT reg. (timer option) */
+#define XCHAL_NUM_TIMERS		3	/* number of CCOMPAREn regs */
+#define XCHAL_NUM_INTERRUPTS		32	/* number of interrupts */
+#define XCHAL_NUM_INTERRUPTS_LOG2	5	/* ceil(log2(NUM_INTERRUPTS)) */
+#define XCHAL_NUM_EXTINTERRUPTS		26	/* num of external interrupts */
+#define XCHAL_NUM_INTLEVELS		6	/* number of interrupt levels
+						   (not including level zero) */
+#define XCHAL_EXCM_LEVEL		3	/* level masked by PS.EXCM */
+	/* (always 1 in XEA1; levels 2 .. EXCM_LEVEL are "medium priority") */
 
 
 /*  Masks of interrupts at each interrupt level:  */
 /*  Masks of interrupts at each interrupt level:  */
-#define XCHAL_INTLEVEL1_MASK        0x000637FF
-#define XCHAL_INTLEVEL2_MASK        0x00380000
-#define XCHAL_INTLEVEL3_MASK        0x28C08800
-#define XCHAL_INTLEVEL4_MASK        0x53000000
-#define XCHAL_INTLEVEL5_MASK        0x84010000
-#define XCHAL_INTLEVEL6_MASK        0x00000000
-#define XCHAL_INTLEVEL7_MASK        0x00004000
+#define XCHAL_INTLEVEL1_MASK		0x000637FF
+#define XCHAL_INTLEVEL2_MASK		0x00380000
+#define XCHAL_INTLEVEL3_MASK		0x28C08800
+#define XCHAL_INTLEVEL4_MASK		0x53000000
+#define XCHAL_INTLEVEL5_MASK		0x84010000
+#define XCHAL_INTLEVEL6_MASK		0x00000000
+#define XCHAL_INTLEVEL7_MASK		0x00004000
 
 
 /*  Masks of interrupts at each range 1..n of interrupt levels:  */
 /*  Masks of interrupts at each range 1..n of interrupt levels:  */
-#define XCHAL_INTLEVEL1_ANDBELOW_MASK   0x000637FF
-#define XCHAL_INTLEVEL2_ANDBELOW_MASK   0x003E37FF
-#define XCHAL_INTLEVEL3_ANDBELOW_MASK   0x28FEBFFF
-#define XCHAL_INTLEVEL4_ANDBELOW_MASK   0x7BFEBFFF
-#define XCHAL_INTLEVEL5_ANDBELOW_MASK   0xFFFFBFFF
-#define XCHAL_INTLEVEL6_ANDBELOW_MASK   0xFFFFBFFF
-#define XCHAL_INTLEVEL7_ANDBELOW_MASK   0xFFFFFFFF
+#define XCHAL_INTLEVEL1_ANDBELOW_MASK	0x000637FF
+#define XCHAL_INTLEVEL2_ANDBELOW_MASK	0x003E37FF
+#define XCHAL_INTLEVEL3_ANDBELOW_MASK	0x28FEBFFF
+#define XCHAL_INTLEVEL4_ANDBELOW_MASK	0x7BFEBFFF
+#define XCHAL_INTLEVEL5_ANDBELOW_MASK	0xFFFFBFFF
+#define XCHAL_INTLEVEL6_ANDBELOW_MASK	0xFFFFBFFF
+#define XCHAL_INTLEVEL7_ANDBELOW_MASK	0xFFFFFFFF
 
 
 /*  Level of each interrupt:  */
 /*  Level of each interrupt:  */
-#define XCHAL_INT0_LEVEL        1
-#define XCHAL_INT1_LEVEL        1
-#define XCHAL_INT2_LEVEL        1
-#define XCHAL_INT3_LEVEL        1
-#define XCHAL_INT4_LEVEL        1
-#define XCHAL_INT5_LEVEL        1
-#define XCHAL_INT6_LEVEL        1
-#define XCHAL_INT7_LEVEL        1
-#define XCHAL_INT8_LEVEL        1
-#define XCHAL_INT9_LEVEL        1
-#define XCHAL_INT10_LEVEL       1
-#define XCHAL_INT11_LEVEL       3
-#define XCHAL_INT12_LEVEL       1
-#define XCHAL_INT13_LEVEL       1
-#define XCHAL_INT14_LEVEL       7
-#define XCHAL_INT15_LEVEL       3
-#define XCHAL_INT16_LEVEL       5
-#define XCHAL_INT17_LEVEL       1
-#define XCHAL_INT18_LEVEL       1
-#define XCHAL_INT19_LEVEL       2
-#define XCHAL_INT20_LEVEL       2
-#define XCHAL_INT21_LEVEL       2
-#define XCHAL_INT22_LEVEL       3
-#define XCHAL_INT23_LEVEL       3
-#define XCHAL_INT24_LEVEL       4
-#define XCHAL_INT25_LEVEL       4
-#define XCHAL_INT26_LEVEL       5
-#define XCHAL_INT27_LEVEL       3
-#define XCHAL_INT28_LEVEL       4
-#define XCHAL_INT29_LEVEL       3
-#define XCHAL_INT30_LEVEL       4
-#define XCHAL_INT31_LEVEL       5
-#define XCHAL_DEBUGLEVEL        6   /* debug interrupt level */
-#define XCHAL_HAVE_DEBUG_EXTERN_INT 1   /* OCD external db interrupt */
-#define XCHAL_NMILEVEL          7   /* NMI "level" (for use with EXCSAVE/EPS/EPC_n, RFI n) */
+#define XCHAL_INT0_LEVEL		1
+#define XCHAL_INT1_LEVEL		1
+#define XCHAL_INT2_LEVEL		1
+#define XCHAL_INT3_LEVEL		1
+#define XCHAL_INT4_LEVEL		1
+#define XCHAL_INT5_LEVEL		1
+#define XCHAL_INT6_LEVEL		1
+#define XCHAL_INT7_LEVEL		1
+#define XCHAL_INT8_LEVEL		1
+#define XCHAL_INT9_LEVEL		1
+#define XCHAL_INT10_LEVEL		1
+#define XCHAL_INT11_LEVEL		3
+#define XCHAL_INT12_LEVEL		1
+#define XCHAL_INT13_LEVEL		1
+#define XCHAL_INT14_LEVEL		7
+#define XCHAL_INT15_LEVEL		3
+#define XCHAL_INT16_LEVEL		5
+#define XCHAL_INT17_LEVEL		1
+#define XCHAL_INT18_LEVEL		1
+#define XCHAL_INT19_LEVEL		2
+#define XCHAL_INT20_LEVEL		2
+#define XCHAL_INT21_LEVEL		2
+#define XCHAL_INT22_LEVEL		3
+#define XCHAL_INT23_LEVEL		3
+#define XCHAL_INT24_LEVEL		4
+#define XCHAL_INT25_LEVEL		4
+#define XCHAL_INT26_LEVEL		5
+#define XCHAL_INT27_LEVEL		3
+#define XCHAL_INT28_LEVEL		4
+#define XCHAL_INT29_LEVEL		3
+#define XCHAL_INT30_LEVEL		4
+#define XCHAL_INT31_LEVEL		5
+#define XCHAL_DEBUGLEVEL		6	/* debug interrupt level */
+#define XCHAL_HAVE_DEBUG_EXTERN_INT	1	/* OCD external db interrupt */
+#define XCHAL_NMILEVEL			7	/* NMI "level" (for use with
+						   EXCSAVE/EPS/EPC_n, RFI n) */
 
 
 /*  Type of each interrupt:  */
 /*  Type of each interrupt:  */
-#define XCHAL_INT0_TYPE     XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT1_TYPE     XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT2_TYPE     XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT3_TYPE     XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT4_TYPE     XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT5_TYPE     XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT6_TYPE     XTHAL_INTTYPE_TIMER
-#define XCHAL_INT7_TYPE     XTHAL_INTTYPE_SOFTWARE
-#define XCHAL_INT8_TYPE     XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT9_TYPE     XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT10_TYPE    XTHAL_INTTYPE_EXTERN_EDGE
-#define XCHAL_INT11_TYPE    XTHAL_INTTYPE_PROFILING
-#define XCHAL_INT12_TYPE    XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT13_TYPE    XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT14_TYPE    XTHAL_INTTYPE_NMI
-#define XCHAL_INT15_TYPE    XTHAL_INTTYPE_TIMER
-#define XCHAL_INT16_TYPE    XTHAL_INTTYPE_TIMER
-#define XCHAL_INT17_TYPE    XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT18_TYPE    XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT19_TYPE    XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT20_TYPE    XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT21_TYPE    XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT22_TYPE    XTHAL_INTTYPE_EXTERN_EDGE
-#define XCHAL_INT23_TYPE    XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT24_TYPE    XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT25_TYPE    XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT26_TYPE    XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT27_TYPE    XTHAL_INTTYPE_EXTERN_LEVEL
-#define XCHAL_INT28_TYPE    XTHAL_INTTYPE_EXTERN_EDGE
-#define XCHAL_INT29_TYPE    XTHAL_INTTYPE_SOFTWARE
-#define XCHAL_INT30_TYPE    XTHAL_INTTYPE_EXTERN_EDGE
-#define XCHAL_INT31_TYPE    XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT0_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT1_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT2_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT3_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT4_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT5_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT6_TYPE 	XTHAL_INTTYPE_TIMER
+#define XCHAL_INT7_TYPE 	XTHAL_INTTYPE_SOFTWARE
+#define XCHAL_INT8_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT9_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT10_TYPE 	XTHAL_INTTYPE_EXTERN_EDGE
+#define XCHAL_INT11_TYPE 	XTHAL_INTTYPE_PROFILING
+#define XCHAL_INT12_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT13_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT14_TYPE 	XTHAL_INTTYPE_NMI
+#define XCHAL_INT15_TYPE 	XTHAL_INTTYPE_TIMER
+#define XCHAL_INT16_TYPE 	XTHAL_INTTYPE_TIMER
+#define XCHAL_INT17_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT18_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT19_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT20_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT21_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT22_TYPE 	XTHAL_INTTYPE_EXTERN_EDGE
+#define XCHAL_INT23_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT24_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT25_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT26_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT27_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
+#define XCHAL_INT28_TYPE 	XTHAL_INTTYPE_EXTERN_EDGE
+#define XCHAL_INT29_TYPE 	XTHAL_INTTYPE_SOFTWARE
+#define XCHAL_INT30_TYPE 	XTHAL_INTTYPE_EXTERN_EDGE
+#define XCHAL_INT31_TYPE 	XTHAL_INTTYPE_EXTERN_LEVEL
 
 
 /*  Masks of interrupts for each type of interrupt:  */
 /*  Masks of interrupts for each type of interrupt:  */
-#define XCHAL_INTTYPE_MASK_UNCONFIGURED 0x00000000
-#define XCHAL_INTTYPE_MASK_SOFTWARE 0x20000080
-#define XCHAL_INTTYPE_MASK_EXTERN_EDGE  0x50400400
-#define XCHAL_INTTYPE_MASK_EXTERN_LEVEL 0x8FBE333F
-#define XCHAL_INTTYPE_MASK_TIMER    0x00018040
-#define XCHAL_INTTYPE_MASK_NMI      0x00004000
-#define XCHAL_INTTYPE_MASK_WRITE_ERROR  0x00000000
-#define XCHAL_INTTYPE_MASK_PROFILING    0x00000800
-#define XCHAL_INTTYPE_MASK_IDMA_DONE    0x00000000
-#define XCHAL_INTTYPE_MASK_IDMA_ERR 0x00000000
-#define XCHAL_INTTYPE_MASK_GS_ERR   0x00000000
+#define XCHAL_INTTYPE_MASK_UNCONFIGURED	0x00000000
+#define XCHAL_INTTYPE_MASK_SOFTWARE	0x20000080
+#define XCHAL_INTTYPE_MASK_EXTERN_EDGE	0x50400400
+#define XCHAL_INTTYPE_MASK_EXTERN_LEVEL	0x8FBE333F
+#define XCHAL_INTTYPE_MASK_TIMER	0x00018040
+#define XCHAL_INTTYPE_MASK_NMI		0x00004000
+#define XCHAL_INTTYPE_MASK_WRITE_ERROR	0x00000000
+#define XCHAL_INTTYPE_MASK_PROFILING	0x00000800
+#define XCHAL_INTTYPE_MASK_IDMA_DONE	0x00000000
+#define XCHAL_INTTYPE_MASK_IDMA_ERR	0x00000000
+#define XCHAL_INTTYPE_MASK_GS_ERR	0x00000000
 
 
 /*  Interrupt numbers assigned to specific interrupt sources:  */
 /*  Interrupt numbers assigned to specific interrupt sources:  */
-#define XCHAL_TIMER0_INTERRUPT      6   /* CCOMPARE0 */
-#define XCHAL_TIMER1_INTERRUPT      15  /* CCOMPARE1 */
-#define XCHAL_TIMER2_INTERRUPT      16  /* CCOMPARE2 */
-#define XCHAL_TIMER3_INTERRUPT      XTHAL_TIMER_UNCONFIGURED
-#define XCHAL_NMI_INTERRUPT     14  /* non-maskable interrupt */
-#define XCHAL_PROFILING_INTERRUPT   11
+#define XCHAL_TIMER0_INTERRUPT		6	/* CCOMPARE0 */
+#define XCHAL_TIMER1_INTERRUPT		15	/* CCOMPARE1 */
+#define XCHAL_TIMER2_INTERRUPT		16	/* CCOMPARE2 */
+#define XCHAL_TIMER3_INTERRUPT		XTHAL_TIMER_UNCONFIGURED
+#define XCHAL_NMI_INTERRUPT		14	/* non-maskable interrupt */
+#define XCHAL_PROFILING_INTERRUPT	11
 
 
 /*  Interrupt numbers for levels at which only one interrupt is configured:  */
 /*  Interrupt numbers for levels at which only one interrupt is configured:  */
-#define XCHAL_INTLEVEL7_NUM     14
+#define XCHAL_INTLEVEL7_NUM		14
 /*  (There are many interrupts each at level(s) 1, 2, 3, 4, 5.)  */
 /*  (There are many interrupts each at level(s) 1, 2, 3, 4, 5.)  */
 
 
 
 
@@ -482,188 +487,193 @@
  */
  */
 
 
 /*  Core interrupt numbers mapped to each EXTERNAL BInterrupt pin number:  */
 /*  Core interrupt numbers mapped to each EXTERNAL BInterrupt pin number:  */
-#define XCHAL_EXTINT0_NUM       0   /* (intlevel 1) */
-#define XCHAL_EXTINT1_NUM       1   /* (intlevel 1) */
-#define XCHAL_EXTINT2_NUM       2   /* (intlevel 1) */
-#define XCHAL_EXTINT3_NUM       3   /* (intlevel 1) */
-#define XCHAL_EXTINT4_NUM       4   /* (intlevel 1) */
-#define XCHAL_EXTINT5_NUM       5   /* (intlevel 1) */
-#define XCHAL_EXTINT6_NUM       8   /* (intlevel 1) */
-#define XCHAL_EXTINT7_NUM       9   /* (intlevel 1) */
-#define XCHAL_EXTINT8_NUM       10  /* (intlevel 1) */
-#define XCHAL_EXTINT9_NUM       12  /* (intlevel 1) */
-#define XCHAL_EXTINT10_NUM      13  /* (intlevel 1) */
-#define XCHAL_EXTINT11_NUM      14  /* (intlevel 7) */
-#define XCHAL_EXTINT12_NUM      17  /* (intlevel 1) */
-#define XCHAL_EXTINT13_NUM      18  /* (intlevel 1) */
-#define XCHAL_EXTINT14_NUM      19  /* (intlevel 2) */
-#define XCHAL_EXTINT15_NUM      20  /* (intlevel 2) */
-#define XCHAL_EXTINT16_NUM      21  /* (intlevel 2) */
-#define XCHAL_EXTINT17_NUM      22  /* (intlevel 3) */
-#define XCHAL_EXTINT18_NUM      23  /* (intlevel 3) */
-#define XCHAL_EXTINT19_NUM      24  /* (intlevel 4) */
-#define XCHAL_EXTINT20_NUM      25  /* (intlevel 4) */
-#define XCHAL_EXTINT21_NUM      26  /* (intlevel 5) */
-#define XCHAL_EXTINT22_NUM      27  /* (intlevel 3) */
-#define XCHAL_EXTINT23_NUM      28  /* (intlevel 4) */
-#define XCHAL_EXTINT24_NUM      30  /* (intlevel 4) */
-#define XCHAL_EXTINT25_NUM      31  /* (intlevel 5) */
+#define XCHAL_EXTINT0_NUM		0	/* (intlevel 1) */
+#define XCHAL_EXTINT1_NUM		1	/* (intlevel 1) */
+#define XCHAL_EXTINT2_NUM		2	/* (intlevel 1) */
+#define XCHAL_EXTINT3_NUM		3	/* (intlevel 1) */
+#define XCHAL_EXTINT4_NUM		4	/* (intlevel 1) */
+#define XCHAL_EXTINT5_NUM		5	/* (intlevel 1) */
+#define XCHAL_EXTINT6_NUM		8	/* (intlevel 1) */
+#define XCHAL_EXTINT7_NUM		9	/* (intlevel 1) */
+#define XCHAL_EXTINT8_NUM		10	/* (intlevel 1) */
+#define XCHAL_EXTINT9_NUM		12	/* (intlevel 1) */
+#define XCHAL_EXTINT10_NUM		13	/* (intlevel 1) */
+#define XCHAL_EXTINT11_NUM		14	/* (intlevel 7) */
+#define XCHAL_EXTINT12_NUM		17	/* (intlevel 1) */
+#define XCHAL_EXTINT13_NUM		18	/* (intlevel 1) */
+#define XCHAL_EXTINT14_NUM		19	/* (intlevel 2) */
+#define XCHAL_EXTINT15_NUM		20	/* (intlevel 2) */
+#define XCHAL_EXTINT16_NUM		21	/* (intlevel 2) */
+#define XCHAL_EXTINT17_NUM		22	/* (intlevel 3) */
+#define XCHAL_EXTINT18_NUM		23	/* (intlevel 3) */
+#define XCHAL_EXTINT19_NUM		24	/* (intlevel 4) */
+#define XCHAL_EXTINT20_NUM		25	/* (intlevel 4) */
+#define XCHAL_EXTINT21_NUM		26	/* (intlevel 5) */
+#define XCHAL_EXTINT22_NUM		27	/* (intlevel 3) */
+#define XCHAL_EXTINT23_NUM		28	/* (intlevel 4) */
+#define XCHAL_EXTINT24_NUM		30	/* (intlevel 4) */
+#define XCHAL_EXTINT25_NUM		31	/* (intlevel 5) */
 /*  EXTERNAL BInterrupt pin numbers mapped to each core interrupt number:  */
 /*  EXTERNAL BInterrupt pin numbers mapped to each core interrupt number:  */
-#define XCHAL_INT0_EXTNUM       0   /* (intlevel 1) */
-#define XCHAL_INT1_EXTNUM       1   /* (intlevel 1) */
-#define XCHAL_INT2_EXTNUM       2   /* (intlevel 1) */
-#define XCHAL_INT3_EXTNUM       3   /* (intlevel 1) */
-#define XCHAL_INT4_EXTNUM       4   /* (intlevel 1) */
-#define XCHAL_INT5_EXTNUM       5   /* (intlevel 1) */
-#define XCHAL_INT8_EXTNUM       6   /* (intlevel 1) */
-#define XCHAL_INT9_EXTNUM       7   /* (intlevel 1) */
-#define XCHAL_INT10_EXTNUM      8   /* (intlevel 1) */
-#define XCHAL_INT12_EXTNUM      9   /* (intlevel 1) */
-#define XCHAL_INT13_EXTNUM      10  /* (intlevel 1) */
-#define XCHAL_INT14_EXTNUM      11  /* (intlevel 7) */
-#define XCHAL_INT17_EXTNUM      12  /* (intlevel 1) */
-#define XCHAL_INT18_EXTNUM      13  /* (intlevel 1) */
-#define XCHAL_INT19_EXTNUM      14  /* (intlevel 2) */
-#define XCHAL_INT20_EXTNUM      15  /* (intlevel 2) */
-#define XCHAL_INT21_EXTNUM      16  /* (intlevel 2) */
-#define XCHAL_INT22_EXTNUM      17  /* (intlevel 3) */
-#define XCHAL_INT23_EXTNUM      18  /* (intlevel 3) */
-#define XCHAL_INT24_EXTNUM      19  /* (intlevel 4) */
-#define XCHAL_INT25_EXTNUM      20  /* (intlevel 4) */
-#define XCHAL_INT26_EXTNUM      21  /* (intlevel 5) */
-#define XCHAL_INT27_EXTNUM      22  /* (intlevel 3) */
-#define XCHAL_INT28_EXTNUM      23  /* (intlevel 4) */
-#define XCHAL_INT30_EXTNUM      24  /* (intlevel 4) */
-#define XCHAL_INT31_EXTNUM      25  /* (intlevel 5) */
+#define XCHAL_INT0_EXTNUM		0	/* (intlevel 1) */
+#define XCHAL_INT1_EXTNUM		1	/* (intlevel 1) */
+#define XCHAL_INT2_EXTNUM		2	/* (intlevel 1) */
+#define XCHAL_INT3_EXTNUM		3	/* (intlevel 1) */
+#define XCHAL_INT4_EXTNUM		4	/* (intlevel 1) */
+#define XCHAL_INT5_EXTNUM		5	/* (intlevel 1) */
+#define XCHAL_INT8_EXTNUM		6	/* (intlevel 1) */
+#define XCHAL_INT9_EXTNUM		7	/* (intlevel 1) */
+#define XCHAL_INT10_EXTNUM		8	/* (intlevel 1) */
+#define XCHAL_INT12_EXTNUM		9	/* (intlevel 1) */
+#define XCHAL_INT13_EXTNUM		10	/* (intlevel 1) */
+#define XCHAL_INT14_EXTNUM		11	/* (intlevel 7) */
+#define XCHAL_INT17_EXTNUM		12	/* (intlevel 1) */
+#define XCHAL_INT18_EXTNUM		13	/* (intlevel 1) */
+#define XCHAL_INT19_EXTNUM		14	/* (intlevel 2) */
+#define XCHAL_INT20_EXTNUM		15	/* (intlevel 2) */
+#define XCHAL_INT21_EXTNUM		16	/* (intlevel 2) */
+#define XCHAL_INT22_EXTNUM		17	/* (intlevel 3) */
+#define XCHAL_INT23_EXTNUM		18	/* (intlevel 3) */
+#define XCHAL_INT24_EXTNUM		19	/* (intlevel 4) */
+#define XCHAL_INT25_EXTNUM		20	/* (intlevel 4) */
+#define XCHAL_INT26_EXTNUM		21	/* (intlevel 5) */
+#define XCHAL_INT27_EXTNUM		22	/* (intlevel 3) */
+#define XCHAL_INT28_EXTNUM		23	/* (intlevel 4) */
+#define XCHAL_INT30_EXTNUM		24	/* (intlevel 4) */
+#define XCHAL_INT31_EXTNUM		25	/* (intlevel 5) */
 
 
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-            EXCEPTIONS and VECTORS
+			EXCEPTIONS and VECTORS
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
-#define XCHAL_XEA_VERSION       2   /* Xtensa Exception Architecture number: 1 == XEA1 (old) 2 == XEA2 (new) 0 == XEAX (extern) or TX */
-#define XCHAL_HAVE_XEA1         0   /* Exception Architecture 1 */
-#define XCHAL_HAVE_XEA2         1   /* Exception Architecture 2 */
-#define XCHAL_HAVE_XEAX         0   /* External Exception Arch. */
-#define XCHAL_HAVE_EXCEPTIONS       1   /* exception option */
-#define XCHAL_HAVE_HALT         0   /* halt architecture option */
-#define XCHAL_HAVE_BOOTLOADER       0   /* boot loader (for TX) */
-#define XCHAL_HAVE_MEM_ECC_PARITY   0   /* local memory ECC/parity */
-#define XCHAL_HAVE_VECTOR_SELECT    1   /* relocatable vectors */
-#define XCHAL_HAVE_VECBASE      1   /* relocatable vectors */
-#define XCHAL_VECBASE_RESET_VADDR   0x40000000  /* VECBASE reset value */
-#define XCHAL_VECBASE_RESET_PADDR   0x40000000
-#define XCHAL_RESET_VECBASE_OVERLAP 0
-
-#define XCHAL_RESET_VECTOR0_VADDR   0x50000000
-#define XCHAL_RESET_VECTOR0_PADDR   0x50000000
-#define XCHAL_RESET_VECTOR1_VADDR   0x40000400
-#define XCHAL_RESET_VECTOR1_PADDR   0x40000400
-#define XCHAL_RESET_VECTOR_VADDR    0x40000400
-#define XCHAL_RESET_VECTOR_PADDR    0x40000400
-#define XCHAL_USER_VECOFS       0x00000340
-#define XCHAL_USER_VECTOR_VADDR     0x40000340
-#define XCHAL_USER_VECTOR_PADDR     0x40000340
-#define XCHAL_KERNEL_VECOFS     0x00000300
-#define XCHAL_KERNEL_VECTOR_VADDR   0x40000300
-#define XCHAL_KERNEL_VECTOR_PADDR   0x40000300
-#define XCHAL_DOUBLEEXC_VECOFS      0x000003C0
-#define XCHAL_DOUBLEEXC_VECTOR_VADDR    0x400003C0
-#define XCHAL_DOUBLEEXC_VECTOR_PADDR    0x400003C0
-#define XCHAL_WINDOW_OF4_VECOFS     0x00000000
-#define XCHAL_WINDOW_UF4_VECOFS     0x00000040
-#define XCHAL_WINDOW_OF8_VECOFS     0x00000080
-#define XCHAL_WINDOW_UF8_VECOFS     0x000000C0
-#define XCHAL_WINDOW_OF12_VECOFS    0x00000100
-#define XCHAL_WINDOW_UF12_VECOFS    0x00000140
-#define XCHAL_WINDOW_VECTORS_VADDR  0x40000000
-#define XCHAL_WINDOW_VECTORS_PADDR  0x40000000
-#define XCHAL_INTLEVEL2_VECOFS      0x00000180
-#define XCHAL_INTLEVEL2_VECTOR_VADDR    0x40000180
-#define XCHAL_INTLEVEL2_VECTOR_PADDR    0x40000180
-#define XCHAL_INTLEVEL3_VECOFS      0x000001C0
-#define XCHAL_INTLEVEL3_VECTOR_VADDR    0x400001C0
-#define XCHAL_INTLEVEL3_VECTOR_PADDR    0x400001C0
-#define XCHAL_INTLEVEL4_VECOFS      0x00000200
-#define XCHAL_INTLEVEL4_VECTOR_VADDR    0x40000200
-#define XCHAL_INTLEVEL4_VECTOR_PADDR    0x40000200
-#define XCHAL_INTLEVEL5_VECOFS      0x00000240
-#define XCHAL_INTLEVEL5_VECTOR_VADDR    0x40000240
-#define XCHAL_INTLEVEL5_VECTOR_PADDR    0x40000240
-#define XCHAL_INTLEVEL6_VECOFS      0x00000280
-#define XCHAL_INTLEVEL6_VECTOR_VADDR    0x40000280
-#define XCHAL_INTLEVEL6_VECTOR_PADDR    0x40000280
-#define XCHAL_DEBUG_VECOFS      XCHAL_INTLEVEL6_VECOFS
-#define XCHAL_DEBUG_VECTOR_VADDR    XCHAL_INTLEVEL6_VECTOR_VADDR
-#define XCHAL_DEBUG_VECTOR_PADDR    XCHAL_INTLEVEL6_VECTOR_PADDR
-#define XCHAL_NMI_VECOFS        0x000002C0
-#define XCHAL_NMI_VECTOR_VADDR      0x400002C0
-#define XCHAL_NMI_VECTOR_PADDR      0x400002C0
-#define XCHAL_INTLEVEL7_VECOFS      XCHAL_NMI_VECOFS
-#define XCHAL_INTLEVEL7_VECTOR_VADDR    XCHAL_NMI_VECTOR_VADDR
-#define XCHAL_INTLEVEL7_VECTOR_PADDR    XCHAL_NMI_VECTOR_PADDR
+#define XCHAL_XEA_VERSION		2	/* Xtensa Exception Architecture
+						   number: 1 == XEA1 (old)
+							   2 == XEA2 (new)
+							   0 == XEAX (extern) or TX */
+#define XCHAL_HAVE_XEA1			0	/* Exception Architecture 1 */
+#define XCHAL_HAVE_XEA2			1	/* Exception Architecture 2 */
+#define XCHAL_HAVE_XEAX			0	/* External Exception Arch. */
+#define XCHAL_HAVE_EXCEPTIONS		1	/* exception option */
+#define XCHAL_HAVE_HALT			0	/* halt architecture option */
+#define XCHAL_HAVE_BOOTLOADER		0	/* boot loader (for TX) */
+#define XCHAL_HAVE_MEM_ECC_PARITY	0	/* local memory ECC/parity */
+#define XCHAL_HAVE_VECTOR_SELECT	1	/* relocatable vectors */
+#define XCHAL_HAVE_VECBASE		1	/* relocatable vectors */
+#define XCHAL_VECBASE_RESET_VADDR	0x40000000  /* VECBASE reset value */
+#define XCHAL_VECBASE_RESET_PADDR	0x40000000
+#define XCHAL_RESET_VECBASE_OVERLAP	0
+
+#define XCHAL_RESET_VECTOR0_VADDR	0x50000000
+#define XCHAL_RESET_VECTOR0_PADDR	0x50000000
+#define XCHAL_RESET_VECTOR1_VADDR	0x40000400
+#define XCHAL_RESET_VECTOR1_PADDR	0x40000400
+#define XCHAL_RESET_VECTOR_VADDR	0x40000400
+#define XCHAL_RESET_VECTOR_PADDR	0x40000400
+#define XCHAL_USER_VECOFS		0x00000340
+#define XCHAL_USER_VECTOR_VADDR		0x40000340
+#define XCHAL_USER_VECTOR_PADDR		0x40000340
+#define XCHAL_KERNEL_VECOFS		0x00000300
+#define XCHAL_KERNEL_VECTOR_VADDR	0x40000300
+#define XCHAL_KERNEL_VECTOR_PADDR	0x40000300
+#define XCHAL_DOUBLEEXC_VECOFS		0x000003C0
+#define XCHAL_DOUBLEEXC_VECTOR_VADDR	0x400003C0
+#define XCHAL_DOUBLEEXC_VECTOR_PADDR	0x400003C0
+#define XCHAL_WINDOW_OF4_VECOFS		0x00000000
+#define XCHAL_WINDOW_UF4_VECOFS		0x00000040
+#define XCHAL_WINDOW_OF8_VECOFS		0x00000080
+#define XCHAL_WINDOW_UF8_VECOFS		0x000000C0
+#define XCHAL_WINDOW_OF12_VECOFS	0x00000100
+#define XCHAL_WINDOW_UF12_VECOFS	0x00000140
+#define XCHAL_WINDOW_VECTORS_VADDR	0x40000000
+#define XCHAL_WINDOW_VECTORS_PADDR	0x40000000
+#define XCHAL_INTLEVEL2_VECOFS		0x00000180
+#define XCHAL_INTLEVEL2_VECTOR_VADDR	0x40000180
+#define XCHAL_INTLEVEL2_VECTOR_PADDR	0x40000180
+#define XCHAL_INTLEVEL3_VECOFS		0x000001C0
+#define XCHAL_INTLEVEL3_VECTOR_VADDR	0x400001C0
+#define XCHAL_INTLEVEL3_VECTOR_PADDR	0x400001C0
+#define XCHAL_INTLEVEL4_VECOFS		0x00000200
+#define XCHAL_INTLEVEL4_VECTOR_VADDR	0x40000200
+#define XCHAL_INTLEVEL4_VECTOR_PADDR	0x40000200
+#define XCHAL_INTLEVEL5_VECOFS		0x00000240
+#define XCHAL_INTLEVEL5_VECTOR_VADDR	0x40000240
+#define XCHAL_INTLEVEL5_VECTOR_PADDR	0x40000240
+#define XCHAL_INTLEVEL6_VECOFS		0x00000280
+#define XCHAL_INTLEVEL6_VECTOR_VADDR	0x40000280
+#define XCHAL_INTLEVEL6_VECTOR_PADDR	0x40000280
+#define XCHAL_DEBUG_VECOFS		XCHAL_INTLEVEL6_VECOFS
+#define XCHAL_DEBUG_VECTOR_VADDR	XCHAL_INTLEVEL6_VECTOR_VADDR
+#define XCHAL_DEBUG_VECTOR_PADDR	XCHAL_INTLEVEL6_VECTOR_PADDR
+#define XCHAL_NMI_VECOFS		0x000002C0
+#define XCHAL_NMI_VECTOR_VADDR		0x400002C0
+#define XCHAL_NMI_VECTOR_PADDR		0x400002C0
+#define XCHAL_INTLEVEL7_VECOFS		XCHAL_NMI_VECOFS
+#define XCHAL_INTLEVEL7_VECTOR_VADDR	XCHAL_NMI_VECTOR_VADDR
+#define XCHAL_INTLEVEL7_VECTOR_PADDR	XCHAL_NMI_VECTOR_PADDR
 
 
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-                DEBUG MODULE
+				DEBUG MODULE
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
 /*  Misc  */
 /*  Misc  */
-#define XCHAL_HAVE_DEBUG_ERI        1   /* ERI to debug module */
-#define XCHAL_HAVE_DEBUG_APB        0   /* APB to debug module */
-#define XCHAL_HAVE_DEBUG_JTAG       1   /* JTAG to debug module */
+#define XCHAL_HAVE_DEBUG_ERI		1	/* ERI to debug module */
+#define XCHAL_HAVE_DEBUG_APB		0	/* APB to debug module */
+#define XCHAL_HAVE_DEBUG_JTAG		1	/* JTAG to debug module */
 
 
 /*  On-Chip Debug (OCD)  */
 /*  On-Chip Debug (OCD)  */
-#define XCHAL_HAVE_OCD          1   /* OnChipDebug option */
-#define XCHAL_NUM_IBREAK        2   /* number of IBREAKn regs */
-#define XCHAL_NUM_DBREAK        2   /* number of DBREAKn regs */
-#define XCHAL_HAVE_OCD_DIR_ARRAY    0   /* faster OCD option (to LX4) */
-#define XCHAL_HAVE_OCD_LS32DDR      1   /* L32DDR/S32DDR (faster OCD) */
+#define XCHAL_HAVE_OCD			1	/* OnChipDebug option */
+#define XCHAL_NUM_IBREAK		2	/* number of IBREAKn regs */
+#define XCHAL_NUM_DBREAK		2	/* number of DBREAKn regs */
+#define XCHAL_HAVE_OCD_DIR_ARRAY	0	/* faster OCD option (to LX4) */
+#define XCHAL_HAVE_OCD_LS32DDR		1	/* L32DDR/S32DDR (faster OCD) */
 
 
 /*  TRAX (in core)  */
 /*  TRAX (in core)  */
-#define XCHAL_HAVE_TRAX         1   /* TRAX in debug module */
-#define XCHAL_TRAX_MEM_SIZE     16384   /* TRAX memory size in bytes */
-#define XCHAL_TRAX_MEM_SHAREABLE    1   /* start/end regs; ready sig. */
-#define XCHAL_TRAX_ATB_WIDTH        0   /* ATB width (bits), 0=no ATB */
-#define XCHAL_TRAX_TIME_WIDTH       0   /* timestamp bitwidth, 0=none */
+#define XCHAL_HAVE_TRAX			1	/* TRAX in debug module */
+#define XCHAL_TRAX_MEM_SIZE		16384	/* TRAX memory size in bytes */
+#define XCHAL_TRAX_MEM_SHAREABLE	1	/* start/end regs; ready sig. */
+#define XCHAL_TRAX_ATB_WIDTH		0	/* ATB width (bits), 0=no ATB */
+#define XCHAL_TRAX_TIME_WIDTH		0	/* timestamp bitwidth, 0=none */
 
 
 /*  Perf counters  */
 /*  Perf counters  */
-#define XCHAL_NUM_PERF_COUNTERS     2   /* performance counters */
+#define XCHAL_NUM_PERF_COUNTERS		2	/* performance counters */
 
 
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-                MMU
+				MMU
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
 /*  See core-matmap.h header file for more details.  */
 /*  See core-matmap.h header file for more details.  */
 
 
-#define XCHAL_HAVE_TLBS             1   /* inverse of HAVE_CACHEATTR */
-#define XCHAL_HAVE_SPANNING_WAY     1   /* one way maps I+D 4GB vaddr */
-#define XCHAL_SPANNING_WAY          0   /* TLB spanning way number */
-#define XCHAL_HAVE_IDENTITY_MAP     1   /* vaddr == paddr always */
-#define XCHAL_HAVE_CACHEATTR        0   /* CACHEATTR register present */
-#define XCHAL_HAVE_MIMIC_CACHEATTR  1   /* region protection */
-#define XCHAL_HAVE_XLT_CACHEATTR    0   /* region prot. w/translation */
-#define XCHAL_HAVE_PTP_MMU          0   /* full MMU (with page table [autorefill] and protection) usable for an MMU-based OS */
+#define XCHAL_HAVE_TLBS			1	/* inverse of HAVE_CACHEATTR */
+#define XCHAL_HAVE_SPANNING_WAY		1	/* one way maps I+D 4GB vaddr */
+#define XCHAL_SPANNING_WAY		0	/* TLB spanning way number */
+#define XCHAL_HAVE_IDENTITY_MAP		1	/* vaddr == paddr always */
+#define XCHAL_HAVE_CACHEATTR		0	/* CACHEATTR register present */
+#define XCHAL_HAVE_MIMIC_CACHEATTR	1	/* region protection */
+#define XCHAL_HAVE_XLT_CACHEATTR	0	/* region prot. w/translation */
+#define XCHAL_HAVE_PTP_MMU		0	/* full MMU (with page table
+						   [autorefill] and protection)
+						   usable for an MMU-based OS */
 
 
 /*  If none of the above last 5 are set, it's a custom TLB configuration.  */
 /*  If none of the above last 5 are set, it's a custom TLB configuration.  */
 
 
-#define XCHAL_MMU_ASID_BITS     0   /* number of bits in ASIDs */
-#define XCHAL_MMU_RINGS         1   /* number of rings (1..4) */
-#define XCHAL_MMU_RING_BITS     0   /* num of bits in RING field */
+#define XCHAL_MMU_ASID_BITS		0	/* number of bits in ASIDs */
+#define XCHAL_MMU_RINGS			1	/* number of rings (1..4) */
+#define XCHAL_MMU_RING_BITS		0	/* num of bits in RING field */
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-                MPU
+				MPU
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
-#define XCHAL_HAVE_MPU          0
-#define XCHAL_MPU_ENTRIES       0
+#define XCHAL_HAVE_MPU			0
+#define XCHAL_MPU_ENTRIES		0
 
 
-#define XCHAL_MPU_ALIGN_REQ     1   /* MPU requires alignment of entries to background map */
-#define XCHAL_MPU_BACKGROUND_ENTRIES    0   /* number of entries in bg map*/
-#define XCHAL_MPU_BG_CACHEADRDIS    0   /* default CACHEADRDIS for bg */
+#define XCHAL_MPU_ALIGN_REQ		1	/* MPU requires alignment of entries to background map */
+#define XCHAL_MPU_BACKGROUND_ENTRIES	0	/* number of entries in bg map*/
+#define XCHAL_MPU_BG_CACHEADRDIS	0	/* default CACHEADRDIS for bg */
 
 
-#define XCHAL_MPU_ALIGN_BITS        0
-#define XCHAL_MPU_ALIGN         0
+#define XCHAL_MPU_ALIGN_BITS		0
+#define XCHAL_MPU_ALIGN			0
 
 
 #endif /* !XTENSA_HAL_NON_PRIVILEGED_ONLY */
 #endif /* !XTENSA_HAL_NON_PRIVILEGED_ONLY */
 
 

+ 219 - 216
components/xtensa/esp32s3/include/xtensa/config/core-matmap.h

@@ -1,6 +1,6 @@
 /*
 /*
  * xtensa/config/core-matmap.h -- Memory access and translation mapping
  * xtensa/config/core-matmap.h -- Memory access and translation mapping
- *  parameters (CHAL) of the Xtensa processor core configuration.
+ *	parameters (CHAL) of the Xtensa processor core configuration.
  *
  *
  *  If you are using Xtensa Tools, see <xtensa/config/core.h> (which includes
  *  If you are using Xtensa Tools, see <xtensa/config/core.h> (which includes
  *  this file) for more details.
  *  this file) for more details.
@@ -9,20 +9,20 @@
  *  defined in this file are derivable (at least in theory) from
  *  defined in this file are derivable (at least in theory) from
  *  information contained in the core-isa.h header file.
  *  information contained in the core-isa.h header file.
  *  In particular, the following core configuration parameters are relevant:
  *  In particular, the following core configuration parameters are relevant:
- *  XCHAL_HAVE_CACHEATTR
- *  XCHAL_HAVE_MIMIC_CACHEATTR
- *  XCHAL_HAVE_XLT_CACHEATTR
- *  XCHAL_HAVE_PTP_MMU
- *  XCHAL_ITLB_ARF_ENTRIES_LOG2
- *  XCHAL_DTLB_ARF_ENTRIES_LOG2
- *  XCHAL_DCACHE_IS_WRITEBACK
- *  XCHAL_ICACHE_SIZE       (presence of I-cache)
- *  XCHAL_DCACHE_SIZE       (presence of D-cache)
- *  XCHAL_HW_VERSION_MAJOR
- *  XCHAL_HW_VERSION_MINOR
+ *	XCHAL_HAVE_CACHEATTR
+ *	XCHAL_HAVE_MIMIC_CACHEATTR
+ *	XCHAL_HAVE_XLT_CACHEATTR
+ *	XCHAL_HAVE_PTP_MMU
+ *	XCHAL_ITLB_ARF_ENTRIES_LOG2
+ *	XCHAL_DTLB_ARF_ENTRIES_LOG2
+ *	XCHAL_DCACHE_IS_WRITEBACK
+ *	XCHAL_ICACHE_SIZE		(presence of I-cache)
+ *	XCHAL_DCACHE_SIZE		(presence of D-cache)
+ *	XCHAL_HW_VERSION_MAJOR
+ *	XCHAL_HW_VERSION_MINOR
  */
  */
 
 
-/* Customer ID=15127; Build=0x86d67; Copyright (c) 1999-2020 Tensilica Inc.
+/* Customer ID=15128; Build=0x90f1f; Copyright (c) 1999-2021 Tensilica Inc.
 
 
    Permission is hereby granted, free of charge, to any person obtaining
    Permission is hereby granted, free of charge, to any person obtaining
    a copy of this software and associated documentation files (the
    a copy of this software and associated documentation files (the
@@ -49,60 +49,60 @@
 
 
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-            CACHE (MEMORY ACCESS) ATTRIBUTES
+			CACHE (MEMORY ACCESS) ATTRIBUTES
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
 
 
 
 
 /*  Cache Attribute encodings -- lists of access modes for each cache attribute:  */
 /*  Cache Attribute encodings -- lists of access modes for each cache attribute:  */
-#define XCHAL_FCA_LIST      XTHAL_FAM_EXCEPTION XCHAL_SEP \
-                XTHAL_FAM_BYPASS    XCHAL_SEP \
-                XTHAL_FAM_BYPASS    XCHAL_SEP \
-                XTHAL_FAM_BYPASS    XCHAL_SEP \
-                XTHAL_FAM_BYPASS    XCHAL_SEP \
-                XTHAL_FAM_BYPASS    XCHAL_SEP \
-                XTHAL_FAM_BYPASS    XCHAL_SEP \
-                XTHAL_FAM_EXCEPTION XCHAL_SEP \
-                XTHAL_FAM_EXCEPTION XCHAL_SEP \
-                XTHAL_FAM_EXCEPTION XCHAL_SEP \
-                XTHAL_FAM_EXCEPTION XCHAL_SEP \
-                XTHAL_FAM_EXCEPTION XCHAL_SEP \
-                XTHAL_FAM_EXCEPTION XCHAL_SEP \
-                XTHAL_FAM_EXCEPTION XCHAL_SEP \
-                XTHAL_FAM_EXCEPTION XCHAL_SEP \
-                XTHAL_FAM_EXCEPTION
-#define XCHAL_LCA_LIST      XTHAL_LAM_BYPASSG   XCHAL_SEP \
-                XTHAL_LAM_BYPASSG   XCHAL_SEP \
-                XTHAL_LAM_BYPASSG   XCHAL_SEP \
-                XTHAL_LAM_EXCEPTION XCHAL_SEP \
-                XTHAL_LAM_BYPASSG   XCHAL_SEP \
-                XTHAL_LAM_BYPASSG   XCHAL_SEP \
-                XTHAL_LAM_BYPASSG   XCHAL_SEP \
-                XTHAL_LAM_EXCEPTION XCHAL_SEP \
-                XTHAL_LAM_EXCEPTION XCHAL_SEP \
-                XTHAL_LAM_EXCEPTION XCHAL_SEP \
-                XTHAL_LAM_EXCEPTION XCHAL_SEP \
-                XTHAL_LAM_EXCEPTION XCHAL_SEP \
-                XTHAL_LAM_EXCEPTION XCHAL_SEP \
-                XTHAL_LAM_EXCEPTION XCHAL_SEP \
-                XTHAL_LAM_EXCEPTION XCHAL_SEP \
-                XTHAL_LAM_EXCEPTION
-#define XCHAL_SCA_LIST      XTHAL_SAM_BYPASS    XCHAL_SEP \
-                XTHAL_SAM_BYPASS    XCHAL_SEP \
-                XTHAL_SAM_BYPASS    XCHAL_SEP \
-                XTHAL_SAM_EXCEPTION XCHAL_SEP \
-                XTHAL_SAM_BYPASS    XCHAL_SEP \
-                XTHAL_SAM_BYPASS    XCHAL_SEP \
-                XTHAL_SAM_BYPASS    XCHAL_SEP \
-                XTHAL_SAM_EXCEPTION XCHAL_SEP \
-                XTHAL_SAM_EXCEPTION XCHAL_SEP \
-                XTHAL_SAM_EXCEPTION XCHAL_SEP \
-                XTHAL_SAM_EXCEPTION XCHAL_SEP \
-                XTHAL_SAM_EXCEPTION XCHAL_SEP \
-                XTHAL_SAM_EXCEPTION XCHAL_SEP \
-                XTHAL_SAM_EXCEPTION XCHAL_SEP \
-                XTHAL_SAM_EXCEPTION XCHAL_SEP \
-                XTHAL_SAM_EXCEPTION
+#define XCHAL_FCA_LIST		XTHAL_FAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_FAM_BYPASS	XCHAL_SEP \
+				XTHAL_FAM_BYPASS	XCHAL_SEP \
+				XTHAL_FAM_BYPASS	XCHAL_SEP \
+				XTHAL_FAM_BYPASS	XCHAL_SEP \
+				XTHAL_FAM_BYPASS	XCHAL_SEP \
+				XTHAL_FAM_BYPASS	XCHAL_SEP \
+				XTHAL_FAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_FAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_FAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_FAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_FAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_FAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_FAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_FAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_FAM_EXCEPTION
+#define XCHAL_LCA_LIST		XTHAL_LAM_BYPASSG	XCHAL_SEP \
+				XTHAL_LAM_BYPASSG	XCHAL_SEP \
+				XTHAL_LAM_BYPASSG	XCHAL_SEP \
+				XTHAL_LAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_LAM_BYPASSG	XCHAL_SEP \
+				XTHAL_LAM_BYPASSG	XCHAL_SEP \
+				XTHAL_LAM_BYPASSG	XCHAL_SEP \
+				XTHAL_LAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_LAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_LAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_LAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_LAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_LAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_LAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_LAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_LAM_EXCEPTION
+#define XCHAL_SCA_LIST		XTHAL_SAM_BYPASS	XCHAL_SEP \
+				XTHAL_SAM_BYPASS	XCHAL_SEP \
+				XTHAL_SAM_BYPASS	XCHAL_SEP \
+				XTHAL_SAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_SAM_BYPASS	XCHAL_SEP \
+				XTHAL_SAM_BYPASS	XCHAL_SEP \
+				XTHAL_SAM_BYPASS	XCHAL_SEP \
+				XTHAL_SAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_SAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_SAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_SAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_SAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_SAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_SAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_SAM_EXCEPTION	XCHAL_SEP \
+				XTHAL_SAM_EXCEPTION
 
 
 #define XCHAL_CA_R   (0xC0 | 0x40000000)
 #define XCHAL_CA_R   (0xC0 | 0x40000000)
 #define XCHAL_CA_RX  (0xD0 | 0x40000000)
 #define XCHAL_CA_RX  (0xD0 | 0x40000000)
@@ -115,204 +115,207 @@
  *  one is returned instead (eg. writethru instead of writeback,
  *  one is returned instead (eg. writethru instead of writeback,
  *  bypass instead of writethru).
  *  bypass instead of writethru).
  */
  */
-#define XCHAL_CA_BYPASS         2   /* cache disabled (bypassed) mode */
-#define XCHAL_CA_BYPASSBUF          6   /* cache disabled (bypassed) bufferable mode */
-#define XCHAL_CA_WRITETHRU      1   /* cache enabled (write-through) mode */
-#define XCHAL_CA_WRITEBACK      2   /* cache enabled (write-back) mode */
-#define XCHAL_HAVE_CA_WRITEBACK_NOALLOC 0   /* write-back no-allocate availability */
-#define XCHAL_CA_WRITEBACK_NOALLOC  2   /* cache enabled (write-back no-allocate) mode */
-#define XCHAL_CA_BYPASS_RW          0   /* cache disabled (bypassed) mode (no exec) */
-#define XCHAL_CA_WRITETHRU_RW       0   /* cache enabled (write-through) mode (no exec) (FALLBACK) */
-#define XCHAL_CA_WRITEBACK_RW       0   /* cache enabled (write-back) mode (no exec) */
-#define XCHAL_CA_WRITEBACK_NOALLOC_RW   0   /* cache enabled (write-back no-allocate) mode (no exec) */
-#define XCHAL_CA_ILLEGAL        15  /* no access allowed (all cause exceptions) mode */
-#define XCHAL_CA_ISOLATE        0   /* cache isolate (accesses go to cache not memory) mode */
+#define XCHAL_CA_BYPASS  		2	/* cache disabled (bypassed) mode */
+#define XCHAL_CA_BYPASSBUF  		6	/* cache disabled (bypassed) bufferable mode */
+#define XCHAL_CA_WRITETHRU		1	/* cache enabled (write-through) mode */
+#define XCHAL_CA_WRITEBACK		2	/* cache enabled (write-back) mode */
+#define XCHAL_HAVE_CA_WRITEBACK_NOALLOC	0	/* write-back no-allocate availability */
+#define XCHAL_CA_WRITEBACK_NOALLOC	2	/* cache enabled (write-back no-allocate) mode */
+#define XCHAL_CA_BYPASS_RW  		0	/* cache disabled (bypassed) mode (no exec) */
+#define XCHAL_CA_WRITETHRU_RW		0	/* cache enabled (write-through) mode (no exec) (FALLBACK) */
+#define XCHAL_CA_WRITEBACK_RW		0	/* cache enabled (write-back) mode (no exec) */
+#define XCHAL_CA_WRITEBACK_NOALLOC_RW	0	/* cache enabled (write-back no-allocate) mode (no exec) */
+#define XCHAL_CA_ILLEGAL		15	/* no access allowed (all cause exceptions) mode */
+#define XCHAL_CA_ISOLATE		0	/* cache isolate (accesses go to cache not memory) mode */
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-                MMU
+				MMU
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
 /*
 /*
  *  General notes on MMU parameters.
  *  General notes on MMU parameters.
  *
  *
  *  Terminology:
  *  Terminology:
- *  ASID = address-space ID (acts as an "extension" of virtual addresses)
- *  VPN  = virtual page number
- *  PPN  = physical page number
- *  CA   = encoded cache attribute (access modes)
- *  TLB  = translation look-aside buffer (term is stretched somewhat here)
- *  I    = instruction (fetch accesses)
- *  D    = data (load and store accesses)
- *  way  = each TLB (ITLB and DTLB) consists of a number of "ways"
- *      that simultaneously match the virtual address of an access;
- *      a TLB successfully translates a virtual address if exactly
- *      one way matches the vaddr; if none match, it is a miss;
- *      if multiple match, one gets a "multihit" exception;
- *      each way can be independently configured in terms of number of
- *      entries, page sizes, which fields are writable or constant, etc.
- *  set  = group of contiguous ways with exactly identical parameters
- *  ARF  = auto-refill; hardware services a 1st-level miss by loading a PTE
- *      from the page table and storing it in one of the auto-refill ways;
- *      if this PTE load also misses, a miss exception is posted for s/w.
- *  min-wired = a "min-wired" way can be used to map a single (minimum-sized)
- *      page arbitrarily under program control; it has a single entry,
- *      is non-auto-refill (some other way(s) must be auto-refill),
- *      all its fields (VPN, PPN, ASID, CA) are all writable, and it
- *      supports the XCHAL_MMU_MIN_PTE_PAGE_SIZE page size (a current
- *      restriction is that this be the only page size it supports).
+ *	ASID = address-space ID (acts as an "extension" of virtual addresses)
+ *	VPN  = virtual page number
+ *	PPN  = physical page number
+ *	CA   = encoded cache attribute (access modes)
+ *	TLB  = translation look-aside buffer (term is stretched somewhat here)
+ *	I    = instruction (fetch accesses)
+ *	D    = data (load and store accesses)
+ *	way  = each TLB (ITLB and DTLB) consists of a number of "ways"
+ *		that simultaneously match the virtual address of an access;
+ *		a TLB successfully translates a virtual address if exactly
+ *		one way matches the vaddr; if none match, it is a miss;
+ *		if multiple match, one gets a "multihit" exception;
+ *		each way can be independently configured in terms of number of
+ *		entries, page sizes, which fields are writable or constant, etc.
+ *	set  = group of contiguous ways with exactly identical parameters
+ *	ARF  = auto-refill; hardware services a 1st-level miss by loading a PTE
+ *		from the page table and storing it in one of the auto-refill ways;
+ *		if this PTE load also misses, a miss exception is posted for s/w.
+ *	min-wired = a "min-wired" way can be used to map a single (minimum-sized)
+ * 		page arbitrarily under program control; it has a single entry,
+ *		is non-auto-refill (some other way(s) must be auto-refill),
+ *		all its fields (VPN, PPN, ASID, CA) are all writable, and it
+ *		supports the XCHAL_MMU_MIN_PTE_PAGE_SIZE page size (a current
+ *		restriction is that this be the only page size it supports).
  *
  *
  *  TLB way entries are virtually indexed.
  *  TLB way entries are virtually indexed.
  *  TLB ways that support multiple page sizes:
  *  TLB ways that support multiple page sizes:
- *  - must have all writable VPN and PPN fields;
- *  - can only use one page size at any given time (eg. setup at startup),
- *    selected by the respective ITLBCFG or DTLBCFG special register,
- *    whose bits n*4+3 .. n*4 index the list of page sizes for way n
- *    (XCHAL_xTLB_SETm_PAGESZ_LOG2_LIST for set m corresponding to way n);
- *    this list may be sparse for auto-refill ways because auto-refill
- *    ways have independent lists of supported page sizes sharing a
- *    common encoding with PTE entries; the encoding is the index into
- *    this list; unsupported sizes for a given way are zero in the list;
- *    selecting unsupported sizes results in undefine hardware behaviour;
- *  - is only possible for ways 0 thru 7 (due to ITLBCFG/DTLBCFG definition).
+ *	- must have all writable VPN and PPN fields;
+ *	- can only use one page size at any given time (eg. setup at startup),
+ *	  selected by the respective ITLBCFG or DTLBCFG special register,
+ *	  whose bits n*4+3 .. n*4 index the list of page sizes for way n
+ *	  (XCHAL_xTLB_SETm_PAGESZ_LOG2_LIST for set m corresponding to way n);
+ *	  this list may be sparse for auto-refill ways because auto-refill
+ *	  ways have independent lists of supported page sizes sharing a
+ *	  common encoding with PTE entries; the encoding is the index into
+ *	  this list; unsupported sizes for a given way are zero in the list;
+ *	  selecting unsupported sizes results in undefine hardware behaviour;
+ *	- is only possible for ways 0 thru 7 (due to ITLBCFG/DTLBCFG definition).
  */
  */
 
 
-#define XCHAL_MMU_ASID_INVALID      0   /* ASID value indicating invalid address space */
-#define XCHAL_MMU_ASID_KERNEL       0   /* ASID value indicating kernel (ring 0) address space */
-#define XCHAL_MMU_SR_BITS       0   /* number of size-restriction bits supported */
-#define XCHAL_MMU_CA_BITS       4    /* number of bits needed to hold cache attribute encoding */
-#define XCHAL_MMU_MAX_PTE_PAGE_SIZE 29  /* max page size in a PTE structure (log2) */
-#define XCHAL_MMU_MIN_PTE_PAGE_SIZE 29  /* min page size in a PTE structure (log2) */
+#define XCHAL_MMU_ASID_INVALID		0	/* ASID value indicating invalid address space */
+#define XCHAL_MMU_ASID_KERNEL		0	/* ASID value indicating kernel (ring 0) address space */
+#define XCHAL_MMU_SR_BITS		0	/* number of size-restriction bits supported */
+#define XCHAL_MMU_CA_BITS		4	 /* number of bits needed to hold cache attribute encoding */
+#define XCHAL_MMU_MAX_PTE_PAGE_SIZE	29	/* max page size in a PTE structure (log2) */
+#define XCHAL_MMU_MIN_PTE_PAGE_SIZE	29	/* min page size in a PTE structure (log2) */
 
 
 
 
 /***  Instruction TLB:  ***/
 /***  Instruction TLB:  ***/
 
 
-#define XCHAL_ITLB_WAY_BITS     0   /* number of bits holding the ways */
-#define XCHAL_ITLB_WAYS         1   /* number of ways (n-way set-associative TLB) */
-#define XCHAL_ITLB_ARF_WAYS     0   /* number of auto-refill ways */
-#define XCHAL_ITLB_SETS         1   /* number of sets (groups of ways with identical settings) */
+#define XCHAL_ITLB_WAY_BITS		0	/* number of bits holding the ways */
+#define XCHAL_ITLB_WAYS			1	/* number of ways (n-way set-associative TLB) */
+#define XCHAL_ITLB_ARF_WAYS		0	/* number of auto-refill ways */
+#define XCHAL_ITLB_SETS			1	/* number of sets (groups of ways with identical settings) */
 
 
 /*  Way set to which each way belongs:  */
 /*  Way set to which each way belongs:  */
-#define XCHAL_ITLB_WAY0_SET     0
+#define XCHAL_ITLB_WAY0_SET		0
 
 
 /*  Ways sets that are used by hardware auto-refill (ARF):  */
 /*  Ways sets that are used by hardware auto-refill (ARF):  */
-#define XCHAL_ITLB_ARF_SETS     0   /* number of auto-refill sets */
+#define XCHAL_ITLB_ARF_SETS		0	/* number of auto-refill sets */
 
 
 /*  Way sets that are "min-wired" (see terminology comment above):  */
 /*  Way sets that are "min-wired" (see terminology comment above):  */
-#define XCHAL_ITLB_MINWIRED_SETS    0   /* number of "min-wired" sets */
+#define XCHAL_ITLB_MINWIRED_SETS	0	/* number of "min-wired" sets */
 
 
 
 
 /*  ITLB way set 0 (group of ways 0 thru 0):  */
 /*  ITLB way set 0 (group of ways 0 thru 0):  */
-#define XCHAL_ITLB_SET0_WAY         0   /* index of first way in this way set */
-#define XCHAL_ITLB_SET0_WAYS            1   /* number of (contiguous) ways in this way set */
-#define XCHAL_ITLB_SET0_ENTRIES_LOG2        3   /* log2(number of entries in this way) */
-#define XCHAL_ITLB_SET0_ENTRIES         8   /* number of entries in this way (always a power of 2) */
-#define XCHAL_ITLB_SET0_ARF         0   /* 1=autorefill by h/w, 0=non-autorefill (wired/constant/static) */
-#define XCHAL_ITLB_SET0_PAGESIZES       1   /* number of supported page sizes in this way */
-#define XCHAL_ITLB_SET0_PAGESZ_BITS     0   /* number of bits to encode the page size */
-#define XCHAL_ITLB_SET0_PAGESZ_LOG2_MIN     29  /* log2(minimum supported page size) */
-#define XCHAL_ITLB_SET0_PAGESZ_LOG2_MAX     29  /* log2(maximum supported page size) */
-#define XCHAL_ITLB_SET0_PAGESZ_LOG2_LIST    29  /* list of log2(page size)s, separated by XCHAL_SEP;
-                               2^PAGESZ_BITS entries in list, unsupported entries are zero */
-#define XCHAL_ITLB_SET0_ASID_CONSTMASK      0   /* constant ASID bits; 0 if all writable */
-#define XCHAL_ITLB_SET0_VPN_CONSTMASK       0x00000000  /* constant VPN bits, not including entry index bits; 0 if all writable */
-#define XCHAL_ITLB_SET0_PPN_CONSTMASK       0xE0000000  /* constant PPN bits, including entry index bits; 0 if all writable */
-#define XCHAL_ITLB_SET0_CA_CONSTMASK        0   /* constant CA bits; 0 if all writable */
-#define XCHAL_ITLB_SET0_ASID_RESET      0   /* 1 if ASID reset values defined (and all writable); 0 otherwise */
-#define XCHAL_ITLB_SET0_VPN_RESET       0   /* 1 if VPN reset values defined (and all writable); 0 otherwise */
-#define XCHAL_ITLB_SET0_PPN_RESET       0   /* 1 if PPN reset values defined (and all writable); 0 otherwise */
-#define XCHAL_ITLB_SET0_CA_RESET        1   /* 1 if CA reset values defined (and all writable); 0 otherwise */
+#define XCHAL_ITLB_SET0_WAY			0	/* index of first way in this way set */
+#define XCHAL_ITLB_SET0_WAYS			1	/* number of (contiguous) ways in this way set */
+#define XCHAL_ITLB_SET0_ENTRIES_LOG2		3	/* log2(number of entries in this way) */
+#define XCHAL_ITLB_SET0_ENTRIES			8	/* number of entries in this way (always a power of 2) */
+#define XCHAL_ITLB_SET0_ARF			0	/* 1=autorefill by h/w, 0=non-autorefill (wired/constant/static) */
+#define XCHAL_ITLB_SET0_PAGESIZES		1	/* number of supported page sizes in this way */
+#define XCHAL_ITLB_SET0_PAGESZ_BITS		0	/* number of bits to encode the page size */
+#define XCHAL_ITLB_SET0_PAGESZ_LOG2_MIN		29	/* log2(minimum supported page size) */
+#define XCHAL_ITLB_SET0_PAGESZ_LOG2_MAX		29	/* log2(maximum supported page size) */
+#define XCHAL_ITLB_SET0_PAGESZ_LOG2_LIST	29	/* list of log2(page size)s, separated by XCHAL_SEP;
+							   2^PAGESZ_BITS entries in list, unsupported entries are zero */
+#define XCHAL_ITLB_SET0_ASID_CONSTMASK		0	/* constant ASID bits; 0 if all writable */
+#define XCHAL_ITLB_SET0_VPN_CONSTMASK		0x00000000	/* constant VPN bits, not including entry index bits; 0 if all writable */
+#define XCHAL_ITLB_SET0_PPN_CONSTMASK		0xE0000000	/* constant PPN bits, including entry index bits; 0 if all writable */
+#define XCHAL_ITLB_SET0_CA_CONSTMASK		0	/* constant CA bits; 0 if all writable */
+#define XCHAL_ITLB_SET0_ASID_RESET		0	/* 1 if ASID reset values defined (and all writable); 0 otherwise */
+#define XCHAL_ITLB_SET0_VPN_RESET		0	/* 1 if VPN reset values defined (and all writable); 0 otherwise */
+#define XCHAL_ITLB_SET0_PPN_RESET		0	/* 1 if PPN reset values defined (and all writable); 0 otherwise */
+#define XCHAL_ITLB_SET0_CA_RESET		1	/* 1 if CA reset values defined (and all writable); 0 otherwise */
 /*  Constant VPN values for each entry of ITLB way set 0 (because VPN_CONSTMASK is non-zero):  */
 /*  Constant VPN values for each entry of ITLB way set 0 (because VPN_CONSTMASK is non-zero):  */
-#define XCHAL_ITLB_SET0_E0_VPN_CONST        0x00000000
-#define XCHAL_ITLB_SET0_E1_VPN_CONST        0x20000000
-#define XCHAL_ITLB_SET0_E2_VPN_CONST        0x40000000
-#define XCHAL_ITLB_SET0_E3_VPN_CONST        0x60000000
-#define XCHAL_ITLB_SET0_E4_VPN_CONST        0x80000000
-#define XCHAL_ITLB_SET0_E5_VPN_CONST        0xA0000000
-#define XCHAL_ITLB_SET0_E6_VPN_CONST        0xC0000000
-#define XCHAL_ITLB_SET0_E7_VPN_CONST        0xE0000000
+#define XCHAL_ITLB_SET0_E0_VPN_CONST		0x00000000
+#define XCHAL_ITLB_SET0_E1_VPN_CONST		0x20000000
+#define XCHAL_ITLB_SET0_E2_VPN_CONST		0x40000000
+#define XCHAL_ITLB_SET0_E3_VPN_CONST		0x60000000
+#define XCHAL_ITLB_SET0_E4_VPN_CONST		0x80000000
+#define XCHAL_ITLB_SET0_E5_VPN_CONST		0xA0000000
+#define XCHAL_ITLB_SET0_E6_VPN_CONST		0xC0000000
+#define XCHAL_ITLB_SET0_E7_VPN_CONST		0xE0000000
 /*  Constant PPN values for each entry of ITLB way set 0 (because PPN_CONSTMASK is non-zero):  */
 /*  Constant PPN values for each entry of ITLB way set 0 (because PPN_CONSTMASK is non-zero):  */
-#define XCHAL_ITLB_SET0_E0_PPN_CONST        0x00000000
-#define XCHAL_ITLB_SET0_E1_PPN_CONST        0x20000000
-#define XCHAL_ITLB_SET0_E2_PPN_CONST        0x40000000
-#define XCHAL_ITLB_SET0_E3_PPN_CONST        0x60000000
-#define XCHAL_ITLB_SET0_E4_PPN_CONST        0x80000000
-#define XCHAL_ITLB_SET0_E5_PPN_CONST        0xA0000000
-#define XCHAL_ITLB_SET0_E6_PPN_CONST        0xC0000000
-#define XCHAL_ITLB_SET0_E7_PPN_CONST        0xE0000000
+#define XCHAL_ITLB_SET0_E0_PPN_CONST		0x00000000
+#define XCHAL_ITLB_SET0_E1_PPN_CONST		0x20000000
+#define XCHAL_ITLB_SET0_E2_PPN_CONST		0x40000000
+#define XCHAL_ITLB_SET0_E3_PPN_CONST		0x60000000
+#define XCHAL_ITLB_SET0_E4_PPN_CONST		0x80000000
+#define XCHAL_ITLB_SET0_E5_PPN_CONST		0xA0000000
+#define XCHAL_ITLB_SET0_E6_PPN_CONST		0xC0000000
+#define XCHAL_ITLB_SET0_E7_PPN_CONST		0xE0000000
 /*  Reset CA values for each entry of ITLB way set 0 (because SET0_CA_RESET is non-zero):  */
 /*  Reset CA values for each entry of ITLB way set 0 (because SET0_CA_RESET is non-zero):  */
-#define XCHAL_ITLB_SET0_E0_CA_RESET     0x02
-#define XCHAL_ITLB_SET0_E1_CA_RESET     0x02
-#define XCHAL_ITLB_SET0_E2_CA_RESET     0x02
-#define XCHAL_ITLB_SET0_E3_CA_RESET     0x02
-#define XCHAL_ITLB_SET0_E4_CA_RESET     0x02
-#define XCHAL_ITLB_SET0_E5_CA_RESET     0x02
-#define XCHAL_ITLB_SET0_E6_CA_RESET     0x02
-#define XCHAL_ITLB_SET0_E7_CA_RESET     0x02
+#define XCHAL_ITLB_SET0_E0_CA_RESET		0x02
+#define XCHAL_ITLB_SET0_E1_CA_RESET		0x02
+#define XCHAL_ITLB_SET0_E2_CA_RESET		0x02
+#define XCHAL_ITLB_SET0_E3_CA_RESET		0x02
+#define XCHAL_ITLB_SET0_E4_CA_RESET		0x02
+#define XCHAL_ITLB_SET0_E5_CA_RESET		0x02
+#define XCHAL_ITLB_SET0_E6_CA_RESET		0x02
+#define XCHAL_ITLB_SET0_E7_CA_RESET		0x02
 
 
 
 
 /***  Data TLB:  ***/
 /***  Data TLB:  ***/
 
 
-#define XCHAL_DTLB_WAY_BITS     0   /* number of bits holding the ways */
-#define XCHAL_DTLB_WAYS         1   /* number of ways (n-way set-associative TLB) */
-#define XCHAL_DTLB_ARF_WAYS     0   /* number of auto-refill ways */
-#define XCHAL_DTLB_SETS         1   /* number of sets (groups of ways with identical settings) */
+#define XCHAL_DTLB_WAY_BITS		0	/* number of bits holding the ways */
+#define XCHAL_DTLB_WAYS			1	/* number of ways (n-way set-associative TLB) */
+#define XCHAL_DTLB_ARF_WAYS		0	/* number of auto-refill ways */
+#define XCHAL_DTLB_SETS			1	/* number of sets (groups of ways with identical settings) */
 
 
 /*  Way set to which each way belongs:  */
 /*  Way set to which each way belongs:  */
-#define XCHAL_DTLB_WAY0_SET     0
+#define XCHAL_DTLB_WAY0_SET		0
 
 
 /*  Ways sets that are used by hardware auto-refill (ARF):  */
 /*  Ways sets that are used by hardware auto-refill (ARF):  */
-#define XCHAL_DTLB_ARF_SETS     0   /* number of auto-refill sets */
+#define XCHAL_DTLB_ARF_SETS		0	/* number of auto-refill sets */
 
 
 /*  Way sets that are "min-wired" (see terminology comment above):  */
 /*  Way sets that are "min-wired" (see terminology comment above):  */
-#define XCHAL_DTLB_MINWIRED_SETS    0   /* number of "min-wired" sets */
+#define XCHAL_DTLB_MINWIRED_SETS	0	/* number of "min-wired" sets */
 
 
 
 
 /*  DTLB way set 0 (group of ways 0 thru 0):  */
 /*  DTLB way set 0 (group of ways 0 thru 0):  */
-#define XCHAL_DTLB_SET0_WAY         0   /* index of first way in this way set */
-#define XCHAL_DTLB_SET0_WAYS            1   /* number of (contiguous) ways in this way set */
-#define XCHAL_DTLB_SET0_ENTRIES_LOG2        3   /* log2(number of entries in this way) */
-#define XCHAL_DTLB_SET0_ENTRIES         8   /* number of entries in this way (always a power of 2) */
-#define XCHAL_DTLB_SET0_ARF         0   /* 1=autorefill by h/w, 0=non-autorefill (wired/constant/static) */
-#define XCHAL_DTLB_SET0_PAGESIZES       1   /* number of supported page sizes in this way */
-#define XCHAL_DTLB_SET0_PAGESZ_BITS     0   /* number of bits to encode the page size */
-#define XCHAL_DTLB_SET0_PAGESZ_LOG2_MIN     29  /* log2(minimum supported page size) */
-#define XCHAL_DTLB_SET0_PAGESZ_LOG2_MAX     29  /* log2(maximum supported page size) */
-#define XCHAL_DTLB_SET0_PAGESZ_LOG2_LIST    29  /* list of log2(page size)s, separated by XCHAL_SEP;
-                               2^PAGESZ_BITS entries in list, unsupported entries are zero */
-#define XCHAL_DTLB_SET0_ASID_CONSTMASK      0   /* constant ASID bits; 0 if all writable */
-#define XCHAL_DTLB_SET0_VPN_CONSTMASK       0x00000000  /* constant VPN bits, not including entry index bits; 0 if all writable */
-#define XCHAL_DTLB_SET0_PPN_CONSTMASK       0xE0000000  /* constant PPN bits, including entry index bits; 0 if all writable */
-#define XCHAL_DTLB_SET0_CA_CONSTMASK        0   /* constant CA bits; 0 if all writable */
-#define XCHAL_DTLB_SET0_ASID_RESET      0   /* 1 if ASID reset values defined (and all writable); 0 otherwise */
-#define XCHAL_DTLB_SET0_VPN_RESET       0   /* 1 if VPN reset values defined (and all writable); 0 otherwise */
-#define XCHAL_DTLB_SET0_PPN_RESET       0   /* 1 if PPN reset values defined (and all writable); 0 otherwise */
-#define XCHAL_DTLB_SET0_CA_RESET        1   /* 1 if CA reset values defined (and all writable); 0 otherwise */
+#define XCHAL_DTLB_SET0_WAY			0	/* index of first way in this way set */
+#define XCHAL_DTLB_SET0_WAYS			1	/* number of (contiguous) ways in this way set */
+#define XCHAL_DTLB_SET0_ENTRIES_LOG2		3	/* log2(number of entries in this way) */
+#define XCHAL_DTLB_SET0_ENTRIES			8	/* number of entries in this way (always a power of 2) */
+#define XCHAL_DTLB_SET0_ARF			0	/* 1=autorefill by h/w, 0=non-autorefill (wired/constant/static) */
+#define XCHAL_DTLB_SET0_PAGESIZES		1	/* number of supported page sizes in this way */
+#define XCHAL_DTLB_SET0_PAGESZ_BITS		0	/* number of bits to encode the page size */
+#define XCHAL_DTLB_SET0_PAGESZ_LOG2_MIN		29	/* log2(minimum supported page size) */
+#define XCHAL_DTLB_SET0_PAGESZ_LOG2_MAX		29	/* log2(maximum supported page size) */
+#define XCHAL_DTLB_SET0_PAGESZ_LOG2_LIST	29	/* list of log2(page size)s, separated by XCHAL_SEP;
+							   2^PAGESZ_BITS entries in list, unsupported entries are zero */
+#define XCHAL_DTLB_SET0_ASID_CONSTMASK		0	/* constant ASID bits; 0 if all writable */
+#define XCHAL_DTLB_SET0_VPN_CONSTMASK		0x00000000	/* constant VPN bits, not including entry index bits; 0 if all writable */
+#define XCHAL_DTLB_SET0_PPN_CONSTMASK		0xE0000000	/* constant PPN bits, including entry index bits; 0 if all writable */
+#define XCHAL_DTLB_SET0_CA_CONSTMASK		0	/* constant CA bits; 0 if all writable */
+#define XCHAL_DTLB_SET0_ASID_RESET		0	/* 1 if ASID reset values defined (and all writable); 0 otherwise */
+#define XCHAL_DTLB_SET0_VPN_RESET		0	/* 1 if VPN reset values defined (and all writable); 0 otherwise */
+#define XCHAL_DTLB_SET0_PPN_RESET		0	/* 1 if PPN reset values defined (and all writable); 0 otherwise */
+#define XCHAL_DTLB_SET0_CA_RESET		1	/* 1 if CA reset values defined (and all writable); 0 otherwise */
 /*  Constant VPN values for each entry of DTLB way set 0 (because VPN_CONSTMASK is non-zero):  */
 /*  Constant VPN values for each entry of DTLB way set 0 (because VPN_CONSTMASK is non-zero):  */
-#define XCHAL_DTLB_SET0_E0_VPN_CONST        0x00000000
-#define XCHAL_DTLB_SET0_E1_VPN_CONST        0x20000000
-#define XCHAL_DTLB_SET0_E2_VPN_CONST        0x40000000
-#define XCHAL_DTLB_SET0_E3_VPN_CONST        0x60000000
-#define XCHAL_DTLB_SET0_E4_VPN_CONST        0x80000000
-#define XCHAL_DTLB_SET0_E5_VPN_CONST        0xA0000000
-#define XCHAL_DTLB_SET0_E6_VPN_CONST        0xC0000000
-#define XCHAL_DTLB_SET0_E7_VPN_CONST        0xE0000000
+#define XCHAL_DTLB_SET0_E0_VPN_CONST		0x00000000
+#define XCHAL_DTLB_SET0_E1_VPN_CONST		0x20000000
+#define XCHAL_DTLB_SET0_E2_VPN_CONST		0x40000000
+#define XCHAL_DTLB_SET0_E3_VPN_CONST		0x60000000
+#define XCHAL_DTLB_SET0_E4_VPN_CONST		0x80000000
+#define XCHAL_DTLB_SET0_E5_VPN_CONST		0xA0000000
+#define XCHAL_DTLB_SET0_E6_VPN_CONST		0xC0000000
+#define XCHAL_DTLB_SET0_E7_VPN_CONST		0xE0000000
 /*  Constant PPN values for each entry of DTLB way set 0 (because PPN_CONSTMASK is non-zero):  */
 /*  Constant PPN values for each entry of DTLB way set 0 (because PPN_CONSTMASK is non-zero):  */
-#define XCHAL_DTLB_SET0_E0_PPN_CONST        0x00000000
-#define XCHAL_DTLB_SET0_E1_PPN_CONST        0x20000000
-#define XCHAL_DTLB_SET0_E2_PPN_CONST        0x40000000
-#define XCHAL_DTLB_SET0_E3_PPN_CONST        0x60000000
-#define XCHAL_DTLB_SET0_E4_PPN_CONST        0x80000000
-#define XCHAL_DTLB_SET0_E5_PPN_CONST        0xA0000000
-#define XCHAL_DTLB_SET0_E6_PPN_CONST        0xC0000000
-#define XCHAL_DTLB_SET0_E7_PPN_CONST        0xE0000000
+#define XCHAL_DTLB_SET0_E0_PPN_CONST		0x00000000
+#define XCHAL_DTLB_SET0_E1_PPN_CONST		0x20000000
+#define XCHAL_DTLB_SET0_E2_PPN_CONST		0x40000000
+#define XCHAL_DTLB_SET0_E3_PPN_CONST		0x60000000
+#define XCHAL_DTLB_SET0_E4_PPN_CONST		0x80000000
+#define XCHAL_DTLB_SET0_E5_PPN_CONST		0xA0000000
+#define XCHAL_DTLB_SET0_E6_PPN_CONST		0xC0000000
+#define XCHAL_DTLB_SET0_E7_PPN_CONST		0xE0000000
 /*  Reset CA values for each entry of DTLB way set 0 (because SET0_CA_RESET is non-zero):  */
 /*  Reset CA values for each entry of DTLB way set 0 (because SET0_CA_RESET is non-zero):  */
-#define XCHAL_DTLB_SET0_E0_CA_RESET     0x02
-#define XCHAL_DTLB_SET0_E1_CA_RESET     0x02
-#define XCHAL_DTLB_SET0_E2_CA_RESET     0x02
-#define XCHAL_DTLB_SET0_E3_CA_RESET     0x02
-#define XCHAL_DTLB_SET0_E4_CA_RESET     0x02
-#define XCHAL_DTLB_SET0_E5_CA_RESET     0x02
-#define XCHAL_DTLB_SET0_E6_CA_RESET     0x02
-#define XCHAL_DTLB_SET0_E7_CA_RESET     0x02
+#define XCHAL_DTLB_SET0_E0_CA_RESET		0x02
+#define XCHAL_DTLB_SET0_E1_CA_RESET		0x02
+#define XCHAL_DTLB_SET0_E2_CA_RESET		0x02
+#define XCHAL_DTLB_SET0_E3_CA_RESET		0x02
+#define XCHAL_DTLB_SET0_E4_CA_RESET		0x02
+#define XCHAL_DTLB_SET0_E5_CA_RESET		0x02
+#define XCHAL_DTLB_SET0_E6_CA_RESET		0x02
+#define XCHAL_DTLB_SET0_E7_CA_RESET		0x02
+
+
+
 
 
 #endif /*XTENSA_CONFIG_CORE_MATMAP_H*/
 #endif /*XTENSA_CONFIG_CORE_MATMAP_H*/

+ 1 - 1
components/xtensa/esp32s3/include/xtensa/config/defs.h

@@ -1,6 +1,6 @@
 /* Definitions for Xtensa instructions, types, and protos. */
 /* Definitions for Xtensa instructions, types, and protos. */
 
 
-/* Customer ID=15127; Build=0x86d67; Copyright (c) 2003-2004 Tensilica Inc.
+/* Customer ID=15128; Build=0x90f1f; Copyright (c) 2003-2004 Tensilica Inc.
 
 
    Permission is hereby granted, free of charge, to any person obtaining
    Permission is hereby granted, free of charge, to any person obtaining
    a copy of this software and associated documentation files (the
    a copy of this software and associated documentation files (the

+ 76 - 76
components/xtensa/esp32s3/include/xtensa/config/specreg.h

@@ -4,7 +4,7 @@
 
 
 /* $Id: //depot/rel/Foxhill/dot.12/Xtensa/SWConfig/hal/specreg.h.tpp#1 $ */
 /* $Id: //depot/rel/Foxhill/dot.12/Xtensa/SWConfig/hal/specreg.h.tpp#1 $ */
 
 
-/* Customer ID=15127; Build=0x86d67; Copyright (c) 1998-2002 Tensilica Inc.
+/* Customer ID=15128; Build=0x90f1f; Copyright (c) 1998-2002 Tensilica Inc.
 
 
    Permission is hereby granted, free of charge, to any person obtaining
    Permission is hereby granted, free of charge, to any person obtaining
    a copy of this software and associated documentation files (the
    a copy of this software and associated documentation files (the
@@ -33,86 +33,86 @@
 
 
 
 
 /*  Special registers:  */
 /*  Special registers:  */
-#define LBEG         0
-#define LEND         1
-#define LCOUNT       2
-#define SAR          3
-#define BR           4
-#define SCOMPARE1    12
-#define ACCLO        16
-#define ACCHI        17
-#define MR_0         32
-#define MR_1         33
-#define MR_2         34
-#define MR_3         35
-#define WINDOWBASE   72
-#define WINDOWSTART  73
-#define IBREAKENABLE 96
-#define MEMCTL       97
-#define ATOMCTL      99
-#define DDR          104
-#define IBREAKA_0    128
-#define IBREAKA_1    129
-#define DBREAKA_0    144
-#define DBREAKA_1    145
-#define DBREAKC_0    160
-#define DBREAKC_1    161
+#define LBEG		0
+#define LEND		1
+#define LCOUNT		2
+#define SAR		3
+#define BR		4
+#define SCOMPARE1	12
+#define ACCLO		16
+#define ACCHI		17
+#define MR_0		32
+#define MR_1		33
+#define MR_2		34
+#define MR_3		35
+#define WINDOWBASE	72
+#define WINDOWSTART	73
+#define IBREAKENABLE	96
+#define MEMCTL		97
+#define ATOMCTL		99
+#define DDR		104
+#define IBREAKA_0	128
+#define IBREAKA_1	129
+#define DBREAKA_0	144
+#define DBREAKA_1	145
+#define DBREAKC_0	160
+#define DBREAKC_1	161
 #define CONFIGID0    176
 #define CONFIGID0    176
-#define EPC_1        177
-#define EPC_2        178
-#define EPC_3        179
-#define EPC_4        180
-#define EPC_5        181
-#define EPC_6        182
-#define EPC_7        183
-#define DEPC         192
-#define EPS_2        194
-#define EPS_3        195
-#define EPS_4        196
-#define EPS_5        197
-#define EPS_6        198
-#define EPS_7        199
+#define EPC_1		177
+#define EPC_2		178
+#define EPC_3		179
+#define EPC_4		180
+#define EPC_5		181
+#define EPC_6		182
+#define EPC_7		183
+#define DEPC		192
+#define EPS_2		194
+#define EPS_3		195
+#define EPS_4		196
+#define EPS_5		197
+#define EPS_6		198
+#define EPS_7		199
 #define CONFIGID1    208
 #define CONFIGID1    208
-#define EXCSAVE_1    209
-#define EXCSAVE_2    210
-#define EXCSAVE_3    211
-#define EXCSAVE_4    212
-#define EXCSAVE_5    213
-#define EXCSAVE_6    214
-#define EXCSAVE_7    215
-#define CPENABLE     224
-#define INTERRUPT    226
-#define INTENABLE    228
-#define PS           230
-#define VECBASE      231
-#define EXCCAUSE     232
-#define DEBUGCAUSE   233
-#define CCOUNT       234
-#define PRID         235
-#define ICOUNT       236
-#define ICOUNTLEVEL  237
-#define EXCVADDR     238
-#define CCOMPARE_0   240
-#define CCOMPARE_1   241
-#define CCOMPARE_2   242
-#define MISC_REG_0   244
-#define MISC_REG_1   245
-#define MISC_REG_2   246
-#define MISC_REG_3   247
+#define EXCSAVE_1	209
+#define EXCSAVE_2	210
+#define EXCSAVE_3	211
+#define EXCSAVE_4	212
+#define EXCSAVE_5	213
+#define EXCSAVE_6	214
+#define EXCSAVE_7	215
+#define CPENABLE	224
+#define INTERRUPT	226
+#define INTENABLE	228
+#define PS		230
+#define VECBASE		231
+#define EXCCAUSE	232
+#define DEBUGCAUSE	233
+#define CCOUNT		234
+#define PRID		235
+#define ICOUNT		236
+#define ICOUNTLEVEL	237
+#define EXCVADDR	238
+#define CCOMPARE_0	240
+#define CCOMPARE_1	241
+#define CCOMPARE_2	242
+#define MISC_REG_0	244
+#define MISC_REG_1	245
+#define MISC_REG_2	246
+#define MISC_REG_3	247
 
 
 /*  Special cases (bases of special register series):  */
 /*  Special cases (bases of special register series):  */
-#define MR           32
-#define IBREAKA      128
-#define DBREAKA      144
-#define DBREAKC      160
-#define EPC          176
-#define EPS          192
-#define EXCSAVE      208
-#define CCOMPARE     240
+#define MR		32
+#define IBREAKA		128
+#define DBREAKA		144
+#define DBREAKC		160
+#define EPC		176
+#define EPS		192
+#define EXCSAVE		208
+#define CCOMPARE	240
 
 
 /*  Special names for read-only and write-only interrupt registers:  */
 /*  Special names for read-only and write-only interrupt registers:  */
-#define INTREAD      226
-#define INTSET       226
-#define INTCLEAR     227
+#define INTREAD		226
+#define INTSET		226
+#define INTCLEAR	227
 
 
 #endif /* XTENSA_SPECREG_H */
 #endif /* XTENSA_SPECREG_H */

+ 117 - 117
components/xtensa/esp32s3/include/xtensa/config/system.h

@@ -10,7 +10,7 @@
  *  core-specific but system independent.
  *  core-specific but system independent.
  */
  */
 
 
-/* Customer ID=15127; Build=0x86d67; Copyright (c) 2000-2010 Tensilica Inc.
+/* Customer ID=15128; Build=0x90f1f; Copyright (c) 2000-2010 Tensilica Inc.
 
 
    Permission is hereby granted, free of charge, to any person obtaining
    Permission is hereby granted, free of charge, to any person obtaining
    a copy of this software and associated documentation files (the
    a copy of this software and associated documentation files (the
@@ -40,41 +40,41 @@
 
 
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-                CONFIGURED SOFTWARE OPTIONS
+				CONFIGURED SOFTWARE OPTIONS
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
-#define XSHAL_USE_ABSOLUTE_LITERALS 0   /* (sw-only option, whether software uses absolute literals) */
+#define XSHAL_USE_ABSOLUTE_LITERALS	0	/* (sw-only option, whether software uses absolute literals) */
 #define XSHAL_HAVE_TEXT_SECTION_LITERALS 1 /* Set if there is some memory that allows both code and literals.  */
 #define XSHAL_HAVE_TEXT_SECTION_LITERALS 1 /* Set if there is some memory that allows both code and literals.  */
 
 
-#define XSHAL_ABI           XTHAL_ABI_WINDOWED  /* (sw-only option, selected ABI) */
+#define XSHAL_ABI			XTHAL_ABI_WINDOWED	/* (sw-only option, selected ABI) */
 /*  The above maps to one of the following constants:  */
 /*  The above maps to one of the following constants:  */
-#define XTHAL_ABI_WINDOWED      0
-#define XTHAL_ABI_CALL0         1
+#define XTHAL_ABI_WINDOWED		0
+#define XTHAL_ABI_CALL0			1
 /*  Alternatives:  */
 /*  Alternatives:  */
-/*#define XSHAL_WINDOWED_ABI        1*/ /* set if windowed ABI selected */
-/*#define XSHAL_CALL0_ABI       0*/ /* set if call0 ABI selected */
+/*#define XSHAL_WINDOWED_ABI		1*/	/* set if windowed ABI selected */
+/*#define XSHAL_CALL0_ABI		0*/	/* set if call0 ABI selected */
 
 
-#define XSHAL_CLIB          XTHAL_CLIB_NEWLIB   /* (sw-only option, selected C library) */
+#define XSHAL_CLIB			XTHAL_CLIB_NEWLIB	/* (sw-only option, selected C library) */
 /*  The above maps to one of the following constants:  */
 /*  The above maps to one of the following constants:  */
-#define XTHAL_CLIB_NEWLIB       0
-#define XTHAL_CLIB_UCLIBC       1
-#define XTHAL_CLIB_XCLIB        2
+#define XTHAL_CLIB_NEWLIB		0
+#define XTHAL_CLIB_UCLIBC		1
+#define XTHAL_CLIB_XCLIB		2
 /*  Alternatives:  */
 /*  Alternatives:  */
-/*#define XSHAL_NEWLIB          1*/ /* set if newlib C library selected */
-/*#define XSHAL_UCLIBC          0*/ /* set if uCLibC C library selected */
-/*#define XSHAL_XCLIB           0*/ /* set if Xtensa C library selected */
+/*#define XSHAL_NEWLIB			1*/	/* set if newlib C library selected */
+/*#define XSHAL_UCLIBC			0*/	/* set if uCLibC C library selected */
+/*#define XSHAL_XCLIB			0*/	/* set if Xtensa C library selected */
 
 
-#define XSHAL_USE_FLOATING_POINT    1
+#define XSHAL_USE_FLOATING_POINT	1
 
 
-#define XSHAL_FLOATING_POINT_ABI    0
+#define XSHAL_FLOATING_POINT_ABI	0
 
 
 /*  SW workarounds enabled for HW errata:  */
 /*  SW workarounds enabled for HW errata:  */
 
 
 /*  SW options for functional safety:  */
 /*  SW options for functional safety:  */
-#define XSHAL_FUNC_SAFETY_ENABLED   0
+#define XSHAL_FUNC_SAFETY_ENABLED	0
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-                DEVICE ADDRESSES
+				DEVICE ADDRESSES
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
 /*
 /*
@@ -85,31 +85,31 @@
  */
  */
 
 
 /*  I/O Block areas:  */
 /*  I/O Block areas:  */
-#define XSHAL_IOBLOCK_CACHED_VADDR  0x70000000
-#define XSHAL_IOBLOCK_CACHED_PADDR  0x70000000
-#define XSHAL_IOBLOCK_CACHED_SIZE   0x0E000000
+#define XSHAL_IOBLOCK_CACHED_VADDR	0x70000000
+#define XSHAL_IOBLOCK_CACHED_PADDR	0x70000000
+#define XSHAL_IOBLOCK_CACHED_SIZE	0x0E000000
 
 
-#define XSHAL_IOBLOCK_BYPASS_VADDR  0x90000000
-#define XSHAL_IOBLOCK_BYPASS_PADDR  0x90000000
-#define XSHAL_IOBLOCK_BYPASS_SIZE   0x0E000000
+#define XSHAL_IOBLOCK_BYPASS_VADDR	0x90000000
+#define XSHAL_IOBLOCK_BYPASS_PADDR	0x90000000
+#define XSHAL_IOBLOCK_BYPASS_SIZE	0x0E000000
 
 
 /*  System ROM:  */
 /*  System ROM:  */
-#define XSHAL_ROM_VADDR     0x50000000
-#define XSHAL_ROM_PADDR     0x50000000
-#define XSHAL_ROM_SIZE      0x01000000
+#define XSHAL_ROM_VADDR		0x50000000
+#define XSHAL_ROM_PADDR		0x50000000
+#define XSHAL_ROM_SIZE		0x01000000
 /*  Largest available area (free of vectors):  */
 /*  Largest available area (free of vectors):  */
-#define XSHAL_ROM_AVAIL_VADDR   0x50000000
-#define XSHAL_ROM_AVAIL_VSIZE   0x01000000
+#define XSHAL_ROM_AVAIL_VADDR	0x50000000
+#define XSHAL_ROM_AVAIL_VSIZE	0x01000000
 
 
 /*  System RAM:  */
 /*  System RAM:  */
-#define XSHAL_RAM_VADDR     0x60000000
-#define XSHAL_RAM_PADDR     0x60000000
-#define XSHAL_RAM_VSIZE     0x20000000
-#define XSHAL_RAM_PSIZE     0x20000000
-#define XSHAL_RAM_SIZE      XSHAL_RAM_PSIZE
+#define XSHAL_RAM_VADDR		0x60000000
+#define XSHAL_RAM_PADDR		0x60000000
+#define XSHAL_RAM_VSIZE		0x20000000
+#define XSHAL_RAM_PSIZE		0x20000000
+#define XSHAL_RAM_SIZE		XSHAL_RAM_PSIZE
 /*  Largest available area (free of vectors):  */
 /*  Largest available area (free of vectors):  */
-#define XSHAL_RAM_AVAIL_VADDR   0x60000000
-#define XSHAL_RAM_AVAIL_VSIZE   0x20000000
+#define XSHAL_RAM_AVAIL_VADDR	0x60000000
+#define XSHAL_RAM_AVAIL_VSIZE	0x20000000
 
 
 /*
 /*
  *  Shadow system RAM (same device as system RAM, at different address).
  *  Shadow system RAM (same device as system RAM, at different address).
@@ -120,35 +120,35 @@
  *  addresses are viewed through the BYPASS static map rather than
  *  addresses are viewed through the BYPASS static map rather than
  *  the CACHED static map.
  *  the CACHED static map.
  */
  */
-#define XSHAL_RAM_BYPASS_VADDR      0xA0000000
-#define XSHAL_RAM_BYPASS_PADDR      0xA0000000
-#define XSHAL_RAM_BYPASS_PSIZE      0x20000000
+#define XSHAL_RAM_BYPASS_VADDR		0xA0000000
+#define XSHAL_RAM_BYPASS_PADDR		0xA0000000
+#define XSHAL_RAM_BYPASS_PSIZE		0x20000000
 
 
 /*  Alternate system RAM (different device than system RAM):  */
 /*  Alternate system RAM (different device than system RAM):  */
-/*#define XSHAL_ALTRAM_[VP]ADDR     ...not configured...*/
-/*#define XSHAL_ALTRAM_SIZE     ...not configured...*/
+/*#define XSHAL_ALTRAM_[VP]ADDR		...not configured...*/
+/*#define XSHAL_ALTRAM_SIZE		...not configured...*/
 
 
 /*  Some available location in which to place devices in a simulation (eg. XTMP):  */
 /*  Some available location in which to place devices in a simulation (eg. XTMP):  */
-#define XSHAL_SIMIO_CACHED_VADDR    0xC0000000
-#define XSHAL_SIMIO_BYPASS_VADDR    0xC0000000
-#define XSHAL_SIMIO_PADDR       0xC0000000
-#define XSHAL_SIMIO_SIZE        0x20000000
+#define XSHAL_SIMIO_CACHED_VADDR	0xC0000000
+#define XSHAL_SIMIO_BYPASS_VADDR	0xC0000000
+#define XSHAL_SIMIO_PADDR		0xC0000000
+#define XSHAL_SIMIO_SIZE		0x20000000
 
 
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
  *  For use by reference testbench exit and diagnostic routines.
  *  For use by reference testbench exit and diagnostic routines.
  */
  */
-#define XSHAL_MAGIC_EXIT        0x0
+#define XSHAL_MAGIC_EXIT		0x0
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
- *          DEVICE-ADDRESS DEPENDENT...
+ *			DEVICE-ADDRESS DEPENDENT...
  *
  *
  *  Values written to CACHEATTR special register (or its equivalent)
  *  Values written to CACHEATTR special register (or its equivalent)
  *  to enable and disable caches in various modes.
  *  to enable and disable caches in various modes.
  *----------------------------------------------------------------------*/
  *----------------------------------------------------------------------*/
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-            BACKWARD COMPATIBILITY ...
+			BACKWARD COMPATIBILITY ...
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
 /*
 /*
@@ -156,56 +156,56 @@
  *  board-specific macros instead, which are specially tuned for the
  *  board-specific macros instead, which are specially tuned for the
  *  particular target environments' memory maps.
  *  particular target environments' memory maps.
  */
  */
-#define XSHAL_CACHEATTR_BYPASS      XSHAL_XT2000_CACHEATTR_BYPASS   /* disable caches in bypass mode */
-#define XSHAL_CACHEATTR_DEFAULT     XSHAL_XT2000_CACHEATTR_DEFAULT  /* default setting to enable caches (no writeback!) */
+#define XSHAL_CACHEATTR_BYPASS		XSHAL_XT2000_CACHEATTR_BYPASS	/* disable caches in bypass mode */
+#define XSHAL_CACHEATTR_DEFAULT		XSHAL_XT2000_CACHEATTR_DEFAULT	/* default setting to enable caches (no writeback!) */
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-                GENERIC
+				GENERIC
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
 /*  For the following, a 512MB region is used if it contains a system (PIF) RAM,
 /*  For the following, a 512MB region is used if it contains a system (PIF) RAM,
  *  system (PIF) ROM, local memory, or XLMI.  */
  *  system (PIF) ROM, local memory, or XLMI.  */
 
 
 /*  These set any unused 512MB region to cache-BYPASS attribute:  */
 /*  These set any unused 512MB region to cache-BYPASS attribute:  */
-#define XSHAL_ALLVALID_CACHEATTR_WRITEBACK  0x22221112  /* enable caches in write-back mode */
-#define XSHAL_ALLVALID_CACHEATTR_WRITEALLOC 0x22221112  /* enable caches in write-allocate mode */
-#define XSHAL_ALLVALID_CACHEATTR_WRITETHRU  0x22221112  /* enable caches in write-through mode */
-#define XSHAL_ALLVALID_CACHEATTR_BYPASS     0x22222222  /* disable caches in bypass mode */
-#define XSHAL_ALLVALID_CACHEATTR_DEFAULT    XSHAL_ALLVALID_CACHEATTR_WRITEBACK  /* default setting to enable caches */
+#define XSHAL_ALLVALID_CACHEATTR_WRITEBACK	0x22221112	/* enable caches in write-back mode */
+#define XSHAL_ALLVALID_CACHEATTR_WRITEALLOC	0x22221112	/* enable caches in write-allocate mode */
+#define XSHAL_ALLVALID_CACHEATTR_WRITETHRU	0x22221112	/* enable caches in write-through mode */
+#define XSHAL_ALLVALID_CACHEATTR_BYPASS		0x22222222	/* disable caches in bypass mode */
+#define XSHAL_ALLVALID_CACHEATTR_DEFAULT	XSHAL_ALLVALID_CACHEATTR_WRITEBACK	/* default setting to enable caches */
 
 
 /*  These set any unused 512MB region to ILLEGAL attribute:  */
 /*  These set any unused 512MB region to ILLEGAL attribute:  */
-#define XSHAL_STRICT_CACHEATTR_WRITEBACK    0xFFFF111F  /* enable caches in write-back mode */
-#define XSHAL_STRICT_CACHEATTR_WRITEALLOC   0xFFFF111F  /* enable caches in write-allocate mode */
-#define XSHAL_STRICT_CACHEATTR_WRITETHRU    0xFFFF111F  /* enable caches in write-through mode */
-#define XSHAL_STRICT_CACHEATTR_BYPASS       0xFFFF222F  /* disable caches in bypass mode */
-#define XSHAL_STRICT_CACHEATTR_DEFAULT      XSHAL_STRICT_CACHEATTR_WRITEBACK    /* default setting to enable caches */
+#define XSHAL_STRICT_CACHEATTR_WRITEBACK	0xFFFF111F	/* enable caches in write-back mode */
+#define XSHAL_STRICT_CACHEATTR_WRITEALLOC	0xFFFF111F	/* enable caches in write-allocate mode */
+#define XSHAL_STRICT_CACHEATTR_WRITETHRU	0xFFFF111F	/* enable caches in write-through mode */
+#define XSHAL_STRICT_CACHEATTR_BYPASS		0xFFFF222F	/* disable caches in bypass mode */
+#define XSHAL_STRICT_CACHEATTR_DEFAULT		XSHAL_STRICT_CACHEATTR_WRITEBACK	/* default setting to enable caches */
 
 
 /*  These set the first 512MB, if unused, to ILLEGAL attribute to help catch
 /*  These set the first 512MB, if unused, to ILLEGAL attribute to help catch
  *  NULL-pointer dereference bugs; all other unused 512MB regions are set
  *  NULL-pointer dereference bugs; all other unused 512MB regions are set
  *  to cache-BYPASS attribute:  */
  *  to cache-BYPASS attribute:  */
-#define XSHAL_TRAPNULL_CACHEATTR_WRITEBACK  0x2222111F  /* enable caches in write-back mode */
-#define XSHAL_TRAPNULL_CACHEATTR_WRITEALLOC 0x2222111F  /* enable caches in write-allocate mode */
-#define XSHAL_TRAPNULL_CACHEATTR_WRITETHRU  0x2222111F  /* enable caches in write-through mode */
-#define XSHAL_TRAPNULL_CACHEATTR_BYPASS     0x2222222F  /* disable caches in bypass mode */
-#define XSHAL_TRAPNULL_CACHEATTR_DEFAULT    XSHAL_TRAPNULL_CACHEATTR_WRITEBACK  /* default setting to enable caches */
+#define XSHAL_TRAPNULL_CACHEATTR_WRITEBACK	0x2222111F	/* enable caches in write-back mode */
+#define XSHAL_TRAPNULL_CACHEATTR_WRITEALLOC	0x2222111F	/* enable caches in write-allocate mode */
+#define XSHAL_TRAPNULL_CACHEATTR_WRITETHRU	0x2222111F	/* enable caches in write-through mode */
+#define XSHAL_TRAPNULL_CACHEATTR_BYPASS		0x2222222F	/* disable caches in bypass mode */
+#define XSHAL_TRAPNULL_CACHEATTR_DEFAULT	XSHAL_TRAPNULL_CACHEATTR_WRITEBACK	/* default setting to enable caches */
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-            ISS (Instruction Set Simulator) SPECIFIC ...
+			ISS (Instruction Set Simulator) SPECIFIC ...
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
 /*  For now, ISS defaults to the TRAPNULL settings:  */
 /*  For now, ISS defaults to the TRAPNULL settings:  */
-#define XSHAL_ISS_CACHEATTR_WRITEBACK   XSHAL_TRAPNULL_CACHEATTR_WRITEBACK
-#define XSHAL_ISS_CACHEATTR_WRITEALLOC  XSHAL_TRAPNULL_CACHEATTR_WRITEALLOC
-#define XSHAL_ISS_CACHEATTR_WRITETHRU   XSHAL_TRAPNULL_CACHEATTR_WRITETHRU
-#define XSHAL_ISS_CACHEATTR_BYPASS  XSHAL_TRAPNULL_CACHEATTR_BYPASS
-#define XSHAL_ISS_CACHEATTR_DEFAULT XSHAL_TRAPNULL_CACHEATTR_WRITEBACK
+#define XSHAL_ISS_CACHEATTR_WRITEBACK	XSHAL_TRAPNULL_CACHEATTR_WRITEBACK
+#define XSHAL_ISS_CACHEATTR_WRITEALLOC	XSHAL_TRAPNULL_CACHEATTR_WRITEALLOC
+#define XSHAL_ISS_CACHEATTR_WRITETHRU	XSHAL_TRAPNULL_CACHEATTR_WRITETHRU
+#define XSHAL_ISS_CACHEATTR_BYPASS	XSHAL_TRAPNULL_CACHEATTR_BYPASS
+#define XSHAL_ISS_CACHEATTR_DEFAULT	XSHAL_TRAPNULL_CACHEATTR_WRITEBACK
 
 
-#define XSHAL_ISS_PIPE_REGIONS  0
-#define XSHAL_ISS_SDRAM_REGIONS 0
+#define XSHAL_ISS_PIPE_REGIONS	0
+#define XSHAL_ISS_SDRAM_REGIONS	0
 
 
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-            XT2000 BOARD SPECIFIC ...
+			XT2000 BOARD SPECIFIC ...
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
 /*  For the following, a 512MB region is used if it contains any system RAM,
 /*  For the following, a 512MB region is used if it contains any system RAM,
@@ -214,24 +214,24 @@
  *  of whether the macro is _WRITEBACK vs. _BYPASS etc.  */
  *  of whether the macro is _WRITEBACK vs. _BYPASS etc.  */
 
 
 /*  These set any 512MB region unused on the XT2000 to ILLEGAL attribute:  */
 /*  These set any 512MB region unused on the XT2000 to ILLEGAL attribute:  */
-#define XSHAL_XT2000_CACHEATTR_WRITEBACK    0xFF22111F  /* enable caches in write-back mode */
-#define XSHAL_XT2000_CACHEATTR_WRITEALLOC   0xFF22111F  /* enable caches in write-allocate mode */
-#define XSHAL_XT2000_CACHEATTR_WRITETHRU    0xFF22111F  /* enable caches in write-through mode */
-#define XSHAL_XT2000_CACHEATTR_BYPASS       0xFF22222F  /* disable caches in bypass mode */
-#define XSHAL_XT2000_CACHEATTR_DEFAULT      XSHAL_XT2000_CACHEATTR_WRITEBACK    /* default setting to enable caches */
+#define XSHAL_XT2000_CACHEATTR_WRITEBACK	0xFF22111F	/* enable caches in write-back mode */
+#define XSHAL_XT2000_CACHEATTR_WRITEALLOC	0xFF22111F	/* enable caches in write-allocate mode */
+#define XSHAL_XT2000_CACHEATTR_WRITETHRU	0xFF22111F	/* enable caches in write-through mode */
+#define XSHAL_XT2000_CACHEATTR_BYPASS		0xFF22222F	/* disable caches in bypass mode */
+#define XSHAL_XT2000_CACHEATTR_DEFAULT		XSHAL_XT2000_CACHEATTR_WRITEBACK	/* default setting to enable caches */
 
 
-#define XSHAL_XT2000_PIPE_REGIONS   0x00000000  /* BusInt pipeline regions */
-#define XSHAL_XT2000_SDRAM_REGIONS  0x00000440  /* BusInt SDRAM regions */
+#define XSHAL_XT2000_PIPE_REGIONS	0x00000000	/* BusInt pipeline regions */
+#define XSHAL_XT2000_SDRAM_REGIONS	0x00000440	/* BusInt SDRAM regions */
 
 
 
 
 /*----------------------------------------------------------------------
 /*----------------------------------------------------------------------
-                VECTOR INFO AND SIZES
+				VECTOR INFO AND SIZES
   ----------------------------------------------------------------------*/
   ----------------------------------------------------------------------*/
 
 
-#define XSHAL_VECTORS_PACKED        0
-#define XSHAL_STATIC_VECTOR_SELECT  1
-#define XSHAL_RESET_VECTOR_VADDR    0x40000400
-#define XSHAL_RESET_VECTOR_PADDR    0x40000400
+#define XSHAL_VECTORS_PACKED		0
+#define XSHAL_STATIC_VECTOR_SELECT	1
+#define XSHAL_RESET_VECTOR_VADDR	0x40000400
+#define XSHAL_RESET_VECTOR_PADDR	0x40000400
 
 
 /*
 /*
  *  Sizes allocated to vectors by the system (memory map) configuration.
  *  Sizes allocated to vectors by the system (memory map) configuration.
@@ -242,35 +242,35 @@
  *  Whether or not each vector happens to be in a system ROM is also
  *  Whether or not each vector happens to be in a system ROM is also
  *  a system configuration matter, sometimes useful, included here also:
  *  a system configuration matter, sometimes useful, included here also:
  */
  */
-#define XSHAL_RESET_VECTOR_SIZE 0x00000300
-#define XSHAL_RESET_VECTOR_ISROM    0
-#define XSHAL_USER_VECTOR_SIZE  0x00000038
-#define XSHAL_USER_VECTOR_ISROM 0
-#define XSHAL_PROGRAMEXC_VECTOR_SIZE    XSHAL_USER_VECTOR_SIZE  /* for backward compatibility */
-#define XSHAL_USEREXC_VECTOR_SIZE   XSHAL_USER_VECTOR_SIZE  /* for backward compatibility */
-#define XSHAL_KERNEL_VECTOR_SIZE    0x00000038
-#define XSHAL_KERNEL_VECTOR_ISROM   0
-#define XSHAL_STACKEDEXC_VECTOR_SIZE    XSHAL_KERNEL_VECTOR_SIZE    /* for backward compatibility */
-#define XSHAL_KERNELEXC_VECTOR_SIZE XSHAL_KERNEL_VECTOR_SIZE    /* for backward compatibility */
-#define XSHAL_DOUBLEEXC_VECTOR_SIZE 0x00000040
-#define XSHAL_DOUBLEEXC_VECTOR_ISROM    0
-#define XSHAL_WINDOW_VECTORS_SIZE   0x00000178
-#define XSHAL_WINDOW_VECTORS_ISROM  0
-#define XSHAL_INTLEVEL2_VECTOR_SIZE 0x00000038
-#define XSHAL_INTLEVEL2_VECTOR_ISROM    0
-#define XSHAL_INTLEVEL3_VECTOR_SIZE 0x00000038
-#define XSHAL_INTLEVEL3_VECTOR_ISROM    0
-#define XSHAL_INTLEVEL4_VECTOR_SIZE 0x00000038
-#define XSHAL_INTLEVEL4_VECTOR_ISROM    0
-#define XSHAL_INTLEVEL5_VECTOR_SIZE 0x00000038
-#define XSHAL_INTLEVEL5_VECTOR_ISROM    0
-#define XSHAL_INTLEVEL6_VECTOR_SIZE 0x00000038
-#define XSHAL_INTLEVEL6_VECTOR_ISROM    0
-#define XSHAL_DEBUG_VECTOR_SIZE     XSHAL_INTLEVEL6_VECTOR_SIZE
-#define XSHAL_DEBUG_VECTOR_ISROM    XSHAL_INTLEVEL6_VECTOR_ISROM
-#define XSHAL_NMI_VECTOR_SIZE   0x00000038
-#define XSHAL_NMI_VECTOR_ISROM  0
-#define XSHAL_INTLEVEL7_VECTOR_SIZE XSHAL_NMI_VECTOR_SIZE
+#define XSHAL_RESET_VECTOR_SIZE	0x00000300
+#define XSHAL_RESET_VECTOR_ISROM	0
+#define XSHAL_USER_VECTOR_SIZE	0x00000038
+#define XSHAL_USER_VECTOR_ISROM	0
+#define XSHAL_PROGRAMEXC_VECTOR_SIZE	XSHAL_USER_VECTOR_SIZE	/* for backward compatibility */
+#define XSHAL_USEREXC_VECTOR_SIZE	XSHAL_USER_VECTOR_SIZE	/* for backward compatibility */
+#define XSHAL_KERNEL_VECTOR_SIZE	0x00000038
+#define XSHAL_KERNEL_VECTOR_ISROM	0
+#define XSHAL_STACKEDEXC_VECTOR_SIZE	XSHAL_KERNEL_VECTOR_SIZE	/* for backward compatibility */
+#define XSHAL_KERNELEXC_VECTOR_SIZE	XSHAL_KERNEL_VECTOR_SIZE	/* for backward compatibility */
+#define XSHAL_DOUBLEEXC_VECTOR_SIZE	0x00000040
+#define XSHAL_DOUBLEEXC_VECTOR_ISROM	0
+#define XSHAL_WINDOW_VECTORS_SIZE	0x00000178
+#define XSHAL_WINDOW_VECTORS_ISROM	0
+#define XSHAL_INTLEVEL2_VECTOR_SIZE	0x00000038
+#define XSHAL_INTLEVEL2_VECTOR_ISROM	0
+#define XSHAL_INTLEVEL3_VECTOR_SIZE	0x00000038
+#define XSHAL_INTLEVEL3_VECTOR_ISROM	0
+#define XSHAL_INTLEVEL4_VECTOR_SIZE	0x00000038
+#define XSHAL_INTLEVEL4_VECTOR_ISROM	0
+#define XSHAL_INTLEVEL5_VECTOR_SIZE	0x00000038
+#define XSHAL_INTLEVEL5_VECTOR_ISROM	0
+#define XSHAL_INTLEVEL6_VECTOR_SIZE	0x00000038
+#define XSHAL_INTLEVEL6_VECTOR_ISROM	0
+#define XSHAL_DEBUG_VECTOR_SIZE		XSHAL_INTLEVEL6_VECTOR_SIZE
+#define XSHAL_DEBUG_VECTOR_ISROM	XSHAL_INTLEVEL6_VECTOR_ISROM
+#define XSHAL_NMI_VECTOR_SIZE	0x00000038
+#define XSHAL_NMI_VECTOR_ISROM	0
+#define XSHAL_INTLEVEL7_VECTOR_SIZE	XSHAL_NMI_VECTOR_SIZE
 
 
 
 
 #endif /*XTENSA_CONFIG_SYSTEM_H*/
 #endif /*XTENSA_CONFIG_SYSTEM_H*/

+ 378 - 370
components/xtensa/esp32s3/include/xtensa/config/tie-asm.h

@@ -8,7 +8,7 @@
    macros, etc.) for this specific Xtensa processor's TIE extensions
    macros, etc.) for this specific Xtensa processor's TIE extensions
    and options.  It is customized to this Xtensa processor configuration.
    and options.  It is customized to this Xtensa processor configuration.
 
 
-   Customer ID=15127; Build=0x86d67; Copyright (c) 1999-2020 Cadence Design Systems Inc.
+   Customer ID=15128; Build=0x90f1f; Copyright (c) 1999-2021 Cadence Design Systems Inc.
 
 
    Permission is hereby granted, free of charge, to any person obtaining
    Permission is hereby granted, free of charge, to any person obtaining
    a copy of this software and associated documentation files (the
    a copy of this software and associated documentation files (the
@@ -34,388 +34,396 @@
 
 
 /*  Selection parameter values for save-area save/restore macros:  */
 /*  Selection parameter values for save-area save/restore macros:  */
 /*  Option vs. TIE:  */
 /*  Option vs. TIE:  */
-#define XTHAL_SAS_TIE   0x0001  /* custom extension or coprocessor */
-#define XTHAL_SAS_OPT   0x0002  /* optional (and not a coprocessor) */
-#define XTHAL_SAS_ANYOT 0x0003  /* both of the above */
+#define XTHAL_SAS_TIE	0x0001	/* custom extension or coprocessor */
+#define XTHAL_SAS_OPT	0x0002	/* optional (and not a coprocessor) */
+#define XTHAL_SAS_ANYOT	0x0003	/* both of the above */
 /*  Whether used automatically by compiler:  */
 /*  Whether used automatically by compiler:  */
-#define XTHAL_SAS_NOCC  0x0004  /* not used by compiler w/o special opts/code */
-#define XTHAL_SAS_CC    0x0008  /* used by compiler without special opts/code */
-#define XTHAL_SAS_ANYCC 0x000C  /* both of the above */
+#define XTHAL_SAS_NOCC	0x0004	/* not used by compiler w/o special opts/code */
+#define XTHAL_SAS_CC	0x0008	/* used by compiler without special opts/code */
+#define XTHAL_SAS_ANYCC	0x000C	/* both of the above */
 /*  ABI handling across function calls:  */
 /*  ABI handling across function calls:  */
-#define XTHAL_SAS_CALR  0x0010  /* caller-saved */
-#define XTHAL_SAS_CALE  0x0020  /* callee-saved */
-#define XTHAL_SAS_GLOB  0x0040  /* global across function calls (in thread) */
-#define XTHAL_SAS_ANYABI    0x0070  /* all of the above three */
+#define XTHAL_SAS_CALR	0x0010	/* caller-saved */
+#define XTHAL_SAS_CALE	0x0020	/* callee-saved */
+#define XTHAL_SAS_GLOB	0x0040	/* global across function calls (in thread) */
+#define XTHAL_SAS_ANYABI	0x0070	/* all of the above three */
 /*  Misc  */
 /*  Misc  */
-#define XTHAL_SAS_ALL   0xFFFF  /* include all default NCP contents */
-#define XTHAL_SAS3(optie,ccuse,abi) ( ((optie) & XTHAL_SAS_ANYOT)  \
-                    | ((ccuse) & XTHAL_SAS_ANYCC)  \
-                    | ((abi)   & XTHAL_SAS_ANYABI) )
+#define XTHAL_SAS_ALL	0xFFFF	/* include all default NCP contents */
+#define XTHAL_SAS3(optie,ccuse,abi)	( ((optie) & XTHAL_SAS_ANYOT)  \
+					| ((ccuse) & XTHAL_SAS_ANYCC)  \
+					| ((abi)   & XTHAL_SAS_ANYABI) )
 
 
 
 
-/*
-  *  Macro to store all non-coprocessor (extra) custom TIE and optional state
-  *  (not including zero-overhead loop registers).
-  *  Required parameters:
-  *      ptr         Save area pointer address register (clobbered)
-  *                  (register must contain a 4 byte aligned address).
-  *      at1..at4    Four temporary address registers (first XCHAL_NCP_NUM_ATMPS
-  *                  registers are clobbered, the remaining are unused).
-  *  Optional parameters:
-  *      continue    If macro invoked as part of a larger store sequence, set to 1
-  *                  if this is not the first in the sequence.  Defaults to 0.
-  *      ofs         Offset from start of larger sequence (from value of first ptr
-  *                  in sequence) at which to store.  Defaults to next available space
-  *                  (or 0 if <continue> is 0).
-  *      select      Select what category(ies) of registers to store, as a bitmask
-  *                  (see XTHAL_SAS_xxx constants).  Defaults to all registers.
-  *      alloc       Select what category(ies) of registers to allocate; if any
-  *                  category is selected here that is not in <select>, space for
-  *                  the corresponding registers is skipped without doing any store.
-  */
-.macro xchal_ncp_store  ptr at1 at2 at3 at4  continue = 0 ofs = -1 select = XTHAL_SAS_ALL alloc = 0
-        xchal_sa_start  \continue, \ofs
-        // Optional global registers used by default by the compiler:
-        .ifeq (XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_GLOB) & ~(\select)
-        xchal_sa_align  \ptr, 0, 1016, 4, 4
-        rur.THREADPTR   \at1        // threadptr option
-        s32i    \at1, \ptr, .Lxchal_ofs_ + 0
-        .set    .Lxchal_ofs_, .Lxchal_ofs_ + 4
-        .elseif ((XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_GLOB) & ~(\alloc)) == 0
-        xchal_sa_align  \ptr, 0, 1016, 4, 4
-        .set    .Lxchal_ofs_, .Lxchal_ofs_ + 4
-        .endif
-        // Optional caller-saved registers used by default by the compiler:
-        .ifeq (XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_CALR) & ~(\select)
-        xchal_sa_align  \ptr, 0, 1012, 4, 4
-        rsr.ACCLO   \at1        // MAC16 option
-        s32i    \at1, \ptr, .Lxchal_ofs_ + 0
-        rsr.ACCHI   \at1        // MAC16 option
-        s32i    \at1, \ptr, .Lxchal_ofs_ + 4
-        .set    .Lxchal_ofs_, .Lxchal_ofs_ + 8
-        .elseif ((XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
-        xchal_sa_align  \ptr, 0, 1012, 4, 4
-        .set    .Lxchal_ofs_, .Lxchal_ofs_ + 8
-        .endif
-        // Optional caller-saved registers not used by default by the compiler:
-        .ifeq (XTHAL_SAS_OPT | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
-        xchal_sa_align  \ptr, 0, 996, 4, 4
-        rsr.BR  \at1        // boolean option
-        s32i    \at1, \ptr, .Lxchal_ofs_ + 0
-        rsr.SCOMPARE1   \at1        // conditional store option
-        s32i    \at1, \ptr, .Lxchal_ofs_ + 4
-        rsr.M0  \at1        // MAC16 option
-        s32i    \at1, \ptr, .Lxchal_ofs_ + 8
-        rsr.M1  \at1        // MAC16 option
-        s32i    \at1, \ptr, .Lxchal_ofs_ + 12
-        rsr.M2  \at1        // MAC16 option
-        s32i    \at1, \ptr, .Lxchal_ofs_ + 16
-        rsr.M3  \at1        // MAC16 option
-        s32i    \at1, \ptr, .Lxchal_ofs_ + 20
-        .set    .Lxchal_ofs_, .Lxchal_ofs_ + 24
-        .elseif ((XTHAL_SAS_OPT | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
-        xchal_sa_align  \ptr, 0, 996, 4, 4
-        .set    .Lxchal_ofs_, .Lxchal_ofs_ + 24
-        .endif
-        // Custom caller-saved registers not used by default by the compiler:
-        .ifeq (XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
-        xchal_sa_align  \ptr, 0, 1016, 4, 4
-        rur.SAR_BYTE    \at1        // ureg 13
-        s32i    \at1, \ptr, .Lxchal_ofs_ + 0
-        .set    .Lxchal_ofs_, .Lxchal_ofs_ + 4
-        .elseif ((XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
-        xchal_sa_align  \ptr, 0, 1016, 4, 4
-        .set    .Lxchal_ofs_, .Lxchal_ofs_ + 4
-        .endif
-        .endm   // xchal_ncp_store
+    /*
+      *  Macro to store all non-coprocessor (extra) custom TIE and optional state
+      *  (not including zero-overhead loop registers).
+      *  Required parameters:
+      *      ptr         Save area pointer address register (clobbered)
+      *                  (register must contain a 4 byte aligned address).
+      *      at1..at4    Four temporary address registers (first XCHAL_NCP_NUM_ATMPS
+      *                  registers are clobbered, the remaining are unused).
+      *  Optional parameters:
+      *      continue    If macro invoked as part of a larger store sequence, set to 1
+      *                  if this is not the first in the sequence.  Defaults to 0.
+      *      ofs         Offset from start of larger sequence (from value of first ptr
+      *                  in sequence) at which to store.  Defaults to next available space
+      *                  (or 0 if <continue> is 0).
+      *      select      Select what category(ies) of registers to store, as a bitmask
+      *                  (see XTHAL_SAS_xxx constants).  Defaults to all registers.
+      *      alloc       Select what category(ies) of registers to allocate; if any
+      *                  category is selected here that is not in <select>, space for
+      *                  the corresponding registers is skipped without doing any store.
+      */
+    .macro xchal_ncp_store  ptr at1 at2 at3 at4  continue=0 ofs=-1 select=XTHAL_SAS_ALL alloc=0
+	xchal_sa_start	\continue, \ofs
+	// Optional global registers used by default by the compiler:
+	.ifeq (XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_GLOB) & ~(\select)
+	xchal_sa_align	\ptr, 0, 1016, 4, 4
+	rur.THREADPTR	\at1		// threadptr option
+	s32i	\at1, \ptr, .Lxchal_ofs_+0
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 4
+	.elseif ((XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_GLOB) & ~(\alloc)) == 0
+	xchal_sa_align	\ptr, 0, 1016, 4, 4
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 4
+	.endif
+	// Optional caller-saved registers used by default by the compiler:
+	.ifeq (XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_CALR) & ~(\select)
+	xchal_sa_align	\ptr, 0, 1012, 4, 4
+	rsr.ACCLO	\at1		// MAC16 option
+	s32i	\at1, \ptr, .Lxchal_ofs_+0
+	rsr.ACCHI	\at1		// MAC16 option
+	s32i	\at1, \ptr, .Lxchal_ofs_+4
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 8
+	.elseif ((XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
+	xchal_sa_align	\ptr, 0, 1012, 4, 4
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 8
+	.endif
+	// Optional caller-saved registers not used by default by the compiler:
+	.ifeq (XTHAL_SAS_OPT | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
+	xchal_sa_align	\ptr, 0, 996, 4, 4
+	rsr.BR	\at1		// boolean option
+	s32i	\at1, \ptr, .Lxchal_ofs_+0
+	rsr.SCOMPARE1	\at1		// conditional store option
+	s32i	\at1, \ptr, .Lxchal_ofs_+4
+	rsr.M0	\at1		// MAC16 option
+	s32i	\at1, \ptr, .Lxchal_ofs_+8
+	rsr.M1	\at1		// MAC16 option
+	s32i	\at1, \ptr, .Lxchal_ofs_+12
+	rsr.M2	\at1		// MAC16 option
+	s32i	\at1, \ptr, .Lxchal_ofs_+16
+	rsr.M3	\at1		// MAC16 option
+	s32i	\at1, \ptr, .Lxchal_ofs_+20
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 24
+	.elseif ((XTHAL_SAS_OPT | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
+	xchal_sa_align	\ptr, 0, 996, 4, 4
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 24
+	.endif
+    .endm	// xchal_ncp_store
 
 
-        /*
-          *  Macro to load all non-coprocessor (extra) custom TIE and optional state
-          *  (not including zero-overhead loop registers).
-          *  Required parameters:
-          *      ptr         Save area pointer address register (clobbered)
-          *                  (register must contain a 4 byte aligned address).
-          *      at1..at4    Four temporary address registers (first XCHAL_NCP_NUM_ATMPS
-          *                  registers are clobbered, the remaining are unused).
-          *  Optional parameters:
-          *      continue    If macro invoked as part of a larger load sequence, set to 1
-          *                  if this is not the first in the sequence.  Defaults to 0.
-          *      ofs         Offset from start of larger sequence (from value of first ptr
-          *                  in sequence) at which to load.  Defaults to next available space
-          *                  (or 0 if <continue> is 0).
-          *      select      Select what category(ies) of registers to load, as a bitmask
-          *                  (see XTHAL_SAS_xxx constants).  Defaults to all registers.
-          *      alloc       Select what category(ies) of registers to allocate; if any
-          *                  category is selected here that is not in <select>, space for
-          *                  the corresponding registers is skipped without doing any load.
-          */
-        .macro xchal_ncp_load  ptr at1 at2 at3 at4  continue = 0 ofs = -1 select = XTHAL_SAS_ALL alloc = 0
-                xchal_sa_start  \continue, \ofs
-                // Optional global registers used by default by the compiler:
-                .ifeq (XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_GLOB) & ~(\select)
-                xchal_sa_align  \ptr, 0, 1016, 4, 4
-                l32i    \at1, \ptr, .Lxchal_ofs_ + 0
-                wur.THREADPTR   \at1        // threadptr option
-                .set    .Lxchal_ofs_, .Lxchal_ofs_ + 4
-                .elseif ((XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_GLOB) & ~(\alloc)) == 0
-                xchal_sa_align  \ptr, 0, 1016, 4, 4
-                .set    .Lxchal_ofs_, .Lxchal_ofs_ + 4
-                .endif
-                // Optional caller-saved registers used by default by the compiler:
-                .ifeq (XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_CALR) & ~(\select)
-                xchal_sa_align  \ptr, 0, 1012, 4, 4
-                l32i    \at1, \ptr, .Lxchal_ofs_ + 0
-                wsr.ACCLO   \at1        // MAC16 option
-                l32i    \at1, \ptr, .Lxchal_ofs_ + 4
-                wsr.ACCHI   \at1        // MAC16 option
-                .set    .Lxchal_ofs_, .Lxchal_ofs_ + 8
-                .elseif ((XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
-                xchal_sa_align  \ptr, 0, 1012, 4, 4
-                .set    .Lxchal_ofs_, .Lxchal_ofs_ + 8
-                .endif
-                // Optional caller-saved registers not used by default by the compiler:
-                .ifeq (XTHAL_SAS_OPT | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
-                xchal_sa_align  \ptr, 0, 996, 4, 4
-                l32i    \at1, \ptr, .Lxchal_ofs_ + 0
-                wsr.BR  \at1        // boolean option
-                l32i    \at1, \ptr, .Lxchal_ofs_ + 4
-                wsr.SCOMPARE1   \at1        // conditional store option
-                l32i    \at1, \ptr, .Lxchal_ofs_ + 8
-                wsr.M0  \at1        // MAC16 option
-                l32i    \at1, \ptr, .Lxchal_ofs_ + 12
-                wsr.M1  \at1        // MAC16 option
-                l32i    \at1, \ptr, .Lxchal_ofs_ + 16
-                wsr.M2  \at1        // MAC16 option
-                l32i    \at1, \ptr, .Lxchal_ofs_ + 20
-                wsr.M3  \at1        // MAC16 option
-                .set    .Lxchal_ofs_, .Lxchal_ofs_ + 24
-                .elseif ((XTHAL_SAS_OPT | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
-                xchal_sa_align  \ptr, 0, 996, 4, 4
-                .set    .Lxchal_ofs_, .Lxchal_ofs_ + 24
-                .endif
-                // Custom caller-saved registers not used by default by the compiler:
-                .ifeq (XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
-                xchal_sa_align  \ptr, 0, 1016, 4, 4
-                l32i    \at1, \ptr, .Lxchal_ofs_ + 0
-                wur.SAR_BYTE    \at1        // ureg 13
-                .set    .Lxchal_ofs_, .Lxchal_ofs_ + 4
-                .elseif ((XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
-                xchal_sa_align  \ptr, 0, 1016, 4, 4
-                .set    .Lxchal_ofs_, .Lxchal_ofs_ + 4
-                .endif
-                .endm   // xchal_ncp_load
+    /*
+      *  Macro to load all non-coprocessor (extra) custom TIE and optional state
+      *  (not including zero-overhead loop registers).
+      *  Required parameters:
+      *      ptr         Save area pointer address register (clobbered)
+      *                  (register must contain a 4 byte aligned address).
+      *      at1..at4    Four temporary address registers (first XCHAL_NCP_NUM_ATMPS
+      *                  registers are clobbered, the remaining are unused).
+      *  Optional parameters:
+      *      continue    If macro invoked as part of a larger load sequence, set to 1
+      *                  if this is not the first in the sequence.  Defaults to 0.
+      *      ofs         Offset from start of larger sequence (from value of first ptr
+      *                  in sequence) at which to load.  Defaults to next available space
+      *                  (or 0 if <continue> is 0).
+      *      select      Select what category(ies) of registers to load, as a bitmask
+      *                  (see XTHAL_SAS_xxx constants).  Defaults to all registers.
+      *      alloc       Select what category(ies) of registers to allocate; if any
+      *                  category is selected here that is not in <select>, space for
+      *                  the corresponding registers is skipped without doing any load.
+      */
+    .macro xchal_ncp_load  ptr at1 at2 at3 at4  continue=0 ofs=-1 select=XTHAL_SAS_ALL alloc=0
+	xchal_sa_start	\continue, \ofs
+	// Optional global registers used by default by the compiler:
+	.ifeq (XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_GLOB) & ~(\select)
+	xchal_sa_align	\ptr, 0, 1016, 4, 4
+	l32i	\at1, \ptr, .Lxchal_ofs_+0
+	wur.THREADPTR	\at1		// threadptr option
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 4
+	.elseif ((XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_GLOB) & ~(\alloc)) == 0
+	xchal_sa_align	\ptr, 0, 1016, 4, 4
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 4
+	.endif
+	// Optional caller-saved registers used by default by the compiler:
+	.ifeq (XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_CALR) & ~(\select)
+	xchal_sa_align	\ptr, 0, 1012, 4, 4
+	l32i	\at1, \ptr, .Lxchal_ofs_+0
+	wsr.ACCLO	\at1		// MAC16 option
+	l32i	\at1, \ptr, .Lxchal_ofs_+4
+	wsr.ACCHI	\at1		// MAC16 option
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 8
+	.elseif ((XTHAL_SAS_OPT | XTHAL_SAS_CC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
+	xchal_sa_align	\ptr, 0, 1012, 4, 4
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 8
+	.endif
+	// Optional caller-saved registers not used by default by the compiler:
+	.ifeq (XTHAL_SAS_OPT | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
+	xchal_sa_align	\ptr, 0, 996, 4, 4
+	l32i	\at1, \ptr, .Lxchal_ofs_+0
+	wsr.BR	\at1		// boolean option
+	l32i	\at1, \ptr, .Lxchal_ofs_+4
+	wsr.SCOMPARE1	\at1		// conditional store option
+	l32i	\at1, \ptr, .Lxchal_ofs_+8
+	wsr.M0	\at1		// MAC16 option
+	l32i	\at1, \ptr, .Lxchal_ofs_+12
+	wsr.M1	\at1		// MAC16 option
+	l32i	\at1, \ptr, .Lxchal_ofs_+16
+	wsr.M2	\at1		// MAC16 option
+	l32i	\at1, \ptr, .Lxchal_ofs_+20
+	wsr.M3	\at1		// MAC16 option
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 24
+	.elseif ((XTHAL_SAS_OPT | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
+	xchal_sa_align	\ptr, 0, 996, 4, 4
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 24
+	.endif
+    .endm	// xchal_ncp_load
 
 
 
 
-#define XCHAL_NCP_NUM_ATMPS 1
+#define XCHAL_NCP_NUM_ATMPS	1
 
 
-                /*
-                 *  Macro to store the state of TIE coprocessor FPU.
-                 *  Required parameters:
-                 *      ptr         Save area pointer address register (clobbered)
-                 *                  (register must contain a 4 byte aligned address).
-                 *      at1..at4    Four temporary address registers (first XCHAL_CP0_NUM_ATMPS
-                 *                  registers are clobbered, the remaining are unused).
-                 *  Optional parameters are the same as for xchal_ncp_store.
-                 */
-#define xchal_cp_FPU_store  xchal_cp0_store
-                .macro  xchal_cp0_store  ptr at1 at2 at3 at4  continue = 0 ofs = -1 select = XTHAL_SAS_ALL alloc = 0
-                        xchal_sa_start \continue, \ofs
-                        // Custom caller-saved registers not used by default by the compiler:
-                        .ifeq (XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
-                        xchal_sa_align  \ptr, 0, 948, 4, 4
-                        rur.FCR \at1        // ureg 232
-                        s32i    \at1, \ptr, .Lxchal_ofs_ + 0
-                        rur.FSR \at1        // ureg 233
-                        s32i    \at1, \ptr, .Lxchal_ofs_ + 4
-                        ssi f0, \ptr, .Lxchal_ofs_ + 8
-                        ssi f1, \ptr, .Lxchal_ofs_ + 12
-                        ssi f2, \ptr, .Lxchal_ofs_ + 16
-                        ssi f3, \ptr, .Lxchal_ofs_ + 20
-                        ssi f4, \ptr, .Lxchal_ofs_ + 24
-                        ssi f5, \ptr, .Lxchal_ofs_ + 28
-                        ssi f6, \ptr, .Lxchal_ofs_ + 32
-                        ssi f7, \ptr, .Lxchal_ofs_ + 36
-                        ssi f8, \ptr, .Lxchal_ofs_ + 40
-                        ssi f9, \ptr, .Lxchal_ofs_ + 44
-                        ssi f10, \ptr, .Lxchal_ofs_ + 48
-                        ssi f11, \ptr, .Lxchal_ofs_ + 52
-                        ssi f12, \ptr, .Lxchal_ofs_ + 56
-                        ssi f13, \ptr, .Lxchal_ofs_ + 60
-                        ssi f14, \ptr, .Lxchal_ofs_ + 64
-                        ssi f15, \ptr, .Lxchal_ofs_ + 68
-                        .set    .Lxchal_ofs_, .Lxchal_ofs_ + 72
-                        .elseif ((XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
-                        xchal_sa_align  \ptr, 0, 948, 4, 4
-                        .set    .Lxchal_ofs_, .Lxchal_ofs_ + 72
-                        .endif
-                        .endm   // xchal_cp0_store
+    /*
+     *  Macro to store the state of TIE coprocessor FPU.
+     *  Required parameters:
+     *      ptr         Save area pointer address register (clobbered)
+     *                  (register must contain a 4 byte aligned address).
+     *      at1..at4    Four temporary address registers (first XCHAL_CP0_NUM_ATMPS
+     *                  registers are clobbered, the remaining are unused).
+     *  Optional parameters are the same as for xchal_ncp_store.
+     */
+#define xchal_cp_FPU_store	xchal_cp0_store
+    .macro	xchal_cp0_store  ptr at1 at2 at3 at4  continue=0 ofs=-1 select=XTHAL_SAS_ALL alloc=0
+	xchal_sa_start \continue, \ofs
+	// Custom caller-saved registers not used by default by the compiler:
+	.ifeq (XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
+	xchal_sa_align	\ptr, 0, 948, 4, 4
+	rur.FCR	\at1		// ureg 232
+	s32i	\at1, \ptr, .Lxchal_ofs_+0
+	rur.FSR	\at1		// ureg 233
+	s32i	\at1, \ptr, .Lxchal_ofs_+4
+	ssi	f0, \ptr, .Lxchal_ofs_+8
+	ssi	f1, \ptr, .Lxchal_ofs_+12
+	ssi	f2, \ptr, .Lxchal_ofs_+16
+	ssi	f3, \ptr, .Lxchal_ofs_+20
+	ssi	f4, \ptr, .Lxchal_ofs_+24
+	ssi	f5, \ptr, .Lxchal_ofs_+28
+	ssi	f6, \ptr, .Lxchal_ofs_+32
+	ssi	f7, \ptr, .Lxchal_ofs_+36
+	ssi	f8, \ptr, .Lxchal_ofs_+40
+	ssi	f9, \ptr, .Lxchal_ofs_+44
+	ssi	f10, \ptr, .Lxchal_ofs_+48
+	ssi	f11, \ptr, .Lxchal_ofs_+52
+	ssi	f12, \ptr, .Lxchal_ofs_+56
+	ssi	f13, \ptr, .Lxchal_ofs_+60
+	ssi	f14, \ptr, .Lxchal_ofs_+64
+	ssi	f15, \ptr, .Lxchal_ofs_+68
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 72
+	.elseif ((XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
+	xchal_sa_align	\ptr, 0, 948, 4, 4
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 72
+	.endif
+    .endm	// xchal_cp0_store
 
 
-                        /*
-                         *  Macro to load the state of TIE coprocessor FPU.
-                         *  Required parameters:
-                         *      ptr         Save area pointer address register (clobbered)
-                         *                  (register must contain a 4 byte aligned address).
-                         *      at1..at4    Four temporary address registers (first XCHAL_CP0_NUM_ATMPS
-                         *                  registers are clobbered, the remaining are unused).
-                         *  Optional parameters are the same as for xchal_ncp_load.
-                         */
-#define xchal_cp_FPU_load   xchal_cp0_load
-                        .macro  xchal_cp0_load  ptr at1 at2 at3 at4  continue = 0 ofs = -1 select = XTHAL_SAS_ALL alloc = 0
-                                xchal_sa_start \continue, \ofs
-                                // Custom caller-saved registers not used by default by the compiler:
-                                .ifeq (XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
-                                xchal_sa_align  \ptr, 0, 948, 4, 4
-                                l32i    \at1, \ptr, .Lxchal_ofs_ + 0
-                                wur.FCR \at1        // ureg 232
-                                l32i    \at1, \ptr, .Lxchal_ofs_ + 4
-                                wur.FSR \at1        // ureg 233
-                                lsi f0, \ptr, .Lxchal_ofs_ + 8
-                                lsi f1, \ptr, .Lxchal_ofs_ + 12
-                                lsi f2, \ptr, .Lxchal_ofs_ + 16
-                                lsi f3, \ptr, .Lxchal_ofs_ + 20
-                                lsi f4, \ptr, .Lxchal_ofs_ + 24
-                                lsi f5, \ptr, .Lxchal_ofs_ + 28
-                                lsi f6, \ptr, .Lxchal_ofs_ + 32
-                                lsi f7, \ptr, .Lxchal_ofs_ + 36
-                                lsi f8, \ptr, .Lxchal_ofs_ + 40
-                                lsi f9, \ptr, .Lxchal_ofs_ + 44
-                                lsi f10, \ptr, .Lxchal_ofs_ + 48
-                                lsi f11, \ptr, .Lxchal_ofs_ + 52
-                                lsi f12, \ptr, .Lxchal_ofs_ + 56
-                                lsi f13, \ptr, .Lxchal_ofs_ + 60
-                                lsi f14, \ptr, .Lxchal_ofs_ + 64
-                                lsi f15, \ptr, .Lxchal_ofs_ + 68
-                                .set    .Lxchal_ofs_, .Lxchal_ofs_ + 72
-                                .elseif ((XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
-                                xchal_sa_align  \ptr, 0, 948, 4, 4
-                                .set    .Lxchal_ofs_, .Lxchal_ofs_ + 72
-                                .endif
-                                .endm   // xchal_cp0_load
+    /*
+     *  Macro to load the state of TIE coprocessor FPU.
+     *  Required parameters:
+     *      ptr         Save area pointer address register (clobbered)
+     *                  (register must contain a 4 byte aligned address).
+     *      at1..at4    Four temporary address registers (first XCHAL_CP0_NUM_ATMPS
+     *                  registers are clobbered, the remaining are unused).
+     *  Optional parameters are the same as for xchal_ncp_load.
+     */
+#define xchal_cp_FPU_load	xchal_cp0_load
+    .macro	xchal_cp0_load  ptr at1 at2 at3 at4  continue=0 ofs=-1 select=XTHAL_SAS_ALL alloc=0
+	xchal_sa_start \continue, \ofs
+	// Custom caller-saved registers not used by default by the compiler:
+	.ifeq (XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
+	xchal_sa_align	\ptr, 0, 948, 4, 4
+	l32i	\at1, \ptr, .Lxchal_ofs_+0
+	wur.FCR	\at1		// ureg 232
+	l32i	\at1, \ptr, .Lxchal_ofs_+4
+	wur.FSR	\at1		// ureg 233
+	lsi	f0, \ptr, .Lxchal_ofs_+8
+	lsi	f1, \ptr, .Lxchal_ofs_+12
+	lsi	f2, \ptr, .Lxchal_ofs_+16
+	lsi	f3, \ptr, .Lxchal_ofs_+20
+	lsi	f4, \ptr, .Lxchal_ofs_+24
+	lsi	f5, \ptr, .Lxchal_ofs_+28
+	lsi	f6, \ptr, .Lxchal_ofs_+32
+	lsi	f7, \ptr, .Lxchal_ofs_+36
+	lsi	f8, \ptr, .Lxchal_ofs_+40
+	lsi	f9, \ptr, .Lxchal_ofs_+44
+	lsi	f10, \ptr, .Lxchal_ofs_+48
+	lsi	f11, \ptr, .Lxchal_ofs_+52
+	lsi	f12, \ptr, .Lxchal_ofs_+56
+	lsi	f13, \ptr, .Lxchal_ofs_+60
+	lsi	f14, \ptr, .Lxchal_ofs_+64
+	lsi	f15, \ptr, .Lxchal_ofs_+68
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 72
+	.elseif ((XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
+	xchal_sa_align	\ptr, 0, 948, 4, 4
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 72
+	.endif
+    .endm	// xchal_cp0_load
 
 
-#define XCHAL_CP0_NUM_ATMPS 1
-                                /*
-                                 *  Macro to store the state of TIE coprocessor cop_ai.
-                                 *  Required parameters:
-                                 *      ptr         Save area pointer address register (clobbered)
-                                 *                  (register must contain a 16 byte aligned address).
-                                 *      at1..at4    Four temporary address registers (first XCHAL_CP3_NUM_ATMPS
-                                 *                  registers are clobbered, the remaining are unused).
-                                 *  Optional parameters are the same as for xchal_ncp_store.
-                                 */
-#define xchal_cp_cop_ai_store   xchal_cp3_store
-                                .macro  xchal_cp3_store  ptr at1 at2 at3 at4  continue = 0 ofs = -1 select = XTHAL_SAS_ALL alloc = 0
-                                        xchal_sa_start \continue, \ofs
-                                        // Custom caller-saved registers not used by default by the compiler:
-                                        .ifeq (XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
-                                        xchal_sa_align  \ptr, 0, 0, 16, 16
-                                        rur.ACCX_0  \at1        // ureg 0
-                                        s32i    \at1, \ptr, .Lxchal_ofs_ + 0
-                                        rur.ACCX_1  \at1        // ureg 1
-                                        s32i    \at1, \ptr, .Lxchal_ofs_ + 4
-                                        rur.QACC_H_0    \at1        // ureg 2
-                                        s32i    \at1, \ptr, .Lxchal_ofs_ + 8
-                                        rur.QACC_H_1    \at1        // ureg 3
-                                        s32i    \at1, \ptr, .Lxchal_ofs_ + 12
-                                        rur.QACC_H_2    \at1        // ureg 4
-                                        s32i    \at1, \ptr, .Lxchal_ofs_ + 16
-                                        rur.QACC_H_3    \at1        // ureg 5
-                                        s32i    \at1, \ptr, .Lxchal_ofs_ + 20
-                                        rur.QACC_H_4    \at1        // ureg 6
-                                        s32i    \at1, \ptr, .Lxchal_ofs_ + 24
-                                        rur.QACC_L_0    \at1        // ureg 7
-                                        s32i    \at1, \ptr, .Lxchal_ofs_ + 28
-                                        rur.QACC_L_1    \at1        // ureg 8
-                                        s32i    \at1, \ptr, .Lxchal_ofs_ + 32
-                                        rur.QACC_L_2    \at1        // ureg 9
-                                        s32i    \at1, \ptr, .Lxchal_ofs_ + 36
-                                        rur.QACC_L_3    \at1        // ureg 10
-                                        s32i    \at1, \ptr, .Lxchal_ofs_ + 40
-                                        rur.QACC_L_4    \at1        // ureg 11
-                                        s32i    \at1, \ptr, .Lxchal_ofs_ + 44
-                                        st.qr   q0, \ptr, .Lxchal_ofs_ + 48
-                                        st.qr   q1, \ptr, .Lxchal_ofs_ + 64
-                                        st.qr   q2, \ptr, .Lxchal_ofs_ + 80
-                                        st.qr   q3, \ptr, .Lxchal_ofs_ + 96
-                                        st.qr   q4, \ptr, .Lxchal_ofs_ + 112
-                                        addi    \ptr, \ptr, 128
-                                        st.qr   q5, \ptr, .Lxchal_ofs_ + 0
-                                        .set    .Lxchal_pofs_, .Lxchal_pofs_ + 128
-                                        .set    .Lxchal_ofs_, .Lxchal_ofs_ + 16
-                                        .elseif ((XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
-                                        xchal_sa_align  \ptr, 0, 0, 16, 16
-                                        .set    .Lxchal_ofs_, .Lxchal_ofs_ + 144
-                                        .endif
-                                        .endm   // xchal_cp3_store
+#define XCHAL_CP0_NUM_ATMPS	1
+    /*
+     *  Macro to store the state of TIE coprocessor cop_ai.
+     *  Required parameters:
+     *      ptr         Save area pointer address register (clobbered)
+     *                  (register must contain a 16 byte aligned address).
+     *      at1..at4    Four temporary address registers (first XCHAL_CP3_NUM_ATMPS
+     *                  registers are clobbered, the remaining are unused).
+     *  Optional parameters are the same as for xchal_ncp_store.
+     */
+#define xchal_cp_cop_ai_store	xchal_cp3_store
+    .macro	xchal_cp3_store  ptr at1 at2 at3 at4  continue=0 ofs=-1 select=XTHAL_SAS_ALL alloc=0
+	xchal_sa_start \continue, \ofs
+	// Custom caller-saved registers not used by default by the compiler:
+	.ifeq (XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
+	xchal_sa_align	\ptr, 0, 0, 16, 16
+	rur.ACCX_0	\at1		// ureg 0
+	s32i	\at1, \ptr, .Lxchal_ofs_+0
+	rur.ACCX_1	\at1		// ureg 1
+	s32i	\at1, \ptr, .Lxchal_ofs_+4
+	rur.QACC_H_0	\at1		// ureg 2
+	s32i	\at1, \ptr, .Lxchal_ofs_+8
+	rur.QACC_H_1	\at1		// ureg 3
+	s32i	\at1, \ptr, .Lxchal_ofs_+12
+	rur.QACC_H_2	\at1		// ureg 4
+	s32i	\at1, \ptr, .Lxchal_ofs_+16
+	rur.QACC_H_3	\at1		// ureg 5
+	s32i	\at1, \ptr, .Lxchal_ofs_+20
+	rur.QACC_H_4	\at1		// ureg 6
+	s32i	\at1, \ptr, .Lxchal_ofs_+24
+	rur.QACC_L_0	\at1		// ureg 7
+	s32i	\at1, \ptr, .Lxchal_ofs_+28
+	rur.QACC_L_1	\at1		// ureg 8
+	s32i	\at1, \ptr, .Lxchal_ofs_+32
+	rur.QACC_L_2	\at1		// ureg 9
+	s32i	\at1, \ptr, .Lxchal_ofs_+36
+	rur.QACC_L_3	\at1		// ureg 10
+	s32i	\at1, \ptr, .Lxchal_ofs_+40
+	rur.QACC_L_4	\at1		// ureg 11
+	s32i	\at1, \ptr, .Lxchal_ofs_+44
+	rur.SAR_BYTE	\at1		// ureg 13
+	s32i	\at1, \ptr, .Lxchal_ofs_+48
+	rur.FFT_BIT_WIDTH	\at1		// ureg 14
+	s32i	\at1, \ptr, .Lxchal_ofs_+52
+	rur.UA_STATE_0	\at1		// ureg 15
+	s32i	\at1, \ptr, .Lxchal_ofs_+56
+	rur.UA_STATE_1	\at1		// ureg 16
+	s32i	\at1, \ptr, .Lxchal_ofs_+60
+	rur.UA_STATE_2	\at1		// ureg 17
+	s32i	\at1, \ptr, .Lxchal_ofs_+64
+	rur.UA_STATE_3	\at1		// ureg 18
+	s32i	\at1, \ptr, .Lxchal_ofs_+68
+	st.qr	q0, \ptr, .Lxchal_ofs_+80
+	st.qr	q1, \ptr, .Lxchal_ofs_+96
+	st.qr	q2, \ptr, .Lxchal_ofs_+112
+	addi	\ptr, \ptr, 128
+	st.qr	q3, \ptr, .Lxchal_ofs_+0
+	st.qr	q4, \ptr, .Lxchal_ofs_+16
+	st.qr	q5, \ptr, .Lxchal_ofs_+32
+	st.qr	q6, \ptr, .Lxchal_ofs_+48
+	st.qr	q7, \ptr, .Lxchal_ofs_+64
+	.set	.Lxchal_pofs_, .Lxchal_pofs_ + 128
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 80
+	.elseif ((XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
+	xchal_sa_align	\ptr, 0, 0, 16, 16
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 208
+	.endif
+    .endm	// xchal_cp3_store
 
 
-                                        /*
-                                         *  Macro to load the state of TIE coprocessor cop_ai.
-                                         *  Required parameters:
-                                         *      ptr         Save area pointer address register (clobbered)
-                                         *                  (register must contain a 16 byte aligned address).
-                                         *      at1..at4    Four temporary address registers (first XCHAL_CP3_NUM_ATMPS
-                                         *                  registers are clobbered, the remaining are unused).
-                                         *  Optional parameters are the same as for xchal_ncp_load.
-                                         */
-#define xchal_cp_cop_ai_load    xchal_cp3_load
-                                        .macro  xchal_cp3_load  ptr at1 at2 at3 at4  continue = 0 ofs = -1 select = XTHAL_SAS_ALL alloc = 0
-                                                xchal_sa_start \continue, \ofs
-                                                // Custom caller-saved registers not used by default by the compiler:
-                                                .ifeq (XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
-                                                xchal_sa_align  \ptr, 0, 0, 16, 16
-                                                l32i    \at1, \ptr, .Lxchal_ofs_ + 0
-                                                wur.ACCX_0  \at1        // ureg 0
-                                                l32i    \at1, \ptr, .Lxchal_ofs_ + 4
-                                                wur.ACCX_1  \at1        // ureg 1
-                                                l32i    \at1, \ptr, .Lxchal_ofs_ + 8
-                                                wur.QACC_H_0    \at1        // ureg 2
-                                                l32i    \at1, \ptr, .Lxchal_ofs_ + 12
-                                                wur.QACC_H_1    \at1        // ureg 3
-                                                l32i    \at1, \ptr, .Lxchal_ofs_ + 16
-                                                wur.QACC_H_2    \at1        // ureg 4
-                                                l32i    \at1, \ptr, .Lxchal_ofs_ + 20
-                                                wur.QACC_H_3    \at1        // ureg 5
-                                                l32i    \at1, \ptr, .Lxchal_ofs_ + 24
-                                                wur.QACC_H_4    \at1        // ureg 6
-                                                l32i    \at1, \ptr, .Lxchal_ofs_ + 28
-                                                wur.QACC_L_0    \at1        // ureg 7
-                                                l32i    \at1, \ptr, .Lxchal_ofs_ + 32
-                                                wur.QACC_L_1    \at1        // ureg 8
-                                                l32i    \at1, \ptr, .Lxchal_ofs_ + 36
-                                                wur.QACC_L_2    \at1        // ureg 9
-                                                l32i    \at1, \ptr, .Lxchal_ofs_ + 40
-                                                wur.QACC_L_3    \at1        // ureg 10
-                                                l32i    \at1, \ptr, .Lxchal_ofs_ + 44
-                                                wur.QACC_L_4    \at1        // ureg 11
-                                                ld.qr   q0, \ptr, .Lxchal_ofs_ + 48
-                                                ld.qr   q1, \ptr, .Lxchal_ofs_ + 64
-                                                ld.qr   q2, \ptr, .Lxchal_ofs_ + 80
-                                                ld.qr   q3, \ptr, .Lxchal_ofs_ + 96
-                                                ld.qr   q4, \ptr, .Lxchal_ofs_ + 112
-                                                addi    \ptr, \ptr, 128
-                                                ld.qr   q5, \ptr, .Lxchal_ofs_ + 0
-                                                .set    .Lxchal_pofs_, .Lxchal_pofs_ + 128
-                                                .set    .Lxchal_ofs_, .Lxchal_ofs_ + 16
-                                                .elseif ((XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
-                                                xchal_sa_align  \ptr, 0, 0, 16, 16
-                                                .set    .Lxchal_ofs_, .Lxchal_ofs_ + 144
-                                                .endif
-                                                .endm   // xchal_cp3_load
+    /*
+     *  Macro to load the state of TIE coprocessor cop_ai.
+     *  Required parameters:
+     *      ptr         Save area pointer address register (clobbered)
+     *                  (register must contain a 16 byte aligned address).
+     *      at1..at4    Four temporary address registers (first XCHAL_CP3_NUM_ATMPS
+     *                  registers are clobbered, the remaining are unused).
+     *  Optional parameters are the same as for xchal_ncp_load.
+     */
+#define xchal_cp_cop_ai_load	xchal_cp3_load
+    .macro	xchal_cp3_load  ptr at1 at2 at3 at4  continue=0 ofs=-1 select=XTHAL_SAS_ALL alloc=0
+	xchal_sa_start \continue, \ofs
+	// Custom caller-saved registers not used by default by the compiler:
+	.ifeq (XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\select)
+	xchal_sa_align	\ptr, 0, 0, 16, 16
+	l32i	\at1, \ptr, .Lxchal_ofs_+0
+	wur.ACCX_0	\at1		// ureg 0
+	l32i	\at1, \ptr, .Lxchal_ofs_+4
+	wur.ACCX_1	\at1		// ureg 1
+	l32i	\at1, \ptr, .Lxchal_ofs_+8
+	wur.QACC_H_0	\at1		// ureg 2
+	l32i	\at1, \ptr, .Lxchal_ofs_+12
+	wur.QACC_H_1	\at1		// ureg 3
+	l32i	\at1, \ptr, .Lxchal_ofs_+16
+	wur.QACC_H_2	\at1		// ureg 4
+	l32i	\at1, \ptr, .Lxchal_ofs_+20
+	wur.QACC_H_3	\at1		// ureg 5
+	l32i	\at1, \ptr, .Lxchal_ofs_+24
+	wur.QACC_H_4	\at1		// ureg 6
+	l32i	\at1, \ptr, .Lxchal_ofs_+28
+	wur.QACC_L_0	\at1		// ureg 7
+	l32i	\at1, \ptr, .Lxchal_ofs_+32
+	wur.QACC_L_1	\at1		// ureg 8
+	l32i	\at1, \ptr, .Lxchal_ofs_+36
+	wur.QACC_L_2	\at1		// ureg 9
+	l32i	\at1, \ptr, .Lxchal_ofs_+40
+	wur.QACC_L_3	\at1		// ureg 10
+	l32i	\at1, \ptr, .Lxchal_ofs_+44
+	wur.QACC_L_4	\at1		// ureg 11
+	l32i	\at1, \ptr, .Lxchal_ofs_+48
+	wur.SAR_BYTE	\at1		// ureg 13
+	l32i	\at1, \ptr, .Lxchal_ofs_+52
+	wur.FFT_BIT_WIDTH	\at1		// ureg 14
+	l32i	\at1, \ptr, .Lxchal_ofs_+56
+	wur.UA_STATE_0	\at1		// ureg 15
+	l32i	\at1, \ptr, .Lxchal_ofs_+60
+	wur.UA_STATE_1	\at1		// ureg 16
+	l32i	\at1, \ptr, .Lxchal_ofs_+64
+	wur.UA_STATE_2	\at1		// ureg 17
+	l32i	\at1, \ptr, .Lxchal_ofs_+68
+	wur.UA_STATE_3	\at1		// ureg 18
+	ld.qr	q0, \ptr, .Lxchal_ofs_+80
+	ld.qr	q1, \ptr, .Lxchal_ofs_+96
+	ld.qr	q2, \ptr, .Lxchal_ofs_+112
+	addi	\ptr, \ptr, 128
+	ld.qr	q3, \ptr, .Lxchal_ofs_+0
+	ld.qr	q4, \ptr, .Lxchal_ofs_+16
+	ld.qr	q5, \ptr, .Lxchal_ofs_+32
+	ld.qr	q6, \ptr, .Lxchal_ofs_+48
+	ld.qr	q7, \ptr, .Lxchal_ofs_+64
+	.set	.Lxchal_pofs_, .Lxchal_pofs_ + 128
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 80
+	.elseif ((XTHAL_SAS_TIE | XTHAL_SAS_NOCC | XTHAL_SAS_CALR) & ~(\alloc)) == 0
+	xchal_sa_align	\ptr, 0, 0, 16, 16
+	.set	.Lxchal_ofs_, .Lxchal_ofs_ + 208
+	.endif
+    .endm	// xchal_cp3_load
 
 
-#define XCHAL_CP3_NUM_ATMPS 1
-#define XCHAL_SA_NUM_ATMPS  1
+#define XCHAL_CP3_NUM_ATMPS	1
+#define XCHAL_SA_NUM_ATMPS	1
 
 
-                                                /*  Empty macros for unconfigured coprocessors:  */
-                                                .macro xchal_cp1_store  p a b c d continue = 0 ofs = -1 select = -1 ; .endm
-.macro xchal_cp1_load   p a b c d continue = 0 ofs = -1 select = -1 ; .endm
-.macro xchal_cp2_store  p a b c d continue = 0 ofs = -1 select = -1 ; .endm
-.macro xchal_cp2_load   p a b c d continue = 0 ofs = -1 select = -1 ; .endm
-.macro xchal_cp4_store  p a b c d continue = 0 ofs = -1 select = -1 ; .endm
-.macro xchal_cp4_load   p a b c d continue = 0 ofs = -1 select = -1 ; .endm
-.macro xchal_cp5_store  p a b c d continue = 0 ofs = -1 select = -1 ; .endm
-.macro xchal_cp5_load   p a b c d continue = 0 ofs = -1 select = -1 ; .endm
-.macro xchal_cp6_store  p a b c d continue = 0 ofs = -1 select = -1 ; .endm
-.macro xchal_cp6_load   p a b c d continue = 0 ofs = -1 select = -1 ; .endm
-.macro xchal_cp7_store  p a b c d continue = 0 ofs = -1 select = -1 ; .endm
-.macro xchal_cp7_load   p a b c d continue = 0 ofs = -1 select = -1 ; .endm
+	/*  Empty macros for unconfigured coprocessors:  */
+	.macro xchal_cp1_store	p a b c d continue=0 ofs=-1 select=-1 ; .endm
+	.macro xchal_cp1_load	p a b c d continue=0 ofs=-1 select=-1 ; .endm
+	.macro xchal_cp2_store	p a b c d continue=0 ofs=-1 select=-1 ; .endm
+	.macro xchal_cp2_load	p a b c d continue=0 ofs=-1 select=-1 ; .endm
+	.macro xchal_cp4_store	p a b c d continue=0 ofs=-1 select=-1 ; .endm
+	.macro xchal_cp4_load	p a b c d continue=0 ofs=-1 select=-1 ; .endm
+	.macro xchal_cp5_store	p a b c d continue=0 ofs=-1 select=-1 ; .endm
+	.macro xchal_cp5_load	p a b c d continue=0 ofs=-1 select=-1 ; .endm
+	.macro xchal_cp6_store	p a b c d continue=0 ofs=-1 select=-1 ; .endm
+	.macro xchal_cp6_load	p a b c d continue=0 ofs=-1 select=-1 ; .endm
+	.macro xchal_cp7_store	p a b c d continue=0 ofs=-1 select=-1 ; .endm
+	.macro xchal_cp7_load	p a b c d continue=0 ofs=-1 select=-1 ; .endm
 
 
 #endif /*_XTENSA_CORE_TIE_ASM_H*/
 #endif /*_XTENSA_CORE_TIE_ASM_H*/

+ 93 - 86
components/xtensa/esp32s3/include/xtensa/config/tie.h

@@ -8,7 +8,7 @@
    that extend basic Xtensa core functionality.  It is customized to this
    that extend basic Xtensa core functionality.  It is customized to this
    Xtensa processor configuration.
    Xtensa processor configuration.
 
 
-   Customer ID=15127; Build=0x86d67; Copyright (c) 1999-2020 Cadence Design Systems Inc.
+   Customer ID=15128; Build=0x90f1f; Copyright (c) 1999-2021 Cadence Design Systems Inc.
 
 
    Permission is hereby granted, free of charge, to any person obtaining
    Permission is hereby granted, free of charge, to any person obtaining
    a copy of this software and associated documentation files (the
    a copy of this software and associated documentation files (the
@@ -32,44 +32,44 @@
 #ifndef _XTENSA_CORE_TIE_H
 #ifndef _XTENSA_CORE_TIE_H
 #define _XTENSA_CORE_TIE_H
 #define _XTENSA_CORE_TIE_H
 
 
-#define XCHAL_CP_NUM            2   /* number of coprocessors */
-#define XCHAL_CP_MAX            4   /* max CP ID + 1 (0 if none) */
-#define XCHAL_CP_MASK           0x09    /* bitmask of all CPs by ID */
-#define XCHAL_CP_PORT_MASK      0x00    /* bitmask of only port CPs */
+#define XCHAL_CP_NUM			2	/* number of coprocessors */
+#define XCHAL_CP_MAX			4	/* max CP ID + 1 (0 if none) */
+#define XCHAL_CP_MASK			0x09	/* bitmask of all CPs by ID */
+#define XCHAL_CP_PORT_MASK		0x00	/* bitmask of only port CPs */
 
 
 /*  Basic parameters of each coprocessor:  */
 /*  Basic parameters of each coprocessor:  */
-#define XCHAL_CP0_NAME          "FPU"
-#define XCHAL_CP0_IDENT         FPU
-#define XCHAL_CP0_SA_SIZE       72  /* size of state save area */
-#define XCHAL_CP0_SA_ALIGN      4   /* min alignment of save area */
-#define XCHAL_CP_ID_FPU                 0   /* coprocessor ID (0..7) */
-#define XCHAL_CP3_NAME          "cop_ai"
-#define XCHAL_CP3_IDENT         cop_ai
-#define XCHAL_CP3_SA_SIZE       144 /* size of state save area */
-#define XCHAL_CP3_SA_ALIGN      16  /* min alignment of save area */
-#define XCHAL_CP_ID_COP_AI              3   /* coprocessor ID (0..7) */
+#define XCHAL_CP0_NAME			"FPU"
+#define XCHAL_CP0_IDENT			FPU
+#define XCHAL_CP0_SA_SIZE		72	/* size of state save area */
+#define XCHAL_CP0_SA_ALIGN		4	/* min alignment of save area */
+#define XCHAL_CP_ID_FPU             	0	/* coprocessor ID (0..7) */
+#define XCHAL_CP3_NAME			"cop_ai"
+#define XCHAL_CP3_IDENT			cop_ai
+#define XCHAL_CP3_SA_SIZE		208	/* size of state save area */
+#define XCHAL_CP3_SA_ALIGN		16	/* min alignment of save area */
+#define XCHAL_CP_ID_COP_AI          	3	/* coprocessor ID (0..7) */
 
 
 /*  Filler info for unassigned coprocessors, to simplify arrays etc:  */
 /*  Filler info for unassigned coprocessors, to simplify arrays etc:  */
-#define XCHAL_CP1_SA_SIZE       0
-#define XCHAL_CP1_SA_ALIGN      1
-#define XCHAL_CP2_SA_SIZE       0
-#define XCHAL_CP2_SA_ALIGN      1
-#define XCHAL_CP4_SA_SIZE       0
-#define XCHAL_CP4_SA_ALIGN      1
-#define XCHAL_CP5_SA_SIZE       0
-#define XCHAL_CP5_SA_ALIGN      1
-#define XCHAL_CP6_SA_SIZE       0
-#define XCHAL_CP6_SA_ALIGN      1
-#define XCHAL_CP7_SA_SIZE       0
-#define XCHAL_CP7_SA_ALIGN      1
+#define XCHAL_CP1_SA_SIZE		0
+#define XCHAL_CP1_SA_ALIGN		1
+#define XCHAL_CP2_SA_SIZE		0
+#define XCHAL_CP2_SA_ALIGN		1
+#define XCHAL_CP4_SA_SIZE		0
+#define XCHAL_CP4_SA_ALIGN		1
+#define XCHAL_CP5_SA_SIZE		0
+#define XCHAL_CP5_SA_ALIGN		1
+#define XCHAL_CP6_SA_SIZE		0
+#define XCHAL_CP6_SA_ALIGN		1
+#define XCHAL_CP7_SA_SIZE		0
+#define XCHAL_CP7_SA_ALIGN		1
 
 
 /*  Save area for non-coprocessor optional and custom (TIE) state:  */
 /*  Save area for non-coprocessor optional and custom (TIE) state:  */
-#define XCHAL_NCP_SA_SIZE       40
-#define XCHAL_NCP_SA_ALIGN      4
+#define XCHAL_NCP_SA_SIZE		36
+#define XCHAL_NCP_SA_ALIGN		4
 
 
 /*  Total save area for optional and custom state (NCP + CPn):  */
 /*  Total save area for optional and custom state (NCP + CPn):  */
-#define XCHAL_TOTAL_SA_SIZE     272 /* with 16-byte align padding */
-#define XCHAL_TOTAL_SA_ALIGN    16  /* actual minimum alignment */
+#define XCHAL_TOTAL_SA_SIZE		336	/* with 16-byte align padding */
+#define XCHAL_TOTAL_SA_ALIGN		16	/* actual minimum alignment */
 
 
 /*
 /*
  * Detailed contents of save areas.
  * Detailed contents of save areas.
@@ -77,42 +77,42 @@
  * before expanding the XCHAL_xxx_SA_LIST() macros.
  * before expanding the XCHAL_xxx_SA_LIST() macros.
  *
  *
  * XCHAL_SA_REG(s,ccused,abikind,kind,opt,name,galign,align,asize,
  * XCHAL_SA_REG(s,ccused,abikind,kind,opt,name,galign,align,asize,
- *      dbnum,base,regnum,bitsz,gapsz,reset,x...)
+ *		dbnum,base,regnum,bitsz,gapsz,reset,x...)
  *
  *
- *  s = passed from XCHAL_*_LIST(s), eg. to select how to expand
- *  ccused = set if used by compiler without special options or code
- *  abikind = 0 (caller-saved), 1 (callee-saved), or 2 (thread-global)
- *  kind = 0 (special reg), 1 (TIE user reg), or 2 (TIE regfile reg)
- *  opt = 0 (custom TIE extension or coprocessor), or 1 (optional reg)
- *  name = lowercase reg name (no quotes)
- *  galign = group byte alignment (power of 2) (galign >= align)
- *  align = register byte alignment (power of 2)
- *  asize = allocated size in bytes (asize*8 == bitsz + gapsz + padsz)
- *    (not including any pad bytes required to galign this or next reg)
- *  dbnum = unique target number f/debug (see <xtensa-libdb-macros.h>)
- *  base = reg shortname w/o index (or sr=special, ur=TIE user reg)
- *  regnum = reg index in regfile, or special/TIE-user reg number
- *  bitsz = number of significant bits (regfile width, or ur/sr mask bits)
- *  gapsz = intervening bits, if bitsz bits not stored contiguously
- *  (padsz = pad bits at end [TIE regfile] or at msbits [ur,sr] of asize)
- *  reset = register reset value (or 0 if undefined at reset)
- *  x = reserved for future use (0 until then)
+ *	s = passed from XCHAL_*_LIST(s), eg. to select how to expand
+ *	ccused = set if used by compiler without special options or code
+ *	abikind = 0 (caller-saved), 1 (callee-saved), or 2 (thread-global)
+ *	kind = 0 (special reg), 1 (TIE user reg), or 2 (TIE regfile reg)
+ *	opt = 0 (custom TIE extension or coprocessor), or 1 (optional reg)
+ *	name = lowercase reg name (no quotes)
+ *	galign = group byte alignment (power of 2) (galign >= align)
+ *	align = register byte alignment (power of 2)
+ *	asize = allocated size in bytes (asize*8 == bitsz + gapsz + padsz)
+ *	  (not including any pad bytes required to galign this or next reg)
+ *	dbnum = unique target number f/debug (see <xtensa-libdb-macros.h>)
+ *	base = reg shortname w/o index (or sr=special, ur=TIE user reg)
+ *	regnum = reg index in regfile, or special/TIE-user reg number
+ *	bitsz = number of significant bits (regfile width, or ur/sr mask bits)
+ *	gapsz = intervening bits, if bitsz bits not stored contiguously
+ *	(padsz = pad bits at end [TIE regfile] or at msbits [ur,sr] of asize)
+ *	reset = register reset value (or 0 if undefined at reset)
+ *	x = reserved for future use (0 until then)
  *
  *
  *  To filter out certain registers, e.g. to expand only the non-global
  *  To filter out certain registers, e.g. to expand only the non-global
  *  registers used by the compiler, you can do something like this:
  *  registers used by the compiler, you can do something like this:
  *
  *
- *  #define XCHAL_SA_REG(s,ccused,p...) SELCC##ccused(p)
+ *  #define XCHAL_SA_REG(s,ccused,p...)	SELCC##ccused(p)
  *  #define SELCC0(p...)
  *  #define SELCC0(p...)
- *  #define SELCC1(abikind,p...)    SELAK##abikind(p)
- *  #define SELAK0(p...)        REG(p)
- *  #define SELAK1(p...)        REG(p)
+ *  #define SELCC1(abikind,p...)	SELAK##abikind(p)
+ *  #define SELAK0(p...)		REG(p)
+ *  #define SELAK1(p...)		REG(p)
  *  #define SELAK2(p...)
  *  #define SELAK2(p...)
  *  #define REG(kind,tie,name,galn,aln,asz,csz,dbnum,base,rnum,bsz,rst,x...) \
  *  #define REG(kind,tie,name,galn,aln,asz,csz,dbnum,base,rnum,bsz,rst,x...) \
- *      ...what you want to expand...
+ *		...what you want to expand...
  */
  */
 
 
-#define XCHAL_NCP_SA_NUM    10
-#define XCHAL_NCP_SA_LIST(s)    \
+#define XCHAL_NCP_SA_NUM	9
+#define XCHAL_NCP_SA_LIST(s)	\
  XCHAL_SA_REG(s,1,2,1,1,      threadptr, 4, 4, 4,0x03E7,  ur,231, 32,0,0,0) \
  XCHAL_SA_REG(s,1,2,1,1,      threadptr, 4, 4, 4,0x03E7,  ur,231, 32,0,0,0) \
  XCHAL_SA_REG(s,1,0,0,1,          acclo, 4, 4, 4,0x0210,  sr,16 , 32,0,0,0) \
  XCHAL_SA_REG(s,1,0,0,1,          acclo, 4, 4, 4,0x0210,  sr,16 , 32,0,0,0) \
  XCHAL_SA_REG(s,1,0,0,1,          acchi, 4, 4, 4,0x0211,  sr,17 ,  8,0,0,0) \
  XCHAL_SA_REG(s,1,0,0,1,          acchi, 4, 4, 4,0x0211,  sr,17 ,  8,0,0,0) \
@@ -121,11 +121,10 @@
  XCHAL_SA_REG(s,0,0,0,1,             m0, 4, 4, 4,0x0220,  sr,32 , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,0,1,             m0, 4, 4, 4,0x0220,  sr,32 , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,0,1,             m1, 4, 4, 4,0x0221,  sr,33 , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,0,1,             m1, 4, 4, 4,0x0221,  sr,33 , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,0,1,             m2, 4, 4, 4,0x0222,  sr,34 , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,0,1,             m2, 4, 4, 4,0x0222,  sr,34 , 32,0,0,0) \
- XCHAL_SA_REG(s,0,0,0,1,             m3, 4, 4, 4,0x0223,  sr,35 , 32,0,0,0) \
- XCHAL_SA_REG(s,0,0,1,0,       sar_byte, 4, 4, 4,0x030D,  ur,13 ,  5,0,0,0)
+ XCHAL_SA_REG(s,0,0,0,1,             m3, 4, 4, 4,0x0223,  sr,35 , 32,0,0,0)
 
 
-#define XCHAL_CP0_SA_NUM    18
-#define XCHAL_CP0_SA_LIST(s)    \
+#define XCHAL_CP0_SA_NUM	18
+#define XCHAL_CP0_SA_LIST(s)	\
  XCHAL_SA_REG(s,0,0,1,0,            fcr, 4, 4, 4,0x03E8,  ur,232, 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,1,0,            fcr, 4, 4, 4,0x03E8,  ur,232, 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,1,0,            fsr, 4, 4, 4,0x03E9,  ur,233, 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,1,0,            fsr, 4, 4, 4,0x03E9,  ur,233, 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,             f0, 4, 4, 4,0x0030,   f,0  , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,             f0, 4, 4, 4,0x0030,   f,0  , 32,0,0,0) \
@@ -145,14 +144,14 @@
  XCHAL_SA_REG(s,0,0,2,0,            f14, 4, 4, 4,0x003E,   f,14 , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,            f14, 4, 4, 4,0x003E,   f,14 , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,            f15, 4, 4, 4,0x003F,   f,15 , 32,0,0,0)
  XCHAL_SA_REG(s,0,0,2,0,            f15, 4, 4, 4,0x003F,   f,15 , 32,0,0,0)
 
 
-#define XCHAL_CP1_SA_NUM    0
-#define XCHAL_CP1_SA_LIST(s)    /* empty */
+#define XCHAL_CP1_SA_NUM	0
+#define XCHAL_CP1_SA_LIST(s)	/* empty */
 
 
-#define XCHAL_CP2_SA_NUM    0
-#define XCHAL_CP2_SA_LIST(s)    /* empty */
+#define XCHAL_CP2_SA_NUM	0
+#define XCHAL_CP2_SA_LIST(s)	/* empty */
 
 
-#define XCHAL_CP3_SA_NUM    18
-#define XCHAL_CP3_SA_LIST(s)    \
+#define XCHAL_CP3_SA_NUM	26
+#define XCHAL_CP3_SA_LIST(s)	\
  XCHAL_SA_REG(s,0,0,1,0,         accx_0,16, 4, 4,0x0300,  ur,0  , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,1,0,         accx_0,16, 4, 4,0x0300,  ur,0  , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,1,0,         accx_1, 4, 4, 4,0x0301,  ur,1  ,  8,0,0,0) \
  XCHAL_SA_REG(s,0,0,1,0,         accx_1, 4, 4, 4,0x0301,  ur,1  ,  8,0,0,0) \
  XCHAL_SA_REG(s,0,0,1,0,       qacc_h_0, 4, 4, 4,0x0302,  ur,2  , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,1,0,       qacc_h_0, 4, 4, 4,0x0302,  ur,2  , 32,0,0,0) \
@@ -165,36 +164,44 @@
  XCHAL_SA_REG(s,0,0,1,0,       qacc_l_2, 4, 4, 4,0x0309,  ur,9  , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,1,0,       qacc_l_2, 4, 4, 4,0x0309,  ur,9  , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,1,0,       qacc_l_3, 4, 4, 4,0x030A,  ur,10 , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,1,0,       qacc_l_3, 4, 4, 4,0x030A,  ur,10 , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,1,0,       qacc_l_4, 4, 4, 4,0x030B,  ur,11 , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,1,0,       qacc_l_4, 4, 4, 4,0x030B,  ur,11 , 32,0,0,0) \
+ XCHAL_SA_REG(s,0,0,1,0,       sar_byte, 4, 4, 4,0x030D,  ur,13 ,  4,0,0,0) \
+ XCHAL_SA_REG(s,0,0,1,0,  fft_bit_width, 4, 4, 4,0x030E,  ur,14 ,  4,0,0,0) \
+ XCHAL_SA_REG(s,0,0,1,0,     ua_state_0, 4, 4, 4,0x030F,  ur,15 , 32,0,0,0) \
+ XCHAL_SA_REG(s,0,0,1,0,     ua_state_1, 4, 4, 4,0x0310,  ur,16 , 32,0,0,0) \
+ XCHAL_SA_REG(s,0,0,1,0,     ua_state_2, 4, 4, 4,0x0311,  ur,17 , 32,0,0,0) \
+ XCHAL_SA_REG(s,0,0,1,0,     ua_state_3, 4, 4, 4,0x0312,  ur,18 , 32,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,             q0,16,16,16,0x1008,   q,0  ,128,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,             q0,16,16,16,0x1008,   q,0  ,128,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,             q1,16,16,16,0x1009,   q,1  ,128,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,             q1,16,16,16,0x1009,   q,1  ,128,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,             q2,16,16,16,0x100A,   q,2  ,128,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,             q2,16,16,16,0x100A,   q,2  ,128,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,             q3,16,16,16,0x100B,   q,3  ,128,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,             q3,16,16,16,0x100B,   q,3  ,128,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,             q4,16,16,16,0x100C,   q,4  ,128,0,0,0) \
  XCHAL_SA_REG(s,0,0,2,0,             q4,16,16,16,0x100C,   q,4  ,128,0,0,0) \
- XCHAL_SA_REG(s,0,0,2,0,             q5,16,16,16,0x100D,   q,5  ,128,0,0,0)
+ XCHAL_SA_REG(s,0,0,2,0,             q5,16,16,16,0x100D,   q,5  ,128,0,0,0) \
+ XCHAL_SA_REG(s,0,0,2,0,             q6,16,16,16,0x100E,   q,6  ,128,0,0,0) \
+ XCHAL_SA_REG(s,0,0,2,0,             q7,16,16,16,0x100F,   q,7  ,128,0,0,0)
 
 
-#define XCHAL_CP4_SA_NUM    0
-#define XCHAL_CP4_SA_LIST(s)    /* empty */
+#define XCHAL_CP4_SA_NUM	0
+#define XCHAL_CP4_SA_LIST(s)	/* empty */
 
 
-#define XCHAL_CP5_SA_NUM    0
-#define XCHAL_CP5_SA_LIST(s)    /* empty */
+#define XCHAL_CP5_SA_NUM	0
+#define XCHAL_CP5_SA_LIST(s)	/* empty */
 
 
-#define XCHAL_CP6_SA_NUM    0
-#define XCHAL_CP6_SA_LIST(s)    /* empty */
+#define XCHAL_CP6_SA_NUM	0
+#define XCHAL_CP6_SA_LIST(s)	/* empty */
 
 
-#define XCHAL_CP7_SA_NUM    0
-#define XCHAL_CP7_SA_LIST(s)    /* empty */
+#define XCHAL_CP7_SA_NUM	0
+#define XCHAL_CP7_SA_LIST(s)	/* empty */
 
 
 /* Byte length of instruction from its first nibble (op0 field), per FLIX.  */
 /* Byte length of instruction from its first nibble (op0 field), per FLIX.  */
-#define XCHAL_OP0_FORMAT_LENGTHS    3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3
+#define XCHAL_OP0_FORMAT_LENGTHS	3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4
 /* Byte length of instruction from its first byte, per FLIX.  */
 /* Byte length of instruction from its first byte, per FLIX.  */
-#define XCHAL_BYTE0_FORMAT_LENGTHS  \
-    3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3,\
-    3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3,\
-    3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3,\
-    3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3,\
-    3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3,\
-    3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3,\
-    3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3,\
-    3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,3
+#define XCHAL_BYTE0_FORMAT_LENGTHS	\
+	3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4,\
+	3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4,\
+	3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4,\
+	3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4,\
+	3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4,\
+	3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4,\
+	3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4,\
+	3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4, 3,3,3,3,3,3,3,3,2,2,2,2,2,2,4,4
 
 
 #endif /*_XTENSA_CORE_TIE_H*/
 #endif /*_XTENSA_CORE_TIE_H*/