Mercurial > avr_jtag
view include/avriotools.h @ 13:1ea479d26fce tip
Make sure shifting phase and add bypass.py.
- shifting phase is started after entering SHIFT state
Transition from CAP to SHIFT does not induce shifting.
- shifting phase is stoped after leaving SHIFT state.
Transition from SHIFT to EXIT1 also induce a bit of shifting.
author | Thinker K.F. Li <thinker@branda.to> |
---|---|
date | Wed, 25 Feb 2009 20:08:29 +0800 |
parents | a0ce8ebf2f18 |
children |
line wrap: on
line source
#ifndef __AVRIOTOOLS_H_ #define __AVRIOTOOLS_H_ #include <stdint.h> #include <avr/io.h> typedef enum {PM_INPUT, PM_OUTPUT} pin_mode_t; extern int pin_mode(volatile uint8_t * port, int pin, pin_mode_t mode); #define pin_hi(port, pin) do { port |= _BV(pin); } while(0) #define pin_lo(port, pin) do { port &= ~_BV(pin); } while(0) #define UBRRH UBRR0L #define UBRRL UBRR0L #define UCSRA UCSR0A #define U2X U2X0 #define UDRE UDRE0 #define UDR UDR0 #define RXC RXC0 #define FE FE0 #define DOR DOR0 extern int uart_init(uint32_t baud); #define uart_getc(c) \ do { \ loop_until_bit_is_set(UCSRA, RXC); \ if (UCSRA & _BV(FE)) \ continue; \ if (UCSRA & _BV(DOR)) \ continue; \ c = UDR; \ } while(0) /* * c == -1 if not data been read. * \note c must be an integer. */ #define uart_getc_nowait(c) \ do { \ c = -1; \ if(bit_is_clear(UCSRA, RXC)) break; \ if (UCSRA & _BV(FE)) \ break; \ if (UCSRA & _BV(DOR)) \ break; \ c = UDR; \ } while(0) #define uart_putc(c) \ do { \ loop_until_bit_is_set(UCSRA, UDRE); \ UDR = ((uint8_t)(c & 0xff)); \ } while(0) /* * c == -1 if it been wrote out. * \note c must be an integer. */ #define uart_putc_nowait(c) \ do { \ if(bit_is_clear(UCSRA, UDRE)) \ break; \ UDR = ((uint8_t)(c & 0xff)); \ c = -1; \ } while(0) #endif /* __AVRIOTOOLS_H_ */