; ; hello2.blink.asm ; (c) Neil Gershenfeld CBA MIT 8/14/04 ; blink the LED ; .include "tn13def.inc" .equ ledpin = PB4; LED pin .equ txpin = PB2; transmit pin .def bitcnt = R16; bit counter .def temp = R17; temporary storage .def temp1 = R18; temporary storage .def temp2 = R19; temporary storage .def txbyte = R20; data byte .cseg .org 0 rjmp reset ; ; putchar ; assumes no line driver (doesn't invert bits) ; .equ sb = 1; number of stop bits putchar: ldi bitcnt, 9+sb; 1+8+sb com txbyte; invert everything sec; set start bit putchar0: brcc putchar1; if carry set sbi PORTB, txpin; send a '0' rjmp putchar2; else putchar1: cbi PORTB, txpin ; send a '1' nop ; even out timing putchar2: rcall bitdelay; one bit delay rcall bitdelay lsr txbyte; get next bit dec bitcnt; if not all bits sent brne putchar0; send next bit ret; ; ; bit delay ; 1 MHz crystal: 9600 bps - b=14, 19200 bps - b=5, 28800 bps - b=2 ; .equ b = 17 bitdelay: ldi temp, b bitloop: dec temp brne bitloop ret ; ; long_print_delay ; delay between printed lines ; .equ delay = 100 long_print_delay: ldi temp2, delay charloop2: ldi temp1, delay charloop1: ldi temp, delay charloop0: dec temp brne charloop0 dec temp1 brne charloop1 dec temp2 brne charloop2 ret ; ; print ; prints a null-terminated string ; print: print_loop: lpm mov txbyte,R0 cpi txbyte,0 breq return rcall putchar inc zl rjmp print_loop return: ret ; ; string to print ; print_string: .db "blink",13,10,0 ; ; main program ; reset: ldi temp, low(RAMEND) ; set stack pointer to top of RAM out SPL, temp ; sbi PORTB, txpin; init comm pin sbi DDRB, txpin sbi PORTB, ledpin; init LED pin sbi DDRB, ledpin loop: ldi zl,low(print_string*2) ldi zh,high(print_string*2) sbi PORTB, ledpin rcall print rcall long_print_delay cbi PORTB, ledpin rcall long_print_delay rjmp loop