altos: Add ChaosKey v1.0 product
[fw/altos] / src / chaoskey-v1.0 / 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_IOPBEN
22 #define LED_PORT        (&stm_gpiob)
23 #define LED_PIN_RED     4
24 #define AO_LED_RED      (1 << LED_PIN_RED)
25
26 #define LEDS_AVAILABLE  (AO_LED_RED)
27
28 #define AO_POWER_MANAGEMENT     1
29 #define AO_LED_POWER            AO_LED_RED
30
31 #define HAS_BEEP        0
32
33 /* 48MHz clock based on USB */
34 #define AO_HSI48        1
35
36 /* HCLK = 48MHz */
37 #define AO_AHB_PRESCALER        1
38 #define AO_RCC_CFGR_HPRE_DIV    STM_RCC_CFGR_HPRE_DIV_1
39
40 /* APB = 48MHz */
41 #define AO_APB_PRESCALER        1
42 #define AO_RCC_CFGR_PPRE_DIV    STM_RCC_CFGR_PPRE_DIV_1
43
44 #define HAS_USB                         1
45 #define AO_USB_DIRECTIO                 1
46 #define AO_PA11_PA12_RMP                1
47 #define AO_USB_DEVICE_CLASS             0xff
48 #define AO_USB_INTERFACE_CLASS_DATA     0xff
49 #define AO_USB_HAS_OUT                  0
50 #define AO_USB_HAS_IN                   1
51 #define AO_USB_HAS_IN2                  1
52 #define AO_USB_HAS_INT                  0
53 #define AO_USB_SELF_POWER               0
54 #define AO_USB_DEVICE_ID_SERIAL         1
55 #define AO_USB_START_DISABLED           1
56 #define USE_USB_STDIO                   0
57
58 #define IS_FLASH_LOADER 0
59
60 /* ADC */
61
62 #define AO_ADC_PIN0_PORT        (&stm_gpioa)
63 #define AO_ADC_PIN0_PIN         0
64 #define AO_ADC_PIN0_CH          0
65
66 #define AO_ADC_RCC_AHBENR       ((1 << STM_RCC_AHBENR_IOPAEN))
67
68 #define AO_NUM_ADC              1
69
70 /* TRNG enable */
71
72 #define AO_TRNG_ENABLE_PORT     (&stm_gpioa)
73 #define AO_TRNG_ENABLE_BIT      1
74
75 /* CRC */
76 #define AO_CRC_WIDTH    32
77 #define AO_CRC_INIT     0xffffffff
78
79 /* Mode pin */
80 #define AO_RAW_PORT             (&stm_gpioa)
81 #define AO_RAW_BIT              15
82
83 #endif /* _AO_PINS_H_ */