⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 bsp.h

📁 RTEMS (Real-Time Executive for Multiprocessor Systems) is a free open source real-time operating sys
💻 H
字号:
/*  bsp.h * *  This include file contains some definitions specific to the *  Cyclone CVME960 and CVME961 boards.  These boards are the *  same except the 960 uses SRAM and the 961 DRAM. * *  COPYRIGHT (c) 1989-1999. *  On-Line Applications Research Corporation (OAR). * *  The license and distribution terms for this file may be *  found in the file LICENSE in this distribution or at *  http://www.rtems.com/license/LICENSE. * *  $Id: bsp.h,v 1.15.4.1 2003/09/04 18:44:11 joel Exp $ */#ifndef __CVME961_h#define __CVME961_h#ifdef __cplusplusextern "C" {#endif#include <bspopts.h>#include <rtems.h>#include <libcpu/i960CA.h>#include <iosupp.h>#include <console.h>#include <clockdrv.h>/* *  confdefs.h overrides for this BSP: *   - number of termios serial ports (defaults to 1) *   - Interrupt stack space is not minimum if defined. *//* #define CONFIGURE_NUMBER_OF_TERMIOS_PORTS 2 */#define CONFIGURE_INTERRUPT_STACK_MEMORY  (4 * 1024)/* *  Define the time limits for RTEMS Test Suite test durations. *  Long test and short test duration limits are provided.  These *  values are in seconds and need to be converted to ticks for the *  application. * */#define MAX_LONG_TEST_DURATION       300 /* 5 minutes = 300 seconds */#define MAX_SHORT_TEST_DURATION      3   /* 3 seconds *//* *  Define the interrupt mechanism for Time Test 27 * *  NOTE: Following are for i960CA and are board independent * */#define MUST_WAIT_FOR_INTERRUPT 0#define Install_tm27_vector( handler ) set_vector( (handler), 6, 1 )#define Cause_tm27_intr()  i960_cause_intr( 0x62 )#define Clear_tm27_intr()  i960_clear_intr( 6 )#define Lower_tm27_intr()/* *  Simple spin delay in microsecond units for device drivers. *  This is very dependent on the clock speed of the target. */#define rtems_bsp_delay( microseconds ) \  { register rtems_unsigned32 _delay=(microseconds); \    register rtems_unsigned32 _tmp = 0; /* initialized to avoid warning */ \    asm volatile( "0: \                     remo      3,31,%0 ; \                     cmpo      0,%0 ; \                     subo      1,%1,%1 ; \                     cmpobne.t 0,%1,0b " \                  : "=d" (_tmp), "=d" (_delay) \                  : "0"  (_tmp), "1"  (_delay) ); \  }/* Constants */#define RAM_START 0#define RAM_END   0x100000/* NINDY console I/O requests: *   CO sends a single character to stdout, *   CI reads one. */#define NINDY_INPUT   0#define NINDY_OUTPUT  1/* *  get_prcb * *  Returns the PRCB pointer. */static inline i960ca_PRCB *get_prcb( void ){  register i960ca_PRCB *_prcb = 0;  asm volatile( "calls 5; \                 mov   g0,%0" \                 : "=d" (_prcb) \                 : "0" (_prcb) );  return ( _prcb );}#ifdef C961_INIT#undef BSP_EXTERN#define BSP_EXTERN#else#undef BSP_EXTERN#define BSP_EXTERN extern#endif/* miscellaneous stuff assumed to exist */extern rtems_configuration_table BSP_Configuration;BSP_EXTERN i960ca_PRCB           *Prcb;BSP_EXTERN i960ca_control_table  *Ctl_tbl;/* *  Device Driver Table Entries *//* * NOTE: Use the standard Console driver entry */ /* * NOTE: Use the standard Clock driver entry *//* functions */void bsp_cleanup( void );i960_isr_entry set_vector( rtems_isr_entry, unsigned int, unsigned int );#ifdef __cplusplus}#endif#endif/* end of include file */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -