Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 59c69f2a authored by Venki Pallipadi's avatar Venki Pallipadi Committed by Thomas Gleixner
Browse files

x86: HPET try to activate force detected hpet



Enable HPET later during boot, after the force detect in PCI quirks.  Also add
a call to repeat the force enabling at resume time.

Signed-off-by: default avatarVenkatesh Pallipadi <venkatesh.pallipadi@intel.com>
Cc: Andi Kleen <ak@suse.de>
Cc: john stultz <johnstul@us.ibm.com>
Cc: Greg KH <greg@kroah.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarIngo Molnar <mingo@elte.hu>
Signed-off-by: default avatarArjan van de Ven <arjan@linux.intel.com>
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
parent d54bd57d
Loading
Loading
Loading
Loading
+25 −2
Original line number Original line Diff line number Diff line
@@ -164,6 +164,7 @@ static struct clock_event_device hpet_clockevent = {
	.set_next_event = hpet_legacy_next_event,
	.set_next_event = hpet_legacy_next_event,
	.shift		= 32,
	.shift		= 32,
	.irq		= 0,
	.irq		= 0,
	.rating		= 50,
};
};


static void hpet_start_counter(void)
static void hpet_start_counter(void)
@@ -178,6 +179,17 @@ static void hpet_start_counter(void)
	hpet_writel(cfg, HPET_CFG);
	hpet_writel(cfg, HPET_CFG);
}
}


static void hpet_resume_device(void)
{
	ich_force_hpet_resume();
}

static void hpet_restart_counter(void)
{
	hpet_resume_device();
	hpet_start_counter();
}

static void hpet_enable_legacy_int(void)
static void hpet_enable_legacy_int(void)
{
{
	unsigned long cfg = hpet_readl(HPET_CFG);
	unsigned long cfg = hpet_readl(HPET_CFG);
@@ -299,7 +311,7 @@ static struct clocksource clocksource_hpet = {
	.mask		= HPET_MASK,
	.mask		= HPET_MASK,
	.shift		= HPET_SHIFT,
	.shift		= HPET_SHIFT,
	.flags		= CLOCK_SOURCE_IS_CONTINUOUS,
	.flags		= CLOCK_SOURCE_IS_CONTINUOUS,
	.resume		= hpet_start_counter,
	.resume		= hpet_restart_counter,
#ifdef CONFIG_X86_64
#ifdef CONFIG_X86_64
	.vread		= vread_hpet,
	.vread		= vread_hpet,
#endif
#endif
@@ -412,10 +424,21 @@ int __init hpet_enable(void)
 */
 */
static __init int hpet_late_init(void)
static __init int hpet_late_init(void)
{
{
	if (!is_hpet_capable())
	if (boot_hpet_disable)
		return -ENODEV;

	if (!hpet_address) {
		if (!force_hpet_address)
			return -ENODEV;
			return -ENODEV;


		hpet_address = force_hpet_address;
		hpet_enable();
		if (!hpet_virt_address)
			return -ENODEV;
	}

	hpet_reserve_platform_timers(hpet_readl(HPET_ID));
	hpet_reserve_platform_timers(hpet_readl(HPET_ID));

	return 0;
	return 0;
}
}
fs_initcall(hpet_late_init);
fs_initcall(hpet_late_init);
+1 −0
Original line number Original line Diff line number Diff line
@@ -63,6 +63,7 @@


/* hpet memory map physical address */
/* hpet memory map physical address */
extern unsigned long hpet_address;
extern unsigned long hpet_address;
extern unsigned long force_hpet_address;
extern int is_hpet_enabled(void);
extern int is_hpet_enabled(void);
extern int hpet_enable(void);
extern int hpet_enable(void);
extern unsigned long hpet_readl(unsigned long a);
extern unsigned long hpet_readl(unsigned long a);