blob: 79f49bd5f673a3c6a454358d5d0a7b799d8b9ffd [file] [log] [blame]
Simon Glassca831f42016-01-18 20:19:17 -07001/*
2 * Copyright (c) 2015 Google, Inc
3 * Written by Simon Glass <sjg@chromium.org>
4 *
5 * SPDX-License-Identifier: GPL-2.0+
6 */
7
8#ifndef __pch_h
9#define __pch_h
10
11enum pch_version {
12 PCHV_UNKNOWN,
13 PCHV_7,
14 PCHV_9,
15};
16
Simon Glass1ff4f322016-01-18 20:19:18 -070017#define PCH_RCBA 0xf0
18
19#define BIOS_CTRL_BIOSWE BIT(0)
20
Simon Glassca831f42016-01-18 20:19:17 -070021/* Operations for the Platform Controller Hub */
22struct pch_ops {
23 /**
24 * get_sbase() - get the address of SPI base
25 *
26 * @dev: PCH device to check
27 * @sbasep: Returns address of SPI base if available, else 0
28 * @return 0 if OK, -ve on error (e.g. there is no SPI base)
29 */
30 int (*get_sbase)(struct udevice *dev, ulong *sbasep);
31
32 /**
33 * get_version() - get the PCH version
34 *
35 * @return version, or -ENOSYS if unknown
36 */
37 enum pch_version (*get_version)(struct udevice *dev);
38
39 /**
40 * set_spi_protect() - set whether SPI flash is protected or not
41 *
42 * @dev: PCH device to adjust
43 * @protect: true to protect, false to unprotect
44 *
45 * @return 0 on success, -ENOSYS if not implemented
46 */
47 int (*set_spi_protect)(struct udevice *dev, bool protect);
48};
49
50#define pch_get_ops(dev) ((struct pch_ops *)(dev)->driver->ops)
51
52/**
53 * pch_get_sbase() - get the address of SPI base
54 *
55 * @dev: PCH device to check
56 * @sbasep: Returns address of SPI base if available, else 0
57 * @return 0 if OK, -ve on error (e.g. there is no SPI base)
58 */
59int pch_get_sbase(struct udevice *dev, ulong *sbasep);
60
61/**
62 * pch_get_version() - get the PCH version
63 *
64 * @return version, or -ENOSYS if unknown
65 */
66enum pch_version pch_get_version(struct udevice *dev);
67
68/**
69 * set_spi_protect() - set whether SPI flash is protected or not
70 *
71 * @dev: PCH device to adjust
72 * @protect: true to protect, false to unprotect
73 *
74 * @return 0 on success, -ENOSYS if not implemented
75 */
76int pch_set_spi_protect(struct udevice *dev, bool protect);
77
78#endif