/** @file
*
* Copyright (c) 2016, Hisilicon Limited. All rights reserved.
* Copyright (c) 2016, Linaro Limited. All rights reserved.
*
* This program and the accompanying materials
* are licensed and made available under the terms and conditions of the BSD License
* which accompanies this distribution. The full text of the license may be found at
* http://opensource.org/licenses/bsd-license.php
*
* THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
* WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
*
**/
#ifndef _LPC_LIB_H_
#define _LPC_LIB_H_
#include <Uefi.h>
#define PCIE_SUBSYS_IO_MUX 0xA0170000
#define PCIE_SUBSYS_IOMG033 (PCIE_SUBSYS_IO_MUX + 0x84)
#define PCIE_SUBSYS_IOMG035 (PCIE_SUBSYS_IO_MUX + 0x8C)
#define PCIE_SUBSYS_IOMG036 (PCIE_SUBSYS_IO_MUX + 0x90)
#define PCIE_SUBSYS_IOMG045 (PCIE_SUBSYS_IO_MUX + 0xB4)
#define PCIE_SUBSYS_IOMG046 (PCIE_SUBSYS_IO_MUX + 0xB8)
#define PCIE_SUBSYS_IOMG047 (PCIE_SUBSYS_IO_MUX + 0xBC)
#define PCIE_SUBSYS_IOMG048 (PCIE_SUBSYS_IO_MUX + 0xC0)
#define PCIE_SUBSYS_IOMG049 (PCIE_SUBSYS_IO_MUX + 0xC4)
#define PCIE_SUBSYS_IOMG050 (PCIE_SUBSYS_IO_MUX + 0xC8)
#define IO_WRAP_CTRL_BASE 0xA0100000
#define SC_LPC_CLK_EN_REG (IO_WRAP_CTRL_BASE + 0x03a0)
#define SC_LPC_CLK_DIS_REG (IO_WRAP_CTRL_BASE + 0x03a4)
#define SC_LPC_BUS_CLK_EN_REG (IO_WRAP_CTRL_BASE + 0x03a8)
#define SC_LPC_BUS_CLK_DIS_REG (IO_WRAP_CTRL_BASE + 0x03ac)
#define SC_LPC_RESET_REQ (IO_WRAP_CTRL_BASE + 0x0ad8)
#define SC_LPC_RESET_DREQ (IO_WRAP_CTRL_BASE + 0x0adc)
#define SC_LPC_BUS_RESET_REQ (IO_WRAP_CTRL_BASE + 0x0ae0)
#define SC_LPC_BUS_RESET_DREQ (IO_WRAP_CTRL_BASE + 0x0ae4)
#define SC_LPC_CTRL_REG (IO_WRAP_CTRL_BASE + 0x2028)
#define LPC_BASE 0xA01B0000
#define LPC_START_REG (LPC_BASE + 0x00)
#define LPC_OP_STATUS_REG (LPC_BASE + 0x04)
#define LPC_IRQ_ST_REG (LPC_BASE + 0x08)
#define LPC_OP_LEN_REG (LPC_BASE + 0x10)
#define LPC_CMD_REG (LPC_BASE + 0x14)
#define LPC_FWH_ID_MSIZE_REG (LPC_BASE + 0x18)
#define LPC_ADDR_REG (LPC_BASE + 0x20)
#define LPC_WDATA_REG (LPC_BASE + 0x24)
#define LPC_RDATA_REG (LPC_BASE + 0x28)
#define LPC_LONG_CNT_REG (LPC_BASE + 0x30)
#define LPC_TX_FIFO_ST_REG (LPC_BASE + 0x50)
#define LPC_RX_FIFO_ST_REG (LPC_BASE + 0x54)
#define LPC_TIME_OUT_REG (LPC_BASE + 0x58)
#define LPC_SIRQ_CTRL0_REG (LPC_BASE + 0x80)
#define LPC_SIRQ_CTRL1_REG (LPC_BASE + 0x84)
#define LPC_SIRQ_INT_REG (LPC_BASE + 0x90)
#define LPC_SIRQ_INT_MASK_REG (LPC_BASE + 0x94)
#define LPC_SIRQ_STAT_REG (LPC_BASE + 0xA0)
#define LPC_FIFO_LEN (16)
typedef enum{
LPC_ADDR_MODE_INCREASE,
LPC_ADDR_MODE_SINGLE
}LPC_ADDR_MODE;
typedef enum{
LPC_TYPE_IO,
LPC_TYPE_MEM,
LPC_TYPE_FWH
}LPC_TYPE;
typedef union {
struct{
UINT32 lpc_wr:1;
UINT32 lpc_type:2;
UINT32 same_addr:1;
UINT32 resv:28;
}bits;
UINT32 u32;
}LPC_CMD_STRUCT;
typedef union {
struct{
UINT32 op_len:5;
UINT32 resv:27;
}bits;
UINT32 u32;
}LPC_OP_LEN_STRUCT;
VOID LpcInit(VOID);
BOOLEAN LpcIdle(VOID);
EFI_STATUS LpcByteWrite(
IN UINT32 Addr,
IN UINT8 Data);
EFI_STATUS LpcByteRead(
IN UINT32 Addr,
IN OUT UINT8 *Data);
EFI_STATUS LpcWrite(
IN UINT32 Addr,
IN UINT8 *Data,
IN UINT8 Len);
#endif