blob: 723e3eae995d70cfc80d85a2f44969c295b87b2d [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001// SPDX-License-Identifier: GPL-2.0
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
3 * linux/arch/arm/mach-footbridge/isa-timer.c
4 *
5 * Copyright (C) 1998 Russell King.
6 * Copyright (C) 1998 Phil Blundell
7 */
Russell King4e8d7632011-01-28 21:00:39 +00008#include <linux/clockchips.h>
Ralf Baechle334955e2011-06-01 19:04:57 +01009#include <linux/i8253.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070010#include <linux/init.h>
11#include <linux/interrupt.h>
Thomas Gleixner55e86982006-07-01 22:32:17 +010012#include <linux/irq.h>
Russell King8c414ff2011-05-08 18:50:20 +010013#include <linux/spinlock.h>
Russell King4e8d7632011-01-28 21:00:39 +000014#include <linux/timex.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070015
Linus Torvalds1da177e2005-04-16 15:20:36 -070016#include <asm/irq.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070017#include <asm/mach/time.h>
18
19#include "common.h"
20
Russell King4e8d7632011-01-28 21:00:39 +000021static irqreturn_t pit_timer_interrupt(int irq, void *dev_id)
22{
23 struct clock_event_device *ce = dev_id;
24 ce->event_handler(ce);
Linus Torvalds1da177e2005-04-16 15:20:36 -070025 return IRQ_HANDLED;
26}
27
Stephen Warren6bb27d72012-11-08 12:40:59 -070028void __init isa_timer_init(void)
Linus Torvalds1da177e2005-04-16 15:20:36 -070029{
Russell King8c414ff2011-05-08 18:50:20 +010030 clocksource_i8253_init();
Russell King4e8d7632011-01-28 21:00:39 +000031
afzal mohammed5926e7e2020-03-12 14:51:23 +010032 if (request_irq(i8253_clockevent.irq, pit_timer_interrupt,
33 IRQF_TIMER | IRQF_IRQPOLL, "pit", &i8253_clockevent))
34 pr_err("Failed to request irq %d(pit)\n", i8253_clockevent.irq);
Thomas Gleixner8560a6c2011-06-09 13:08:28 +000035 clockevent_i8253_init(false);
Linus Torvalds1da177e2005-04-16 15:20:36 -070036}