2013-04-01 02:11:43 +02:00
|
|
|
/*
|
|
|
|
* mc1322x.h - mc1322x specific definitions
|
|
|
|
* Copyright (C) 2013 Oliver Hahm <oliver.hahm@inria.fr>
|
|
|
|
*
|
|
|
|
* This source code is licensed under the GNU General Public License,
|
|
|
|
* Version 3. See the file LICENSE for more details.
|
|
|
|
*
|
|
|
|
* This file is part of RIOT.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef MC1322X_H
|
|
|
|
#define MC1322X_H
|
|
|
|
|
2013-04-02 02:06:24 +02:00
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
/*-----------------------------------------------------------------*/
|
|
|
|
/* System Management */
|
|
|
|
#define SW_RST_VAL (0x87651234)
|
|
|
|
|
|
|
|
#define CRM_BASE (0x80003000)
|
|
|
|
|
|
|
|
/* Structure-based CRM access */
|
|
|
|
struct CRM_struct {
|
|
|
|
union {
|
|
|
|
uint32_t SYS_CNTL;
|
|
|
|
struct CRM_SYS_CNTL {
|
|
|
|
uint32_t PWR_SOURCE:2;
|
|
|
|
uint32_t PADS_1P8V_SEL:1;
|
|
|
|
uint32_t :1;
|
|
|
|
uint32_t JTAG_SECU_OFF:1;
|
|
|
|
uint32_t XTAL32_EXISTS:1;
|
|
|
|
uint32_t :2;
|
|
|
|
uint32_t XTAL_CLKDIV:6;
|
|
|
|
uint32_t :18;
|
|
|
|
} SYS_CNTLbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t WU_CNTL;
|
|
|
|
struct CRM_WU_CNTL {
|
|
|
|
uint32_t TIMER_WU_EN:1;
|
|
|
|
uint32_t RTC_WU_EN:1;
|
|
|
|
uint32_t HOST_WAKE:1;
|
|
|
|
uint32_t AUTO_ADC:1;
|
|
|
|
uint32_t EXT_WU_EN:4;
|
|
|
|
uint32_t EXT_WU_EDGE:4;
|
|
|
|
uint32_t EXT_WU_POL:4;
|
|
|
|
uint32_t TIMER_WU_IEN:1;
|
|
|
|
uint32_t RTC_WU_IEN:1;
|
|
|
|
uint32_t :2;
|
|
|
|
uint32_t EXT_WU_IEN:4;
|
|
|
|
uint32_t :4;
|
|
|
|
uint32_t EXT_OUT_POL:4;
|
|
|
|
} WU_CNTLbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t SLEEP_CNTL;
|
|
|
|
struct CRM_SLEEP_CNTL {
|
|
|
|
uint32_t HIB:1;
|
|
|
|
uint32_t DOZE:1;
|
|
|
|
uint32_t :2;
|
|
|
|
uint32_t RAM_RET:2;
|
|
|
|
uint32_t MCU_RET:1;
|
|
|
|
uint32_t DIG_PAD_EN:1;
|
|
|
|
uint32_t :24;
|
|
|
|
} SLEEP_CNTLbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t BS_CNTL;
|
|
|
|
struct CRM_BS_CNTL {
|
|
|
|
uint32_t BS_EN:1;
|
|
|
|
uint32_t WAIT4IRQ:1;
|
|
|
|
uint32_t BS_MAN_EN:1;
|
|
|
|
uint32_t :2;
|
|
|
|
uint32_t ARM_OFF_TIME:6;
|
|
|
|
uint32_t :18;
|
|
|
|
} BS_CNTLbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t COP_CNTL;
|
|
|
|
struct CRM_COP_CNTL {
|
|
|
|
uint32_t COP_EN:1;
|
|
|
|
uint32_t COP_OUT:1;
|
|
|
|
uint32_t COP_WP:1;
|
|
|
|
uint32_t :5;
|
|
|
|
uint32_t COP_TIMEOUT:7;
|
|
|
|
uint32_t :1;
|
|
|
|
uint32_t COP_COUNT:7;
|
|
|
|
uint32_t :9;
|
|
|
|
} COP_CNTLbits;
|
|
|
|
};
|
|
|
|
uint32_t COP_SERVICE;
|
|
|
|
union {
|
|
|
|
uint32_t STATUS;
|
|
|
|
struct CRM_STATUS {
|
|
|
|
uint32_t SLEEP_SYNC:1;
|
|
|
|
uint32_t HIB_WU_EVT:1;
|
|
|
|
uint32_t DOZE_WU_EVT:1;
|
|
|
|
uint32_t RTC_WU_EVT:1;
|
|
|
|
uint32_t EXT_WU_EVT:4;
|
|
|
|
uint32_t :1;
|
|
|
|
uint32_t CAL_DONE:1;
|
|
|
|
uint32_t COP_EVT:1;
|
|
|
|
uint32_t :6;
|
|
|
|
uint32_t VREG_BUCK_RDY:1;
|
|
|
|
uint32_t VREG_1P8V_RDY:1;
|
|
|
|
uint32_t VREG_1P5V_RDY:1;
|
|
|
|
uint32_t :12;
|
|
|
|
} STATUSbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t MOD_STATUS;
|
|
|
|
struct CRM_MOD_STATUS {
|
|
|
|
uint32_t ARM_EN:1;
|
|
|
|
uint32_t MACA_EN:1;
|
|
|
|
uint32_t ASM_EN:1;
|
|
|
|
uint32_t SPI_EN:1;
|
|
|
|
uint32_t GPIO_EN:1;
|
|
|
|
uint32_t UART1_EN:1;
|
|
|
|
uint32_t UART2_EN:1;
|
|
|
|
uint32_t TMR_EN:1;
|
|
|
|
uint32_t RIF_EN:1;
|
|
|
|
uint32_t I2C_EN:1;
|
|
|
|
uint32_t SSI_EN:1;
|
|
|
|
uint32_t SPIF_EN:1;
|
|
|
|
uint32_t ADC_EN:1;
|
|
|
|
uint32_t :1;
|
|
|
|
uint32_t JTA_EN:1;
|
|
|
|
uint32_t NEX_EN:1;
|
|
|
|
uint32_t :1;
|
|
|
|
uint32_t AIM_EN:1;
|
|
|
|
uint32_t :14;
|
|
|
|
} MOD_STATUSbits;
|
|
|
|
};
|
|
|
|
uint32_t WU_COUNT;
|
|
|
|
uint32_t WU_TIMEOUT;
|
|
|
|
uint32_t RTC_COUNT;
|
|
|
|
uint32_t RTC_TIMEOUT;
|
|
|
|
uint32_t reserved1;
|
|
|
|
union {
|
|
|
|
uint32_t CAL_CNTL;
|
|
|
|
struct CRM_CAL_CNTL {
|
|
|
|
uint32_t CAL_TIMEOUT:16;
|
|
|
|
uint32_t CAL_EN:1;
|
|
|
|
uint32_t CAL_IEN:1;
|
|
|
|
uint32_t :14;
|
|
|
|
} CAL_CNTLbits;
|
|
|
|
};
|
|
|
|
uint32_t CAL_COUNT;
|
|
|
|
union {
|
|
|
|
uint32_t RINGOSC_CNTL;
|
|
|
|
struct CRM_RINGOSC_CNTL {
|
|
|
|
uint32_t ROSC_EN:1;
|
|
|
|
uint32_t :3;
|
|
|
|
uint32_t ROSC_FTUNE:5;
|
|
|
|
uint32_t ROSC_CTUNE:4;
|
|
|
|
uint32_t :19;
|
|
|
|
} RINGOSC_CNTLbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t XTAL_CNTL;
|
|
|
|
struct CRM_XTAL_CNTL {
|
|
|
|
uint32_t :8;
|
|
|
|
uint32_t XTAL_IBIAS_SEL:4;
|
|
|
|
uint32_t :4;
|
|
|
|
uint32_t XTAL_FTUNE:5;
|
|
|
|
uint32_t XTAL_CTUNE:5;
|
|
|
|
uint32_t :6;
|
|
|
|
} XTAL_CNTLbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t XTAL32_CNTL;
|
|
|
|
struct CRM_XTAL32_CNTL {
|
|
|
|
uint32_t XTAL32_EN:1;
|
|
|
|
uint32_t :3;
|
|
|
|
uint32_t XTAL32_GAIN:2;
|
|
|
|
uint32_t :26;
|
|
|
|
} XTAL32_CNTLbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t VREG_CNTL;
|
|
|
|
struct CRM_VREG_CNTL {
|
|
|
|
uint32_t BUCK_EN:1;
|
|
|
|
uint32_t BUCK_SYNC_REC_EN:1;
|
|
|
|
uint32_t BUCK_BYPASS_EN:1;
|
|
|
|
uint32_t VREG_1P5V_EN:2;
|
|
|
|
uint32_t VREG_1P5V_SEL:2;
|
|
|
|
uint32_t VREG_1P8V_EN:1;
|
|
|
|
uint32_t BUCK_CLKDIV:4;
|
|
|
|
uint32_t :20;
|
|
|
|
} VREG_CNTLbits;
|
|
|
|
};
|
|
|
|
uint32_t reserved2;
|
|
|
|
uint32_t SW_RST;
|
|
|
|
uint32_t reserved3;
|
|
|
|
uint32_t reserved4;
|
|
|
|
uint32_t reserved5;
|
|
|
|
uint32_t reserved6;
|
|
|
|
};
|
|
|
|
|
|
|
|
static volatile struct CRM_struct * const CRM = (void*) (CRM_BASE);
|
|
|
|
|
|
|
|
|
|
|
|
/*-----------------------------------------------------------------*/
|
|
|
|
/* TIMERS */
|
|
|
|
|
2013-04-01 02:11:43 +02:00
|
|
|
#define F_CPU (24000000) ///< CPU target speed in Hz
|
|
|
|
|
|
|
|
/* Timer registers are all 16-bit wide with 16-bit access only */
|
|
|
|
#define TMR_OFFSET (0x20)
|
|
|
|
#define TMR_BASE (0x80007000)
|
|
|
|
#define TMR0_BASE (TMR_BASE)
|
|
|
|
#define TMR1_BASE (TMR_BASE + TMR_OFFSET*1)
|
|
|
|
#define TMR2_BASE (TMR_BASE + TMR_OFFSET*2)
|
|
|
|
#define TMR3_BASE (TMR_BASE + TMR_OFFSET*3)
|
|
|
|
|
|
|
|
struct TMR_struct {
|
|
|
|
uint16_t COMP1;
|
|
|
|
uint16_t COMP2;
|
|
|
|
uint16_t CAPT;
|
|
|
|
uint16_t LOAD;
|
|
|
|
uint16_t HOLD;
|
|
|
|
uint16_t CNTR;
|
|
|
|
union {
|
|
|
|
uint16_t CTRL;
|
|
|
|
struct TMR_CTRL {
|
|
|
|
uint16_t OUTPUT_MODE:3;
|
|
|
|
uint16_t CO_INIT:1;
|
|
|
|
uint16_t DIR:1;
|
|
|
|
uint16_t LENGTH:1;
|
|
|
|
uint16_t ONCE:1;
|
|
|
|
uint16_t SECONDARY_CNT_SOURCE:2;
|
|
|
|
uint16_t PRIMARY_CNT_SOURCE:4;
|
|
|
|
uint16_t COUNT_MODE:3;
|
|
|
|
} CTRLbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint16_t SCTRL;
|
|
|
|
struct TMR_SCTRL {
|
|
|
|
uint16_t OEN:1;
|
|
|
|
uint16_t OPS:1;
|
|
|
|
uint16_t FORCE:1;
|
|
|
|
uint16_t VAL:1;
|
|
|
|
uint16_t EEOF:1;
|
|
|
|
uint16_t MSTR:1;
|
|
|
|
uint16_t CAPTURE_MODE:2;
|
|
|
|
uint16_t INPUT:1;
|
|
|
|
uint16_t IPS:1;
|
|
|
|
uint16_t IEFIE:1;
|
|
|
|
uint16_t IEF:1;
|
|
|
|
uint16_t TOFIE:1;
|
|
|
|
uint16_t TOF:1;
|
|
|
|
uint16_t TCFIE:1;
|
|
|
|
uint16_t TCF:1;
|
|
|
|
} SCTRLbits;
|
|
|
|
};
|
|
|
|
uint16_t CMPLD1;
|
|
|
|
uint16_t CMPLD2;
|
|
|
|
union {
|
|
|
|
uint16_t CSCTRL;
|
|
|
|
struct TMR_CSCTRL {
|
|
|
|
uint16_t CL1:2;
|
|
|
|
uint16_t CL2:2;
|
|
|
|
uint16_t TCF1:1;
|
|
|
|
uint16_t TCF2:1;
|
|
|
|
uint16_t TCF1EN:1;
|
|
|
|
uint16_t TCF2EN:1;
|
|
|
|
uint16_t :5;
|
|
|
|
uint16_t FILT_EN:1;
|
|
|
|
uint16_t DBG_EN:2;
|
|
|
|
} CSCTRLbits;
|
|
|
|
};
|
|
|
|
|
|
|
|
uint16_t reserved[4];
|
|
|
|
|
|
|
|
union {
|
|
|
|
uint16_t ENBL;
|
|
|
|
struct TMR_ENBL {
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
uint16_t ENBL:4;
|
|
|
|
};
|
|
|
|
struct {
|
|
|
|
uint16_t ENBL3:1;
|
|
|
|
uint16_t ENBL2:1;
|
|
|
|
uint16_t ENBL1:1;
|
|
|
|
uint16_t ENBL0:1;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
uint16_t :12;
|
|
|
|
} ENBLbits;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
static volatile struct TMR_struct * const TMR0 = (void *) (TMR0_BASE);
|
|
|
|
static volatile struct TMR_struct * const TMR1 = (void *) (TMR1_BASE);
|
|
|
|
static volatile struct TMR_struct * const TMR2 = (void *) (TMR2_BASE);
|
|
|
|
static volatile struct TMR_struct * const TMR3 = (void *) (TMR3_BASE);
|
|
|
|
|
|
|
|
/* Get timer pointer from timer number */
|
|
|
|
#define TMR_ADDR(x) (*(volatile struct TMR_struct *)(((uint32_t)(x) * TMR_OFFSET) + TMR_BASE))
|
|
|
|
|
|
|
|
/* Get timer number from the timer pointer. */
|
|
|
|
#define TMR_NUM(x) (((uint32_t)(x) - TMR_BASE) / TMR_OFFSET)
|
|
|
|
|
2013-04-02 02:06:24 +02:00
|
|
|
/*-----------------------------------------------------------------*/
|
|
|
|
/* UART */
|
|
|
|
#define UART1_BASE (0x80005000)
|
|
|
|
#define UART2_BASE (0x8000B000)
|
|
|
|
|
|
|
|
struct UART_struct {
|
|
|
|
union {
|
|
|
|
uint32_t CON;
|
|
|
|
struct UART_CON {
|
|
|
|
uint32_t :16;
|
|
|
|
uint32_t TST:1;
|
|
|
|
uint32_t MRXR:1;
|
|
|
|
uint32_t MTXR:1;
|
|
|
|
uint32_t FCE:1;
|
|
|
|
uint32_t FCP:1;
|
|
|
|
uint32_t XTIM:1;
|
|
|
|
uint32_t :2;
|
|
|
|
uint32_t TXOENB:1;
|
|
|
|
uint32_t CONTX:1;
|
|
|
|
uint32_t SB:1;
|
|
|
|
uint32_t ST2:1;
|
|
|
|
uint32_t EP:1;
|
|
|
|
uint32_t PEN:1;
|
|
|
|
uint32_t RXE:1;
|
|
|
|
uint32_t TXE:1;
|
|
|
|
} CONbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t STAT;
|
|
|
|
struct UART_STAT {
|
|
|
|
uint32_t :24;
|
|
|
|
uint32_t TXRDY:1;
|
|
|
|
uint32_t RXRDY:1;
|
|
|
|
uint32_t RUE:1;
|
|
|
|
uint32_t ROE:1;
|
|
|
|
uint32_t TOE:1;
|
|
|
|
uint32_t FE:1;
|
|
|
|
uint32_t PE:1;
|
|
|
|
uint32_t SE:1;
|
|
|
|
} USTATbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t DATA;
|
|
|
|
struct UART_DATA {
|
|
|
|
uint32_t :24;
|
|
|
|
uint32_t DATA:8;
|
|
|
|
} DATAbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t RXCON;
|
|
|
|
struct UART_URXCON {
|
|
|
|
uint32_t :26;
|
|
|
|
uint32_t LVL:6;
|
|
|
|
} RXCONbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t TXCON;
|
|
|
|
struct UART_TXCON {
|
|
|
|
uint32_t :26;
|
|
|
|
uint32_t LVL:6;
|
|
|
|
} TXCONbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t CTS;
|
|
|
|
struct UART_CTS {
|
|
|
|
uint32_t :27;
|
|
|
|
uint32_t LVL:5;
|
|
|
|
} CTSbits;
|
|
|
|
};
|
|
|
|
union {
|
|
|
|
uint32_t BR;
|
|
|
|
struct UART_BR {
|
|
|
|
uint32_t INC:16;
|
|
|
|
uint32_t MOD:16;
|
|
|
|
} BRbits;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
static volatile struct UART_struct * const UART1 = (void *) (UART1_BASE);
|
|
|
|
static volatile struct UART_struct * const UART2 = (void *) (UART2_BASE);
|
|
|
|
|
2013-04-01 02:11:43 +02:00
|
|
|
#endif /* MC1322X_H */
|