Braswell: Implement Gpio library functions to read RAMID

Added GPIO library code to allow all BSW board specific code
to use memory configuration GPIOs in GPIO Input mode and read
them to determine which memory type is on the board.

Also added other GPIO related APIs to support GPIO access
in BSW.

Original-Reviewed-on: https://chromium-review.googlesource.com/294893
Original-Reviewed-by: Aaron Durbin <adurbin@chromium.org>

Change-Id: Idd65136c0449f0cdebfae12a510985e29889fa2b
Signed-off-by: Subrata Banik <subrata.banik@intel.com>
Signed-off-by: Hannah Williams <hannah.williams@intel.com>
Reviewed-on: https://review.coreboot.org/12735
Tested-by: build bot (Jenkins)
Reviewed-by: Martin Roth <martinroth@google.com>
This commit is contained in:
Subrata Banik 2015-08-22 10:36:41 +05:30 committed by Martin Roth
parent 2cfab90baa
commit ed7275f2c3
4 changed files with 321 additions and 3 deletions

View file

@ -23,6 +23,7 @@ ramstage-y += gpio.c
ifeq ($(CONFIG_GOP_SUPPORT),n)
ramstage-y += gfx.c
endif
ramstage-y += gpio_support.c
ramstage-y += hda.c
ramstage-y += iosf.c
ramstage-y += lpe.c

View file

@ -12,7 +12,7 @@
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
#include <gpio.h>
#include <console/console.h>
#include <soc/gpio.h>
@ -71,12 +71,97 @@ uint32_t *gpio_pad_config_reg(uint8_t community, uint8_t pad)
* Refer to BSW BIOS Writers Guide, Table "Per Pad Memory Space
* Registers Addresses" for the Pad configuration register calculation.
*/
pad_config_reg = (uint32_t *)(COMMUNITY_BASE(community) + 0x4400 +
(0x400 * (fpad >> 8)) + (8 * (fpad & 0xff)));
pad_config_reg = (uint32_t *)(COMMUNITY_BASE(community)
+ FAMILY_PAD_REGS_OFF + (FAMILY_PAD_REGS_SIZE * (fpad >> 8))
+ (GPIO_REGS_SIZE * (fpad & 0xff)));
return pad_config_reg;
}
static int gpio_get_community_num(gpio_t gpio_num, int *pad)
{
int comm = 0;
if (gpio_num >= GP_SW_00 && gpio_num <= GP_SW_97) {
comm = GP_SOUTHWEST;
*pad = gpio_num % GP_SOUTHWEST_COUNT;
} else if (gpio_num >= GP_NC_00 && gpio_num <= GP_NC_72) {
comm = GP_NORTH;
*pad = gpio_num % GP_SOUTHWEST_COUNT;
} else if (gpio_num >= GP_E_00 && gpio_num <= GP_E_26) {
comm = GP_EAST;
*pad = gpio_num %
(GP_SOUTHWEST_COUNT + GP_NORTH_COUNT);
} else {
comm = GP_SOUTHEAST;
*pad = gpio_num % (GP_SOUTHWEST_COUNT +
GP_NORTH_COUNT + GP_EAST_COUNT);
}
return comm;
}
static void gpio_config_pad(gpio_t gpio_num, const struct soc_gpio_map *cfg)
{
int comm = 0;
int pad_num =0;
uint32_t *pad_config0_reg;
uint32_t *pad_config1_reg;
int max_gpio_cnt = GP_SOUTHWEST_COUNT + GP_NORTH_COUNT + GP_EAST_COUNT
+ GP_SOUTHEAST_COUNT;
if(gpio_num > max_gpio_cnt)
return;
/* Get GPIO Community based on GPIO_NUMBER */
comm = gpio_get_community_num(gpio_num, &pad_num);
/* CONF0 */
pad_config0_reg = gpio_pad_config_reg(comm, pad_num);
/* CONF1 */
pad_config1_reg = pad_config0_reg + 1;
write32(pad_config0_reg, cfg->pad_conf0);
write32(pad_config1_reg, cfg->pad_conf1);
}
void gpio_input_pullup(gpio_t gpio_num)
{
struct soc_gpio_map cfg = GPIO_INPUT_PU_20K;
gpio_config_pad(gpio_num, &cfg);
}
void gpio_input_pulldown(gpio_t gpio_num)
{
struct soc_gpio_map cfg = GPIO_INPUT_PD_20K;
gpio_config_pad(gpio_num, &cfg);
}
void gpio_input(gpio_t gpio_num)
{
struct soc_gpio_map cfg = GPIO_INPUT_NO_PULL;
gpio_config_pad(gpio_num, &cfg);
}
int gpio_get(gpio_t gpio_num)
{
int comm = 0;
int pad_num =0;
uint32_t *pad_config0_reg;
u32 pad_value;
int max_gpio_cnt = GP_SOUTHWEST_COUNT + GP_NORTH_COUNT + GP_EAST_COUNT
+ GP_SOUTHEAST_COUNT;
if(gpio_num > max_gpio_cnt)
return -1;
/* Get GPIO Community based on GPIO_NUMBER */
comm = gpio_get_community_num(gpio_num, &pad_num);
/* CONF0 */
pad_config0_reg = gpio_pad_config_reg(comm, pad_num);
pad_value = read32(pad_config0_reg);
return pad_value & PAD_RX_BIT;
}
int get_gpio(int community_base, int pad0_offset)
{
return (read32((void *)(community_base + pad0_offset))) & PAD_RX_BIT;

View file

@ -19,6 +19,7 @@
#include <stdint.h>
#include <arch/io.h>
#include <soc/gpio_defs.h>
#include <soc/iomap.h>
#define COMMUNITY_SIZE 0x20000
@ -235,6 +236,16 @@
| PAD_CONFIG0_GPI_DEFAULT, \
.pad_conf1 = PAD_CONFIG1_DEFAULT0 }
#define GPIO_INPUT_PD_5K \
{ .pad_conf0 = PAD_PULL_DOWN_5K | PAD_GPIO_ENABLE \
| PAD_CONFIG0_GPI_DEFAULT, \
.pad_conf1 = PAD_CONFIG1_DEFAULT0 }
#define GPIO_INPUT_PD_20K \
{ .pad_conf0 = PAD_PULL_DOWN_20K | PAD_GPIO_ENABLE \
| PAD_CONFIG0_GPI_DEFAULT, \
.pad_conf1 = PAD_CONFIG1_DEFAULT0 }
#define GPIO_INPUT_PU_5K \
{ .pad_conf0 = PAD_PULL_UP_5K | PAD_GPIO_ENABLE \
| PAD_CONFIG0_GPI_DEFAULT, \
@ -567,6 +578,8 @@ static inline void ssus_disable_internal_pull(int pad)
{
}
typedef int gpio_t;
int get_gpio(int community_base, int pad0_offset);
uint16_t gpio_family_number(uint8_t community, uint8_t pad);
uint32_t *gpio_pad_config_reg(uint8_t community, uint8_t pad);

View file

@ -0,0 +1,219 @@
/*
* This file is part of the coreboot project.
*
* Copyright (C) 2013 Google Inc.
* Copyright (C) 2016 Intel Corp.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 2 of the License.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
#ifndef _SOC_GPIO_DEFS_H_
#define _SOC_GPIO_DEFS_H_
/* GPSOUTHWEST */
#define GP_SW_00 0
#define GP_SW_01 1
#define GP_SW_02 2
#define GP_SW_03 3
#define GP_SW_04 4
#define GP_SW_05 5
#define GP_SW_06 6
#define GP_SW_07 7
#define GP_SW_15 8
#define GP_SW_16 9
#define GP_SW_17 10
#define GP_SW_18 11
#define GP_SW_19 12
#define GP_SW_20 13
#define GP_SW_21 14
#define GP_SW_22 15
#define GP_SW_30 16
#define GP_SW_31 17
#define GP_SW_32 18
#define GP_SW_33 19
#define GP_SW_34 20
#define GP_SW_35 21
#define GP_SW_36 22
#define GP_SW_37 23
#define GP_SW_45 24
#define GP_SW_46 25
#define GP_SW_47 26
#define GP_SW_48 27
#define GP_SW_49 28
#define GP_SW_50 29
#define GP_SW_51 30
#define GP_SW_52 31
#define GP_SW_60 32
#define GP_SW_61 33
#define GP_SW_62 34
#define GP_SW_63 35
#define GP_SW_64 36
#define GP_SW_65 37
#define GP_SW_66 38
#define GP_SW_67 39
#define GP_SW_75 40
#define GP_SW_76 41
#define GP_SW_77 42
#define GP_SW_78 43
#define GP_SW_79 44
#define GP_SW_80 45
#define GP_SW_81 46
#define GP_SW_82 47
#define GP_SW_90 48
#define GP_SW_91 49
#define GP_SW_92 50
#define GP_SW_93 51
#define GP_SW_94 52
#define GP_SW_95 53
#define GP_SW_96 54
#define GP_SW_97 55
/* GPNORTH */
#define GP_NC_00 56
#define GP_NC_01 57
#define GP_NC_02 58
#define GP_NC_03 59
#define GP_NC_04 60
#define GP_NC_05 61
#define GP_NC_06 62
#define GP_NC_07 63
#define GP_NC_08 64
#define GP_NC_15 65
#define GP_NC_16 66
#define GP_NC_17 67
#define GP_NC_18 68
#define GP_NC_19 69
#define GP_NC_20 70
#define GP_NC_21 71
#define GP_NC_22 72
#define GP_NC_23 73
#define GP_NC_24 74
#define GP_NC_25 75
#define GP_NC_26 76
#define GP_NC_27 77
#define GP_NC_30 78
#define GP_NC_31 79
#define GP_NC_32 80
#define GP_NC_33 81
#define GP_NC_34 82
#define GP_NC_35 83
#define GP_NC_36 84
#define GP_NC_37 85
#define GP_NC_38 86
#define GP_NC_39 87
#define GP_NC_40 88
#define GP_NC_41 89
#define GP_NC_45 90
#define GP_NC_46 91
#define GP_NC_47 92
#define GP_NC_48 93
#define GP_NC_49 94
#define GP_NC_50 95
#define GP_NC_51 96
#define GP_NC_52 97
#define GP_NC_53 98
#define GP_NC_54 99
#define GP_NC_55 100
#define GP_NC_56 101
#define GP_NC_60 102
#define GP_NC_61 103
#define GP_NC_62 104
#define GP_NC_63 105
#define GP_NC_64 106
#define GP_NC_65 107
#define GP_NC_66 108
#define GP_NC_67 119
#define GP_NC_68 110
#define GP_NC_69 111
#define GP_NC_70 112
#define GP_NC_71 113
#define GP_NC_72 114
/* GPEAST */
#define GP_E_00 115
#define GP_E_01 116
#define GP_E_02 117
#define GP_E_03 118
#define GP_E_04 119
#define GP_E_05 120
#define GP_E_06 121
#define GP_E_07 122
#define GP_E_08 123
#define GP_E_09 124
#define GP_E_10 125
#define GP_E_11 126
#define GP_E_15 127
#define GP_E_16 128
#define GP_E_17 129
#define GP_E_18 130
#define GP_E_19 131
#define GP_E_20 132
#define GP_E_21 133
#define GP_E_22 134
#define GP_E_23 135
#define GP_E_24 136
#define GP_E_25 137
#define GP_E_26 138
/* GPSOUTHEAST */
#define GP_SE_00 139
#define GP_SE_01 140
#define GP_SE_02 141
#define GP_SE_03 142
#define GP_SE_04 143
#define GP_SE_05 144
#define GP_SE_06 145
#define GP_SE_07 146
#define GP_SE_15 147
#define GP_SE_16 148
#define GP_SE_17 149
#define GP_SE_18 150
#define GP_SE_19 151
#define GP_SE_20 152
#define GP_SE_21 153
#define GP_SE_22 154
#define GP_SE_23 155
#define GP_SE_24 156
#define GP_SE_25 157
#define GP_SE_26 158
#define GP_SE_30 159
#define GP_SE_31 160
#define GP_SE_32 161
#define GP_SE_33 162
#define GP_SE_34 163
#define GP_SE_35 164
#define GP_SE_45 165
#define GP_SE_46 166
#define GP_SE_47 167
#define GP_SE_48 168
#define GP_SE_49 169
#define GP_SE_50 170
#define GP_SE_51 171
#define GP_SE_52 172
#define GP_SE_60 173
#define GP_SE_61 174
#define GP_SE_62 175
#define GP_SE_63 176
#define GP_SE_64 177
#define GP_SE_65 178
#define GP_SE_66 179
#define GP_SE_67 180
#define GP_SE_68 181
#define GP_SE_69 182
#define GP_SE_75 183
#define GP_SE_76 184
#define GP_SE_77 185
#define GP_SE_78 186
#define GP_SE_79 187
#define GP_SE_80 188
#define GP_SE_81 189
#define GP_SE_82 190
#define GP_SE_83 191
#define GP_SE_84 192
#define GP_SE_85 193
#endif /* _SOC_GPIO_DEFS_H_ */