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

📄 lpcuart_8h-source.html

📁 方便飞利浦arm7tdmi 处理器lpc2100开发的C函数库 Procyon ARMlib-LPC2100 C-Language Function Library for Philips LPC21
💻 HTML
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html><head><meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1"><title>Procyon ARMlib-LPC2100: lpcUART.h Source File</title><link href="dox.css" rel="stylesheet" type="text/css"></head><body><!-- Generated by Doxygen 1.3.6 --><div class="qindex"><a class="qindex" href="main.html">Main&nbsp;Page</a> | <a class="qindex" href="files.html">File&nbsp;List</a> | <a class="qindex" href="globals.html">Globals</a></div><h1>lpcUART.h</h1><div class="fragment"><pre>00001 <span class="comment">/******************************************************************************</span>00002 <span class="comment"> *</span>00003 <span class="comment"> * $RCSfile: $</span>00004 <span class="comment"> * $Revision: $</span>00005 <span class="comment"> *</span>00006 <span class="comment"> * Header file for Philips LPC ARM Processors.</span>00007 <span class="comment"> * Copyright 2004 R O SoftWare</span>00008 <span class="comment"> *</span>00009 <span class="comment"> * No guarantees, warrantees, or promises, implied or otherwise.</span>00010 <span class="comment"> * May be used for hobby or commercial purposes provided copyright</span>00011 <span class="comment"> * notice remains intact.</span>00012 <span class="comment"> *</span>00013 <span class="comment"> *****************************************************************************/</span>00014 <span class="preprocessor">#ifndef INC_LPC_UART_H</span>00015 <span class="preprocessor"></span><span class="preprocessor">#define INC_LPC_UART_H</span>00016 <span class="preprocessor"></span>00017 <span class="comment">// Universal Asynchronous Receiver Transmitter Registers</span>00018 <span class="keyword">typedef</span> <span class="keyword">struct</span>00019 <span class="keyword"></span>{00020   <span class="keyword">union</span>00021 <span class="keyword">    </span>{00022     REG_8 rbr;                          <span class="comment">// Receive Buffer Register</span>00023     REG_8 thr;                          <span class="comment">// Transmit Holding Register</span>00024     REG_8 dll;                          <span class="comment">// Divisor Latch Register (LSB)</span>00025     REG_8 _pad0[4];00026     };00027 00028   <span class="keyword">union</span>00029 <span class="keyword">    </span>{00030     REG_8 ier;                          <span class="comment">// Interrupt Enable Register</span>00031     REG_8 dlm;                          <span class="comment">// Divisor Latch Register (MSB)</span>00032     REG_8 _pad1[4];00033     };00034 00035   <span class="keyword">union</span>00036 <span class="keyword">    </span>{00037     REG_8 iir;                          <span class="comment">// Interrupt ID Register</span>00038     REG_8 fcr;                          <span class="comment">// FIFO Control Register</span>00039     REG_8 _pad2[4];00040     };00041 00042   REG_8 lcr;                            <span class="comment">// Line Control Registe</span>00043   REG_8 _pad3[3];00044   REG_8 mcr;                            <span class="comment">// MODEM Control Register</span>00045   REG_8 _pad4[3];00046   REG_8 lsr;                            <span class="comment">// Line Status Register</span>00047   REG_8 _pad5[3];00048   REG_8 msr;                            <span class="comment">// MODEM Status Register</span>00049   REG_8 _pad6[3];00050   REG_8 scr;                            <span class="comment">// Scratch Pad Register</span>00051   REG_8 _pad7[3];00052 } uartRegs_t;00053 <span class="comment"></span>00054 <span class="comment">///////////////////////////////////////////////////////////////////////////////</span>00055 <span class="comment"></span><span class="comment">// UART defines</span>00056 00057 <span class="comment">// Interrupt Enable Register bit definitions</span>00058 <span class="preprocessor">#define UIER_ERBFI          (1 &lt;&lt; 0)    // Enable Receive Data Available Interrupt</span>00059 <span class="preprocessor"></span><span class="preprocessor">#define UIER_ETBEI          (1 &lt;&lt; 1)    // Enable Transmit Holding Register Empty Interrupt</span>00060 <span class="preprocessor"></span><span class="preprocessor">#define UIER_ELSI           (1 &lt;&lt; 2)    // Enable Receive Line Status Interrupt</span>00061 <span class="preprocessor"></span><span class="preprocessor">#define UIER_EDSSI          (1 &lt;&lt; 3)    // Enable MODEM Status Interrupt</span>00062 <span class="preprocessor"></span>00063 <span class="comment">// Interrupt ID Register bit definitions</span>00064 <span class="preprocessor">#define UIIR_NO_INT         (1 &lt;&lt; 0)    // NO INTERRUPTS PENDING</span>00065 <span class="preprocessor"></span><span class="preprocessor">#define UIIR_MS_INT         (0 &lt;&lt; 1)    // MODEM Status</span>00066 <span class="preprocessor"></span><span class="preprocessor">#define UIIR_THRE_INT       (1 &lt;&lt; 1)    // Transmit Holding Register Empty</span>00067 <span class="preprocessor"></span><span class="preprocessor">#define UIIR_RDA_INT        (2 &lt;&lt; 1)    // Receive Data Available</span>00068 <span class="preprocessor"></span><span class="preprocessor">#define UIIR_RLS_INT        (3 &lt;&lt; 1)    // Receive Line Status</span>00069 <span class="preprocessor"></span><span class="preprocessor">#define UIIR_CTI_INT        (6 &lt;&lt; 1)    // Character Timeout Indicator</span>00070 <span class="preprocessor"></span><span class="preprocessor">#define UIIR_ID_MASK        0x0E</span>00071 <span class="preprocessor"></span>00072 <span class="comment">// FIFO Control Register bit definitions</span>00073 <span class="preprocessor">#define UFCR_FIFO_ENABLE    (1 &lt;&lt; 0)    // FIFO Enable</span>00074 <span class="preprocessor"></span><span class="preprocessor">#define UFCR_RX_FIFO_RESET  (1 &lt;&lt; 1)    // Reset Receive FIFO</span>00075 <span class="preprocessor"></span><span class="preprocessor">#define UFCR_TX_FIFO_RESET  (1 &lt;&lt; 2)    // Reset Transmit FIFO</span>00076 <span class="preprocessor"></span><span class="preprocessor">#define UFCR_FIFO_TRIG1     (0 &lt;&lt; 4)    // Trigger @ 1 character in FIFO</span>00077 <span class="preprocessor"></span><span class="preprocessor">#define UFCR_FIFO_TRIG4     (1 &lt;&lt; 4)    // Trigger @ 4 characters in FIFO</span>00078 <span class="preprocessor"></span><span class="preprocessor">#define UFCR_FIFO_TRIG8     (2 &lt;&lt; 4)    // Trigger @ 8 characters in FIFO</span>00079 <span class="preprocessor"></span><span class="preprocessor">#define UFCR_FIFO_TRIG14    (3 &lt;&lt; 4)    // Trigger @ 14 characters in FIFO</span>00080 <span class="preprocessor"></span>00081 <span class="comment">// Line Control Register bit definitions</span>00082 <span class="preprocessor">#define ULCR_CHAR_5         (0 &lt;&lt; 0)    // 5-bit character length</span>00083 <span class="preprocessor"></span><span class="preprocessor">#define ULCR_CHAR_6         (1 &lt;&lt; 0)    // 6-bit character length</span>00084 <span class="preprocessor"></span><span class="preprocessor">#define ULCR_CHAR_7         (2 &lt;&lt; 0)    // 7-bit character length</span>00085 <span class="preprocessor"></span><span class="preprocessor">#define ULCR_CHAR_8         (3 &lt;&lt; 0)    // 8-bit character length</span>00086 <span class="preprocessor"></span><span class="preprocessor">#define ULCR_STOP_0         (0 &lt;&lt; 2)    // no stop bits</span>00087 <span class="preprocessor"></span><span class="preprocessor">#define ULCR_STOP_1         (1 &lt;&lt; 2)    // 1 stop bit</span>00088 <span class="preprocessor"></span><span class="preprocessor">#define ULCR_PAR_NO         (0 &lt;&lt; 3)    // No Parity</span>00089 <span class="preprocessor"></span><span class="preprocessor">#define ULCR_PAR_ODD        (1 &lt;&lt; 3)    // Odd Parity</span>00090 <span class="preprocessor"></span><span class="preprocessor">#define ULCR_PAR_EVEN       (3 &lt;&lt; 3)    // Even Parity</span>00091 <span class="preprocessor"></span><span class="preprocessor">#define ULCR_PAR_MARK       (5 &lt;&lt; 3)    // MARK "1" Parity</span>00092 <span class="preprocessor"></span><span class="preprocessor">#define ULCR_PAR_SPACE      (7 &lt;&lt; 3)    // SPACE "0" Paruty</span>00093 <span class="preprocessor"></span><span class="preprocessor">#define ULCR_BREAK_ENABLE   (1 &lt;&lt; 6)    // Output BREAK line condition</span>00094 <span class="preprocessor"></span><span class="preprocessor">#define ULCR_DLAB_ENABLE    (1 &lt;&lt; 7)    // Enable Divisor Latch Access</span>00095 <span class="preprocessor"></span>00096 <span class="comment">// Modem Control Register bit definitions</span>00097 <span class="preprocessor">#define UMCR_DTR            (1 &lt;&lt; 0)    // Data Terminal Ready</span>00098 <span class="preprocessor"></span><span class="preprocessor">#define UMCR_RTS            (1 &lt;&lt; 1)    // Request To Send</span>00099 <span class="preprocessor"></span><span class="preprocessor">#define UMCR_LB             (1 &lt;&lt; 4)    // Loopback</span>00100 <span class="preprocessor"></span>00101 <span class="comment">// Line Status Register bit definitions</span>00102 <span class="preprocessor">#define ULSR_RDR            (1 &lt;&lt; 0)    // Receive Data Ready</span>00103 <span class="preprocessor"></span><span class="preprocessor">#define ULSR_OE             (1 &lt;&lt; 1)    // Overrun Error</span>00104 <span class="preprocessor"></span><span class="preprocessor">#define ULSR_PE             (1 &lt;&lt; 2)    // Parity Error</span>00105 <span class="preprocessor"></span><span class="preprocessor">#define ULSR_FE             (1 &lt;&lt; 3)    // Framing Error</span>00106 <span class="preprocessor"></span><span class="preprocessor">#define ULSR_BI             (1 &lt;&lt; 4)    // Break Interrupt</span>00107 <span class="preprocessor"></span><span class="preprocessor">#define ULSR_THRE           (1 &lt;&lt; 5)    // Transmit Holding Register Empty</span>00108 <span class="preprocessor"></span><span class="preprocessor">#define ULSR_TEMT           (1 &lt;&lt; 6)    // Transmitter Empty</span>00109 <span class="preprocessor"></span><span class="preprocessor">#define ULSR_RXFE           (1 &lt;&lt; 7)    // Error in Receive FIFO</span>00110 <span class="preprocessor"></span><span class="preprocessor">#define ULSR_ERR_MASK       0x1E</span>00111 <span class="preprocessor"></span>00112 <span class="comment">// Modem Status Register bit definitions</span>00113 <span class="preprocessor">#define UMSR_DCTS           (1 &lt;&lt; 0)    // Delta Clear To Send</span>00114 <span class="preprocessor"></span><span class="preprocessor">#define UMSR_DDSR           (1 &lt;&lt; 1)    // Delta Data Set Ready</span>00115 <span class="preprocessor"></span><span class="preprocessor">#define UMSR_TERI           (1 &lt;&lt; 2)    // Trailing Edge Ring Indicator</span>00116 <span class="preprocessor"></span><span class="preprocessor">#define UMSR_DDCD           (1 &lt;&lt; 3)    // Delta Data Carrier Detect</span>00117 <span class="preprocessor"></span><span class="preprocessor">#define UMSR_CTS            (1 &lt;&lt; 4)    // Clear To Send</span>00118 <span class="preprocessor"></span><span class="preprocessor">#define UMSR_DSR            (1 &lt;&lt; 5)    // Data Set Ready</span>00119 <span class="preprocessor"></span><span class="preprocessor">#define UMSR_RI             (1 &lt;&lt; 6)    // Ring Indicator</span>00120 <span class="preprocessor"></span><span class="preprocessor">#define UMSR_DCD            (1 &lt;&lt; 7)    // Data Carrier Detect</span>00121 <span class="preprocessor"></span>00122 <span class="preprocessor">#endif</span></pre></div><hr size="1"><address style="align: right;"><small>Generated on Tue Jul 13 03:38:12 2004 for Procyon ARMlib-LPC2100 by<a href="http://www.doxygen.org/index.html"><img src="doxygen.png" alt="doxygen" align="middle" border=0 > </a>1.3.6 </small></address></body></html>

⌨️ 快捷键说明

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