385 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			385 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/********************************** (C) COPYRIGHT  *******************************
 | 
						|
* File Name          : core_riscv.h
 | 
						|
* Author             : WCH
 | 
						|
* Version            : V1.0.0
 | 
						|
* Date               : 2021/06/06
 | 
						|
* Description        : RISC-V Core Peripheral Access Layer Header File for CH32V30x
 | 
						|
* Copyright (c) 2021 Nanjing Qinheng Microelectronics Co., Ltd.
 | 
						|
* SPDX-License-Identifier: Apache-2.0
 | 
						|
*******************************************************************************/
 | 
						|
#ifndef __CORE_RISCV_H__
 | 
						|
#define __CORE_RISCV_H__
 | 
						|
 | 
						|
/* IO definitions */
 | 
						|
#ifdef __cplusplus
 | 
						|
  #define     __I     volatile                /* defines 'read only' permissions */
 | 
						|
#else
 | 
						|
  #define     __I     volatile const          /* defines 'read only' permissions */
 | 
						|
#endif
 | 
						|
#define     __O     volatile                  /* defines 'write only' permissions */
 | 
						|
#define     __IO    volatile                  /* defines 'read / write' permissions */
 | 
						|
 | 
						|
/* Standard Peripheral Library old types (maintained for legacy purpose) */
 | 
						|
typedef __I uint64_t vuc64;  /* Read Only */
 | 
						|
typedef __I uint32_t vuc32;  /* Read Only */
 | 
						|
typedef __I uint16_t vuc16;  /* Read Only */
 | 
						|
typedef __I uint8_t vuc8;   /* Read Only */
 | 
						|
 | 
						|
typedef const uint64_t uc64;  /* Read Only */
 | 
						|
typedef const uint32_t uc32;  /* Read Only */
 | 
						|
typedef const uint16_t uc16;  /* Read Only */
 | 
						|
typedef const uint8_t uc8;   /* Read Only */
 | 
						|
 | 
						|
typedef __I int64_t vsc64;  /* Read Only */
 | 
						|
typedef __I int32_t vsc32;  /* Read Only */
 | 
						|
typedef __I int16_t vsc16;  /* Read Only */
 | 
						|
typedef __I int8_t vsc8;   /* Read Only */
 | 
						|
 | 
						|
typedef const int64_t sc64;  /* Read Only */
 | 
						|
typedef const int32_t sc32;  /* Read Only */
 | 
						|
typedef const int16_t sc16;  /* Read Only */
 | 
						|
typedef const int8_t sc8;   /* Read Only */
 | 
						|
 | 
						|
typedef __IO uint64_t  vu64;
 | 
						|
typedef __IO uint32_t  vu32;
 | 
						|
typedef __IO uint16_t vu16;
 | 
						|
typedef __IO uint8_t  vu8;
 | 
						|
 | 
						|
typedef uint64_t  u64;
 | 
						|
typedef uint32_t  u32;
 | 
						|
typedef uint16_t u16;
 | 
						|
typedef uint8_t  u8;
 | 
						|
 | 
						|
typedef __IO int64_t  vs64;
 | 
						|
typedef __IO int32_t  vs32;
 | 
						|
typedef __IO int16_t  vs16;
 | 
						|
typedef __IO int8_t   vs8;
 | 
						|
 | 
						|
typedef int64_t  s64;
 | 
						|
typedef int32_t  s32;
 | 
						|
typedef int16_t s16;
 | 
						|
typedef int8_t  s8;
 | 
						|
 | 
						|
typedef enum {ERROR = 0, SUCCESS = !ERROR} ErrorStatus;
 | 
						|
 | 
						|
typedef enum {DISABLE = 0, ENABLE = !DISABLE} FunctionalState;
 | 
						|
 | 
						|
typedef enum {RESET = 0, SET = !RESET} FlagStatus, ITStatus;
 | 
						|
 | 
						|
#define   RV_STATIC_INLINE  static  inline
 | 
						|
 | 
						|
/* memory mapped structure for Program Fast Interrupt Controller (PFIC) */
 | 
						|
typedef struct{
 | 
						|
  __I  uint32_t ISR[8];
 | 
						|
  __I  uint32_t IPR[8];
 | 
						|
  __IO uint32_t ITHRESDR;
 | 
						|
  __IO uint32_t RESERVED;
 | 
						|
  __IO uint32_t CFGR;
 | 
						|
  __I  uint32_t GISR;
 | 
						|
  uint8_t VTFIDR[4];
 | 
						|
  uint8_t RESERVED0[12];
 | 
						|
  __IO uint32_t VTFADDR[4];
 | 
						|
  uint8_t RESERVED1[0x90];
 | 
						|
  __O  uint32_t IENR[8];
 | 
						|
  uint8_t RESERVED2[0x60];
 | 
						|
  __O  uint32_t IRER[8];
 | 
						|
  uint8_t RESERVED3[0x60];
 | 
						|
  __O  uint32_t IPSR[8];
 | 
						|
  uint8_t RESERVED4[0x60];
 | 
						|
  __O  uint32_t IPRR[8];
 | 
						|
  uint8_t RESERVED5[0x60];
 | 
						|
  __IO uint32_t IACTR[8];
 | 
						|
  uint8_t RESERVED6[0xE0];
 | 
						|
  __IO uint8_t IPRIOR[256];
 | 
						|
  uint8_t RESERVED7[0x810];
 | 
						|
  __IO uint32_t SCTLR;
 | 
						|
}PFIC_Type;
 | 
						|
 | 
						|
/* memory mapped structure for SysTick */
 | 
						|
typedef struct
 | 
						|
{
 | 
						|
    __IO u32 CTLR;
 | 
						|
    __IO u32 SR;
 | 
						|
    __IO u64 CNT;
 | 
						|
    __IO u64 CMP;
 | 
						|
}SysTick_Type;
 | 
						|
 | 
						|
 | 
						|
#define PFIC            ((PFIC_Type *) 0xE000E000 )
 | 
						|
#define NVIC            PFIC
 | 
						|
#define NVIC_KEY1       ((uint32_t)0xFA050000)
 | 
						|
#define	NVIC_KEY2				((uint32_t)0xBCAF0000)
 | 
						|
#define	NVIC_KEY3				((uint32_t)0xBEEF0000)
 | 
						|
 | 
						|
#define SysTick         ((SysTick_Type *) 0xE000F000)
 | 
						|
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      __enable_irq
 | 
						|
 *
 | 
						|
 * @brief   Enable Global Interrupt
 | 
						|
 *
 | 
						|
 * @return  none
 | 
						|
 */
 | 
						|
RV_STATIC_INLINE void __enable_irq(void)
 | 
						|
{
 | 
						|
  __asm volatile ("csrw 0x800, %0" : : "r" (0x6088) );
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      __disable_irq
 | 
						|
 *
 | 
						|
 * @brief   Disable Global Interrupt
 | 
						|
 *
 | 
						|
 * @return  none
 | 
						|
 */
 | 
						|
RV_STATIC_INLINE void __disable_irq(void)
 | 
						|
{
 | 
						|
  __asm volatile ("csrw 0x800, %0" : : "r" (0x6000) );
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      __NOP
 | 
						|
 *
 | 
						|
 * @brief   nop
 | 
						|
 *
 | 
						|
 * @return  none
 | 
						|
 */
 | 
						|
RV_STATIC_INLINE void __NOP(void)
 | 
						|
{
 | 
						|
  __asm volatile ("nop");
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      NVIC_EnableIRQ
 | 
						|
 *
 | 
						|
 * @brief   Enable Interrupt
 | 
						|
 *
 | 
						|
 * @param   IRQn: Interrupt Numbers
 | 
						|
 *
 | 
						|
 * @return  none
 | 
						|
 */
 | 
						|
RV_STATIC_INLINE void NVIC_EnableIRQ(IRQn_Type IRQn)
 | 
						|
{
 | 
						|
  NVIC->IENR[((uint32_t)(IRQn) >> 5)] = (1 << ((uint32_t)(IRQn) & 0x1F));
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      NVIC_DisableIRQ
 | 
						|
 *
 | 
						|
 * @brief   Disable Interrupt
 | 
						|
 *
 | 
						|
 * @param   IRQn: Interrupt Numbers
 | 
						|
 *
 | 
						|
 * @return  none
 | 
						|
 */
 | 
						|
RV_STATIC_INLINE void NVIC_DisableIRQ(IRQn_Type IRQn)
 | 
						|
{
 | 
						|
  NVIC->IRER[((uint32_t)(IRQn) >> 5)] = (1 << ((uint32_t)(IRQn) & 0x1F));
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      NVIC_GetStatusIRQ
 | 
						|
 *
 | 
						|
 * @brief   Get Interrupt Enable State
 | 
						|
 *
 | 
						|
 * @param   IRQn: Interrupt Numbers
 | 
						|
 *
 | 
						|
 * @return  1 - Interrupt Enable
 | 
						|
 *          0 - Interrupt Disable
 | 
						|
 */
 | 
						|
RV_STATIC_INLINE uint32_t NVIC_GetStatusIRQ(IRQn_Type IRQn)
 | 
						|
{
 | 
						|
  return((uint32_t) ((NVIC->ISR[(uint32_t)(IRQn) >> 5] & (1 << ((uint32_t)(IRQn) & 0x1F)))?1:0));
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      NVIC_GetPendingIRQ
 | 
						|
 *
 | 
						|
 * @brief   Get Interrupt Pending State
 | 
						|
 *
 | 
						|
 * @param   IRQn: Interrupt Numbers
 | 
						|
 *
 | 
						|
 * @return  1 - Interrupt Pending Enable
 | 
						|
 *          0 - Interrupt Pending Disable
 | 
						|
 */
 | 
						|
RV_STATIC_INLINE uint32_t NVIC_GetPendingIRQ(IRQn_Type IRQn)
 | 
						|
{
 | 
						|
  return((uint32_t) ((NVIC->IPR[(uint32_t)(IRQn) >> 5] & (1 << ((uint32_t)(IRQn) & 0x1F)))?1:0));
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      NVIC_SetPendingIRQ
 | 
						|
 *
 | 
						|
 * @brief   Set Interrupt Pending
 | 
						|
 *
 | 
						|
 * @param   IRQn: Interrupt Numbers
 | 
						|
 *
 | 
						|
 * @return  None
 | 
						|
 */
 | 
						|
RV_STATIC_INLINE void NVIC_SetPendingIRQ(IRQn_Type IRQn)
 | 
						|
{
 | 
						|
  NVIC->IPSR[((uint32_t)(IRQn) >> 5)] = (1 << ((uint32_t)(IRQn) & 0x1F));
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      NVIC_ClearPendingIRQ
 | 
						|
 *
 | 
						|
 * @brief   Clear Interrupt Pending
 | 
						|
 *
 | 
						|
 * @param   IRQn: Interrupt Numbers
 | 
						|
 *
 | 
						|
 * @return  None
 | 
						|
 */
 | 
						|
RV_STATIC_INLINE void NVIC_ClearPendingIRQ(IRQn_Type IRQn)
 | 
						|
{
 | 
						|
  NVIC->IPRR[((uint32_t)(IRQn) >> 5)] = (1 << ((uint32_t)(IRQn) & 0x1F));
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      NVIC_GetActive
 | 
						|
 *
 | 
						|
 * @brief   Get Interrupt Active State
 | 
						|
 *
 | 
						|
 * @param   IRQn: Interrupt Numbers
 | 
						|
 *
 | 
						|
 * @return  1 - Interrupt Active
 | 
						|
 *          0 - Interrupt No Active
 | 
						|
 */
 | 
						|
RV_STATIC_INLINE uint32_t NVIC_GetActive(IRQn_Type IRQn)
 | 
						|
{
 | 
						|
  return((uint32_t)((NVIC->IACTR[(uint32_t)(IRQn) >> 5] & (1 << ((uint32_t)(IRQn) & 0x1F)))?1:0));
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      NVIC_SetPriority
 | 
						|
 *
 | 
						|
 * @brief   Set Interrupt Priority
 | 
						|
 *
 | 
						|
 * @param   IRQn - Interrupt Numbers
 | 
						|
 *          priority -
 | 
						|
 *              bit7 - pre-emption priority
 | 
						|
 *              bit6~bit4 - subpriority
 | 
						|
 * @return  None
 | 
						|
 */
 | 
						|
RV_STATIC_INLINE void NVIC_SetPriority(IRQn_Type IRQn, uint8_t priority)
 | 
						|
{
 | 
						|
  NVIC->IPRIOR[(uint32_t)(IRQn)] = priority;
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      __WFI
 | 
						|
 *
 | 
						|
 * @brief   Wait for Interrupt
 | 
						|
 *
 | 
						|
 * @return  None
 | 
						|
 */
 | 
						|
__attribute__( ( always_inline ) ) RV_STATIC_INLINE void __WFI(void)
 | 
						|
{
 | 
						|
  NVIC->SCTLR &= ~(1<<3);	// wfi
 | 
						|
  asm volatile ("wfi");
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      __WFE
 | 
						|
 *
 | 
						|
 * @brief   Wait for Events
 | 
						|
 *
 | 
						|
 * @return  None
 | 
						|
 */
 | 
						|
__attribute__( ( always_inline ) ) RV_STATIC_INLINE void __WFE(void)
 | 
						|
{
 | 
						|
  uint32_t t;
 | 
						|
 | 
						|
  t = NVIC->SCTLR;
 | 
						|
  NVIC->SCTLR |= (1<<3)|(1<<5);		// (wfi->wfe)+(__sev)
 | 
						|
  NVIC->SCTLR = (NVIC->SCTLR & ~(1<<5)) | ( t & (1<<5));
 | 
						|
  asm volatile ("wfi");
 | 
						|
  asm volatile ("wfi");
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      SetVTFIRQ
 | 
						|
 *
 | 
						|
 * @brief   Set VTF Interrupt
 | 
						|
 *
 | 
						|
 * @param   add - VTF interrupt service function base address.
 | 
						|
 *          IRQn -Interrupt Numbers
 | 
						|
 *          num - VTF Interrupt Numbers
 | 
						|
 *          NewState - DISABLE or ENABLE
 | 
						|
 * @return  None
 | 
						|
 */
 | 
						|
RV_STATIC_INLINE void SetVTFIRQ(uint32_t addr, IRQn_Type IRQn, uint8_t num, FunctionalState NewState){
 | 
						|
  if(num > 3)  return ;
 | 
						|
 | 
						|
  if (NewState != DISABLE)
 | 
						|
  {
 | 
						|
      NVIC->VTFIDR[num] = IRQn;
 | 
						|
      NVIC->VTFADDR[num] = ((addr&0xFFFFFFFE)|0x1);
 | 
						|
  }
 | 
						|
  else{
 | 
						|
      NVIC->VTFIDR[num] = IRQn;
 | 
						|
      NVIC->VTFADDR[num] = ((addr&0xFFFFFFFE)&(~0x1));
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
/*********************************************************************
 | 
						|
 * @fn      NVIC_SystemReset
 | 
						|
 *
 | 
						|
 * @brief   Initiate a system reset request
 | 
						|
 *
 | 
						|
 * @return  None
 | 
						|
 */
 | 
						|
RV_STATIC_INLINE void NVIC_SystemReset(void)
 | 
						|
{
 | 
						|
  NVIC->CFGR = NVIC_KEY3|(1<<7);
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
/* Core_Exported_Functions */  
 | 
						|
extern uint32_t __get_FFLAGS(void);
 | 
						|
extern void __set_FFLAGS(uint32_t value);
 | 
						|
extern uint32_t __get_FRM(void);
 | 
						|
extern void __set_FRM(uint32_t value);
 | 
						|
extern uint32_t __get_FCSR(void);
 | 
						|
extern void __set_FCSR(uint32_t value);
 | 
						|
extern uint32_t __get_MSTATUS(void);
 | 
						|
extern void __set_MSTATUS(uint32_t value);
 | 
						|
extern uint32_t __get_MISA(void);
 | 
						|
extern void __set_MISA(uint32_t value);
 | 
						|
extern uint32_t __get_MIE(void);
 | 
						|
extern void __set_MIE(uint32_t value);
 | 
						|
extern uint32_t __get_MTVEC(void);
 | 
						|
extern void __set_MTVEC(uint32_t value);
 | 
						|
extern uint32_t __get_MSCRATCH(void);
 | 
						|
extern void __set_MSCRATCH(uint32_t value);
 | 
						|
extern uint32_t __get_MEPC(void);
 | 
						|
extern void __set_MEPC(uint32_t value);
 | 
						|
extern uint32_t __get_MCAUSE(void);
 | 
						|
extern void __set_MCAUSE(uint32_t value);
 | 
						|
extern uint32_t __get_MTVAL(void);
 | 
						|
extern void __set_MTVAL(uint32_t value);
 | 
						|
extern uint32_t __get_MIP(void);
 | 
						|
extern void __set_MIP(uint32_t value);
 | 
						|
extern uint32_t __get_MCYCLE(void);
 | 
						|
extern void __set_MCYCLE(uint32_t value);
 | 
						|
extern uint32_t __get_MCYCLEH(void);
 | 
						|
extern void __set_MCYCLEH(uint32_t value);
 | 
						|
extern uint32_t __get_MINSTRET(void);
 | 
						|
extern void __set_MINSTRET(uint32_t value);
 | 
						|
extern uint32_t __get_MINSTRETH(void);
 | 
						|
extern void __set_MINSTRETH(uint32_t value);
 | 
						|
extern uint32_t __get_MVENDORID(void);
 | 
						|
extern uint32_t __get_MARCHID(void);
 | 
						|
extern uint32_t __get_MIMPID(void);
 | 
						|
extern uint32_t __get_MHARTID(void);
 | 
						|
extern uint32_t __get_SP(void);
 | 
						|
 | 
						|
 | 
						|
#endif
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 | 
						|
 |