altos/chaoskey: Add support for flipping between raw and cooked bits
[fw/altos] / src / chaoskey-v0.1 / ao_pins.h
1 /*
2  * Copyright © 2015 Keith Packard <keithp@keithp.com>
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; version 2 of the License.
7  *
8  * This program is distributed in the hope that it will be useful, but
9  * WITHOUT ANY WARRANTY; without even the implied warranty of
10  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
11  * General Public License for more details.
12  *
13  * You should have received a copy of the GNU General Public License along
14  * with this program; if not, write to the Free Software Foundation, Inc.,
15  * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
16  */
17
18 #ifndef _AO_PINS_H_
19 #define _AO_PINS_H_
20
21 #define LED_PORT_ENABLE STM_RCC_AHBENR_IOPAEN
22 #define LED_PORT        (&stm_gpioa)
23 #define LED_PIN_RED     2
24 #define LED_PIN_GREEN   3
25 #define AO_LED_RED      (1 << LED_PIN_RED)
26 #define AO_LED_GREEN    (1 << LED_PIN_GREEN)
27
28 #define LEDS_AVAILABLE  (AO_LED_RED | AO_LED_GREEN)
29
30 #define HAS_BEEP        0
31
32 /* 48MHz clock based on USB */
33 #define AO_HSI48        1
34
35 /* HCLK = 48MHz */
36 #define AO_AHB_PRESCALER        1
37 #define AO_RCC_CFGR_HPRE_DIV    STM_RCC_CFGR_HPRE_DIV_1
38
39 /* APB = 48MHz */
40 #define AO_APB_PRESCALER        1
41 #define AO_RCC_CFGR_PPRE_DIV    STM_RCC_CFGR_PPRE_DIV_1
42
43 #define HAS_USB                 1
44 #define AO_USB_DIRECTIO         1
45 #define AO_PA11_PA12_RMP        0
46 #define AO_USB_INTERFACE_CLASS  0xff
47
48 #define IS_FLASH_LOADER 0
49
50 /* ADC */
51
52 #define AO_ADC_PIN0_PORT        (&stm_gpioa)
53 #define AO_ADC_PIN0_PIN         6
54 #define AO_ADC_PIN0_CH          6
55
56 #define AO_ADC_RCC_AHBENR       ((1 << STM_RCC_AHBENR_IOPAEN))
57
58 #define AO_NUM_ADC              1
59
60 /* HV enable */
61
62 #define AO_HV_ENABLE_PORT       (&stm_gpioa)
63 #define AO_HV_ENABLE_BIT        8
64
65 /* CRC */
66 #define AO_CRC_WIDTH    32
67 #define AO_CRC_INIT     0xffffffff
68
69 /* TRNG */
70 #define AO_LED_TRNG_COOKED      AO_LED_GREEN
71 #define AO_LED_TRNG_RAW         AO_LED_RED
72
73 /* Mode pin */
74 #define AO_RAW_PORT             (&stm_gpioa)
75 #define AO_RAW_BIT              15
76
77 #endif /* _AO_PINS_H_ */