📄 hplpxa27xgpiom.nc
字号:
// $Id: HplPXA27xGPIOM.nc,v 1.6 2008/06/11 00:46:24 razvanm Exp $/* * IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING. By * downloading, copying, installing or using the software you agree to * this license. If you do not agree to this license, do not download, * install, copy or use the software. * * Intel Open Source License * * Copyright (c) 2002 Intel 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 Intel 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 INTEL 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 Buonadonnamodule HplPXA27xGPIOM { provides { interface Init; interface HplPXA27xGPIOPin[uint8_t pin]; interface HplPXA27xGPIO; } uses { interface HplPXA27xInterrupt as GPIOIrq0; interface HplPXA27xInterrupt as GPIOIrq1; interface HplPXA27xInterrupt as GPIOIrq; // GPIO 2 - 120 only }}implementation { bool gfInitialized = FALSE; command error_t Init.init() { bool isInited; atomic { isInited = gfInitialized; gfInitialized = TRUE; } if (!isInited) { call GPIOIrq0.allocate(); call GPIOIrq1.allocate(); call GPIOIrq.allocate(); call GPIOIrq0.enable(); call GPIOIrq1.enable(); call GPIOIrq.enable(); } return SUCCESS; } async command bool HplPXA27xGPIOPin.getGPLRbit[uint8_t pin]() { return ((GPLR(pin) & _GPIO_bit(pin)) != 0); } async command void HplPXA27xGPIOPin.setGPDRbit[uint8_t pin](bool dir) { if (dir) { GPDR(pin) |= _GPIO_bit(pin); } else { GPDR(pin) &= ~(_GPIO_bit(pin)); } return; } async command bool HplPXA27xGPIOPin.getGPDRbit[uint8_t pin]() { return ((GPDR(pin) & _GPIO_bit(pin)) != 0); } async command void HplPXA27xGPIOPin.setGPSRbit[uint8_t pin]() { GPSR(pin) = _GPIO_bit(pin); return; } async command void HplPXA27xGPIOPin.setGPCRbit[uint8_t pin]() { GPCR(pin) = _GPIO_bit(pin); return; } async command void HplPXA27xGPIOPin.setGRERbit[uint8_t pin](bool flag) { if (flag) { GRER(pin) |= _GPIO_bit(pin); } else { GRER(pin) &= ~(_GPIO_bit(pin)); } return; } async command bool HplPXA27xGPIOPin.getGRERbit[uint8_t pin]() { return ((GRER(pin) & _GPIO_bit(pin)) != 0); } async command void HplPXA27xGPIOPin.setGFERbit[uint8_t pin](bool flag) { if (flag) { GFER(pin) |= _GPIO_bit(pin); } else { GFER(pin) &= ~(_GPIO_bit(pin)); } return; } async command bool HplPXA27xGPIOPin.getGFERbit[uint8_t pin]() { return ((GFER(pin) & _GPIO_bit(pin)) != 0); } async command bool HplPXA27xGPIOPin.getGEDRbit[uint8_t pin]() { return ((GEDR(pin) & _GPIO_bit(pin)) != 0); } async command bool HplPXA27xGPIOPin.clearGEDRbit[uint8_t pin]() { bool flag; flag = ((GEDR(pin) & _GPIO_bit(pin)) != 0); GEDR(pin) = _GPIO_bit(pin); return flag; } async command void HplPXA27xGPIOPin.setGAFRpin[uint8_t pin](uint8_t func) { func &= 0x3; _GPIO_setaltfn(pin,func); return; } async command uint8_t HplPXA27xGPIOPin.getGAFRpin[uint8_t pin]() { return (_GPIO_getaltfun(pin)); } default async event void HplPXA27xGPIOPin.interruptGPIOPin[uint8_t pin]() { call HplPXA27xGPIOPin.clearGEDRbit[pin](); return; } async command void HplPXA27xGPIO.setGPLR0(uint32_t val) {GPLR0 = val;} async command uint32_t HplPXA27xGPIO.getGPLR0() {return GPLR0;} async command void HplPXA27xGPIO.setGPLR1(uint32_t val) {GPLR1 = val;} async command uint32_t HplPXA27xGPIO.getGPLR1() {return GPLR1;} async command void HplPXA27xGPIO.setGPLR2(uint32_t val) {GPLR2 = val;} async command uint32_t HplPXA27xGPIO.getGPLR2() {return GPLR2;} async command void HplPXA27xGPIO.setGPLR3(uint32_t val) {GPLR3 = val;} async command uint32_t HplPXA27xGPIO.getGPLR3() {return GPLR3;} async command void HplPXA27xGPIO.setGPDR0(uint32_t val) {GPDR0 = val;} async command uint32_t HplPXA27xGPIO.getGPDR0() {return GPDR0;} async command void HplPXA27xGPIO.setGPDR1(uint32_t val) {GPDR1 = val;} async command uint32_t HplPXA27xGPIO.getGPDR1() {return GPDR1;} async command void HplPXA27xGPIO.setGPDR2(uint32_t val) {GPDR2 = val;} async command uint32_t HplPXA27xGPIO.getGPDR2() {return GPDR2;} async command void HplPXA27xGPIO.setGPDR3(uint32_t val) {GPDR3 = val;} async command uint32_t HplPXA27xGPIO.getGPDR3() {return GPDR3;} async command void HplPXA27xGPIO.setGPSR0(uint32_t val) {GPSR0 = val;} async command uint32_t HplPXA27xGPIO.getGPSR0() {return GPSR0;} async command void HplPXA27xGPIO.setGPSR1(uint32_t val) {GPSR1 = val;} async command uint32_t HplPXA27xGPIO.getGPSR1() {return GPSR1;} async command void HplPXA27xGPIO.setGPSR2(uint32_t val) {GPSR2 = val;} async command uint32_t HplPXA27xGPIO.getGPSR2() {return GPSR2;} async command void HplPXA27xGPIO.setGPSR3(uint32_t val) {GPSR3 = val;} async command uint32_t HplPXA27xGPIO.getGPSR3() {return GPSR3;} async command void HplPXA27xGPIO.setGPCR0(uint32_t val) {GPCR0 = val;} async command uint32_t HplPXA27xGPIO.getGPCR0() {return GPCR0;} async command void HplPXA27xGPIO.setGPCR1(uint32_t val) {GPCR1 = val;} async command uint32_t HplPXA27xGPIO.getGPCR1() {return GPCR1;} async command void HplPXA27xGPIO.setGPCR2(uint32_t val) {GPCR2 = val;} async command uint32_t HplPXA27xGPIO.getGPCR2() {return GPCR2;} async command void HplPXA27xGPIO.setGPCR3(uint32_t val) {GPCR3 = val;} async command uint32_t HplPXA27xGPIO.getGPCR3() {return GPCR3;} async command void HplPXA27xGPIO.setGRER0(uint32_t val) {GRER0 = val;} async command uint32_t HplPXA27xGPIO.getGRER0() {return GRER0;} async command void HplPXA27xGPIO.setGRER1(uint32_t val) {GRER1 = val;} async command uint32_t HplPXA27xGPIO.getGRER1() {return GRER1;} async command void HplPXA27xGPIO.setGRER2(uint32_t val) {GRER2 = val;} async command uint32_t HplPXA27xGPIO.getGRER2() {return GRER2;} async command void HplPXA27xGPIO.setGRER3(uint32_t val) {GRER3 = val;} async command uint32_t HplPXA27xGPIO.getGRER3() {return GRER3;} async command void HplPXA27xGPIO.setGFER0(uint32_t val) {GFER0 = val;} async command uint32_t HplPXA27xGPIO.getGFER0() {return GFER0;} async command void HplPXA27xGPIO.setGFER1(uint32_t val) {GFER1 = val;} async command uint32_t HplPXA27xGPIO.getGFER1() {return GFER1;} async command void HplPXA27xGPIO.setGFER2(uint32_t val) {GFER2 = val;} async command uint32_t HplPXA27xGPIO.getGFER2() {return GFER2;} async command void HplPXA27xGPIO.setGFER3(uint32_t val) {GFER3 = val;} async command uint32_t HplPXA27xGPIO.getGFER3() {return GFER3;} async command void HplPXA27xGPIO.setGEDR0(uint32_t val) {GEDR0 = val;} async command uint32_t HplPXA27xGPIO.getGEDR0() {return GEDR0;} async command void HplPXA27xGPIO.setGEDR1(uint32_t val) {GEDR1 = val;} async command uint32_t HplPXA27xGPIO.getGEDR1() {return GEDR1;} async command void HplPXA27xGPIO.setGEDR2(uint32_t val) {GEDR2 = val;} async command uint32_t HplPXA27xGPIO.getGEDR2() {return GEDR2;} async command void HplPXA27xGPIO.setGEDR3(uint32_t val) {GEDR3 = val;} async command uint32_t HplPXA27xGPIO.getGEDR3() {return GEDR3;} async command void HplPXA27xGPIO.setGAFR0_L(uint32_t val) {GAFR0_L = val;} async command uint32_t HplPXA27xGPIO.getGAFR0_L() {return GAFR0_L;} async command void HplPXA27xGPIO.setGAFR0_U(uint32_t val) {GAFR0_U = val;} async command uint32_t HplPXA27xGPIO.getGAFR0_U() {return GAFR0_U;} async command void HplPXA27xGPIO.setGAFR1_L(uint32_t val) {GAFR1_L = val;} async command uint32_t HplPXA27xGPIO.getGAFR1_L() {return GAFR1_L;} async command void HplPXA27xGPIO.setGAFR1_U(uint32_t val) {GAFR1_U = val;} async command uint32_t HplPXA27xGPIO.getGAFR1_U() {return GAFR1_U;} async command void HplPXA27xGPIO.setGAFR2_L(uint32_t val) {GAFR2_L = val;} async command uint32_t HplPXA27xGPIO.getGAFR2_L() {return GAFR2_L;} async command void HplPXA27xGPIO.setGAFR2_U(uint32_t val) {GAFR2_U = val;} async command uint32_t HplPXA27xGPIO.getGAFR2_U() {return GAFR2_U;} async command void HplPXA27xGPIO.setGAFR3_L(uint32_t val) {GAFR3_L = val;} async command uint32_t HplPXA27xGPIO.getGAFR3_L() {return GAFR3_L;} async command void HplPXA27xGPIO.setGAFR3_U(uint32_t val) {GAFR3_U = val;} async command uint32_t HplPXA27xGPIO.getGAFR3_U() {return GAFR3_U;} default async event void HplPXA27xGPIO.fired() { return; } async event void GPIOIrq.fired() { uint32_t DetectReg; uint8_t pin; signal HplPXA27xGPIO.fired(); // Mask off GPIO 0 and 1 (handled by direct IRQs) atomic DetectReg = (GEDR0 & ~((1<<1) | (1<<0))); while (DetectReg) { pin = 31 - _pxa27x_clzui(DetectReg); signal HplPXA27xGPIOPin.interruptGPIOPin[pin](); DetectReg &= ~(1 << pin); } atomic DetectReg = GEDR1; while (DetectReg) { pin = 31 - _pxa27x_clzui(DetectReg); signal HplPXA27xGPIOPin.interruptGPIOPin[(pin+32)](); DetectReg &= ~(1 << pin); } atomic DetectReg = GEDR2; while (DetectReg) { pin = 31 - _pxa27x_clzui(DetectReg); signal HplPXA27xGPIOPin.interruptGPIOPin[(pin+64)](); DetectReg &= ~(1 << pin); } atomic DetectReg = GEDR3; while (DetectReg) { pin = 31 - _pxa27x_clzui(DetectReg); signal HplPXA27xGPIOPin.interruptGPIOPin[(pin+96)](); DetectReg &= ~(1 << pin); } return; } async event void GPIOIrq0.fired() { signal HplPXA27xGPIOPin.interruptGPIOPin[0](); } async event void GPIOIrq1.fired() { signal HplPXA27xGPIOPin.interruptGPIOPin[1](); } }
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -