73f763071df5ae1c04059bf89372211159155401
[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_IN2                  1
54 #define AO_USB_HAS_INT                  0
55 #define USE_USB_STDIO                   0
56 #define AO_USB_SELF_POWER               0
57 #define AO_USB_DEVICE_ID_SERIAL         1
58
59 #define IS_FLASH_LOADER 0
60
61 /* ADC */
62
63 #define AO_ADC_PIN0_PORT        (&stm_gpioa)
64 #define AO_ADC_PIN0_PIN         6
65 #define AO_ADC_PIN0_CH          6
66
67 #define AO_ADC_RCC_AHBENR       ((1 << STM_RCC_AHBENR_IOPAEN))
68
69 #define AO_NUM_ADC              1
70
71 /* TRNG enable */
72
73 #define AO_TRNG_ENABLE_PORT     (&stm_gpioa)
74 #define AO_TRNG_ENABLE_BIT      8
75
76 /* CRC */
77 #define AO_CRC_WIDTH    32
78 #define AO_CRC_INIT     0xffffffff
79
80 /* TRNG */
81 #define AO_LED_TRNG_COOKED      AO_LED_GREEN
82 #define AO_LED_TRNG_RAW         AO_LED_GREEN
83
84 /* Mode pin */
85 #define AO_RAW_PORT             (&stm_gpioa)
86 #define AO_RAW_BIT              15
87
88 #endif /* _AO_PINS_H_ */