nb/intel/pineview: Extract HPET setup and delay function
To allow other platforms to reuse this code, extract it into a separate compilation unit. Since HPET is enabled through the southbridge, place the code in the southbridge scope. Finally, select the newly-added Kconfig option from i82801gx and replace lpc.c `enable_hpet` function. Change-Id: I7a28cc4d12c6d79cd8ec45dfc8100f15e6eac303 Signed-off-by: Angel Pons <th3fanbus@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/49365 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Arthur Heymans <arthur@aheymans.xyz>
This commit is contained in:
committed by
Patrick Georgi
parent
70dca08f25
commit
eef4343a9f
@@ -18,6 +18,7 @@
|
||||
#include <arch/smp/mpspec.h>
|
||||
#include <string.h>
|
||||
#include <southbridge/intel/common/acpi_pirq_gen.h>
|
||||
#include <southbridge/intel/common/hpet.h>
|
||||
#include <southbridge/intel/common/pmbase.h>
|
||||
#include <southbridge/intel/common/spi.h>
|
||||
|
||||
@@ -268,21 +269,6 @@ static void i82801gx_rtc_init(struct device *dev)
|
||||
cmos_init(rtc_failed);
|
||||
}
|
||||
|
||||
static void enable_hpet(void)
|
||||
{
|
||||
u32 reg32;
|
||||
|
||||
/* Move HPET to default address 0xfed00000 and enable it */
|
||||
reg32 = RCBA32(HPTC);
|
||||
reg32 |= (1 << 7); // HPET Address Enable
|
||||
reg32 &= ~(3 << 0);
|
||||
RCBA32(HPTC) = reg32;
|
||||
/* On NM10 this only works if read back */
|
||||
RCBA32(HPTC);
|
||||
|
||||
write32((u32 *)0xfed00010, read32((u32 *)0xfed00010) | 1);
|
||||
}
|
||||
|
||||
static void enable_clock_gating(void)
|
||||
{
|
||||
u32 reg32;
|
||||
|
Reference in New Issue
Block a user