aboutsummaryrefslogtreecommitdiffstats
path: root/os/hal/boards/OLIMEX_LPC_P1227/board.h
blob: a7dbf18adee8ff826175e0c2ff2783b415a1fdb7 (plain)
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
/*
    ChibiOS - Copyright (C) 2006..2015 Giovanni Di Sirio

    Licensed under the Apache License, Version 2.0 (the "License");
    you may not use this file except in compliance with the License.
    You may obtain a copy of the License at

        http://www.apache.org/licenses/LICENSE-2.0

    Unless required by applicable law or agreed to in writing, software
    distributed under the License is distributed on an "AS IS" BASIS,
    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    See the License for the specific language governing permissions and
    limitations under the License.
*/

#ifndef _BOARD_H_
#define _BOARD_H_

/*
 * Setup for Olimex LPC-P1227 board.
 *
 */

/*
 * Board identifiers.
 */
#define OLIMEX_LPC_P1227
#define BOARD_NAME "Olimex LPC-P1227"

/*
 * Board frequencies.
 */
#define SYSOSCCLK               12000000


/*
 * GPIO 0 initial setup.
 */
#define VAL_GPIO0DIR            0x00000000
#define VAL_GPIO0DATA           0x00000000

/*
 * GPIO 1 initial setup.
 */
#define VAL_GPIO1DIR            PAL_PORT_BIT(GPIO1_LED1)   |                 \
                                PAL_PORT_BIT(GPIO1_LED2)   |                 \
                                PAL_PORT_BIT(GPIO1_BUZZER)

#define VAL_GPIO1DATA           PAL_PORT_BIT(GPIO1_LED1)


/*
 * GPIO 2 initial setup.
 */
#define VAL_GPIO2DIR            PAL_PORT_BIT(GPIO2_LCD_DC)   |               \
                                PAL_PORT_BIT(GPIO2_LCD_SS)   |               \
                                PAL_PORT_BIT(GPIO2_LCD_RES)
#define VAL_GPIO2DATA           PAL_PORT_BIT(GPIO2_LCD_SS)


/*
 * Pin definitions.
 */

#define GPIO1_LED1              5
#define GPIO1_LED2              4
#define GPIO1_SW_WAKEUP         3
#define GPIO1_BUZZER            6

#define GPIO2_SW_USER1          12
#define GPIO2_SW_USER2          11
#define GPIO2_SW_USER3          10
#define GPIO2_LCD_DC            15
#define GPIO2_LCD_SS            14
#define GPIO2_LCD_RES           13

/* LCD3310 pins */
#define LCD3310_RES_PIN   GPIO2_LCD_RES
#define LCD3310_RES_PORT  GPIO2
#define LCD3310_DC_PIN    GPIO2_LCD_DC
#define LCD3310_DC_PORT   GPIO2

#if !defined(_FROM_ASM_)
#ifdef __cplusplus
extern "C" {
#endif
  void boardInit(void);
#ifdef __cplusplus
}
#endif
#endif /* _FROM_ASM_ */

#endif /* _BOARD_H_ */