亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? isadma.c

?? mtx604在vxworks下的bsp源代碼
?? C
字號:
/* isaDma.c - DMA Controller Device (I8237) Utilities/Support Module *//* Copyright 1984-2001 Wind River Systems, Inc. *//* Copyright 1996,1997,1998 Motorola, Inc., All Rights Reserved *//*modification history--------------------01c,16sep01,dat  Use of WRS_ASM macro01b,15apr98,dat  added INCLUDE_ISADMA01a,12dec97,rbb  created by Motorola.*//*DESCRIPTIONThis module contains routines that support ISA DMA transfers.  The routinesprovided will initialize the DMA configuration, start and stop DMA transfersand return the status of an ISA DMA transfer.This module is normally included as a source module.  The macro INCLUDE_ISADMAmust be defined if any code is to be compiled.Notes:1. These routines assume that a dual i8237 DMA controller device   is present (e.g., I82378ZB, W83C553F).*//* includes */#include "vxWorks.h"#include "i8237.h"#include "config.h"#ifdef INCLUDE_ISADMA	/* do nothing if not defined *//* defines */#ifndef EIEIO_SYNC# define EIEIO_SYNC  WRS_ASM(" eieio; sync")#endif  /* EIEIO_SYNC */#define I8237_BASE_ADDRESS	CPU_PCI_ISA_IO_ADRS#define PCIV_PCIMPU_RAM_OFFSET	PCI2DRAM_BASE_ADRS/* typedefs *//* globals *//* forward declarations */extern void isaDmaInit();	/* initialize DMA (global configuration) */extern void isaDmaStart();	/* initialize DMA channel for transfer */extern void isaDmaStop();	/* disable DMA channel */extern UINT isaDmaStatus();	/* query DMA channel for transfer status *//* externals *//********************************************************************************* isaDmaInit - DMA controller initialization** This function's purpose is to initialize the dual DMA controller* device to a sane state.  This initialization is from a global* configuration standpoint, and needs only to be performed once.** RETURNS: N/A*/void isaDmaInit (void)    {    register UINT channel;    register UINT rvalue1, rvalue2;    register I8237_DMA1 *pDma1;    register I8237_DMA2 *pDma2;    /* setup pointers to the DMA controller devices */    pDma1 = (I8237_DMA1 *)(I8237_BASE_ADDRESS + I8237_DMA1_OFFSET);    pDma2 = (I8237_DMA2 *)(I8237_BASE_ADDRESS + I8237_DMA2_OFFSET);    /* perform a H/W reset of the devices */    pDma1->mc = 0x00;     EIEIO_SYNC;    pDma2->mc = 0x00;     EIEIO_SYNC;    /* initialize all channels to a sane state */    for (channel = 0; channel < 4; channel++) 	{        /*         * dependent upon the channel, setup the specifics:         *         * demand         * address-increment         * autoinitialize-disable         * read-transfer         */	switch (channel) 	    {	    case 0:		rvalue1 =		(I8237_MODE_TM_DEMAND|I8237_MODE_CH0SEL|I8237_MODE_TT_READ);		rvalue2 =		(I8237_MODE_TM_CASCADE|I8237_MODE_CH0SEL);		break;	    case 1:	        rvalue1 =	        (I8237_MODE_TM_DEMAND|I8237_MODE_CH1SEL|I8237_MODE_TT_READ);	        rvalue2 =	        (I8237_MODE_TM_DEMAND|I8237_MODE_CH1SEL|I8237_MODE_TT_READ);	        break;	    case 2:	        rvalue1 =	        (I8237_MODE_TM_DEMAND|I8237_MODE_CH2SEL|I8237_MODE_TT_READ);	        rvalue2 =	        (I8237_MODE_TM_DEMAND|I8237_MODE_CH2SEL|I8237_MODE_TT_READ);	        break;	    case 3:	        rvalue1 =	        (I8237_MODE_TM_DEMAND|I8237_MODE_CH2SEL|I8237_MODE_TT_READ);	        rvalue2 =	        (I8237_MODE_TM_DEMAND|I8237_MODE_CH2SEL|I8237_MODE_TT_READ);	        break;	    default:	        rvalue1 = 0x00;	        rvalue2 = 0x00;	        break;	    }	/* write to write mode registers */	pDma1->wm = rvalue1; 	EIEIO_SYNC;	pDma2->wm = rvalue2; 	EIEIO_SYNC;	}    /* enable all channels */    pDma1->cm = 0x00;     EIEIO_SYNC;    pDma2->cm = 0x00;     EIEIO_SYNC;   /*    * initialize the global DMA configuration    *    * DACK# active low    * DREQ active high    * fixed priority    * channel group enable    */    pDma1->cs = 0x00;     EIEIO_SYNC;    pDma2->cs = 0x00;     EIEIO_SYNC;    }/********************************************************************************* isaDmaStart - start DMA transfer** This function's purpose is to initialize the specified DMA* channel for a DMA transfer.** RETURNS: N/A*/void isaDmaStart    (    register UINT dmaChannelNumber,		/* DMA channel number (0 - 7) */    register UINT dmaTransferMode,		/* DMA transfer mode */    register UINT dmaTransferType,		/* DMA transfer type */    register UINT address,			/* address */    register UINT nBytes			/* number of bytes */    )    {    register UINT rvalue;    register UINT channelNumber;    register I8237_DMA1 *pDma1;    register I8237_DMA2 *pDma2;    register I8237_PAGE *pPage;    register I8237_HIGHPAGE *pHigh;    /* setup pointers to the DMA controller devices */        pDma1 = (I8237_DMA1 *)(I8237_BASE_ADDRESS + I8237_DMA1_OFFSET);    pDma2 = (I8237_DMA2 *)(I8237_BASE_ADDRESS + I8237_DMA2_OFFSET);    pPage = (I8237_PAGE *)(I8237_BASE_ADDRESS + I8237_PAGE_OFFSET);    pHigh = (I8237_HIGHPAGE *)(I8237_BASE_ADDRESS + I8237_HIGH_OFFSET);    /*     * create DMA address (PCI/ISA to system memory)     * create physical i8237 channel number     * number of programmed bytes is less one than the transfer     */    address |= PCIV_PCIMPU_RAM_OFFSET;    channelNumber = dmaChannelNumber & 0x3;    nBytes--;    /*     * disable channel for DMA transfer initialization     * setup the address of the transfer     */    if (dmaChannelNumber < 4) 	{        /* disable the selected channel */        pDma1->wsmb = (I8237_WSMB_CHMASKSEL | channelNumber); 	EIEIO_SYNC;        /*         * initialize the address (A07-A00) of the transfer         * initialize the address (A15-A08) of the transfer         */        pDma1->cbp = 0x00; 	EIEIO_SYNC;        pDma1->bac[channelNumber].bca = (UCHAR)(address >> 0); 	EIEIO_SYNC;        pDma1->bac[channelNumber].bca = (UCHAR)(address >> 8); 	EIEIO_SYNC;        /* initialize the count of the transfer */        pDma1->cbp = 0x00; 	EIEIO_SYNC;        pDma1->bac[channelNumber].bcc = (UCHAR)(nBytes >> 0); 	EIEIO_SYNC;        pDma1->bac[channelNumber].bcc = (UCHAR)(nBytes >> 8); 	EIEIO_SYNC;	}     else 	{        /* disable the selected channel */        pDma2->wsmb = (I8237_WSMB_CHMASKSEL | channelNumber); 	EIEIO_SYNC;        /*         * initialize the address (A07-A00) of the transfer         * initialize the address (A15-A08) of the transfer         */        pDma2->cbp = 0x00; 	EIEIO_SYNC;        pDma2->bac[channelNumber].bca = (UCHAR)(address >> 0); 	EIEIO_SYNC;        pDma2->bac[channelNumber].bca = (UCHAR)(address >> 8); 	EIEIO_SYNC;        /* initialize the count of the transfer */        pDma2->cbp = 0x00; 	EIEIO_SYNC;        pDma2->bac[channelNumber].bcc = (UCHAR)(nBytes >> 0); 	EIEIO_SYNC;        pDma2->bac[channelNumber].bcc = (UCHAR)(nBytes >> 8); 	EIEIO_SYNC;	}    /*     * setup the address (A23-A16) of the transfer     * setup the address (A31-A24) of the transfer     */    switch (dmaChannelNumber) 	{	case 0:	    pPage->p_ch0 = (UCHAR)(address >> 16); 	    EIEIO_SYNC;	    pHigh->p_ch0 = (UCHAR)(address >> 24); 	    EIEIO_SYNC;	    break;	    case 1:	    pPage->p_ch1 = (UCHAR)(address >> 16); 	    EIEIO_SYNC;	    pHigh->p_ch1 = (UCHAR)(address >> 24); 	    EIEIO_SYNC;	    break;	case 2:	    pPage->p_ch2 = (UCHAR)(address >> 16); 	    EIEIO_SYNC;	    pHigh->p_ch2 = (UCHAR)(address >> 24); 	    EIEIO_SYNC;	    break;	case 3:	    pPage->p_ch3 = (UCHAR)(address >> 16); 	    EIEIO_SYNC;	    pHigh->p_ch3 = (UCHAR)(address >> 24); 	    EIEIO_SYNC;	    break;	case 5:	    pPage->p_ch5 = (UCHAR)(address >> 16); 	    EIEIO_SYNC;	    pHigh->p_ch5 = (UCHAR)(address >> 24); 	    EIEIO_SYNC;	    break;	case 6:	    pPage->p_ch6 = (UCHAR)(address >> 16); 	    EIEIO_SYNC;	    pHigh->p_ch6 = (UCHAR)(address >> 24); 	    EIEIO_SYNC;	    break;	case 7:	    pPage->p_ch7 = (UCHAR)(address >> 16); 	    EIEIO_SYNC;	    pHigh->p_ch7 = (UCHAR)(address >> 24); 	    EIEIO_SYNC;	    break;	}    /* initialize the transfer specifics (write mode register) */        switch (channelNumber) 	{	case 0:	    rvalue = dmaTransferMode | dmaTransferType | I8237_MODE_CH0SEL;	    break;	case 1:	    rvalue = dmaTransferMode | dmaTransferType | I8237_MODE_CH1SEL;	    break;	case 2:	    rvalue = dmaTransferMode | dmaTransferType | I8237_MODE_CH2SEL;	    break;	case 3:	    rvalue = dmaTransferMode | dmaTransferType | I8237_MODE_CH3SEL;	    break;	default:	    rvalue = 0x00;	    break;	}    /* enable channel for DMA transfer */       if (dmaChannelNumber < 4) 	{	pDma1->wm = rvalue; 	EIEIO_SYNC;	pDma1->wsmb = channelNumber; 	EIEIO_SYNC;        }    else 	{	pDma2->wm = rvalue; 	EIEIO_SYNC;	pDma2->wsmb = channelNumber; 	EIEIO_SYNC;	}    }/********************************************************************************* isaDmaStop - Stop DMA transfer** This functions purpose is to disable (stop) the specified DMA* channel for a DMA transfer.** RETURNS: N/A*/void isaDmaStop    (    register UINT dmaChannelNumber	/* DMA channel number (0 - 7) */    )    {    register UINT channelNumber;    register I8237_DMA1 *pDma1;    register I8237_DMA2 *pDma2;    /* setup pointers to the DMA controller devices */    pDma1 = (I8237_DMA1 *)(I8237_BASE_ADDRESS + I8237_DMA1_OFFSET);    pDma2 = (I8237_DMA2 *)(I8237_BASE_ADDRESS + I8237_DMA2_OFFSET);    /* create physical i8237 channel number */    channelNumber = dmaChannelNumber & 0x3;    /* disable channel */    if (dmaChannelNumber < 4) 	{        pDma1->wsmb = (I8237_WSMB_CHMASKSEL | channelNumber); 	EIEIO_SYNC;        }     else 	{        pDma2->wsmb = (I8237_WSMB_CHMASKSEL | channelNumber); 	EIEIO_SYNC;        }    }/********************************************************************************* isaDmaStatus - get DMA transfer status** This function's purpose is to query the specified DMA channel* for DMA transfer status.  And to return this status in a* logical format (see values below).** RETURNS: DMA Transfer Status*  	   0: Request=0, TerminalCount=0*	   1: Request=0, TerminalCount=1*	   2: Request=1, TerminalCount=0*	   3: Request=1, TerminalCount=1*/UINT isaDmaStatus    (    register UINT dmaChannelNumber	/* DMA channel number (0 - 7) */    )    {    register UINT rvalue, svalue;    register UINT channelNumber;    register I8237_DMA1 *pDma1;    register I8237_DMA2 *pDma2;    /* setup pointers to the DMA controller devices */    pDma1 = (I8237_DMA1 *)(I8237_BASE_ADDRESS + I8237_DMA1_OFFSET);    pDma2 = (I8237_DMA2 *)(I8237_BASE_ADDRESS + I8237_DMA2_OFFSET);    /* create physical i8237 channel number */     channelNumber = dmaChannelNumber & 0x3;    /* read DMA status register */      if (dmaChannelNumber < 4)         {        rvalue = pDma1->cs; 	EIEIO_SYNC;        }     else         {        rvalue = pDma2->cs; 	EIEIO_SYNC;        }    /* mask off unwanted channels' status */       rvalue &= ((0x10 << channelNumber) | (0x01 << channelNumber));    /* convert to logical status */        svalue = 0;    if (rvalue & 0xF0) 	{ 	svalue |= 0x2; 	}    if (rvalue & 0x0F) 	{ 	svalue |= 0x1; 	}    return (svalue);}#endif /* INCLUDE_ISADMA */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩国产一区二| 亚洲国产精品精华液ab| 欧美日韩视频在线一区二区| 激情五月激情综合网| 欧美午夜片在线看| 日韩精品免费视频人成| 日韩欧美激情在线| 国产伦精品一区二区三区视频青涩| 成人爽a毛片一区二区免费| 国产精品久久久久久久久免费樱桃 | 久久噜噜亚洲综合| 国产精品一区二区男女羞羞无遮挡 | 亚洲人成小说网站色在线| 色综合天天做天天爱| 日韩精品一卡二卡三卡四卡无卡| 色域天天综合网| 天天影视网天天综合色在线播放| 99久久久久久| 午夜影视日本亚洲欧洲精品| 欧美不卡激情三级在线观看| 成人一级黄色片| 亚洲成人精品影院| 久久综合久久鬼色中文字| 99精品欧美一区二区三区小说| 久久久久久久综合色一本| 91视频观看免费| 免费成人结看片| 中文字幕亚洲精品在线观看| 51午夜精品国产| 午夜久久福利影院| 日本一区二区三区久久久久久久久不 | 亚洲精品免费看| 日韩欧美色综合| 成+人+亚洲+综合天堂| 天堂va蜜桃一区二区三区| 国产视频一区在线播放| 欧美无人高清视频在线观看| 亚洲夂夂婷婷色拍ww47| 久久久国产精华| 4hu四虎永久在线影院成人| 成人av免费在线| 麻豆精品一区二区av白丝在线| 91精品欧美一区二区三区综合在| 亚洲mv在线观看| 国产精品毛片大码女人| 欧美一区二区不卡视频| 久久精品国产在热久久| 一区二区三区欧美激情| 国产女人18水真多18精品一级做| 国产精品18久久久久久久网站| xnxx国产精品| 成人黄色av电影| 久久精品av麻豆的观看方式| 一区二区三区四区五区视频在线观看| 欧洲精品视频在线观看| 亚洲午夜一区二区| 日韩三级视频中文字幕| 欧美色涩在线第一页| av电影在线观看不卡| 国产成人欧美日韩在线电影| 久久国产尿小便嘘嘘| 亚洲chinese男男1069| 一区二区欧美在线观看| 91精品国产入口在线| 欧美偷拍一区二区| 99精品视频在线播放观看| 亚洲国产成人tv| 尤物av一区二区| 亚洲欧美日本在线| 亚洲欧美日本韩国| 亚洲精品成人在线| 亚洲精品美国一| 欧美变态tickling挠脚心| 欧美精品xxxxbbbb| 欧美精品粉嫩高潮一区二区| 欧美日本视频在线| 欧美久久久久免费| 成人开心网精品视频| 成人网在线播放| 国产成人一区在线| 日本欧美一区二区三区| 免费人成精品欧美精品| 麻豆国产欧美日韩综合精品二区| 国产精品无遮挡| 中文字幕一区二区三区四区不卡 | 中文字幕一区二区三区不卡| 欧美日韩亚洲另类| 成人一区二区三区| 91丝袜国产在线播放| 日本高清视频一区二区| 欧美日韩国产首页在线观看| 欧美久久一二三四区| 精品国产乱码久久| 欧美色图一区二区三区| 欧美喷水一区二区| 精品电影一区二区三区| 国产午夜三级一区二区三| 中文字幕一区三区| 国产欧美日韩亚州综合| 日韩一区二区在线观看| 91精品1区2区| 欧美伦理电影网| 色香蕉久久蜜桃| 成人一级视频在线观看| 国产在线一区观看| av在线不卡网| 欧美一二三区精品| 国产精品免费视频网站| 久久久久久久久伊人| 亚洲人成亚洲人成在线观看图片 | 99re这里只有精品6| 欧美日韩视频专区在线播放| 91首页免费视频| 91精品国产一区二区三区| 欧美色视频在线| 精品av综合导航| 亚洲精品一卡二卡| 免费欧美日韩国产三级电影| 99久久久国产精品| 欧美一区国产二区| 国产精品久久福利| 奇米777欧美一区二区| 成人av资源站| 日韩亚洲欧美在线观看| 中文字幕亚洲综合久久菠萝蜜| 欧美国产精品一区| 日韩国产一区二| 日韩一区精品字幕| 91亚洲精品久久久蜜桃| 日韩视频在线永久播放| 一区av在线播放| 国产a视频精品免费观看| 91精品免费观看| 欧美一级爆毛片| 洋洋成人永久网站入口| 亚洲不卡一区二区三区| 性做久久久久久免费观看欧美| 五月婷婷综合网| 成人91在线观看| www日韩大片| 日韩影视精彩在线| 欧美亚洲一区三区| 91精品国产91综合久久蜜臀| 日韩一区二区三区精品视频| 一区二区三区欧美亚洲| 不卡视频在线观看| 国产偷国产偷精品高清尤物| 日韩影院在线观看| 欧美日韩美少妇| 亚洲午夜精品在线| 91免费版在线| 欧美一区二区三区四区视频| 亚洲欧美日韩国产中文在线| 亚洲va国产天堂va久久en| 久久成人免费日本黄色| 99视频精品免费视频| 欧美激情中文不卡| 亚洲国产视频网站| 99久久国产综合精品女不卡| 中文子幕无线码一区tr| 国产精品99久久久久久久vr | 欧美日韩久久久一区| 精品久久久久av影院| 日韩影院免费视频| 欧美日韩精品专区| 天天做天天摸天天爽国产一区| 国产在线精品一区二区夜色| 日韩一级免费一区| 激情文学综合插| ww亚洲ww在线观看国产| 国产高清不卡一区| 在线中文字幕一区二区| 亚洲午夜三级在线| 欧美精品1区2区3区| 轻轻草成人在线| 欧美电视剧在线看免费| 亚洲欧美一区二区三区国产精品| 奇米777欧美一区二区| av亚洲精华国产精华精华 | 日本va欧美va欧美va精品| 欧美精选午夜久久久乱码6080| 中文字幕免费一区| 婷婷久久综合九色国产成人| 欧美疯狂做受xxxx富婆| 日韩精品一二三区| 精品久久久久久久久久久久久久久| 亚洲激情在线激情| 欧美另类久久久品| 亚洲欧美日韩电影| 欧美电影一区二区三区| 久久99热国产| 欧美激情综合网| 国产精品资源站在线| 制服丝袜中文字幕一区| 极品少妇一区二区三区精品视频 | 欧美日韩一区二区三区在线| 日韩成人av影视| 欧美极品xxx| 欧美日韩一区二区三区在线| 精品在线亚洲视频|