soc/amd/*/i2c: Move reset_i2c_peripherals to i2c.c
Move i2c SoC related code from early_fch.c to i2c.c TEST=build boards for each SoC Signed-off-by: Fred Reitberger <reitbergerfred@gmail.com> Change-Id: I69d4b32cf95ce74586bd8971c7ee4b56c1c2fc04 Reviewed-on: https://review.coreboot.org/c/coreboot/+/68499 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Felix Held <felix-coreboot@felixheld.de> Reviewed-by: Jason Glenesk <jason.glenesk@gmail.com> Reviewed-by: Matt DeVillier <matt.devillier@amd.corp-partner.google.com>
This commit is contained in:
committed by
Felix Held
parent
f2b36036c7
commit
13831223be
@@ -12,13 +12,6 @@
|
|||||||
|
|
||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
|
|
||||||
/* Table to switch SCL pins to outputs to initially reset the I2C peripherals */
|
|
||||||
static const struct soc_i2c_scl_pin i2c_scl_pins[] = {
|
|
||||||
I2C_RESET_SCL_PIN(I2C0_SCL_PIN, GPIO_I2C0_SCL),
|
|
||||||
I2C_RESET_SCL_PIN(I2C1_SCL_PIN, GPIO_I2C1_SCL),
|
|
||||||
I2C_RESET_SCL_PIN(I2C2_SCL_PIN, GPIO_I2C2_SCL),
|
|
||||||
I2C_RESET_SCL_PIN(I2C3_SCL_PIN, GPIO_I2C3_SCL),
|
|
||||||
};
|
|
||||||
|
|
||||||
static void lpc_configure_decodes(void)
|
static void lpc_configure_decodes(void)
|
||||||
{
|
{
|
||||||
@@ -26,17 +19,6 @@ static void lpc_configure_decodes(void)
|
|||||||
lpc_enable_port80();
|
lpc_enable_port80();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void reset_i2c_peripherals(void)
|
|
||||||
{
|
|
||||||
const struct soc_amd_cezanne_config *cfg = config_of_soc();
|
|
||||||
struct soc_i2c_peripheral_reset_info reset_info;
|
|
||||||
|
|
||||||
reset_info.i2c_scl_reset_mask = cfg->i2c_scl_reset & GPIO_I2C_MASK;
|
|
||||||
reset_info.i2c_scl = i2c_scl_pins;
|
|
||||||
reset_info.num_pins = ARRAY_SIZE(i2c_scl_pins);
|
|
||||||
sb_reset_i2c_peripherals(&reset_info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Before console init */
|
/* Before console init */
|
||||||
void fch_pre_init(void)
|
void fch_pre_init(void)
|
||||||
{
|
{
|
||||||
|
@@ -6,6 +6,14 @@
|
|||||||
#include <soc/southbridge.h>
|
#include <soc/southbridge.h>
|
||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
|
|
||||||
|
/* Table to switch SCL pins to outputs to initially reset the I2C peripherals */
|
||||||
|
static const struct soc_i2c_scl_pin i2c_scl_pins[] = {
|
||||||
|
I2C_RESET_SCL_PIN(I2C0_SCL_PIN, GPIO_I2C0_SCL),
|
||||||
|
I2C_RESET_SCL_PIN(I2C1_SCL_PIN, GPIO_I2C1_SCL),
|
||||||
|
I2C_RESET_SCL_PIN(I2C2_SCL_PIN, GPIO_I2C2_SCL),
|
||||||
|
I2C_RESET_SCL_PIN(I2C3_SCL_PIN, GPIO_I2C3_SCL),
|
||||||
|
};
|
||||||
|
|
||||||
#if ENV_X86
|
#if ENV_X86
|
||||||
static const struct soc_i2c_ctrlr_info i2c_ctrlr[I2C_CTRLR_COUNT] = {
|
static const struct soc_i2c_ctrlr_info i2c_ctrlr[I2C_CTRLR_COUNT] = {
|
||||||
{ I2C_MASTER_MODE, APU_I2C0_BASE, "I2C0" },
|
{ I2C_MASTER_MODE, APU_I2C0_BASE, "I2C0" },
|
||||||
@@ -32,6 +40,17 @@ void i2c_set_bar(unsigned int bus, uintptr_t bar)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
void reset_i2c_peripherals(void)
|
||||||
|
{
|
||||||
|
const struct soc_amd_cezanne_config *cfg = config_of_soc();
|
||||||
|
struct soc_i2c_peripheral_reset_info reset_info;
|
||||||
|
|
||||||
|
reset_info.i2c_scl_reset_mask = cfg->i2c_scl_reset & GPIO_I2C_MASK;
|
||||||
|
reset_info.i2c_scl = i2c_scl_pins;
|
||||||
|
reset_info.num_pins = ARRAY_SIZE(i2c_scl_pins);
|
||||||
|
sb_reset_i2c_peripherals(&reset_info);
|
||||||
|
}
|
||||||
|
|
||||||
void soc_i2c_misc_init(unsigned int bus, const struct dw_i2c_bus_config *cfg)
|
void soc_i2c_misc_init(unsigned int bus, const struct dw_i2c_bus_config *cfg)
|
||||||
{
|
{
|
||||||
const struct soc_amd_cezanne_config *config = config_of_soc();
|
const struct soc_amd_cezanne_config *config = config_of_soc();
|
||||||
|
@@ -24,5 +24,6 @@
|
|||||||
#define I2C3_SCL_PIN_IOMUX_GPIOxx GPIO_19_IOMUX_GPIOxx
|
#define I2C3_SCL_PIN_IOMUX_GPIOxx GPIO_19_IOMUX_GPIOxx
|
||||||
|
|
||||||
void i2c_set_bar(unsigned int bus, uintptr_t bar);
|
void i2c_set_bar(unsigned int bus, uintptr_t bar);
|
||||||
|
void reset_i2c_peripherals(void);
|
||||||
|
|
||||||
#endif /* AMD_CEZANNE_I2C_H */
|
#endif /* AMD_CEZANNE_I2C_H */
|
||||||
|
@@ -14,25 +14,6 @@
|
|||||||
|
|
||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
|
|
||||||
/* Table to switch SCL pins to outputs to initially reset the I2C peripherals */
|
|
||||||
static const struct soc_i2c_scl_pin i2c_scl_pins[] = {
|
|
||||||
I2C_RESET_SCL_PIN(I2C0_SCL_PIN, GPIO_I2C0_SCL),
|
|
||||||
I2C_RESET_SCL_PIN(I2C1_SCL_PIN, GPIO_I2C1_SCL),
|
|
||||||
I2C_RESET_SCL_PIN(I2C2_SCL_PIN, GPIO_I2C2_SCL),
|
|
||||||
I2C_RESET_SCL_PIN(I2C3_SCL_PIN, GPIO_I2C3_SCL),
|
|
||||||
};
|
|
||||||
|
|
||||||
static void reset_i2c_peripherals(void)
|
|
||||||
{
|
|
||||||
const struct soc_amd_mendocino_config *cfg = config_of_soc();
|
|
||||||
struct soc_i2c_peripheral_reset_info reset_info;
|
|
||||||
|
|
||||||
reset_info.i2c_scl_reset_mask = cfg->i2c_scl_reset & GPIO_I2C_MASK;
|
|
||||||
reset_info.i2c_scl = i2c_scl_pins;
|
|
||||||
reset_info.num_pins = ARRAY_SIZE(i2c_scl_pins);
|
|
||||||
sb_reset_i2c_peripherals(&reset_info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Before console init */
|
/* Before console init */
|
||||||
void fch_pre_init(void)
|
void fch_pre_init(void)
|
||||||
{
|
{
|
||||||
|
@@ -6,6 +6,14 @@
|
|||||||
#include <soc/southbridge.h>
|
#include <soc/southbridge.h>
|
||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
|
|
||||||
|
/* Table to switch SCL pins to outputs to initially reset the I2C peripherals */
|
||||||
|
static const struct soc_i2c_scl_pin i2c_scl_pins[] = {
|
||||||
|
I2C_RESET_SCL_PIN(I2C0_SCL_PIN, GPIO_I2C0_SCL),
|
||||||
|
I2C_RESET_SCL_PIN(I2C1_SCL_PIN, GPIO_I2C1_SCL),
|
||||||
|
I2C_RESET_SCL_PIN(I2C2_SCL_PIN, GPIO_I2C2_SCL),
|
||||||
|
I2C_RESET_SCL_PIN(I2C3_SCL_PIN, GPIO_I2C3_SCL),
|
||||||
|
};
|
||||||
|
|
||||||
#if ENV_X86
|
#if ENV_X86
|
||||||
static const struct soc_i2c_ctrlr_info i2c_ctrlr[I2C_CTRLR_COUNT] = {
|
static const struct soc_i2c_ctrlr_info i2c_ctrlr[I2C_CTRLR_COUNT] = {
|
||||||
{ I2C_MASTER_MODE, APU_I2C0_BASE, "I2C0" },
|
{ I2C_MASTER_MODE, APU_I2C0_BASE, "I2C0" },
|
||||||
@@ -32,6 +40,17 @@ void i2c_set_bar(unsigned int bus, uintptr_t bar)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
void reset_i2c_peripherals(void)
|
||||||
|
{
|
||||||
|
const struct soc_amd_mendocino_config *cfg = config_of_soc();
|
||||||
|
struct soc_i2c_peripheral_reset_info reset_info;
|
||||||
|
|
||||||
|
reset_info.i2c_scl_reset_mask = cfg->i2c_scl_reset & GPIO_I2C_MASK;
|
||||||
|
reset_info.i2c_scl = i2c_scl_pins;
|
||||||
|
reset_info.num_pins = ARRAY_SIZE(i2c_scl_pins);
|
||||||
|
sb_reset_i2c_peripherals(&reset_info);
|
||||||
|
}
|
||||||
|
|
||||||
void soc_i2c_misc_init(unsigned int bus, const struct dw_i2c_bus_config *cfg)
|
void soc_i2c_misc_init(unsigned int bus, const struct dw_i2c_bus_config *cfg)
|
||||||
{
|
{
|
||||||
const struct soc_amd_mendocino_config *config = config_of_soc();
|
const struct soc_amd_mendocino_config *config = config_of_soc();
|
||||||
|
@@ -24,5 +24,6 @@
|
|||||||
#define I2C3_SCL_PIN_IOMUX_GPIOxx GPIO_19_IOMUX_GPIOxx
|
#define I2C3_SCL_PIN_IOMUX_GPIOxx GPIO_19_IOMUX_GPIOxx
|
||||||
|
|
||||||
void i2c_set_bar(unsigned int bus, uintptr_t bar);
|
void i2c_set_bar(unsigned int bus, uintptr_t bar);
|
||||||
|
void reset_i2c_peripherals(void);
|
||||||
|
|
||||||
#endif /* AMD_MENDOCINO_I2C_H */
|
#endif /* AMD_MENDOCINO_I2C_H */
|
||||||
|
@@ -14,25 +14,6 @@
|
|||||||
|
|
||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
|
|
||||||
/* Table to switch SCL pins to outputs to initially reset the I2C peripherals */
|
|
||||||
static const struct soc_i2c_scl_pin i2c_scl_pins[] = {
|
|
||||||
I2C_RESET_SCL_PIN(I2C0_SCL_PIN, GPIO_I2C0_SCL),
|
|
||||||
I2C_RESET_SCL_PIN(I2C1_SCL_PIN, GPIO_I2C1_SCL),
|
|
||||||
I2C_RESET_SCL_PIN(I2C2_SCL_PIN, GPIO_I2C2_SCL),
|
|
||||||
I2C_RESET_SCL_PIN(I2C3_SCL_PIN, GPIO_I2C3_SCL),
|
|
||||||
};
|
|
||||||
|
|
||||||
static void reset_i2c_peripherals(void)
|
|
||||||
{
|
|
||||||
const struct soc_amd_morgana_config *cfg = config_of_soc();
|
|
||||||
struct soc_i2c_peripheral_reset_info reset_info;
|
|
||||||
|
|
||||||
reset_info.i2c_scl_reset_mask = cfg->i2c_scl_reset & GPIO_I2C_MASK;
|
|
||||||
reset_info.i2c_scl = i2c_scl_pins;
|
|
||||||
reset_info.num_pins = ARRAY_SIZE(i2c_scl_pins);
|
|
||||||
sb_reset_i2c_peripherals(&reset_info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Before console init */
|
/* Before console init */
|
||||||
void fch_pre_init(void)
|
void fch_pre_init(void)
|
||||||
{
|
{
|
||||||
|
@@ -8,6 +8,14 @@
|
|||||||
#include <soc/southbridge.h>
|
#include <soc/southbridge.h>
|
||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
|
|
||||||
|
/* Table to switch SCL pins to outputs to initially reset the I2C peripherals */
|
||||||
|
static const struct soc_i2c_scl_pin i2c_scl_pins[] = {
|
||||||
|
I2C_RESET_SCL_PIN(I2C0_SCL_PIN, GPIO_I2C0_SCL),
|
||||||
|
I2C_RESET_SCL_PIN(I2C1_SCL_PIN, GPIO_I2C1_SCL),
|
||||||
|
I2C_RESET_SCL_PIN(I2C2_SCL_PIN, GPIO_I2C2_SCL),
|
||||||
|
I2C_RESET_SCL_PIN(I2C3_SCL_PIN, GPIO_I2C3_SCL),
|
||||||
|
};
|
||||||
|
|
||||||
#if ENV_X86
|
#if ENV_X86
|
||||||
static const struct soc_i2c_ctrlr_info i2c_ctrlr[I2C_CTRLR_COUNT] = {
|
static const struct soc_i2c_ctrlr_info i2c_ctrlr[I2C_CTRLR_COUNT] = {
|
||||||
{ I2C_MASTER_MODE, APU_I2C0_BASE, "I2C0" },
|
{ I2C_MASTER_MODE, APU_I2C0_BASE, "I2C0" },
|
||||||
@@ -34,6 +42,17 @@ void i2c_set_bar(unsigned int bus, uintptr_t bar)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
void reset_i2c_peripherals(void)
|
||||||
|
{
|
||||||
|
const struct soc_amd_morgana_config *cfg = config_of_soc();
|
||||||
|
struct soc_i2c_peripheral_reset_info reset_info;
|
||||||
|
|
||||||
|
reset_info.i2c_scl_reset_mask = cfg->i2c_scl_reset & GPIO_I2C_MASK;
|
||||||
|
reset_info.i2c_scl = i2c_scl_pins;
|
||||||
|
reset_info.num_pins = ARRAY_SIZE(i2c_scl_pins);
|
||||||
|
sb_reset_i2c_peripherals(&reset_info);
|
||||||
|
}
|
||||||
|
|
||||||
void soc_i2c_misc_init(unsigned int bus, const struct dw_i2c_bus_config *cfg)
|
void soc_i2c_misc_init(unsigned int bus, const struct dw_i2c_bus_config *cfg)
|
||||||
{
|
{
|
||||||
const struct soc_amd_morgana_config *config = config_of_soc();
|
const struct soc_amd_morgana_config *config = config_of_soc();
|
||||||
|
@@ -26,5 +26,6 @@
|
|||||||
#define I2C3_SCL_PIN_IOMUX_GPIOxx GPIO_19_IOMUX_GPIOxx
|
#define I2C3_SCL_PIN_IOMUX_GPIOxx GPIO_19_IOMUX_GPIOxx
|
||||||
|
|
||||||
void i2c_set_bar(unsigned int bus, uintptr_t bar);
|
void i2c_set_bar(unsigned int bus, uintptr_t bar);
|
||||||
|
void reset_i2c_peripherals(void);
|
||||||
|
|
||||||
#endif /* AMD_MORGANA_I2C_H */
|
#endif /* AMD_MORGANA_I2C_H */
|
||||||
|
@@ -14,30 +14,12 @@
|
|||||||
|
|
||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
|
|
||||||
/* Table to switch SCL pins to outputs to initially reset the I2C peripherals */
|
|
||||||
static const struct soc_i2c_scl_pin i2c_scl_pins[] = {
|
|
||||||
I2C_RESET_SCL_PIN(I2C2_SCL_PIN, GPIO_I2C2_SCL),
|
|
||||||
I2C_RESET_SCL_PIN(I2C3_SCL_PIN, GPIO_I2C3_SCL),
|
|
||||||
/* I2C4 is a peripheral device only */
|
|
||||||
};
|
|
||||||
|
|
||||||
static void lpc_configure_decodes(void)
|
static void lpc_configure_decodes(void)
|
||||||
{
|
{
|
||||||
if (CONFIG(POST_IO) && (CONFIG_POST_IO_PORT == 0x80))
|
if (CONFIG(POST_IO) && (CONFIG_POST_IO_PORT == 0x80))
|
||||||
lpc_enable_port80();
|
lpc_enable_port80();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void reset_i2c_peripherals(void)
|
|
||||||
{
|
|
||||||
const struct soc_amd_picasso_config *cfg = config_of_soc();
|
|
||||||
struct soc_i2c_peripheral_reset_info reset_info;
|
|
||||||
|
|
||||||
reset_info.i2c_scl_reset_mask = cfg->i2c_scl_reset & GPIO_I2C_MASK;
|
|
||||||
reset_info.i2c_scl = i2c_scl_pins;
|
|
||||||
reset_info.num_pins = ARRAY_SIZE(i2c_scl_pins);
|
|
||||||
sb_reset_i2c_peripherals(&reset_info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Before console init */
|
/* Before console init */
|
||||||
void fch_pre_init(void)
|
void fch_pre_init(void)
|
||||||
{
|
{
|
||||||
|
@@ -9,6 +9,13 @@
|
|||||||
#include <soc/southbridge.h>
|
#include <soc/southbridge.h>
|
||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
|
|
||||||
|
/* Table to switch SCL pins to outputs to initially reset the I2C peripherals */
|
||||||
|
static const struct soc_i2c_scl_pin i2c_scl_pins[] = {
|
||||||
|
I2C_RESET_SCL_PIN(I2C2_SCL_PIN, GPIO_I2C2_SCL),
|
||||||
|
I2C_RESET_SCL_PIN(I2C3_SCL_PIN, GPIO_I2C3_SCL),
|
||||||
|
/* I2C4 is a peripheral device only */
|
||||||
|
};
|
||||||
|
|
||||||
#if ENV_X86
|
#if ENV_X86
|
||||||
/* Preferably keep all the I2C controllers operating in a specific mode together. */
|
/* Preferably keep all the I2C controllers operating in a specific mode together. */
|
||||||
static const struct soc_i2c_ctrlr_info i2c_ctrlr[I2C_CTRLR_COUNT] = {
|
static const struct soc_i2c_ctrlr_info i2c_ctrlr[I2C_CTRLR_COUNT] = {
|
||||||
@@ -38,6 +45,17 @@ void i2c_set_bar(unsigned int bus, uintptr_t bar)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
void reset_i2c_peripherals(void)
|
||||||
|
{
|
||||||
|
const struct soc_amd_picasso_config *cfg = config_of_soc();
|
||||||
|
struct soc_i2c_peripheral_reset_info reset_info;
|
||||||
|
|
||||||
|
reset_info.i2c_scl_reset_mask = cfg->i2c_scl_reset & GPIO_I2C_MASK;
|
||||||
|
reset_info.i2c_scl = i2c_scl_pins;
|
||||||
|
reset_info.num_pins = ARRAY_SIZE(i2c_scl_pins);
|
||||||
|
sb_reset_i2c_peripherals(&reset_info);
|
||||||
|
}
|
||||||
|
|
||||||
void soc_i2c_misc_init(unsigned int bus, const struct dw_i2c_bus_config *cfg)
|
void soc_i2c_misc_init(unsigned int bus, const struct dw_i2c_bus_config *cfg)
|
||||||
{
|
{
|
||||||
/* TODO: Picasso supports I2C RX pad configurations 3.3V, 1.8V and off, so make this
|
/* TODO: Picasso supports I2C RX pad configurations 3.3V, 1.8V and off, so make this
|
||||||
|
@@ -25,5 +25,6 @@
|
|||||||
|
|
||||||
/* Sets the base address for the specific I2C bus. */
|
/* Sets the base address for the specific I2C bus. */
|
||||||
void i2c_set_bar(unsigned int bus, uintptr_t bar);
|
void i2c_set_bar(unsigned int bus, uintptr_t bar);
|
||||||
|
void reset_i2c_peripherals(void);
|
||||||
|
|
||||||
#endif /* AMD_PICASSO_I2C_H */
|
#endif /* AMD_PICASSO_I2C_H */
|
||||||
|
@@ -12,14 +12,6 @@
|
|||||||
|
|
||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
|
|
||||||
/* Table to switch SCL pins to outputs to initially reset the I2C peripherals */
|
|
||||||
static const struct soc_i2c_scl_pin i2c_scl_pins[] = {
|
|
||||||
I2C_RESET_SCL_PIN(I2C0_SCL_PIN, GPIO_I2C0_SCL),
|
|
||||||
I2C_RESET_SCL_PIN(I2C1_SCL_PIN, GPIO_I2C1_SCL),
|
|
||||||
I2C_RESET_SCL_PIN(I2C2_SCL_PIN, GPIO_I2C2_SCL),
|
|
||||||
I2C_RESET_SCL_PIN(I2C3_SCL_PIN, GPIO_I2C3_SCL),
|
|
||||||
};
|
|
||||||
|
|
||||||
static void sb_lpc_decode(void)
|
static void sb_lpc_decode(void)
|
||||||
{
|
{
|
||||||
u32 tmp = 0;
|
u32 tmp = 0;
|
||||||
@@ -111,17 +103,6 @@ static void setup_misc(int *reboot)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void reset_i2c_peripherals(void)
|
|
||||||
{
|
|
||||||
const struct soc_amd_stoneyridge_config *cfg = config_of_soc();
|
|
||||||
struct soc_i2c_peripheral_reset_info reset_info;
|
|
||||||
|
|
||||||
reset_info.i2c_scl_reset_mask = cfg->i2c_scl_reset & GPIO_I2C_MASK;
|
|
||||||
reset_info.i2c_scl = i2c_scl_pins;
|
|
||||||
reset_info.num_pins = ARRAY_SIZE(i2c_scl_pins);
|
|
||||||
sb_reset_i2c_peripherals(&reset_info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Before console init */
|
/* Before console init */
|
||||||
void bootblock_fch_early_init(void)
|
void bootblock_fch_early_init(void)
|
||||||
{
|
{
|
||||||
|
@@ -7,6 +7,14 @@
|
|||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
#include <drivers/i2c/designware/dw_i2c.h>
|
#include <drivers/i2c/designware/dw_i2c.h>
|
||||||
|
|
||||||
|
/* Table to switch SCL pins to outputs to initially reset the I2C peripherals */
|
||||||
|
static const struct soc_i2c_scl_pin i2c_scl_pins[] = {
|
||||||
|
I2C_RESET_SCL_PIN(I2C0_SCL_PIN, GPIO_I2C0_SCL),
|
||||||
|
I2C_RESET_SCL_PIN(I2C1_SCL_PIN, GPIO_I2C1_SCL),
|
||||||
|
I2C_RESET_SCL_PIN(I2C2_SCL_PIN, GPIO_I2C2_SCL),
|
||||||
|
I2C_RESET_SCL_PIN(I2C3_SCL_PIN, GPIO_I2C3_SCL),
|
||||||
|
};
|
||||||
|
|
||||||
static const struct soc_i2c_ctrlr_info i2c_ctrlr[] = {
|
static const struct soc_i2c_ctrlr_info i2c_ctrlr[] = {
|
||||||
{ I2C_MASTER_MODE, APU_I2C0_BASE, "I2CA" },
|
{ I2C_MASTER_MODE, APU_I2C0_BASE, "I2CA" },
|
||||||
{ I2C_MASTER_MODE, APU_I2C1_BASE, "I2CB" },
|
{ I2C_MASTER_MODE, APU_I2C1_BASE, "I2CB" },
|
||||||
@@ -14,6 +22,17 @@ static const struct soc_i2c_ctrlr_info i2c_ctrlr[] = {
|
|||||||
{ I2C_MASTER_MODE, APU_I2C3_BASE, "I2CD" },
|
{ I2C_MASTER_MODE, APU_I2C3_BASE, "I2CD" },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void reset_i2c_peripherals(void)
|
||||||
|
{
|
||||||
|
const struct soc_amd_stoneyridge_config *cfg = config_of_soc();
|
||||||
|
struct soc_i2c_peripheral_reset_info reset_info;
|
||||||
|
|
||||||
|
reset_info.i2c_scl_reset_mask = cfg->i2c_scl_reset & GPIO_I2C_MASK;
|
||||||
|
reset_info.i2c_scl = i2c_scl_pins;
|
||||||
|
reset_info.num_pins = ARRAY_SIZE(i2c_scl_pins);
|
||||||
|
sb_reset_i2c_peripherals(&reset_info);
|
||||||
|
}
|
||||||
|
|
||||||
const struct soc_i2c_ctrlr_info *soc_get_i2c_ctrlr_info(size_t *num_ctrlrs)
|
const struct soc_i2c_ctrlr_info *soc_get_i2c_ctrlr_info(size_t *num_ctrlrs)
|
||||||
{
|
{
|
||||||
*num_ctrlrs = ARRAY_SIZE(i2c_ctrlr);
|
*num_ctrlrs = ARRAY_SIZE(i2c_ctrlr);
|
||||||
|
@@ -22,4 +22,6 @@
|
|||||||
#define I2C2_SCL_PIN_IOMUX_GPIOxx GPIO_113_IOMUX_GPIOxx
|
#define I2C2_SCL_PIN_IOMUX_GPIOxx GPIO_113_IOMUX_GPIOxx
|
||||||
#define I2C3_SCL_PIN_IOMUX_GPIOxx GPIO_19_IOMUX_GPIOxx
|
#define I2C3_SCL_PIN_IOMUX_GPIOxx GPIO_19_IOMUX_GPIOxx
|
||||||
|
|
||||||
|
void reset_i2c_peripherals(void);
|
||||||
|
|
||||||
#endif /* AMD_STONEYRIDGE_I2C_H */
|
#endif /* AMD_STONEYRIDGE_I2C_H */
|
||||||
|
Reference in New Issue
Block a user