mirror of
git://projects.qi-hardware.com/ben-wpan.git
synced 2025-01-06 15:00:15 +02:00
f8fbb02bb0
- atusb.c (main), board.h (board_init), board.c (board_init): moved clock and I/O initialization to board file - board.h (led), board.c (led), atusb.c (main): abstracted LED setting in function "led" instead of open-coding it - spi.c (spi_init): set nSS to 1 before enabling the output, so that we don't generate what looks like an empty SPI transaction
51 lines
1.1 KiB
C
51 lines
1.1 KiB
C
#ifndef BOARD_H
|
|
#define BOARD_H
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
#define LED_PORT B
|
|
#define LED_BIT 6
|
|
#define nRST_RF_PORT C
|
|
#define nRST_RF_BIT 7
|
|
#define SLP_TR_PORT B
|
|
#define SLP_TR_BIT 4
|
|
|
|
#define SCLK_PORT D
|
|
#define SCLK_BIT 5
|
|
#define MOSI_PORT D
|
|
#define MOSI_BIT 3
|
|
|
|
#define MISO_PORT D
|
|
#define MISO_BIT 2
|
|
#define nSS_PORT D
|
|
#define nSS_BIT 1
|
|
#define IRQ_RF_PORT D
|
|
#define IRQ_RF_BIT 0
|
|
|
|
|
|
#define SET_2(p, b) PORT##p |= 1 << (b)
|
|
#define CLR_2(p, b) PORT##p &= ~(1 << (b))
|
|
#define IN_2(p, b) DDR##p &= ~(1 << (b))
|
|
#define OUT_2(p, b) DDR##p |= 1 << (b)
|
|
#define PIN_2(p, b) ((PIN##p >> (b)) & 1)
|
|
|
|
#define SET_1(p, b) SET_2(p, b)
|
|
#define CLR_1(p, b) CLR_2(p, b)
|
|
#define IN_1(p, b) IN_2(p, b)
|
|
#define OUT_1(p, b) OUT_2(p, b)
|
|
#define PIN_1(p, b) PIN_2(p, b)
|
|
|
|
#define SET(n) SET_1(n##_PORT, n##_BIT)
|
|
#define CLR(n) CLR_1(n##_PORT, n##_BIT)
|
|
#define IN(n) IN_1(n##_PORT, n##_BIT)
|
|
#define OUT(n) OUT_1(n##_PORT, n##_BIT)
|
|
#define PIN(n) PIN_1(n##_PORT, n##_BIT)
|
|
|
|
void reset_rf(void);
|
|
uint8_t read_irq(void);
|
|
void led(int on);
|
|
void board_init(void);
|
|
|
|
#endif /* !BOARD_H */
|