blob: 733c1594c9aed0d1b6cfbcbfc650fea6098bfc69 [file] [log] [blame]
Angel Ponsba38f372020-04-05 15:46:45 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Michał Żygowski11194282019-03-27 10:39:55 +01002
Angel Ponsfc8e9972021-04-17 12:12:52 +02003#define __SIMPLE_DEVICE__
4
Michał Żygowski11194282019-03-27 10:39:55 +01005#include <soc/iomap.h>
Frans Hendriks863853c2019-06-18 12:18:55 +02006#include <soc/pci_devs.h>
7#include <device/pci_def.h>
8#include <device/pci_type.h>
9#include <device/pci_ops.h>
Kyösti Mälkki1cae4542020-01-06 12:31:34 +020010#include <device/smbus_host.h>
Frans Hendriks863853c2019-06-18 12:18:55 +020011#include <soc/smbus.h>
Michał Żygowski11194282019-03-27 10:39:55 +010012
Frans Hendriks863853c2019-06-18 12:18:55 +020013int smbus_i2c_block_write(u8 addr, u8 bytes, u8 *buf)
14{
Angel Ponsfc8e9972021-04-17 12:12:52 +020015 const pci_devfn_t dev = PCI_DEV(0, SMBUS_DEV, SMBUS_FUNC);
16
Frans Hendriks863853c2019-06-18 12:18:55 +020017 u32 smbase;
18 u32 smb_ctrl_reg;
19 int status;
20
21 /* SMBus I/O BAR */
22 smbase = pci_read_config32(dev, PCI_BASE_ADDRESS_4) & 0xFFFFFFFE;
23
24 /* Enable I2C_EN bit in HOSTC register */
25 smb_ctrl_reg = pci_read_config32(dev, HOSTC);
26 pci_write_config32(dev, HOSTC, smb_ctrl_reg | HOSTC_I2C_EN);
27
28 status = do_i2c_block_write(smbase, addr, bytes, buf);
29
30 /* Restore I2C_EN bit */
31 pci_write_config32(dev, HOSTC, smb_ctrl_reg);
32
33 return status;
34}