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

90USB1287-16AU 参数 Datasheet PDF下载

90USB1287-16AU图片预览
型号: 90USB1287-16AU
PDF下载: 下载PDF文件 查看货源
内容描述: 单片机具有ISP功能的Flash和USB控制器64 / 128K字节 [Microcontroller with 64/128K Bytes of ISP Flash and USB Controller]
分类和应用: 微控制器
文件页数/大小: 434 页 / 3172 K
品牌: ATMEL [ ATMEL ]
 浏览型号90USB1287-16AU的Datasheet PDF文件第186页浏览型号90USB1287-16AU的Datasheet PDF文件第187页浏览型号90USB1287-16AU的Datasheet PDF文件第188页浏览型号90USB1287-16AU的Datasheet PDF文件第189页浏览型号90USB1287-16AU的Datasheet PDF文件第191页浏览型号90USB1287-16AU的Datasheet PDF文件第192页浏览型号90USB1287-16AU的Datasheet PDF文件第193页浏览型号90USB1287-16AU的Datasheet PDF文件第194页  
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 “About Code Examples” on page 8.  
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.5.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  
190  
AT90USB64/128  
7593A–AVR–02/06  
 复制成功!