欢迎访问ic37.com |
会员登录 免费注册
发布采购

ATMEGA16U2-MUR 参数 Datasheet PDF下载

ATMEGA16U2-MUR图片预览
型号: ATMEGA16U2-MUR
PDF下载: 下载PDF文件 查看货源
内容描述: 8位微控制器具有ISP功能的Flash 8/16 / 32K Butes [8-bit Microcontroller with 8/16/32K Butes of ISP Flash]
分类和应用: 微控制器异步传输模式PCATM
文件页数/大小: 310 页 / 4432 K
品牌: ATMEL [ ATMEL ]
 浏览型号ATMEGA16U2-MUR的Datasheet PDF文件第152页浏览型号ATMEGA16U2-MUR的Datasheet PDF文件第153页浏览型号ATMEGA16U2-MUR的Datasheet PDF文件第154页浏览型号ATMEGA16U2-MUR的Datasheet PDF文件第155页浏览型号ATMEGA16U2-MUR的Datasheet PDF文件第157页浏览型号ATMEGA16U2-MUR的Datasheet PDF文件第158页浏览型号ATMEGA16U2-MUR的Datasheet PDF文件第159页浏览型号ATMEGA16U2-MUR的Datasheet PDF文件第160页  
ATmega8U2/16U2/32U2  
a transmit function that handles 9-bit characters. For the assembly code, the data to be sent is  
assumed to be stored in registers R17:R16.  
Assembly Code Example(1)(2)  
USART_Transmit:  
; Wait for empty transmit buffer  
sbis UCSRnA,UDREn  
rjmp USART_Transmit  
; Copy 9th bit from r17 to TXB8  
cbi UCSRnB,TXB8  
sbrc r17,0  
sbi UCSRnB,TXB8  
; Put LSB data (r16) into buffer, sends the data  
out UDRn,r16  
ret  
C Code Example(1)(2)  
void USART_Transmit( unsigned int data )  
{
/* Wait for empty transmit buffer */  
while ( !( UCSRnA & (1<<UDREn))) )  
;
/* Copy 9th bit to TXB8 */  
UCSRnB &= ~(1<<TXB8);  
if ( data & 0x0100 )  
UCSRnB |= (1<<TXB8);  
/* Put data into buffer, sends the data */  
UDRn = data;  
}
Notes: 1. These transmit functions are written to be general functions. They can be optimized if the con-  
tents of the UCSRnB is static. For example, only the TXB8 bit of the UCSRnB Register is used  
after initialization.  
2. See “Code Examples” on page 6.  
The ninth bit can be used for indicating an address frame when using multi processor communi-  
cation mode or for other protocol handling as for example synchronization.  
18.6.3  
Transmitter Flags and Interrupts  
The USART Transmitter has two flags that indicate its state: USART Data Register Empty  
(UDREn) and Transmit Complete (TXCn). Both flags can be used for generating interrupts.  
The Data Register Empty (UDREn) Flag indicates whether the transmit buffer is ready to receive  
new data. This bit is set when the transmit buffer is empty, and cleared when the transmit buffer  
contains data to be transmitted that has not yet been moved into the Shift Register. For compat-  
ibility with future devices, always write this bit to zero when writing the UCSRnA Register.  
When the Data Register Empty Interrupt Enable (UDRIEn) bit in UCSRnB is written to one, the  
USART Data Register Empty Interrupt will be executed as long as UDREn is set (provided that  
global interrupts are enabled). UDREn is cleared by writing UDRn. When interrupt-driven data  
transmission is used, the Data Register Empty interrupt routine must either write new data to  
156  
7799D–AVR–11/10  
 复制成功!