aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86')
-rw-r--r--arch/x86/kernel/hpet.c57
1 files changed, 35 insertions, 22 deletions
diff --git a/arch/x86/kernel/hpet.c b/arch/x86/kernel/hpet.c
index 2913913f4a46..77017e834cf7 100644
--- a/arch/x86/kernel/hpet.c
+++ b/arch/x86/kernel/hpet.c
@@ -45,10 +45,6 @@ struct hpet_dev {
45 char name[10]; 45 char name[10];
46}; 46};
47 47
48static struct hpet_dev *hpet_devs;
49
50static DEFINE_PER_CPU(struct hpet_dev *, cpu_hpet_dev);
51
52unsigned long hpet_readl(unsigned long a) 48unsigned long hpet_readl(unsigned long a)
53{ 49{
54 return readl(hpet_virt_address + a); 50 return readl(hpet_virt_address + a);
@@ -126,23 +122,8 @@ EXPORT_SYMBOL_GPL(is_hpet_enabled);
126 * timer 0 and timer 1 in case of RTC emulation. 122 * timer 0 and timer 1 in case of RTC emulation.
127 */ 123 */
128#ifdef CONFIG_HPET 124#ifdef CONFIG_HPET
129static void hpet_reserve_msi_timers(struct hpet_data *hd)
130{
131 int i;
132 125
133 if (!hpet_devs) 126static void hpet_reserve_msi_timers(struct hpet_data *hd);
134 return;
135
136 for (i = 0; i < hpet_num_timers; i++) {
137 struct hpet_dev *hdev = &hpet_devs[i];
138
139 if (!(hdev->flags & HPET_DEV_VALID))
140 continue;
141
142 hd->hd_irq[hdev->num] = hdev->irq;
143 hpet_reserve_timer(hd, hdev->num);
144 }
145}
146 127
147static void hpet_reserve_platform_timers(unsigned long id) 128static void hpet_reserve_platform_timers(unsigned long id)
148{ 129{
@@ -362,6 +343,10 @@ static int hpet_legacy_next_event(unsigned long delta,
362 * HPET MSI Support 343 * HPET MSI Support
363 */ 344 */
364#ifdef CONFIG_PCI_MSI 345#ifdef CONFIG_PCI_MSI
346
347static DEFINE_PER_CPU(struct hpet_dev *, cpu_hpet_dev);
348static struct hpet_dev *hpet_devs;
349
365void hpet_msi_unmask(unsigned int irq) 350void hpet_msi_unmask(unsigned int irq)
366{ 351{
367 struct hpet_dev *hdev = get_irq_data(irq); 352 struct hpet_dev *hdev = get_irq_data(irq);
@@ -525,7 +510,8 @@ static void init_one_hpet_msi_clockevent(struct hpet_dev *hdev, int cpu)
525#else 510#else
526#define RESERVE_TIMERS 0 511#define RESERVE_TIMERS 0
527#endif 512#endif
528void hpet_msi_capability_lookup(unsigned int start_timer) 513
514static void hpet_msi_capability_lookup(unsigned int start_timer)
529{ 515{
530 unsigned int id; 516 unsigned int id;
531 unsigned int num_timers; 517 unsigned int num_timers;
@@ -571,6 +557,26 @@ void hpet_msi_capability_lookup(unsigned int start_timer)
571 num_timers, num_timers_used); 557 num_timers, num_timers_used);
572} 558}
573 559
560#ifdef CONFIG_HPET
561static void hpet_reserve_msi_timers(struct hpet_data *hd)
562{
563 int i;
564
565 if (!hpet_devs)
566 return;
567
568 for (i = 0; i < hpet_num_timers; i++) {
569 struct hpet_dev *hdev = &hpet_devs[i];
570
571 if (!(hdev->flags & HPET_DEV_VALID))
572 continue;
573
574 hd->hd_irq[hdev->num] = hdev->irq;
575 hpet_reserve_timer(hd, hdev->num);
576 }
577}
578#endif
579
574static struct hpet_dev *hpet_get_unused_timer(void) 580static struct hpet_dev *hpet_get_unused_timer(void)
575{ 581{
576 int i; 582 int i;
@@ -642,10 +648,17 @@ static int hpet_setup_msi_irq(unsigned int irq)
642{ 648{
643 return 0; 649 return 0;
644} 650}
645void hpet_msi_capability_lookup(unsigned int start_timer) 651static void hpet_msi_capability_lookup(unsigned int start_timer)
652{
653 return;
654}
655
656#ifdef CONFIG_HPET
657static void hpet_reserve_msi_timers(struct hpet_data *hd)
646{ 658{
647 return; 659 return;
648} 660}
661#endif
649 662
650static int hpet_cpuhp_notify(struct notifier_block *n, 663static int hpet_cpuhp_notify(struct notifier_block *n,
651 unsigned long action, void *hcpu) 664 unsigned long action, void *hcpu)