summaryrefslogtreecommitdiff
path: root/Silicon/Hisilicon/Include/Library/LpcLib.h
blob: 236a52ba45a74d0f93cfc8d4301f50854d10ce2e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/** @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