-/* $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
-\r
-module HplPXA27xSSPP \r
-{\r
- provides {\r
- interface Init[uint8_t chnl];\r
- interface HplPXA27xSSP[uint8_t chnl];\r
- }\r
- uses {\r
- interface HplPXA27xInterrupt as SSP1Irq;\r
- interface HplPXA27xInterrupt as SSP2Irq;\r
- interface HplPXA27xInterrupt as SSP3Irq;\r
- }\r
-}\r
-\r
-implementation \r
-{\r
-\r
- command error_t Init.init[uint8_t chnl]() {\r
- error_t error = SUCCESS;\r
- \r
- switch (chnl) {\r
- case 1:\r
- CKEN |= CKEN23_SSP1;\r
- call SSP1Irq.enable(); \r
- break;\r
- case 2: \r
- CKEN |= CKEN3_SSP2;\r
- call SSP2Irq.enable(); \r
- break;\r
- case 3: \r
- CKEN |= CKEN4_SSP3;\r
- //call SSP3Irq.allocate();\r
- call SSP3Irq.enable(); \r
- break;\r
- default: \r
- error = FAIL;\r
- break;\r
- }\r
-\r
- return error;\r
- }\r
-\r
- async command void HplPXA27xSSP.setSSCR0[uint8_t chnl](uint32_t val) {\r
- switch (chnl) {\r
- case 1: SSCR0_1 = val; break;\r
- case 2: SSCR0_2 = val; break;\r
- case 3: SSCR0_3 = val; break;\r
- default: break;\r
- }\r
- return;\r
- }\r
-\r
- async command uint32_t HplPXA27xSSP.getSSCR0[uint8_t chnl]() {\r
- switch (chnl) {\r
- case 1: return SSCR0_1; break;\r
- case 2: return SSCR0_2; break;\r
- case 3: return SSCR0_3; break;\r
- default: return 0;\r
- }\r
- }\r
-\r
- async command void HplPXA27xSSP.setSSCR1[uint8_t chnl](uint32_t val) {\r
- switch (chnl) {\r
- case 1: SSCR1_1 = val; break;\r
- case 2: SSCR1_2 = val; break;\r
- case 3: SSCR1_3 = val; break;\r
- default: break;\r
- }\r
- return;\r
- }\r
- async command uint32_t HplPXA27xSSP.getSSCR1[uint8_t chnl]() {\r
- switch (chnl) {\r
- case 1: return SSCR1_1; break;\r
- case 2: return SSCR1_2; break;\r
- case 3: return SSCR1_3; break;\r
- default: return 0;\r
- }\r
- }\r
- \r
- async command void HplPXA27xSSP.setSSSR[uint8_t chnl](uint32_t val) {\r
- switch (chnl) {\r
- case 1: SSSR_1 = val; break;\r
- case 2: SSSR_2 = val; break;\r
- case 3: SSSR_3 = val; break;\r
- default: break;\r
- }\r
- return;\r
- }\r
- async command uint32_t HplPXA27xSSP.getSSSR[uint8_t chnl]() {\r
- switch (chnl) {\r
- case 1: return SSSR_1; break;\r
- case 2: return SSSR_2; break;\r
- case 3: return SSSR_3; break;\r
- default: return 0;\r
- }\r
- }\r
-\r
- async command void HplPXA27xSSP.setSSITR[uint8_t chnl](uint32_t val) {\r
- switch (chnl) {\r
- case 1: SSITR_1 = val; break;\r
- case 2: SSITR_2 = val; break;\r
- case 3: SSITR_3 = val; break;\r
- default: break;\r
- }\r
- return;\r
- }\r
- async command uint32_t HplPXA27xSSP.getSSITR[uint8_t chnl]() {\r
- switch (chnl) {\r
- case 1: return SSITR_1; break;\r
- case 2: return SSITR_2; break;\r
- case 3: return SSITR_3; break;\r
- default: return 0;\r
- }\r
- }\r
-\r
- async command void HplPXA27xSSP.setSSDR[uint8_t chnl](uint32_t val) {\r
- switch (chnl) {\r
- case 1: SSDR_1 = val; break;\r
- case 2: SSDR_2 = val; break;\r
- case 3: SSDR_3 = val; break;\r
- default: break;\r
- }\r
- return;\r
- }\r
- async command uint32_t HplPXA27xSSP.getSSDR[uint8_t chnl]() {\r
- switch (chnl) {\r
- case 1: return SSDR_1; break;\r
- case 2: return SSDR_2; break;\r
- case 3: return SSDR_3; break;\r
- default: return 0;\r
- }\r
- }\r
-\r
- async command void HplPXA27xSSP.setSSTO[uint8_t chnl](uint32_t val) {\r
- switch (chnl) {\r
- case 1: SSTO_1 = val; break;\r
- case 2: SSTO_2 = val; break;\r
- case 3: SSTO_3 = val; break;\r
- default: break;\r
- }\r
- return;\r
- }\r
- async command uint32_t HplPXA27xSSP.getSSTO[uint8_t chnl]() {\r
- switch (chnl) {\r
- case 1: return SSTO_1; break;\r
- case 2: return SSTO_2; break;\r
- case 3: return SSTO_3; break;\r
- default: return 0;\r
- }\r
- }\r
-\r
- async command void HplPXA27xSSP.setSSPSP[uint8_t chnl](uint32_t val) {\r
- switch (chnl) {\r
- case 1: SSPSP_1 = val; break;\r
- case 2: SSPSP_2 = val; break;\r
- case 3: SSPSP_3 = val; break;\r
- default: break;\r
- }\r
- return;\r
- }\r
- async command uint32_t HplPXA27xSSP.getSSPSP[uint8_t chnl]() {\r
- switch (chnl) {\r
- case 1: return SSPSP_1; break;\r
- case 2: return SSPSP_2; break;\r
- case 3: return SSPSP_3; break;\r
- default: return 0;\r
- }\r
- }\r
-\r
- async command void HplPXA27xSSP.setSSTSA[uint8_t chnl](uint32_t val) {\r
- switch (chnl) {\r
- case 1: SSTSA_1 = val; break;\r
- case 2: SSTSA_2 = val; break;\r
- case 3: SSTSA_3 = val; break;\r
- default: break;\r
- }\r
- return;\r
- }\r
- async command uint32_t HplPXA27xSSP.getSSTSA[uint8_t chnl]() {\r
- switch (chnl) {\r
- case 1: return SSTSA_1; break;\r
- case 2: return SSTSA_2; break;\r
- case 3: return SSTSA_3; break;\r
- default: return 0;\r
- }\r
- }\r
-\r
- async command void HplPXA27xSSP.setSSRSA[uint8_t chnl](uint32_t val) {\r
- switch (chnl) {\r
- case 1: SSRSA_1 = val; break;\r
- case 2: SSRSA_2 = val; break;\r
- case 3: SSRSA_3 = val; break;\r
- default: break;\r
- }\r
- return;\r
- }\r
- async command uint32_t HplPXA27xSSP.getSSRSA[uint8_t chnl]() {\r
- switch (chnl) {\r
- case 1: return SSRSA_1; break;\r
- case 2: return SSRSA_2; break;\r
- case 3: return SSRSA_3; break;\r
- default: return 0;\r
- }\r
- }\r
-\r
- async command void HplPXA27xSSP.setSSTSS[uint8_t chnl](uint32_t val) {\r
- switch (chnl) {\r
- case 1: SSTSS_1 = val; break;\r
- case 2: SSTSS_2 = val; break;\r
- case 3: SSTSS_3 = val; break;\r
- default: break;\r
- }\r
- return;\r
- }\r
- async command uint32_t HplPXA27xSSP.getSSTSS[uint8_t chnl]() {\r
- switch (chnl) {\r
- case 1: return SSTSS_1; break;\r
- case 2: return SSTSS_2; break;\r
- case 3: return SSTSS_3; break;\r
- default: return 0;\r
- }\r
- }\r
-\r
- async command void HplPXA27xSSP.setSSACD[uint8_t chnl](uint32_t val) {\r
- switch (chnl) {\r
- case 1: SSACD_1 = val; break;\r
- case 2: SSACD_2 = val; break;\r
- case 3: SSACD_3 = val; break;\r
- default: break;\r
- }\r
- return; \r
- }\r
- async command uint32_t HplPXA27xSSP.getSSACD[uint8_t chnl]() {\r
- switch (chnl) {\r
- case 1: return SSACD_1; break;\r
- case 2: return SSACD_2; break;\r
- case 3: return SSACD_3; break;\r
- default: return 0;\r
- }\r
- }\r
-\r
- default async event void HplPXA27xSSP.interruptSSP[uint8_t chnl]() {\r
- call HplPXA27xSSP.setSSSR[chnl](SSSR_BCE | SSSR_TUR | SSSR_EOC | SSSR_TINT | \r
- SSSR_PINT | SSSR_ROR );\r
- return;\r
- }\r
-\r
- async event void SSP1Irq.fired() {\r
- signal HplPXA27xSSP.interruptSSP[1]();\r
- }\r
- async event void SSP2Irq.fired() {\r
- signal HplPXA27xSSP.interruptSSP[2]();\r
- }\r
- async event void SSP3Irq.fired() {\r
- signal HplPXA27xSSP.interruptSSP[3]();\r
- }\r
-\r
- default async command void SSP1Irq.enable() {return;}\r
- default async command void SSP2Irq.enable() {return;}\r
- default async command void SSP3Irq.enable() {return;}\r
-\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 HplPXA27xSSPP
+{
+ provides {
+ interface Init[uint8_t chnl];
+ interface HplPXA27xSSP[uint8_t chnl];
+ }
+ uses {
+ interface HplPXA27xInterrupt as SSP1Irq;
+ interface HplPXA27xInterrupt as SSP2Irq;
+ interface HplPXA27xInterrupt as SSP3Irq;
+ }
+}
+
+implementation
+{
+
+ command error_t Init.init[uint8_t chnl]() {
+ error_t error = SUCCESS;
+
+ switch (chnl) {
+ case 1:
+ CKEN |= CKEN23_SSP1;
+ call SSP1Irq.enable();
+ break;
+ case 2:
+ CKEN |= CKEN3_SSP2;
+ call SSP2Irq.enable();
+ break;
+ case 3:
+ CKEN |= CKEN4_SSP3;
+ //call SSP3Irq.allocate();
+ call SSP3Irq.enable();
+ break;
+ default:
+ error = FAIL;
+ break;
+ }
+
+ return error;
+ }
+
+ async command void HplPXA27xSSP.setSSCR0[uint8_t chnl](uint32_t val) {
+ switch (chnl) {
+ case 1: SSCR0_1 = val; break;
+ case 2: SSCR0_2 = val; break;
+ case 3: SSCR0_3 = val; break;
+ default: break;
+ }
+ return;
+ }
+
+ async command uint32_t HplPXA27xSSP.getSSCR0[uint8_t chnl]() {
+ switch (chnl) {
+ case 1: return SSCR0_1; break;
+ case 2: return SSCR0_2; break;
+ case 3: return SSCR0_3; break;
+ default: return 0;
+ }
+ }
+
+ async command void HplPXA27xSSP.setSSCR1[uint8_t chnl](uint32_t val) {
+ switch (chnl) {
+ case 1: SSCR1_1 = val; break;
+ case 2: SSCR1_2 = val; break;
+ case 3: SSCR1_3 = val; break;
+ default: break;
+ }
+ return;
+ }
+ async command uint32_t HplPXA27xSSP.getSSCR1[uint8_t chnl]() {
+ switch (chnl) {
+ case 1: return SSCR1_1; break;
+ case 2: return SSCR1_2; break;
+ case 3: return SSCR1_3; break;
+ default: return 0;
+ }
+ }
+
+ async command void HplPXA27xSSP.setSSSR[uint8_t chnl](uint32_t val) {
+ switch (chnl) {
+ case 1: SSSR_1 = val; break;
+ case 2: SSSR_2 = val; break;
+ case 3: SSSR_3 = val; break;
+ default: break;
+ }
+ return;
+ }
+ async command uint32_t HplPXA27xSSP.getSSSR[uint8_t chnl]() {
+ switch (chnl) {
+ case 1: return SSSR_1; break;
+ case 2: return SSSR_2; break;
+ case 3: return SSSR_3; break;
+ default: return 0;
+ }
+ }
+
+ async command void HplPXA27xSSP.setSSITR[uint8_t chnl](uint32_t val) {
+ switch (chnl) {
+ case 1: SSITR_1 = val; break;
+ case 2: SSITR_2 = val; break;
+ case 3: SSITR_3 = val; break;
+ default: break;
+ }
+ return;
+ }
+ async command uint32_t HplPXA27xSSP.getSSITR[uint8_t chnl]() {
+ switch (chnl) {
+ case 1: return SSITR_1; break;
+ case 2: return SSITR_2; break;
+ case 3: return SSITR_3; break;
+ default: return 0;
+ }
+ }
+
+ async command void HplPXA27xSSP.setSSDR[uint8_t chnl](uint32_t val) {
+ switch (chnl) {
+ case 1: SSDR_1 = val; break;
+ case 2: SSDR_2 = val; break;
+ case 3: SSDR_3 = val; break;
+ default: break;
+ }
+ return;
+ }
+ async command uint32_t HplPXA27xSSP.getSSDR[uint8_t chnl]() {
+ switch (chnl) {
+ case 1: return SSDR_1; break;
+ case 2: return SSDR_2; break;
+ case 3: return SSDR_3; break;
+ default: return 0;
+ }
+ }
+
+ async command void HplPXA27xSSP.setSSTO[uint8_t chnl](uint32_t val) {
+ switch (chnl) {
+ case 1: SSTO_1 = val; break;
+ case 2: SSTO_2 = val; break;
+ case 3: SSTO_3 = val; break;
+ default: break;
+ }
+ return;
+ }
+ async command uint32_t HplPXA27xSSP.getSSTO[uint8_t chnl]() {
+ switch (chnl) {
+ case 1: return SSTO_1; break;
+ case 2: return SSTO_2; break;
+ case 3: return SSTO_3; break;
+ default: return 0;
+ }
+ }
+
+ async command void HplPXA27xSSP.setSSPSP[uint8_t chnl](uint32_t val) {
+ switch (chnl) {
+ case 1: SSPSP_1 = val; break;
+ case 2: SSPSP_2 = val; break;
+ case 3: SSPSP_3 = val; break;
+ default: break;
+ }
+ return;
+ }
+ async command uint32_t HplPXA27xSSP.getSSPSP[uint8_t chnl]() {
+ switch (chnl) {
+ case 1: return SSPSP_1; break;
+ case 2: return SSPSP_2; break;
+ case 3: return SSPSP_3; break;
+ default: return 0;
+ }
+ }
+
+ async command void HplPXA27xSSP.setSSTSA[uint8_t chnl](uint32_t val) {
+ switch (chnl) {
+ case 1: SSTSA_1 = val; break;
+ case 2: SSTSA_2 = val; break;
+ case 3: SSTSA_3 = val; break;
+ default: break;
+ }
+ return;
+ }
+ async command uint32_t HplPXA27xSSP.getSSTSA[uint8_t chnl]() {
+ switch (chnl) {
+ case 1: return SSTSA_1; break;
+ case 2: return SSTSA_2; break;
+ case 3: return SSTSA_3; break;
+ default: return 0;
+ }
+ }
+
+ async command void HplPXA27xSSP.setSSRSA[uint8_t chnl](uint32_t val) {
+ switch (chnl) {
+ case 1: SSRSA_1 = val; break;
+ case 2: SSRSA_2 = val; break;
+ case 3: SSRSA_3 = val; break;
+ default: break;
+ }
+ return;
+ }
+ async command uint32_t HplPXA27xSSP.getSSRSA[uint8_t chnl]() {
+ switch (chnl) {
+ case 1: return SSRSA_1; break;
+ case 2: return SSRSA_2; break;
+ case 3: return SSRSA_3; break;
+ default: return 0;
+ }
+ }
+
+ async command void HplPXA27xSSP.setSSTSS[uint8_t chnl](uint32_t val) {
+ switch (chnl) {
+ case 1: SSTSS_1 = val; break;
+ case 2: SSTSS_2 = val; break;
+ case 3: SSTSS_3 = val; break;
+ default: break;
+ }
+ return;
+ }
+ async command uint32_t HplPXA27xSSP.getSSTSS[uint8_t chnl]() {
+ switch (chnl) {
+ case 1: return SSTSS_1; break;
+ case 2: return SSTSS_2; break;
+ case 3: return SSTSS_3; break;
+ default: return 0;
+ }
+ }
+
+ async command void HplPXA27xSSP.setSSACD[uint8_t chnl](uint32_t val) {
+ switch (chnl) {
+ case 1: SSACD_1 = val; break;
+ case 2: SSACD_2 = val; break;
+ case 3: SSACD_3 = val; break;
+ default: break;
+ }
+ return;
+ }
+ async command uint32_t HplPXA27xSSP.getSSACD[uint8_t chnl]() {
+ switch (chnl) {
+ case 1: return SSACD_1; break;
+ case 2: return SSACD_2; break;
+ case 3: return SSACD_3; break;
+ default: return 0;
+ }
+ }
+
+ default async event void HplPXA27xSSP.interruptSSP[uint8_t chnl]() {
+ call HplPXA27xSSP.setSSSR[chnl](SSSR_BCE | SSSR_TUR | SSSR_EOC | SSSR_TINT |
+ SSSR_PINT | SSSR_ROR );
+ return;
+ }
+
+ async event void SSP1Irq.fired() {
+ signal HplPXA27xSSP.interruptSSP[1]();
+ }
+ async event void SSP2Irq.fired() {
+ signal HplPXA27xSSP.interruptSSP[2]();
+ }
+ async event void SSP3Irq.fired() {
+ signal HplPXA27xSSP.interruptSSP[3]();
+ }
+
+ default async command void SSP1Irq.enable() {return;}
+ default async command void SSP2Irq.enable() {return;}
+ default async command void SSP3Irq.enable() {return;}
+
+}
+