RTEMS 6.1-rc1
Macros
sim.h File Reference

Motorola M68K System Integration Module. More...

Go to the source code of this file.

Macros

#define SAM(a, b, c)   ((a << b) & c)
 
#define SIM_VOLATILE_USHORT_POINTER   (volatile unsigned short int * const)
 
#define SIM_VOLATILE_UCHAR_POINTER   (volatile unsigned char * const)
 
#define SIM_CRB   0x7ffa00
 
#define SIMCR   SIM_VOLATILE_USHORT_POINTER(0x00 + SIM_CRB)
 
#define EXOFF   0x8000 /* External Clock Off */
 
#define FRZSW   0x4000 /* Freeze Software Enable */
 
#define FRZBM   0x2000 /* Freeze Bus Monitor Enable */
 
#define SLVEN   0x0800 /* Factory Test Model Enabled (ro)*/
 
#define SHEN   0x0300 /* Show Cycle Enable */
 
#define SUPV   0x0080 /* Supervisor/Unrestricted Data Space */
 
#define MM   0x0040 /* Module Mapping */
 
#define IARB   0x000f /* Interrupt Arbitration Field */
 
#define SIMTR   SIM_VOLATILE_USHORT_POINTER(0x02 + SIM_CRB)
 
#define SYNCR   SIM_VOLATILE_USHORT_POINTER(0x04 + SIM_CRB)
 
#define VCO   0x8000 /* Frequency Control (VCO) */
 
#define PRESCALE   0x4000 /* Frequency Control Bit (Prescale) */
 
#define COUNTER   0x3f00 /* Frequency Control Counter */
 
#define EDIV   0x0080 /* ECLK Divide Rate */
 
#define SLIMP   0x0010 /* Limp Mode Status */
 
#define SLOCK   0x0008 /* Synthesizer Lock */
 
#define RSTEN   0x0004 /* Reset Enable */
 
#define STSIM   0x0002 /* Stop Mode SIM Clock */
 
#define STEXT   0x0001 /* Stop Mode External Clock */
 
#define RSR   SIM_VOLATILE_UCHAR_POINTER(0x07 + SIM_CRB)
 
#define EXT   0x0080 /* External Reset */
 
#define POW   0x0040 /* Power-On Reset */
 
#define SW   0x0020 /* Software Watchdog Reset */
 
#define DBF   0x0010 /* Double Bus Fault Reset */
 
#define LOC   0x0004 /* Loss of Clock Reset */
 
#define SYS   0x0002 /* System Reset */
 
#define TST   0x0001 /* Test Submodule Reset */
 
#define SIMTRE   SIM_VOLATILE_USHORT_POINTER(0x08 + SIM_CRB)
 
#define PORTE0   SIM_VOLATILE_UCHAR_POINTER(0x11 + SIM_CRB)
 
#define PORTE1   SIM_VOLATILE_UCHAR_POINTER(0x13 + SIM_CRB)
 
#define DDRE   SIM_VOLATILE_UCHAR_POINTER(0x15 + SIM_CRB)
 
#define PEPAR   SIM_VOLATILE_UCHAR_POINTER(0x17 + SIM_CRB)
 
#define PORTF0   SIM_VOLATILE_UCHAR_POINTER(0x19 + SIM_CRB)
 
#define PORTF1   SIM_VOLATILE_UCHAR_POINTER(0x1b + SIM_CRB)
 
#define DDRF   SIM_VOLATILE_UCHAR_POINTER(0x1d + SIM_CRB)
 
#define PFPAR   SIM_VOLATILE_UCHAR_POINTER(0x1f + SIM_CRB)
 
#define SYPCR   SIM_VOLATILE_UCHAR_POINTER(0x21 + SIM_CRB)
 
#define SWE   0x80 /* Software Watch Enable */
 
#define SWP   0x40 /* Software Watchdog Prescale */
 
#define SWT   0x30 /* Software Watchdog Timing */
 
#define HME   0x08 /* Halt Monitor Enable */
 
#define BME   0x04 /* Bus Monitor External Enable */
 
#define BMT   0x03 /* Bus Monitor Timing */
 
#define PICR   SIM_VOLATILE_USHORT_POINTER(0x22 + SIM_CRB)
 
#define PIRQL   0x0700 /* Periodic Interrupt Request Level */
 
#define PIV   0x00ff /* Periodic Interrupt Level */
 
#define PITR   SIM_VOLATILE_USHORT_POINTER(0x24 + SIM_CRB)
 
#define PTP   0x0100 /* Periodic Timer Prescaler Control */
 
#define PITM   0x00ff /* Periodic Interrupt Timing Modulus */
 
#define SWSR   SIM_VOLATILE_UCHAR_POINTER(0x27 + SIM_CRB)
 
#define TSTMSRA   SIM_VOLATILE_USHORT_POINTER(0x30 + SIM_CRB)
 
#define TSTMSRB   SIM_VOLATILE_USHORT_POINTER(0x32 + SIM_CRB)
 
#define TSTSC   SIM_VOLATILE_USHORT_POINTER(0x34 + SIM_CRB)
 
#define TSTRC   SIM_VOLATILE_USHORT_POINTER(0x36 + SIM_CRB)
 
#define CREG   SIM_VOLATILE_USHORT_POINTER(0x38 + SIM_CRB)
 
#define DREG   SIM_VOLATILE_USHORT_POINTER(0x3a + SIM_CRB)
 
#define PORTC   SIM_VOLATILE_UCHAR_POINTER(0x41 + SIM_CRB)
 
#define CSPAR0   SIM_VOLATILE_USHORT_POINTER(0x44 + SIM_CRB)
 
#define CSPAR1   SIM_VOLATILE_USHORT_POINTER(0x46 + SIM_CRB)
 
#define DisOut   0x0
 
#define AltFun   0x1
 
#define CS8bit   0x2
 
#define CS16bit   0x3
 
#define CS_5   12 /* !CS5 | FC2 | PC2 */
 
#define CS_4   10 /* !CS4 | FC1 | PC1 */
 
#define CS_3   8 /* !CS3 | FC0 | PC0 */
 
#define CS_2   6 /* !CS2 | !BGACK | */
 
#define CS_1   4 /* !CS1 | !BG | */
 
#define CS_0   2 /* !CS0 | !BR | */
 
#define CSBOOT   0 /* !CSBOOT | | */
 
#define CS_10   8 /* !CS10 | ADDR23 | ECLK */
 
#define CS_9   6 /* !CS9 | ADDR22 | PC6 */
 
#define CS_8   4 /* !CS8 | ADDR21 | PC5 */
 
#define CS_7   2 /* !CS7 | ADDR20 | PC4 */
 
#define CS_6   0 /* !CS6 | ADDR19 | PC3 */
 
#define BS_2K   0x0
 
#define BS_8K   0x1
 
#define BS_16K   0x2
 
#define BS_64K   0x3
 
#define BS_128K   0x4
 
#define BS_256K   0x5
 
#define BS_512K   0x6
 
#define BS_1M   0x7
 
#define CSBARBT   SIM_VOLATILE_USHORT_POINTER(0x48 + SIM_CRB)
 
#define CSBAR0   SIM_VOLATILE_USHORT_POINTER(0x4c + SIM_CRB)
 
#define CSBAR1   SIM_VOLATILE_USHORT_POINTER(0x50 + SIM_CRB)
 
#define CSBAR2   SIM_VOLATILE_USHORT_POINTER(0x54 + SIM_CRB)
 
#define CSBAR3   SIM_VOLATILE_USHORT_POINTER(0x58 + SIM_CRB)
 
#define CSBAR4   SIM_VOLATILE_USHORT_POINTER(0x5c + SIM_CRB)
 
#define CSBAR5   SIM_VOLATILE_USHORT_POINTER(0x60 + SIM_CRB)
 
#define CSBAR6   SIM_VOLATILE_USHORT_POINTER(0x64 + SIM_CRB)
 
#define CSBAR7   SIM_VOLATILE_USHORT_POINTER(0x68 + SIM_CRB)
 
#define CSBAR8   SIM_VOLATILE_USHORT_POINTER(0x6c + SIM_CRB)
 
#define CSBAR9   SIM_VOLATILE_USHORT_POINTER(0x70 + SIM_CRB)
 
#define CSBAR10   SIM_VOLATILE_USHORT_POINTER(0x74 + SIM_CRB)
 
#define MODE   0x8000
 
#define Disable   0
 
#define LowerByte   0x2000
 
#define UpperByte   0x4000
 
#define BothBytes   0x6000
 
#define ReadOnly   0x0800
 
#define WriteOnly   0x1000
 
#define ReadWrite   0x1800
 
#define SyncAS   0x0
 
#define SyncDS   0x0400
 
#define WaitStates_0   (0x0 << 6)
 
#define WaitStates_1   (0x1 << 6)
 
#define WaitStates_2   (0x2 << 6)
 
#define WaitStates_3   (0x3 << 6)
 
#define WaitStates_4   (0x4 << 6)
 
#define WaitStates_5   (0x5 << 6)
 
#define WaitStates_6   (0x6 << 6)
 
#define WaitStates_7   (0x7 << 6)
 
#define WaitStates_8   (0x8 << 6)
 
#define WaitStates_9   (0x9 << 6)
 
#define WaitStates_10   (0xa << 6)
 
#define WaitStates_11   (0xb << 6)
 
#define WaitStates_12   (0xc << 6)
 
#define WaitStates_13   (0xd << 6)
 
#define FastTerm   (0xe << 6)
 
#define External   (0xf << 6)
 
#define CPUSpace   (0x0 << 4)
 
#define UserSpace   (0x1 << 4)
 
#define SupSpace   (0x2 << 4)
 
#define UserSupSpace   (0x3 << 4)
 
#define IPLevel_any   0x0
 
#define IPLevel_1   0x2
 
#define IPLevel_2   0x4
 
#define IPLevel_3   0x6
 
#define IPLevel_4   0x8
 
#define IPLevel_5   0xa
 
#define IPLevel_6   0xc
 
#define IPLevel_7   0xe
 
#define AVEC   1
 
#define CSORBT   SIM_VOLATILE_USHORT_POINTER(0x4a + SIM_CRB)
 
#define CSOR0   SIM_VOLATILE_USHORT_POINTER(0x4e + SIM_CRB)
 
#define CSOR1   SIM_VOLATILE_USHORT_POINTER(0x52 + SIM_CRB)
 
#define CSOR2   SIM_VOLATILE_USHORT_POINTER(0x56 + SIM_CRB)
 
#define CSOR3   SIM_VOLATILE_USHORT_POINTER(0x5a + SIM_CRB)
 
#define CSOR4   SIM_VOLATILE_USHORT_POINTER(0x5e + SIM_CRB)
 
#define CSOR5   SIM_VOLATILE_USHORT_POINTER(0x62 + SIM_CRB)
 
#define CSOR6   SIM_VOLATILE_USHORT_POINTER(0x66 + SIM_CRB)
 
#define CSOR7   SIM_VOLATILE_USHORT_POINTER(0x6a + SIM_CRB)
 
#define CSOR8   SIM_VOLATILE_USHORT_POINTER(0x6e + SIM_CRB)
 
#define CSOR9   SIM_VOLATILE_USHORT_POINTER(0x72 + SIM_CRB)
 
#define CSOR10   SIM_VOLATILE_USHORT_POINTER(0x76 + SIM_CRB)
 

Detailed Description

Motorola M68K System Integration Module.

The system integration module (SIM) is used on many Motorola 16- and 32-bit MCUs for the following functions:

() System configuration and protection. Bus and software watchdog monitors are provided in addition to periodic interrupt generators.

() Clock signal generation for other intermodule bus (IMB) members and external devices.

() The generation of chip-select signals that simplify external circuitry interface.

() Data ports that are available for general purpose input and output.

() A system test block that is intended only for factory tests.

For more information, refer to Motorola's "Modular Microcontroller Family System Integration Module Reference Manual" (Motorola document SIMRM/AD).