⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hplmsp430usart.nc

📁 tinyos2.0版本驱动
💻 NC
字号:
/* * Copyright (c) 2004-2005, Technische Universitaet Berlin * 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 Technische Universitaet Berlin 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 COPYRIGHT * OWNER OR 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. *//** * Byte-level interface to control a USART. * <p>The USART can be switched to SPI- or UART-mode. The interface follows * the convention of being stateless, thus a higher layer has to maintain * state information. I.e. calling <code>tx</done> will transmit a byte of * data in the mode (SPI or UART) the USART has been set to before. * * @author Vlado Handziski (handzisk@tkn.tu-berlin.de) * @author Jan Hauer (hauer@tkn.tu-berlin.de) * @author Joe Polastre * @version $Revision: 1.4 $ $Date: 2006/12/12 18:23:11 $ */#include "msp430usart.h"interface HplMsp430Usart {    /**   * Sets the UxCTL Control Register   */  async command void setUctl(msp430_uctl_t control);    /**   * Reads the UxCTL Control Register   */  async command msp430_uctl_t getUctl();    /**   * Sets the UxTCTL Transmit Control Register   */  async command void setUtctl(msp430_utctl_t control);    /**   * Reads the UxTCTL Transmit Control Register   */  async command msp430_utctl_t getUtctl();    /**   * Sets the UxRCTL Receive Control Register   */  async command void setUrctl(msp430_urctl_t control);    /**   * Reads the UxRCTL Receive Control Register   */  async command msp430_urctl_t getUrctl();  /**   * Sets the UxBR0 and UxBR1 Baud Rate Control Registers   */  async command void setUbr(uint16_t ubr);    /**   * Reads the UxBR0 and UxBR1 Baud Rate Control Registers   */  async command uint16_t getUbr();    /**   * Sets the UxMCTL Modulation Control Register   */  async command void setUmctl(uint8_t umctl);    /**   * Reads the UxMCTL Modulation Control Register   */  async command uint8_t getUmctl();    async command void resetUsart(bool reset);    /**   * Returns an enum value corresponding to the current mode of the   * USART module.   */  async command msp430_usartmode_t getMode();    /**   * Returns TRUE if the USART has Uart TX mode enabled   */  async command bool isUartTx();    /**   * Returns TRUE if the USART has Uart RX mode enabled   */  async command bool isUartRx();    /**   * Returns TRUE if the USART is set to Uart mode (both RX and TX)   */  async command bool isUart();  /**   * Enables both the Rx and the Tx Uart modules.   */  async command void enableUart();    /**   * Disables both the Rx and the Tx Uart modules.   */  async command void disableUart();    /**   * Enables the Uart TX functionality of the USART module.   */  async command void enableUartTx();    /**   * Disables the Uart TX module.   */  async command void disableUartTx();  /**   * Enables the Uart RX functionality of the USART module.   */  async command void enableUartRx();    /**   * Disables the Uart RX module.   */  async command void disableUartRx();    /**   * Enables the USART when in Spi mode.   */  async command void enableSpi();    /**   * Disables the USART when in Spi mode.   */  async command void disableSpi();    /**   * Returns TRUE if the USART is set to Spi mode   */  async command bool isSpi();    /**   * Switches USART to Spi mode.   */  async command void setModeSpi(msp430_spi_union_config_t* config);    /**   * Switches USART to Uart mode (RX and TX enabled)   * Interrupts disabled by default.   */  async command void setModeUart(msp430_uart_union_config_t* config);    /* Dis/enabling of UTXIFG / URXIFG */  async command void disableRxIntr();  async command void disableTxIntr();  async command void disableIntr();  async command void enableRxIntr();  async command void enableTxIntr();  async command void enableIntr();    /**   * TRUE if TX interrupt pending, flag must be cleared explicitly   */  async command bool isTxIntrPending();    /**   * TRUE if RX interrupt pending, flag must be cleared explicitly   */  async command bool isRxIntrPending();    /**   * Clears RX interrupt pending flag   */  async command void clrRxIntr();    /**   * Clears TX interrupt pending flag   */  async command void clrTxIntr();  /**   * Clears both TX and RX interrupt pending flags   */  async command void clrIntr();  /**   * SUCCESS if the TX buffer is empty and all of the bits have been   * shifted out   */  async command bool isTxEmpty();    /**   * Transmit a byte of data. When the transmission is completed,   * <code>txDone</done> is generated. Only then a new byte may be   * transmitted, otherwise the previous byte will be overwritten.   * The mode of transmission (Uart or Spi) depends on the current   * state of the USART, which must be managed by a higher layer.   *   * @return SUCCESS always.   */  async command void tx(uint8_t data);    /**   * Get current value from RX-buffer.   *   * @return SUCCESS always.   */  async command uint8_t rx();}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -