-/* $Id$ */\r
-/*\r
- * Copyright (c) 2005 Arched Rock Corporation \r
- * All rights reserved. \r
- * Redistribution and use in source and binary forms, with or without\r
- * modification, are permitted provided that the following conditions are\r
- * met:\r
- * Redistributions of source code must retain the above copyright\r
- * notice, this list of conditions and the following disclaimer.\r
- * Redistributions in binary form must reproduce the above copyright\r
- * notice, this list of conditions and the following disclaimer in the\r
- * documentation and/or other materials provided with the distribution.\r
- * \r
- * Neither the name of the Arched Rock Corporation nor the names of its\r
- * contributors may be used to endorse or promote products derived from\r
- * this software without specific prior written permission.\r
- *\r
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS\r
- * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT\r
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR\r
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE ARCHED\r
- * ROCK OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,\r
- * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,\r
- * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS\r
- * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND\r
- * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR\r
- * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE\r
- * USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH\r
- * DAMAGE.\r
- */\r
-/**\r
- * \r
- * @author Phil Buonadonna\r
- */\r
-module HplPXA27xDMAM\r
-{\r
- provides {\r
- interface Init;\r
- interface HplPXA27xDMACntl;\r
- interface HplPXA27xDMAChnl[uint8_t chnl];\r
- }\r
- uses {\r
- interface HplPXA27xInterrupt as DMAIrq;\r
- }\r
-}\r
-\r
-implementation\r
-{\r
- \r
- command error_t Init.init() {\r
- call DMAIrq.allocate();\r
- call DMAIrq.enable();\r
- return SUCCESS;\r
- }\r
- \r
- async command void HplPXA27xDMACntl.setDRCMR(uint8_t peripheral, uint8_t val) {\r
- DRCMR(peripheral) = val;\r
- }\r
- async command uint8_t HplPXA27xDMACntl.getDRCMR(uint8_t peripheral) { return DRCMR(peripheral);}\r
- async command void HplPXA27xDMACntl.setDALGN(uint32_t val) {DALGN = val;}\r
- async command uint32_t HplPXA27xDMACntl.getDALGN(uint32_t val) {return DALGN; }\r
- async command void HplPXA27xDMACntl.setDPCSR(uint32_t val) {DPCSR = val; }\r
- async command uint32_t HplPXA27xDMACntl.getDPSCR() {return DPCSR; }\r
- async command void HplPXA27xDMACntl.setDRQSR0(uint32_t val) {DRQSR0 = val; }\r
- async command uint32_t HplPXA27xDMACntl.getDRQSR0() {return DRQSR0; }\r
- async command void HplPXA27xDMACntl.setDRQSR1(uint32_t val) {DRQSR1 = val; }\r
- async command uint32_t HplPXA27xDMACntl.getDRQSR1() {return DRQSR1; }\r
- async command void HplPXA27xDMACntl.setDRQSR2(uint32_t val) {DRQSR2 = val; }\r
- async command uint32_t HplPXA27xDMACntl.getDRQSR2() {return DRQSR2; }\r
- async command uint32_t HplPXA27xDMACntl.getDINT() {return DINT; }\r
- async command void HplPXA27xDMACntl.setFLYCNFG(uint32_t val) {FLYCNFG = val; }\r
- async command uint32_t HplPXA27xDMACntl.getFLYCNFG() {return FLYCNFG; }\r
-\r
- \r
- async command error_t HplPXA27xDMAChnl.setMap[uint8_t chnl](uint8_t dev) {\r
- call HplPXA27xDMACntl.setDRCMR(dev,(DRCMR_MAPVLD | DRCMR_CHLNUM(chnl)));\r
- return SUCCESS;\r
- }\r
- async command void HplPXA27xDMAChnl.setDALGNbit[uint8_t chnl](bool flag) {\r
- if (flag) {\r
- DALGN |= (1 << chnl);\r
- }\r
- else {\r
- DALGN &= ~(1 << chnl);\r
- }\r
- return;\r
- }\r
- async command bool HplPXA27xDMAChnl.getDALGNbit[uint8_t chnl]() {\r
- return ((DALGN & (1 << chnl)) != 0);\r
- }\r
- async command bool HplPXA27xDMAChnl.getDINTbit[uint8_t chnl]() {\r
- return ((DINT & (1 << chnl)) != 0);\r
- }\r
- async command void HplPXA27xDMAChnl.setDCSR[uint8_t chnl](uint32_t val) {\r
- // uint32_t cycles;\r
- //_pxa27x_perf_clear();\r
- DCSR(chnl) = val;\r
- //_pxa27x_perf_get(cycles);\r
- }\r
- async command uint32_t HplPXA27xDMAChnl.getDCSR[uint8_t chnl]() {return DCSR(chnl); }\r
- async command void HplPXA27xDMAChnl.setDCMD[uint8_t chnl](uint32_t val) {DCMD(chnl) = val; }\r
- async command uint32_t HplPXA27xDMAChnl.getDCMD[uint8_t chnl]() {return DCMD(chnl); }\r
- async command void HplPXA27xDMAChnl.setDDADR[uint8_t chnl](uint32_t val) {DDADR(chnl) = val; }\r
- async command uint32_t HplPXA27xDMAChnl.getDDADR[uint8_t chnl]() {return DDADR(chnl); }\r
- async command void HplPXA27xDMAChnl.setDSADR[uint8_t chnl](uint32_t val) {DSADR(chnl) = val; }\r
- async command uint32_t HplPXA27xDMAChnl.getDSADR[uint8_t chnl]() {return DSADR(chnl); }\r
- async command void HplPXA27xDMAChnl.setDTADR[uint8_t chnl](uint32_t val) {DTADR(chnl) = val; }\r
- async command uint32_t HplPXA27xDMAChnl.getDTADR[uint8_t chnl]() {return DTADR(chnl); }\r
-\r
- async event void DMAIrq.fired() {\r
- uint32_t IntReg;\r
- uint8_t chnl;\r
- IntReg = call HplPXA27xDMACntl.getDINT();\r
-\r
- while (IntReg) {\r
- chnl = 31 - _pxa27x_clzui(IntReg);\r
- signal HplPXA27xDMAChnl.interruptDMA[chnl]();\r
- IntReg &= ~(1 << chnl);\r
- }\r
- return;\r
- }\r
-\r
- default async event void HplPXA27xDMAChnl.interruptDMA[uint8_t chnl]() {\r
- call HplPXA27xDMAChnl.setDCMD[chnl](0);\r
- call HplPXA27xDMAChnl.setDCSR[chnl](DCSR_EORINT | DCSR_ENDINTR\r
- | DCSR_STARTINTR | DCSR_BUSERRINTR);\r
- }\r
-}\r
+/* $Id$ */
+/*
+ * 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);
+ }
+}