device,sb/intel: Move SMBus host controller prototypes
Also change some of the types to match the register widths of the controller. It is expected that these prototypes will be used with SMBus host controllers inside AMD chipsets as well, thus the change of location. Change-Id: I88fe834f3eee7b7bfeff02f91a1c25bb5aee9b65 Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/38226 Reviewed-by: Angel Pons <th3fanbus@gmail.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
5e9ae0c2bc
commit
1cae45432e
23 changed files with 63 additions and 39 deletions
35
src/include/device/smbus_host.h
Normal file
35
src/include/device/smbus_host.h
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
/*
|
||||||
|
* This file is part of the coreboot project.
|
||||||
|
*
|
||||||
|
* 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 __DEVICE_SMBUS_HOST_H__
|
||||||
|
#define __DEVICE_SMBUS_HOST_H__
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
/* Low-level SMBUS host controller. */
|
||||||
|
|
||||||
|
int do_smbus_recv_byte(uintptr_t base, u8 device);
|
||||||
|
int do_smbus_send_byte(uintptr_t base, u8 device, u8 val);
|
||||||
|
int do_smbus_read_byte(uintptr_t base, u8 device, u8 address);
|
||||||
|
int do_smbus_write_byte(uintptr_t base, u8 device, u8 address, u8 data);
|
||||||
|
int do_smbus_read_word(uintptr_t base, u8 device, u8 address);
|
||||||
|
int do_smbus_write_word(uintptr_t base, u8 device, u8 address, u16 data);
|
||||||
|
|
||||||
|
int do_smbus_block_read(uintptr_t base, u8 device, u8 cmd, size_t max_bytes, u8 *buf);
|
||||||
|
int do_smbus_block_write(uintptr_t base, u8 device, u8 cmd, size_t bytes, const u8 *buf);
|
||||||
|
|
||||||
|
/* For Intel, implemented since ICH5. */
|
||||||
|
int do_i2c_eeprom_read(uintptr_t base, u8 device, u8 offset, size_t bytes, u8 *buf);
|
||||||
|
int do_i2c_block_write(uintptr_t base, u8 device, size_t bytes, u8 *buf);
|
||||||
|
|
||||||
|
#endif
|
|
@ -23,11 +23,11 @@
|
||||||
#include <arch/cpu.h>
|
#include <arch/cpu.h>
|
||||||
#include <device/mmio.h>
|
#include <device/mmio.h>
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include <cbmem.h>
|
#include <cbmem.h>
|
||||||
#include <timestamp.h>
|
#include <timestamp.h>
|
||||||
#include <mrc_cache.h>
|
#include <mrc_cache.h>
|
||||||
#include <southbridge/intel/bd82x6x/me.h>
|
#include <southbridge/intel/bd82x6x/me.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
|
||||||
#include <southbridge/intel/bd82x6x/pch.h>
|
#include <southbridge/intel/bd82x6x/pch.h>
|
||||||
#include <cpu/x86/msr.h>
|
#include <cpu/x86/msr.h>
|
||||||
#include <types.h>
|
#include <types.h>
|
||||||
|
|
|
@ -20,8 +20,8 @@
|
||||||
#include <device/pci_def.h>
|
#include <device/pci_def.h>
|
||||||
#include <device/pci_type.h>
|
#include <device/pci_type.h>
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include <soc/smbus.h>
|
#include <soc/smbus.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
|
||||||
|
|
||||||
int smbus_i2c_block_write(u8 addr, u8 bytes, u8 *buf)
|
int smbus_i2c_block_write(u8 addr, u8 bytes, u8 *buf)
|
||||||
{
|
{
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include <soc/ramstage.h>
|
#include <soc/ramstage.h>
|
||||||
#include <soc/smbus.h>
|
#include <soc/smbus.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <southbridge/intel/common/smbus.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
|
|
||||||
static void pch_smbus_init(struct device *dev)
|
static void pch_smbus_init(struct device *dev)
|
||||||
{
|
{
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#include <device/pci_ids.h>
|
#include <device/pci_ids.h>
|
||||||
#include <soc/smbus.h>
|
#include <soc/smbus.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <southbridge/intel/common/smbus.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include "smbuslib.h"
|
#include "smbuslib.h"
|
||||||
|
|
||||||
static int lsmbus_read_byte(struct device *dev, u8 address)
|
static int lsmbus_read_byte(struct device *dev, u8 address)
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
|
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
#include <spd_bin.h>
|
#include <spd_bin.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <device/smbus_host.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "smbuslib.h"
|
#include "smbuslib.h"
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
#include <device/pci_def.h>
|
#include <device/pci_def.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <southbridge/intel/common/smbus.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include "pch.h"
|
#include "pch.h"
|
||||||
|
|
||||||
void enable_smbus(void)
|
void enable_smbus(void)
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
#include <arch/io.h>
|
#include <arch/io.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <southbridge/intel/common/smbus.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include "pch.h"
|
#include "pch.h"
|
||||||
|
|
||||||
static void pch_smbus_init(struct device *dev)
|
static void pch_smbus_init(struct device *dev)
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include <arch/io.h>
|
#include <arch/io.h>
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
#include <device/smbus_def.h>
|
#include <device/smbus_def.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include <types.h>
|
#include <types.h>
|
||||||
|
|
||||||
#include "smbus.h"
|
#include "smbus.h"
|
||||||
|
@ -332,30 +333,27 @@ static int block_cmd_loop(uintptr_t base, u8 *buf, size_t max_bytes, int flags)
|
||||||
return bytes;
|
return bytes;
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_smbus_read_byte(unsigned int smbus_base, u8 device, unsigned int address)
|
int do_smbus_read_byte(uintptr_t smbus_base, u8 device, u8 address)
|
||||||
{
|
{
|
||||||
return smbus_read_cmd(smbus_base, I801_BYTE_DATA, device, address);
|
return smbus_read_cmd(smbus_base, I801_BYTE_DATA, device, address);
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_smbus_read_word(unsigned int smbus_base, u8 device, unsigned int address)
|
int do_smbus_read_word(uintptr_t smbus_base, u8 device, u8 address)
|
||||||
{
|
{
|
||||||
return smbus_read_cmd(smbus_base, I801_WORD_DATA, device, address);
|
return smbus_read_cmd(smbus_base, I801_WORD_DATA, device, address);
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_smbus_write_byte(unsigned int smbus_base, u8 device, unsigned int address,
|
int do_smbus_write_byte(uintptr_t smbus_base, u8 device, u8 address, u8 data)
|
||||||
unsigned int data)
|
|
||||||
{
|
{
|
||||||
return smbus_write_cmd(smbus_base, I801_BYTE_DATA, device, address, data);
|
return smbus_write_cmd(smbus_base, I801_BYTE_DATA, device, address, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_smbus_write_word(unsigned int smbus_base, u8 device, unsigned int address,
|
int do_smbus_write_word(uintptr_t smbus_base, u8 device, u8 address, u16 data)
|
||||||
unsigned int data)
|
|
||||||
{
|
{
|
||||||
return smbus_write_cmd(smbus_base, I801_WORD_DATA, device, address, data);
|
return smbus_write_cmd(smbus_base, I801_WORD_DATA, device, address, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_smbus_block_read(unsigned int smbus_base, u8 device, u8 cmd,
|
int do_smbus_block_read(uintptr_t smbus_base, u8 device, u8 cmd, size_t max_bytes, u8 *buf)
|
||||||
unsigned int max_bytes, u8 *buf)
|
|
||||||
{
|
{
|
||||||
int ret, slave_bytes;
|
int ret, slave_bytes;
|
||||||
|
|
||||||
|
@ -382,8 +380,7 @@ int do_smbus_block_read(unsigned int smbus_base, u8 device, u8 cmd,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_smbus_block_write(unsigned int smbus_base, u8 device, u8 cmd,
|
int do_smbus_block_write(uintptr_t smbus_base, u8 device, u8 cmd, const size_t bytes, const u8 *buf)
|
||||||
const unsigned int bytes, const u8 *buf)
|
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
@ -418,8 +415,7 @@ static int has_i2c_read_command(void)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int do_i2c_eeprom_read(unsigned int smbus_base, u8 device,
|
int do_i2c_eeprom_read(uintptr_t smbus_base, u8 device, u8 offset, const size_t bytes, u8 *buf)
|
||||||
unsigned int offset, const unsigned int bytes, u8 *buf)
|
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
@ -456,8 +452,7 @@ int do_i2c_eeprom_read(unsigned int smbus_base, u8 device,
|
||||||
* The caller is responsible of settings HOSTC I2C_EN bit prior to making this
|
* The caller is responsible of settings HOSTC I2C_EN bit prior to making this
|
||||||
* call!
|
* call!
|
||||||
*/
|
*/
|
||||||
int do_i2c_block_write(unsigned int smbus_base, u8 device,
|
int do_i2c_block_write(uintptr_t smbus_base, u8 device, size_t bytes, u8 *buf)
|
||||||
unsigned int bytes, u8 *buf)
|
|
||||||
{
|
{
|
||||||
u8 cmd;
|
u8 cmd;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
|
@ -32,22 +32,4 @@
|
||||||
#define SMBUS_PIN_CTL 0xf
|
#define SMBUS_PIN_CTL 0xf
|
||||||
#define SMBSLVCMD 0x11
|
#define SMBSLVCMD 0x11
|
||||||
|
|
||||||
int do_smbus_read_byte(unsigned int smbus_base, u8 device,
|
|
||||||
unsigned int address);
|
|
||||||
int do_smbus_write_byte(unsigned int smbus_base, u8 device,
|
|
||||||
unsigned int address, unsigned int data);
|
|
||||||
int do_smbus_read_word(unsigned int smbus_base, u8 device,
|
|
||||||
unsigned int address);
|
|
||||||
int do_smbus_write_word(unsigned int smbus_base, u8 device,
|
|
||||||
unsigned int address, unsigned int data);
|
|
||||||
|
|
||||||
int do_smbus_block_read(unsigned int smbus_base, u8 device,
|
|
||||||
u8 cmd, unsigned int max_bytes, u8 *buf);
|
|
||||||
int do_smbus_block_write(unsigned int smbus_base, u8 device,
|
|
||||||
u8 cmd, unsigned int bytes, const u8 *buf);
|
|
||||||
/* Only since ICH5 */
|
|
||||||
int do_i2c_eeprom_read(unsigned int smbus_base, u8 device,
|
|
||||||
unsigned int offset, unsigned int bytes, u8 *buf);
|
|
||||||
int do_i2c_block_write(unsigned int smbus_base, u8 device,
|
|
||||||
unsigned int bytes, u8 *buf);
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#include <device/pci_ids.h>
|
#include <device/pci_ids.h>
|
||||||
#include <device/pci_def.h>
|
#include <device/pci_def.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <southbridge/intel/common/smbus.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include "i82371eb.h"
|
#include "i82371eb.h"
|
||||||
|
|
||||||
void enable_smbus(void)
|
void enable_smbus(void)
|
||||||
|
|
|
@ -25,7 +25,6 @@
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
#include <device/pci_ids.h>
|
#include <device/pci_ids.h>
|
||||||
#include <device/smbus.h>
|
#include <device/smbus.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
|
||||||
#include "chip.h"
|
#include "chip.h"
|
||||||
#include "i82371eb.h"
|
#include "i82371eb.h"
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include <device/pci_def.h>
|
#include <device/pci_def.h>
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <southbridge/intel/common/smbus.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
|
|
||||||
#include "i82801dx.h"
|
#include "i82801dx.h"
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
#include <device/pci_def.h>
|
#include <device/pci_def.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <southbridge/intel/common/smbus.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include "i82801gx.h"
|
#include "i82801gx.h"
|
||||||
|
|
||||||
void enable_smbus(void)
|
void enable_smbus(void)
|
||||||
|
|
|
@ -19,7 +19,7 @@
|
||||||
#include <device/smbus.h>
|
#include <device/smbus.h>
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
#include <device/pci_ids.h>
|
#include <device/pci_ids.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <device/smbus_host.h>
|
||||||
#include "i82801gx.h"
|
#include "i82801gx.h"
|
||||||
|
|
||||||
static int lsmbus_read_byte(struct device *dev, u8 address)
|
static int lsmbus_read_byte(struct device *dev, u8 address)
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#include <device/pci_def.h>
|
#include <device/pci_def.h>
|
||||||
#include <device/pci_ids.h>
|
#include <device/pci_ids.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <southbridge/intel/common/smbus.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include "i82801ix.h"
|
#include "i82801ix.h"
|
||||||
|
|
||||||
void enable_smbus(void)
|
void enable_smbus(void)
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
#include <device/pci_ids.h>
|
#include <device/pci_ids.h>
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <device/smbus_host.h>
|
||||||
#include "i82801ix.h"
|
#include "i82801ix.h"
|
||||||
|
|
||||||
static void pch_smbus_init(struct device *dev)
|
static void pch_smbus_init(struct device *dev)
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
#include <device/pci_def.h>
|
#include <device/pci_def.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <southbridge/intel/common/smbus.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include "i82801jx.h"
|
#include "i82801jx.h"
|
||||||
|
|
||||||
void enable_smbus(void)
|
void enable_smbus(void)
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
#include <device/pci.h>
|
#include <device/pci.h>
|
||||||
#include <device/pci_ids.h>
|
#include <device/pci_ids.h>
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <device/smbus_host.h>
|
||||||
#include "i82801jx.h"
|
#include "i82801jx.h"
|
||||||
|
|
||||||
static void pch_smbus_init(struct device *dev)
|
static void pch_smbus_init(struct device *dev)
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
#include <device/pci_def.h>
|
#include <device/pci_def.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <southbridge/intel/common/smbus.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include "pch.h"
|
#include "pch.h"
|
||||||
|
|
||||||
void enable_smbus(void)
|
void enable_smbus(void)
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
#include <arch/io.h>
|
#include <arch/io.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <southbridge/intel/common/smbus.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include "pch.h"
|
#include "pch.h"
|
||||||
|
|
||||||
static void pch_smbus_init(struct device *dev)
|
static void pch_smbus_init(struct device *dev)
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include <console/console.h>
|
#include <console/console.h>
|
||||||
#include <device/pci_def.h>
|
#include <device/pci_def.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <southbridge/intel/common/smbus.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include "pch.h"
|
#include "pch.h"
|
||||||
|
|
||||||
void enable_smbus(void)
|
void enable_smbus(void)
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#include <device/pci_ops.h>
|
#include <device/pci_ops.h>
|
||||||
#include <arch/io.h>
|
#include <arch/io.h>
|
||||||
#include <southbridge/intel/common/smbus.h>
|
#include <southbridge/intel/common/smbus.h>
|
||||||
|
#include <device/smbus_host.h>
|
||||||
#include "pch.h"
|
#include "pch.h"
|
||||||
|
|
||||||
static void pch_smbus_init(struct device *dev)
|
static void pch_smbus_init(struct device *dev)
|
||||||
|
|
Loading…
Reference in a new issue