HPLUART1M.nc
上传用户:joranyuan
上传日期:2022-06-23
资源大小:3306k
文件大小:3k
源码类别:

网络

开发平台:

Others

  1. // $Id: HPLUART1M.nc,v 1.1.1.1 2005/04/22 04:26:45 acwarrie Exp $
  2. /* tab:4
  3.  * "Copyright (c) 2000-2003 The Regents of the University  of California.  
  4.  * All rights reserved.
  5.  *
  6.  * Permission to use, copy, modify, and distribute this software and its
  7.  * documentation for any purpose, without fee, and without written agreement is
  8.  * hereby granted, provided that the above copyright notice, the following
  9.  * two paragraphs and the author appear in all copies of this software.
  10.  * 
  11.  * IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR
  12.  * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT
  13.  * OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF THE UNIVERSITY OF
  14.  * CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  15.  * 
  16.  * THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES,
  17.  * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
  18.  * AND FITNESS FOR A PARTICULAR PURPOSE.  THE SOFTWARE PROVIDED HEREUNDER IS
  19.  * ON AN "AS IS" BASIS, AND THE UNIVERSITY OF CALIFORNIA HAS NO OBLIGATION TO
  20.  * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS."
  21.  *
  22.  * Copyright (c) 2002-2003 Intel Corporation
  23.  * All rights reserved.
  24.  *
  25.  * This file is distributed under the terms in the attached INTEL-LICENSE     
  26.  * file. If you do not find these files, copies can be found by writing to
  27.  * Intel Research Berkeley, 2150 Shattuck Avenue, Suite 1300, Berkeley, CA, 
  28.  * 94704.  Attention:  Intel License Inquiry.
  29.  */
  30. /*
  31.  *
  32.  * Authors: Jason Hill, David Gay, Philip Levis, Phil Buonadonna
  33.  * Date last modified:  $Revision: 1.1.1.1 $
  34.  *
  35.  */
  36. // The hardware presentation layer. See hpl.h for the C side.
  37. // Note: there's a separate C side (hpl.h) to get access to the avr macros
  38. // The model is that HPL is stateless. If the desired interface is as stateless
  39. // it can be implemented here (Clock, FlashBitSPI). Otherwise you should
  40. // create a separate component
  41. /**
  42.  * @author Jason Hill
  43.  * @author David Gay
  44.  * @author Philip Levis
  45.  * @author Phil Buonadonna
  46.  */
  47. module HPLUART1M {
  48.   provides interface HPLUART as UART;
  49. }
  50. implementation
  51. {
  52.   async command result_t UART.init() {
  53.     // UART will run at:
  54.     // 115kbps, N-8-1
  55.     // Set 57.6 KBps
  56.     outp(0,UBRR1H);
  57.     outp(15, UBRR1L);
  58.     // Set UART double speed
  59.     outp((1<<U2X),UCSR1A);
  60.     // Set frame format: 8 data-bits, 1 stop-bit
  61.     outp(((1 << UCSZ1) | (1 << UCSZ0)) , UCSR1C);
  62.     // Enable reciever and transmitter and their interrupts
  63.     outp(((1 << RXCIE) | (1 << TXCIE) | (1 << RXEN) | (1 << TXEN)) ,UCSR1B);
  64.     return SUCCESS;
  65.   }
  66.   
  67.   async command result_t UART.stop() {
  68.     outp(0x00, UCSR1A);
  69.     outp(0x00, UCSR1B);
  70.     outp(0x00, UCSR1C);
  71.     return SUCCESS;
  72.   }
  73.   
  74.   default async event result_t UART.get(uint8_t data) { return SUCCESS; }
  75.   TOSH_SIGNAL(SIG_UART1_RECV) {
  76.     if (inp(UCSR1A) & (1 << RXC))
  77.       signal UART.get(inp(UDR1));
  78.   }
  79.   default async event result_t UART.putDone() { return SUCCESS; }
  80.   
  81. #ifdef ENABLE_UART_DEBUG
  82. #warning "UART Interrups Redirected"
  83. #else
  84.   TOSH_INTERRUPT(SIG_UART1_TRANS) {
  85.     signal UART.putDone();
  86.   }
  87. #endif
  88.   command async result_t UART.put(uint8_t data) {
  89.     atomic{
  90.       outp(data, UDR1); 
  91.       sbi(UCSR1A, TXC);
  92.     }
  93.     return SUCCESS;
  94.   }
  95. }