blob: 2a7dbd3b17375fb01fada84bd404cb85555877bb (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
|
/*
* Copyright © 2010 Keith Packard <keithp@keithp.com>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 2 of the License.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
*/
#ifndef _AO_PINS_H_
#define _AO_PINS_H_
#define HAS_RADIO 1
#define HAS_RADIO_FORWARD 1
#define HAS_FLIGHT 0
#define HAS_USB 1
#define HAS_BEEP 0
#define HAS_SERIAL_1 1
#define HAS_SERIAL_1_ALT_1 1
#define HAS_SERIAL_1_ALT_2 0
#define HAS_SERIAL_1_HW_FLOW 1
#define USE_SERIAL_1_STDIN 1
#define DELAY_SERIAL_1_STDIN 1
#define HAS_DBG 1
#define HAS_EEPROM 1
#define HAS_LOG 0
#define USE_INTERNAL_FLASH 1
#define HAS_BTM 1
#define DBG_ON_P1 1
#define DBG_ON_P0 0
#define PACKET_HAS_MASTER 1
#define PACKET_HAS_SLAVE 0
#define AO_LED_RED 1
#define AO_LED_BLUE 2
#define LEDS_AVAILABLE (AO_LED_RED|AO_LED_BLUE)
#define AO_MONITOR_LED AO_LED_RED
#define AO_BT_LED AO_LED_BLUE
#define BT_LINK_ON_P2 0
#define BT_LINK_ON_P1 1
#define BT_LINK_PIN_INDEX 7
#define BT_LINK_PIN P1_7
#define HAS_MONITOR 1
#define HAS_MONITOR_PUT 1
#define LEGACY_MONITOR 0
#define HAS_TELEMETRY 0
#define AO_RADIO_REG_TEST 1
#define HAS_ADC 1
#define AO_PAD_ADC_BATT 0
#define AO_ADC_PINS (1 << AO_PAD_ADC_BATT)
struct ao_adc {
int16_t batt;
};
#define AO_ADC_DUMP(p) \
printf ("tick: %5u batt %5d\n", \
(p)->tick, \
(p)->adc.batt)
#define FETCH_ADC() do { \
a = (uint8_t __xdata *) (&ao_data_ring[ao_data_head].adc.batt); \
a[0] = ADCL; \
a[1] = ADCH; \
} while (0)
#if DBG_ON_P1
#define DBG_CLOCK (1 << 4) /* mi0 */
#define DBG_DATA (1 << 5) /* mo0 */
#define DBG_RESET_N (1 << 3) /* c0 */
#define DBG_CLOCK_PIN (P1_4)
#define DBG_DATA_PIN (P1_5)
#define DBG_RESET_N_PIN (P1_3)
#define DBG_PORT_NUM 1
#define DBG_PORT P1
#define DBG_PORT_SEL P1SEL
#define DBG_PORT_INP P1INP
#define DBG_PORT_DIR P1DIR
#endif /* DBG_ON_P1 */
#if DBG_ON_P0
#define DBG_CLOCK (1 << 3)
#define DBG_DATA (1 << 4)
#define DBG_RESET_N (1 << 5)
#define DBG_CLOCK_PIN (P0_3)
#define DBG_DATA_PIN (P0_4)
#define DBG_RESET_N_PIN (P0_5)
#define DBG_PORT_NUM 0
#define DBG_PORT P0
#define DBG_PORT_SEL P0SEL
#define DBG_PORT_INP P0INP
#define DBG_PORT_DIR P0DIR
#endif /* DBG_ON_P0 */
#endif /* _AO_PINS_H_ */
|