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

📄 sysserial.c

📁 kedin bsp for vxWorks
💻 C
字号:
/* sysSerial.c - KS8695P demo board serial device initialization *//*modification history--------------------9/22/2003  Ritter Yeh  created */#include "vxWorks.h"#include "iv.h"#include "intLib.h"#include "config.h"#include "sysLib.h"#include "ks8695Sio.h"LOCAL KS8695P_CHAN ks8695pChan[N_KS8695P_UART_CHANNELS];/* * Array of pointers to all serial channels configured in system. * See sioChanGet(). It is this array that maps channel pointers * to standard device names.  The first entry will become "/tyCo/0", * the second "/tyCo/1", and so forth. */SIO_CHAN * sysSioChans [] =    {    &ks8695pChan[0].sio, /* /tyCo/0 */    };/* forward declarations *//******************************************************************************** sysSerialHwInit - initialize the BSP serial devices to a quiescent state** This routine initializes the BSP serial device descriptors and puts the* devices in a quiesent state.  It is called from sysHwInit() with* interrupts locked.** RETURNS: N/A** SEE ALSO: sysHwInit()*/void sysSerialHwInit (void)    {    int i;    for (i = 0; i < N_KS8695P_UART_CHANNELS; i++)	{	ks8695pChan[i].regs     = (UINT32 *)UART_0_BASE_ADR;	ks8695pChan[i].baudRate = CONSOLE_BAUD_RATE;	ks8695pChan[i].xtal     = KS8695P_SYSCLK;	ks8695pChan[i].levelRx  = INT_LVL_URS;	ks8695pChan[i].levelTx  = INT_LVL_UTS;	/*	 * Initialise driver functions, getTxChar, putRcvChar and channelMode	 * and initialise UART	 */	ks8695pSioDevInit(&ks8695pChan[i]);	}    }/******************************************************************************** sysSerialHwInit2 - connect BSP serial device interrupts** This routine connects the BSP serial device interrupts.  It is called from* sysHwInit2().  Serial device interrupts could not be connected in* sysSerialHwInit() because the kernel memory allocator was not initialized* at that point, and intConnect() may call malloc().** RETURNS: N/A** SEE ALSO: sysHwInit2()*/void sysSerialHwInit2 (void)    {    int i;    for (i = 0; i < N_KS8695P_UART_CHANNELS; i++)	{	/*	 * Connect and enable the interrupt.	 */	(void) intConnect (INUM_TO_IVEC(INT_LVL_URS),			   ks8695pSioIntRx, (int) &ks8695pChan[i] );	(void) intConnect (INUM_TO_IVEC(INT_LVL_UTS),			   ks8695pSioIntTx, (int) &ks8695pChan[i] );	(void) intConnect (INUM_TO_IVEC(INT_LVL_ULES),			   ks8695pSioIntErr, (int) &ks8695pChan[i] );	intEnable (INT_LVL_URS);	intEnable (INT_LVL_UTS);	intEnable (INT_LVL_ULES);	}    }/******************************************************************************** sysSerialChanGet - get the SIO_CHAN device associated with a serial channel** This routine returns a pointer to the SIO_CHAN device associated with* a specified serial channel.  It is called by usrRoot() to obtain* pointers when creating the system serial devices '/tyCo/x'.  It is also* used by the WDB agent to locate its serial channel.** RETURNS: A pointer to the SIO_CHAN structure for the channel, or ERROR* if the channel is invalid.*/SIO_CHAN * sysSerialChanGet    (    int channel         /* serial channel */    )    {    if (channel < 0 || channel >= (int)(NELEMENTS(sysSioChans)))	return (SIO_CHAN *)ERROR;    return sysSioChans[channel];    }/******************************************************************************** sysSerialReset - reset the sio devices to a quiet state** Reset all devices to prevent them from generating interrupts.** This is called from sysToMonitor to shutdown the system gracefully before* transferring to the boot ROMs.** RETURNS: N/A.*/void sysSerialReset (void)    {    int i;    for (i = 0; i < N_KS8695P_UART_CHANNELS; i++)	{	/* disable serial interrupts */	intDisable (INT_LVL_UTS);	intDisable (INT_LVL_URS);	intDisable (INT_LVL_ULES);	}    }

⌨️ 快捷键说明

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