📄 sys_config.h
字号:
/*
* TOPPERS/JSP Kernel
* Toyohashi Open Platform for Embedded Real-Time Systems/
* Just Standard Profile Kernel
*
* Copyright (C) 2000-2003 by Embedded and Real-Time Systems Laboratory
* Toyohashi Univ. of Technology, JAPAN
*
* TOPPERS/JSP for Blackfin
*
* Copyright (C) 2004 by Suikan
* Copyright (C) 2004 by Ujinosuke
*
* 忋婰挊嶌尃幰偼丆埲壓偺 (1)乣(4) 偺忦審偐丆Free Software Foundation
* 偵傛偭偰岞昞偝傟偰偄傞 GNU General Public License 偺 Version 2 偵婰
* 弎偝傟偰偄傞忦審傪枮偨偡応崌偵尷傝丆杮僜僼僩僂僃傾乮杮僜僼僩僂僃傾
* 傪夵曄偟偨傕偺傪娷傓丏埲壓摨偠乯傪巊梡丒暋惢丒夵曄丒嵞攝晍乮埲壓丆
* 棙梡偲屇傇乯偡傞偙偲傪柍彏偱嫋戻偡傞丏
* (1) 杮僜僼僩僂僃傾傪僜乕僗僐乕僪偺宍偱棙梡偡傞応崌偵偼丆忋婰偺挊嶌
* 尃昞帵丆偙偺棙梡忦審偍傛傃壓婰偺柍曐徹婯掕偑丆偦偺傑傑偺宍偱僜乕
* 僗僐乕僪拞偵娷傑傟偰偄傞偙偲丏
* (2) 杮僜僼僩僂僃傾傪丆儔僀僽儔儕宍幃側偳丆懠偺僜僼僩僂僃傾奐敪偵巊
* 梡偱偒傞宍偱嵞攝晍偡傞応崌偵偼丆嵞攝晍偵敽偆僪僉儏儊儞僩乮棙梡
* 幰儅僯儏傾儖側偳乯偵丆忋婰偺挊嶌尃昞帵丆偙偺棙梡忦審偍傛傃壓婰
* 偺柍曐徹婯掕傪宖嵹偡傞偙偲丏
* (3) 杮僜僼僩僂僃傾傪丆婡婍偵慻傒崬傓側偳丆懠偺僜僼僩僂僃傾奐敪偵巊
* 梡偱偒側偄宍偱嵞攝晍偡傞応崌偵偼丆師偺偄偢傟偐偺忦審傪枮偨偡偙
* 偲丏
* (a) 嵞攝晍偵敽偆僪僉儏儊儞僩乮棙梡幰儅僯儏傾儖側偳乯偵丆忋婰偺挊
* 嶌尃昞帵丆偙偺棙梡忦審偍傛傃壓婰偺柍曐徹婯掕傪宖嵹偡傞偙偲丏
* (b) 嵞攝晍偺宍懺傪丆暿偵掕傔傞曽朄偵傛偭偰丆TOPPERS僾儘僕僃僋僩偵
* 曬崘偡傞偙偲丏
* (4) 杮僜僼僩僂僃傾偺棙梡偵傛傝捈愙揑傑偨偼娫愙揑偵惗偠傞偄偐側傞懝
* 奞偐傜傕丆忋婰挊嶌尃幰偍傛傃TOPPERS僾儘僕僃僋僩傪柶愑偡傞偙偲丏
*
* 杮僜僼僩僂僃傾偼丆柍曐徹偱採嫙偝傟偰偄傞傕偺偱偁傞丏忋婰挊嶌尃幰偍
* 傛傃TOPPERS僾儘僕僃僋僩偼丆杮僜僼僩僂僃傾偵娭偟偰丆偦偺揔梡壜擻惈傕
* 娷傔偰丆偄偐側傞曐徹傕峴傢側偄丏傑偨丆杮僜僼僩僂僃傾偺棙梡偵傛傝捈
* 愙揑傑偨偼娫愙揑偵惗偠偨偄偐側傞懝奞偵娭偟偰傕丆偦偺愑擟傪晧傢側偄丏
*
*
*/
#ifndef _SYS_CONFIG_H_
#define _SYS_CONFIG_H_
/*
* 僇乕僱儖偺撪晹幆暿柤偺儕僱乕儉
*/
#include <sys_rename.h>
/*
* 儃乕僪愝掕僼傽僀儖偺撉傒崬傒
*/
#include <board_config.h>
/*
* 僞乕僎僢僩僔僗僥儉埶懚儌僕儏乕儖乮ADSP-BF537梡乯
*
* 偙偺僀儞僋儖乕僪僼傽僀儖偼丆t_config.h 偺傒偐傜僀儞僋儖乕僪偝傟傞丏
* 懠偺僼傽僀儖偐傜捈愙僀儞僋儖乕僪偟偰偼側傜側偄丏
*/
/*
* 僞乕僎僢僩僔僗僥儉偺僴乕僪僂僃傾帒尮偺掕媊
*
* DEVICE_INTERRUPT_COUNT偼SIC_IMASK偺價僢僩悢
* 傪梌偊傞丅
* ADSP-BF537偺價僢僩悢偼32側偺偱丄抣偼32偱偁傞丅
*/
#define DEVICE_INTERRUPT_COUNT 32
/*
* TIC梡僞僀儅乕偺廃婜
*/
#define PLLCLOCK (CLKIN*MSELVAL)
#define SYSCLOCK (PLLCLOCK / SSELVAL)
#define CORECLOCK (PLLCLOCK / CSELVAL)
/*
* TIC偺妱崬傒僴儞僪儔偺儀僋僞斣崋
*/
#ifdef USE_TIC_CORE
#define INHNO_TIMER INHNO_CORE_TIMER
#else
#define INHNO_TIMER INHNO_GP_TIMER7
#endif
/*
* 僔儕傾儖億乕僩悢偺掕媊
* pidc/simple_sio/uart.c偱巊偆丅
*/
#define TNUM_PORT 0 /* 僒億乕僩偡傞僔儕傾儖億乕僩偺悢 */
#define TNUM_SIOP 0 /* 僒億乕僩偡傞僔儕傾儖億乕僩偺悢 */
/*
* 僔儕傾儖億乕僩斣崋偵娭偡傞掕媊
*/
#define LOGTASK_PORTID 0 /* 僔僗僥儉儘僌偵梡偄傞僔儕傾儖億乕僩斣崋 */
/*
* 僔儕傾儖億乕僩偺儃乕儗乕僩偵娭偡傞掕媊
*
* UART偺儃乕儗乕僩僕僃僱儗乕僞偵愝掕偡傋偒抣丏
* pidc/simple_sio/uart.c偱巊偆丅
*/
#define DLH_VAL SYSCLOCK/16/115200/256 /* 115200bps乮忋埵乯*/
#define DLL_VAL SYSCLOCK/16/115200%256 /* 115200bps乮壓埵乯*/
/*
* 僔儕傾儖億乕僩偺傾僪儗僗
* pidc/simple_sio/uart.c偱巊偆丅
*
*/
#define UART_0 0xFFC00400 // UART THR偺傾僪儗僗丅
/*
* 旝彮帪娫懸偪偺偨傔偺掕媊
* sil_dly_nse偺屇傃弌偟僆乕僶乕僿僢僪偲儖乕僾儃僨傿乕僒僀僋儖傪
* nS偱昞偡丅娭悢偼cpu_support.asm偵掕媊偟偰偁傞丅
* SIL_DLY_TIM1偼24僒僀僋儖丅32nS( 750MHz ), 40nS( 600MHz )
* SIL_DLY_TIM2偼12僒僀僋儖丅16nS( 750MHz ), 20nS( 600MHz )
*/
#define SIL_DLY_TIM1 (24*1000000000/CORECLOCK)
#define SIL_DLY_TIM2 (12*1000000000/CORECLOCK)
/*
* 妱傝崬傒儀僋僩儖斣崋
*
* 偙偺掕媊偼僐儞僼傿僌儗乕僔儑儞僼傽僀儖偱DEF_INH偺堷悢偲偟偰巊偆
* SIC_ISR偵偍偗傞價僢僩斣崋偱偁傞丅
*
*/
#define INHNO_PLL 0
#define INHNO_DMA_ERROR 1
#define INHNO_PERIPHERAL_ERROR 2
#define INHNO_RTC 3
#define INHNO_PPI 4
#define INHNO_SPORT0_RX 5
#define INHNO_SPORT0_TX 6
#define INHNO_SPORT1_RX 7
#define INHNO_SPORT1_TX 8
#define INHNO_TWI 9
#define INHNO_SPI 10
#define INHNO_UART0_RX 11
#define INHNO_UART0_TX 12
#define INHNO_UART1_RX 13
#define INHNO_UART1_TX 14
#define INHNO_CAN_RX 15
#define INHNO_CAN_TX 16
#define INHNO_MAC_RX 17
#define INHNO_PORT_H_A 17
#define INHNO_MAC_TX 18
#define INHNO_PORT_H_B 18
#define INHNO_GP_TIMER0 19
#define INHNO_GP_TIMER1 20
#define INHNO_GP_TIMER2 21
#define INHNO_GP_TIMER3 22
#define INHNO_GP_TIMER4 23
#define INHNO_GP_TIMER5 24
#define INHNO_GP_TIMER6 25
#define INHNO_GP_TIMER7 26
#define INHNO_PORT_FG_A 27
#define INHNO_PORT_G_B 28
#define INHNO_MEMORY_DMA0 29
#define INHNO_MEMORY_DMA1 30
#define INHNO_WDG 31
#define INHNO_PORT_F_B 31
// SIC_ISR偵側偄摿庩側妱傝崬傒
#ifdef USE_HW_ERROR
#define INHNO_HW_ERROR 32
#endif
#define INHNO_GP_TIMER 33
#define INHNO_RAISE 34
/*
* SIC_ISR偺妱傝崬傒偺儀僋僞斣崋
*
* 偙偺掕媊偼ena_int, dis_int偺堷悢偲偟偰巊偆丅
*/
#define INTNO_PLL 0
#define INTNO_DMA_ERROR 1
#define INTNO_PERIPHERAL_ERROR 2
#define INTNO_RTC 3
#define INTNO_PPI 4
#define INTNO_SPORT0_RX 5
#define INTNO_SPORT0_TX 6
#define INTNO_SPORT1_RX 7
#define INTNO_SPORT1_TX 8
#define INTNO_TWI 9
#define INTNO_SPI 10
#define INTNO_UART0_RX 11
#define INTNO_UART0_TX 12
#define INTNO_UART1_RX 13
#define INTNO_UART1_TX 14
#define INTNO_CAN_RX 15
#define INTNO_CAN_TX 16
#define INTNO_MAC_RX 17
#define INTNO_PORT_H_A 17
#define INTNO_MAC_TX 18
#define INTNO_PORT_H_B 18
#define INTNO_GP_TIMER0 19
#define INTNO_GP_TIMER1 20
#define INTNO_GP_TIMER2 21
#define INTNO_GP_TIMER3 22
#define INTNO_GP_TIMER4 23
#define INTNO_GP_TIMER5 24
#define INTNO_GP_TIMER6 25
#define INTNO_GP_TIMER7 26
#define INTNO_PORT_FG_A 27
#define INTNO_PORT_G_B 28
#define INTNO_MEMORY_DMA0 29
#define INTNO_MEMORY_DMA1 30
#define INTNO_WDG 31
#define INTNO_PORT_F_B 31
#ifndef _MACRO_ONLY
/*
* SIC_IARx傪夝愅偟偰丄僀儀儞僩弴埵偛偲偵妱傝摉偰傜傟偰偄傞妱傝崬傒
* 偺價僢僩儅僢僾傪嶌傞丅SIC_IARx偺僼傿乕儖僪抣偼桪愭弴埵-7側偺偱
* 偦偺暘曗惓偡傞丅
*/
void make_priority_mask( void );
/*
* 僞乕僎僢僩僔僗僥儉埶懚偺弶婜壔
*/
extern void sys_initialize(void);
/*
* 僞乕僎僢僩僔僗僥儉偺廔椆
*
* 僔僗僥儉傪廔椆偡傞帪偵巊偆丏ROM儌僯僞乛GDB STUB屇弌偟偱幚尰偡傞丏
*/
extern void sys_exit(void);
/*
* 僞乕僎僢僩僔僗僥儉偺暥帤弌椡
*
* 僔僗僥儉偺掅儗儀儖偺暥帤弌椡儖乕僠儞丏ROM儌僯僞乛GDB STUB屇弌偟偱幚
* 尰偡傞丏
*/
extern void sys_putc(char c);
/*
* SIC_IARx傪夝愅偟偰丄僀儀儞僩弴埵偛偲偵妱傝摉偰傜傟偰偄傞妱傝崬傒
* 偺價僢僩儅僢僾傪嶌傞丅SIC_IARx偺僼傿乕儖僪抣偼桪愭弴埵-7側偺偱
* 偦偺暘曗惓偡傞丅
*/
void make_priority_mask( void );
/*
* 妱傝崬傒偺嫋壜丄嬛巭
*
*/
typedef unsigned int INTNO;
extern ER ena_int( INTNO intno );
extern ER dis_int( INTNO intno );
/*
* 妱傝崬傒儅僗僋偺憖嶌
*
*
*/
typedef unsigned int IMS;
extern ER chg_ims( IMS ims );
extern ER get_ims( IMS * p_ims );
#endif /* _MACRO_ONLY */
#endif /* _SYS_CONFIG_H_ */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -