]> oss.titaniummirror.com Git - tinyos-2.x.git/blobdiff - tos/chips/pxa27x/uart/HplPXA27xUARTP.nc
Convert to Unix-style line terminators.
[tinyos-2.x.git] / tos / chips / pxa27x / uart / HplPXA27xUARTP.nc
index 0ecd79d8fc5033a42c5f41aca077ca02dd15209f..148a20fd7dc11a46ce4f01170bb08d7959086702 100644 (file)
-/* $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
- * Provides low-level initialization, 1st level interrupt dispatch and register\r
- * access for the different uarts.  It is a generic that's bound to \r
- * the particular UART upon creation.\r
- *\r
- * @param baseaddr. The base address of the associated uart. One of \r
- * &FFRBR, &BTRBR or &STRBR.\r
- * This component automatically handles setting of the DLAB bit for\r
- * divisor register access (DLL and DLH) \r
- *\r
- * @author Phil Buonadonna\r
- */\r
-\r
-#include "PXA27X_UARTREG.h"\r
-\r
-generic module HplPXA27xUARTP(uint32_t base_addr)\r
-{\r
-  provides interface Init;\r
-  provides interface HplPXA27xUART as UART;\r
-  uses interface HplPXA27xInterrupt as UARTIrq;\r
-}\r
-\r
-implementation\r
-{\r
-  bool m_fInit = FALSE;\r
-\r
-  command error_t Init.init() {\r
-    bool isInited;\r
-\r
-    atomic {\r
-      isInited = m_fInit;\r
-      m_fInit = TRUE;\r
-    }\r
-\r
-    if (!isInited) {\r
-      switch (base_addr) {\r
-      case (0x40100000):\r
-       CKEN |= CKEN6_FFUART;\r
-       break;\r
-      case (0x40200000):\r
-       CKEN |= CKEN7_BTUART;\r
-       break;\r
-      case (0x40700000):\r
-       CKEN |= CKEN5_STUART;\r
-       break;\r
-      default:\r
-       break;\r
-      }\r
-      call UARTIrq.allocate();\r
-      call UARTIrq.enable();\r
-      UARTLCR(base_addr) |= LCR_DLAB;\r
-      UARTDLL(base_addr) = 0x04;\r
-      UARTDLH(base_addr) = 0x00;\r
-      UARTLCR(base_addr) &= ~LCR_DLAB;\r
-    }\r
-\r
-    return SUCCESS;\r
-  }\r
-\r
-  async command uint32_t UART.getRBR() { return UARTRBR(base_addr); }\r
-  async command void UART.setTHR(uint32_t val) { UARTTHR(base_addr) = val; }\r
-  async command void UART.setDLL(uint32_t val) { \r
-    UARTLCR(base_addr) |= LCR_DLAB;\r
-    UARTDLL(base_addr) = val; \r
-    UARTLCR(base_addr) &= ~LCR_DLAB;\r
-  }\r
-  async command uint32_t UART.getDLL() { \r
-    uint32_t val;\r
-    UARTLCR(base_addr) |= LCR_DLAB;\r
-    val = UARTDLL(base_addr); \r
-    UARTLCR(base_addr) &= ~LCR_DLAB;\r
-    return val;\r
-  }\r
-  async command void UART.setDLH(uint32_t val) { \r
-    UARTLCR(base_addr) |= LCR_DLAB;\r
-    UARTDLH(base_addr) = val; \r
-    UARTLCR(base_addr) &= ~LCR_DLAB;\r
-  }\r
-  async command uint32_t UART.getDLH() { \r
-    uint32_t val;\r
-    UARTLCR(base_addr) |= LCR_DLAB;\r
-    val = UARTDLH(base_addr);\r
-    UARTLCR(base_addr) &= ~LCR_DLAB;\r
-    return val;\r
-  }\r
-  async command void UART.setIER(uint32_t val) { UARTIER(base_addr) = val; }\r
-  async command uint32_t UART.getIER() { return UARTIER(base_addr); }\r
-  async command uint32_t UART.getIIR() { return UARTIIR(base_addr); }\r
-  async command void UART.setFCR(uint32_t val) { UARTFCR(base_addr) = val; }\r
-  async command void UART.setLCR(uint32_t val) { UARTLCR(base_addr) = val; }\r
-  async command uint32_t UART.getLCR() { return UARTLCR(base_addr); }\r
-  async command void UART.setMCR(uint32_t val) { UARTMCR(base_addr) = val; }\r
-  async command uint32_t UART.getMCR() { return UARTMCR(base_addr); }\r
-  async command uint32_t UART.getLSR() { return UARTLSR(base_addr); }\r
-  async command uint32_t UART.getMSR() { return UARTMSR(base_addr); }\r
-  async command void UART.setSPR(uint32_t val) { UARTSPR(base_addr) = val; }\r
-  async command uint32_t UART.getSPR() { return UARTSPR(base_addr); }\r
-  async command void UART.setISR(uint32_t val) { UARTISR(base_addr) = val; }\r
-  async command uint32_t UART.getISR() { return UARTISR(base_addr); }\r
-  async command void UART.setFOR(uint32_t val) { UARTFOR(base_addr) = val; }\r
-  async command uint32_t UART.getFOR() { return UARTFOR(base_addr); }\r
-  async command void UART.setABR(uint32_t val) { UARTABR(base_addr) = val; }\r
-  async command uint32_t UART.getABR() { return UARTABR(base_addr); }\r
-  async command uint32_t UART.getACR() { return UARTACR(base_addr); }\r
-\r
-  async event void UARTIrq.fired () {\r
-\r
-    signal UART.interruptUART();\r
-  }\r
-\r
-  default async event void UART.interruptUART() { return; }\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.
+ */
+/**
+ * Provides low-level initialization, 1st level interrupt dispatch and register
+ * access for the different uarts.  It is a generic that's bound to 
+ * the particular UART upon creation.
+ *
+ * @param baseaddr. The base address of the associated uart. One of 
+ * &FFRBR, &BTRBR or &STRBR.
+ * This component automatically handles setting of the DLAB bit for
+ * divisor register access (DLL and DLH) 
+ *
+ * @author Phil Buonadonna
+ */
+
+#include "PXA27X_UARTREG.h"
+
+generic module HplPXA27xUARTP(uint32_t base_addr)
+{
+  provides interface Init;
+  provides interface HplPXA27xUART as UART;
+  uses interface HplPXA27xInterrupt as UARTIrq;
+}
+
+implementation
+{
+  bool m_fInit = FALSE;
+
+  command error_t Init.init() {
+    bool isInited;
+
+    atomic {
+      isInited = m_fInit;
+      m_fInit = TRUE;
+    }
+
+    if (!isInited) {
+      switch (base_addr) {
+      case (0x40100000):
+       CKEN |= CKEN6_FFUART;
+       break;
+      case (0x40200000):
+       CKEN |= CKEN7_BTUART;
+       break;
+      case (0x40700000):
+       CKEN |= CKEN5_STUART;
+       break;
+      default:
+       break;
+      }
+      call UARTIrq.allocate();
+      call UARTIrq.enable();
+      UARTLCR(base_addr) |= LCR_DLAB;
+      UARTDLL(base_addr) = 0x04;
+      UARTDLH(base_addr) = 0x00;
+      UARTLCR(base_addr) &= ~LCR_DLAB;
+    }
+
+    return SUCCESS;
+  }
+
+  async command uint32_t UART.getRBR() { return UARTRBR(base_addr); }
+  async command void UART.setTHR(uint32_t val) { UARTTHR(base_addr) = val; }
+  async command void UART.setDLL(uint32_t val) { 
+    UARTLCR(base_addr) |= LCR_DLAB;
+    UARTDLL(base_addr) = val; 
+    UARTLCR(base_addr) &= ~LCR_DLAB;
+  }
+  async command uint32_t UART.getDLL() { 
+    uint32_t val;
+    UARTLCR(base_addr) |= LCR_DLAB;
+    val = UARTDLL(base_addr); 
+    UARTLCR(base_addr) &= ~LCR_DLAB;
+    return val;
+  }
+  async command void UART.setDLH(uint32_t val) { 
+    UARTLCR(base_addr) |= LCR_DLAB;
+    UARTDLH(base_addr) = val; 
+    UARTLCR(base_addr) &= ~LCR_DLAB;
+  }
+  async command uint32_t UART.getDLH() { 
+    uint32_t val;
+    UARTLCR(base_addr) |= LCR_DLAB;
+    val = UARTDLH(base_addr);
+    UARTLCR(base_addr) &= ~LCR_DLAB;
+    return val;
+  }
+  async command void UART.setIER(uint32_t val) { UARTIER(base_addr) = val; }
+  async command uint32_t UART.getIER() { return UARTIER(base_addr); }
+  async command uint32_t UART.getIIR() { return UARTIIR(base_addr); }
+  async command void UART.setFCR(uint32_t val) { UARTFCR(base_addr) = val; }
+  async command void UART.setLCR(uint32_t val) { UARTLCR(base_addr) = val; }
+  async command uint32_t UART.getLCR() { return UARTLCR(base_addr); }
+  async command void UART.setMCR(uint32_t val) { UARTMCR(base_addr) = val; }
+  async command uint32_t UART.getMCR() { return UARTMCR(base_addr); }
+  async command uint32_t UART.getLSR() { return UARTLSR(base_addr); }
+  async command uint32_t UART.getMSR() { return UARTMSR(base_addr); }
+  async command void UART.setSPR(uint32_t val) { UARTSPR(base_addr) = val; }
+  async command uint32_t UART.getSPR() { return UARTSPR(base_addr); }
+  async command void UART.setISR(uint32_t val) { UARTISR(base_addr) = val; }
+  async command uint32_t UART.getISR() { return UARTISR(base_addr); }
+  async command void UART.setFOR(uint32_t val) { UARTFOR(base_addr) = val; }
+  async command uint32_t UART.getFOR() { return UARTFOR(base_addr); }
+  async command void UART.setABR(uint32_t val) { UARTABR(base_addr) = val; }
+  async command uint32_t UART.getABR() { return UARTABR(base_addr); }
+  async command uint32_t UART.getACR() { return UARTACR(base_addr); }
+
+  async event void UARTIrq.fired () {
+
+    signal UART.interruptUART();
+  }
+
+  default async event void UART.interruptUART() { return; }
+  
+}