altos/chaoskey: Encode both hardware and software versions in product ID
[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 AO_POWER_MANAGEMENT     1
31 #define AO_LED_POWER            AO_LED_RED
32
33 #define HAS_BEEP        0
34
35 /* 48MHz clock based on USB */
36 #define AO_HSI48        1
37
38 /* HCLK = 48MHz */
39 #define AO_AHB_PRESCALER        1
40 #define AO_RCC_CFGR_HPRE_DIV    STM_RCC_CFGR_HPRE_DIV_1
41
42 /* APB = 48MHz */
43 #define AO_APB_PRESCALER        1
44 #define AO_RCC_CFGR_PPRE_DIV    STM_RCC_CFGR_PPRE_DIV_1
45
46 #define HAS_USB                         1
47 #define AO_USB_DIRECTIO                 1
48 #define AO_PA11_PA12_RMP                0
49 #define AO_USB_DEVICE_CLASS             0xff
50 #define AO_USB_INTERFACE_CLASS_DATA     0xff
51 #define AO_USB_HAS_OUT                  0
52 #define AO_USB_HAS_IN                   1
53 #define AO_USB_HAS_INT                  0
54 #define AO_USB_SELF_POWER               0
55
56 #define IS_FLASH_LOADER 0
57
58 /* ADC */
59
60 #define AO_ADC_PIN0_PORT        (&stm_gpioa)
61 #define AO_ADC_PIN0_PIN         6
62 #define AO_ADC_PIN0_CH          6
63
64 #define AO_ADC_RCC_AHBENR       ((1 << STM_RCC_AHBENR_IOPAEN))
65
66 #define AO_NUM_ADC              1
67
68 /* TRNG enable */
69
70 #define AO_TRNG_ENABLE_PORT     (&stm_gpioa)
71 #define AO_TRNG_ENABLE_BIT      8
72
73 /* CRC */
74 #define AO_CRC_WIDTH    32
75 #define AO_CRC_INIT     0xffffffff
76
77 /* TRNG */
78 #define AO_LED_TRNG_COOKED      AO_LED_GREEN
79 #define AO_LED_TRNG_RAW         AO_LED_GREEN
80
81 /* Mode pin */
82 #define AO_RAW_PORT             (&stm_gpioa)
83 #define AO_RAW_BIT              15
84
85 #endif /* _AO_PINS_H_ */