blob: ef724221c2e6df224f4a4f317c48428ec5afb62b [file] [log] [blame]
Simon Glass567696b2016-01-18 20:19:18 -07001/*
2 * Copyright (C) 2014 Google, Inc
3 *
4 * SPDX-License-Identifier: GPL-2.0+
5 */
6
7#include <common.h>
8#include <dm.h>
9#include <pch.h>
10
11#define BIOS_CTRL 0xd8
12
13static int pch7_get_sbase(struct udevice *dev, ulong *sbasep)
14{
15 u32 rcba;
16
17 dm_pci_read_config32(dev, PCH_RCBA, &rcba);
18 /* Bits 31-14 are the base address, 13-1 are reserved, 0 is enable */
19 rcba = rcba & 0xffffc000;
20 *sbasep = rcba + 0x3020;
21
22 return 0;
23}
24
25static enum pch_version pch7_get_version(struct udevice *dev)
26{
27 return PCHV_7;
28}
29
30static int pch7_set_spi_protect(struct udevice *dev, bool protect)
31{
32 uint8_t bios_cntl;
33
34 /* Adjust the BIOS write protect to dis/allow write commands */
35 dm_pci_read_config8(dev, BIOS_CTRL, &bios_cntl);
36 if (protect)
37 bios_cntl &= ~BIOS_CTRL_BIOSWE;
38 else
39 bios_cntl |= BIOS_CTRL_BIOSWE;
40 dm_pci_write_config8(dev, BIOS_CTRL, bios_cntl);
41
42 return 0;
43}
44
45static const struct pch_ops pch7_ops = {
46 .get_sbase = pch7_get_sbase,
47 .get_version = pch7_get_version,
48 .set_spi_protect = pch7_set_spi_protect,
49};
50
51static const struct udevice_id pch7_ids[] = {
52 { .compatible = "intel,pch7" },
53 { }
54};
55
56U_BOOT_DRIVER(pch7_drv) = {
57 .name = "intel-pch7",
58 .id = UCLASS_PCH,
59 .of_match = pch7_ids,
60 .ops = &pch7_ops,
61};