hplpxa27xdmam.nc
来自「tinyos-2.0源代码!转载而已!要的尽管拿!」· NC 代码 · 共 129 行
NC
129 行
/* $Id: HplPXA27xDMAM.nc,v 1.1.2.2 2005/12/30 19:55:24 philipb Exp $ */
/*
* Copyright (c) 2005 Arched Rock Corporation
* All rights reserved.
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
* Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* Neither the name of the Arched Rock Corporation nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE ARCHED
* ROCK OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
* TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
* USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
* DAMAGE.
*/
/**
*
* @author Phil Buonadonna
*/
module HplPXA27xDMAM
{
provides {
interface Init;
interface HplPXA27xDMACntl;
interface HplPXA27xDMAChnl[uint8_t chnl];
}
uses {
interface HplPXA27xInterrupt as DMAIrq;
}
}
implementation
{
command error_t Init.init() {
call DMAIrq.allocate();
call DMAIrq.enable();
return SUCCESS;
}
async command void HplPXA27xDMACntl.setDRCMR(uint8_t peripheral, uint8_t val) {
DRCMR(peripheral) = val;
}
async command uint8_t HplPXA27xDMACntl.getDRCMR(uint8_t peripheral) { return DRCMR(peripheral);}
async command void HplPXA27xDMACntl.setDALGN(uint32_t val) {DALGN = val;}
async command uint32_t HplPXA27xDMACntl.getDALGN(uint32_t val) {return DALGN; }
async command void HplPXA27xDMACntl.setDPCSR(uint32_t val) {DPCSR = val; }
async command uint32_t HplPXA27xDMACntl.getDPSCR() {return DPCSR; }
async command void HplPXA27xDMACntl.setDRQSR0(uint32_t val) {DRQSR0 = val; }
async command uint32_t HplPXA27xDMACntl.getDRQSR0() {return DRQSR0; }
async command void HplPXA27xDMACntl.setDRQSR1(uint32_t val) {DRQSR1 = val; }
async command uint32_t HplPXA27xDMACntl.getDRQSR1() {return DRQSR1; }
async command void HplPXA27xDMACntl.setDRQSR2(uint32_t val) {DRQSR2 = val; }
async command uint32_t HplPXA27xDMACntl.getDRQSR2() {return DRQSR2; }
async command uint32_t HplPXA27xDMACntl.getDINT() {return DINT; }
async command void HplPXA27xDMACntl.setFLYCNFG(uint32_t val) {FLYCNFG = val; }
async command uint32_t HplPXA27xDMACntl.getFLYCNFG() {return FLYCNFG; }
async command error_t HplPXA27xDMAChnl.setMap[uint8_t chnl](uint8_t dev) {
call HplPXA27xDMACntl.setDRCMR(dev,(DRCMR_MAPVLD | DRCMR_CHLNUM(chnl)));
return SUCCESS;
}
async command void HplPXA27xDMAChnl.setDALGNbit[uint8_t chnl](bool flag) {
if (flag) {
DALGN |= (1 << chnl);
}
else {
DALGN &= ~(1 << chnl);
}
return;
}
async command bool HplPXA27xDMAChnl.getDALGNbit[uint8_t chnl]() {
return ((DALGN & (1 << chnl)) != 0);
}
async command bool HplPXA27xDMAChnl.getDINTbit[uint8_t chnl]() {
return ((DINT & (1 << chnl)) != 0);
}
async command void HplPXA27xDMAChnl.setDCSR[uint8_t chnl](uint32_t val) {
// uint32_t cycles;
//_pxa27x_perf_clear();
DCSR(chnl) = val;
//_pxa27x_perf_get(cycles);
}
async command uint32_t HplPXA27xDMAChnl.getDCSR[uint8_t chnl]() {return DCSR(chnl); }
async command void HplPXA27xDMAChnl.setDCMD[uint8_t chnl](uint32_t val) {DCMD(chnl) = val; }
async command uint32_t HplPXA27xDMAChnl.getDCMD[uint8_t chnl]() {return DCMD(chnl); }
async command void HplPXA27xDMAChnl.setDDADR[uint8_t chnl](uint32_t val) {DDADR(chnl) = val; }
async command uint32_t HplPXA27xDMAChnl.getDDADR[uint8_t chnl]() {return DDADR(chnl); }
async command void HplPXA27xDMAChnl.setDSADR[uint8_t chnl](uint32_t val) {DSADR(chnl) = val; }
async command uint32_t HplPXA27xDMAChnl.getDSADR[uint8_t chnl]() {return DSADR(chnl); }
async command void HplPXA27xDMAChnl.setDTADR[uint8_t chnl](uint32_t val) {DTADR(chnl) = val; }
async command uint32_t HplPXA27xDMAChnl.getDTADR[uint8_t chnl]() {return DTADR(chnl); }
async event void DMAIrq.fired() {
uint32_t IntReg;
uint8_t chnl;
IntReg = call HplPXA27xDMACntl.getDINT();
while (IntReg) {
chnl = 31 - _pxa27x_clzui(IntReg);
signal HplPXA27xDMAChnl.interruptDMA[chnl]();
IntReg &= ~(1 << chnl);
}
return;
}
default async event void HplPXA27xDMAChnl.interruptDMA[uint8_t chnl]() {
call HplPXA27xDMAChnl.setDCMD[chnl](0);
call HplPXA27xDMAChnl.setDCSR[chnl](DCSR_EORINT | DCSR_ENDINTR
| DCSR_STARTINTR | DCSR_BUSERRINTR);
}
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?