Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp4408026imu; Fri, 30 Nov 2018 17:01:34 -0800 (PST) X-Google-Smtp-Source: AFSGD/UrI3YaBOJ+aP6sSLofdTaIhwt04yqPJKuFnRqFAyzkmbb72VCjlirR+26xEe4KVcH+Htmd X-Received: by 2002:a63:e615:: with SMTP id g21mr6691875pgh.290.1543626093965; Fri, 30 Nov 2018 17:01:33 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1543626093; cv=none; d=google.com; s=arc-20160816; b=cEkhuVfNRaZsEKJZuJn5ksfZnZvG6MOH3NAB+sZnvs1sCzm//2H//M6E7RRdK2A5Pq nzFy93YMnmtZ+8aMUE1IkrWyv+netEO+Jsnh0ocE4XGhxbUwBEbI4givjGvkRDw3Z2sZ TPgSYn6ePkgLYlBelty59jfCF2oZ55SL0bTCNyHWQFB7L/XqBy6a6JtucAe4/LnRJQwv j1y7DVWAyp3uo6cudZkfhiNxR1KmIeTjQ3M3fguccHltV1yxNQ7YankQAZJIOYaBhpx3 wQm/DK6vb2trNhGAaucMH6ughMW2TOREsc7EFQpR0SVlojx1pDGhvQGhgBrSaFsqX8C+ /Kfg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:date:subject:from:references:in-reply-to :message-id:cc:to; bh=ipu+Xw724ADn10BeBB7i4NJMt3fdu6hd53Q4Aizi7Q0=; b=hryJQKuabD0tT99X3wB/vfjF1JvTd8mVHUEre+lNgxgPAiZ+WME6I0tlY8gmFREiWI aW0jtiVHz3muciDW6AKnH/Jr8RM59on5Mgd/x4Mcuvv10KVQdwokzZdT7PNyYRkT7YVt o2lU5Y+mZA1xnK+vWbxNXQ044bgFruUwD5/oh1/wkSF//aoy/YwMLXSDPDotc4MRvkwE /+COcbnxvRTAoefyyusmRvAO47wr3x9GigiYiMH3Y1F8FWrD3eE3DtxbO6a7bs4XF33u RQY1WdXf6nj9YXGHqo05HLkkMvjchDC0ryVAdiTXN6BRsQYGyFJOs3DUfeLyYgTiRNrh c/Gg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 128si7257787pfe.4.2018.11.30.17.01.19; Fri, 30 Nov 2018 17:01:33 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727068AbeLAMLj (ORCPT + 99 others); Sat, 1 Dec 2018 07:11:39 -0500 Received: from kvm5.telegraphics.com.au ([98.124.60.144]:38160 "EHLO kvm5.telegraphics.com.au" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726897AbeLAMLc (ORCPT ); Sat, 1 Dec 2018 07:11:32 -0500 Received: by kvm5.telegraphics.com.au (Postfix, from userid 502) id 5ECAC281FF; Fri, 30 Nov 2018 20:00:15 -0500 (EST) To: Geert Uytterhoeven Cc: Andreas Schwab , Arnd Bergmann , Stephen N Chivers , Thomas Gleixner , Kars de Jong , Daniel Lezcano , Michael Schmitz , John Stultz , Linus Walleij , linux-m68k@lists.linux-m68k.org, linux-kernel@vger.kernel.org Message-Id: <68b40c64e1cc2f095f93cf27f860f8f6fc0152cc.1543625590.git.fthain@telegraphics.com.au> In-Reply-To: References: From: Finn Thain Subject: [PATCH v4 11/14] m68k: mvme147: Convert to clocksource API Date: Sat, 01 Dec 2018 11:53:10 +1100 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add a platform clocksource by adapting the existing arch_gettimeoffset implementation. Signed-off-by: Finn Thain Acked-by: Linus Walleij --- Changed since v1: - Moved clk_total access to within the irq lock. - Use type u32 for tick counter. --- arch/m68k/include/asm/mvme147hw.h | 1 - arch/m68k/mvme147/config.c | 36 +++++++++++++++++++++++++------ 2 files changed, 30 insertions(+), 7 deletions(-) diff --git a/arch/m68k/include/asm/mvme147hw.h b/arch/m68k/include/asm/mvme147hw.h index 9c7ff67c5ffd..7c3dd513128e 100644 --- a/arch/m68k/include/asm/mvme147hw.h +++ b/arch/m68k/include/asm/mvme147hw.h @@ -66,7 +66,6 @@ struct pcc_regs { #define PCC_INT_ENAB 0x08 #define PCC_TIMER_INT_CLR 0x80 -#define PCC_TIMER_PRELOAD 63936l #define PCC_LEVEL_ABORT 0x07 #define PCC_LEVEL_SERIAL 0x04 diff --git a/arch/m68k/mvme147/config.c b/arch/m68k/mvme147/config.c index 4ef4faa5ed8b..c44a254e8a8c 100644 --- a/arch/m68k/mvme147/config.c +++ b/arch/m68k/mvme147/config.c @@ -17,6 +17,7 @@ #include #include #include +#include #include #include #include @@ -92,6 +93,21 @@ void __init config_mvme147(void) vme_brdtype = VME_TYPE_MVME147; } +static u64 mvme147_read_clk(struct clocksource *cs); + +static struct clocksource mvme147_clk = { + .name = "pcc", + .rating = 250, + .read = mvme147_read_clk, + .mask = CLOCKSOURCE_MASK(32), + .flags = CLOCK_SOURCE_IS_CONTINUOUS, +}; + +static u32 clk_total; + +#define PCC_TIMER_CLOCK_FREQ 160000 +#define PCC_TIMER_CYCLES (PCC_TIMER_CLOCK_FREQ / HZ) +#define PCC_TIMER_PRELOAD (0x10000 - PCC_TIMER_CYCLES) /* Using pcc tick timer 1 */ @@ -103,6 +119,7 @@ static irqreturn_t mvme147_timer_int (int irq, void *dev_id) local_irq_save(flags); m147_pcc->t1_int_cntrl = PCC_TIMER_INT_CLR; m147_pcc->t1_int_cntrl = PCC_INT_ENAB|PCC_LEVEL_TIMER1; + clk_total += PCC_TIMER_CYCLES; timer_routine(0, NULL); local_irq_restore(flags); @@ -112,32 +129,39 @@ static irqreturn_t mvme147_timer_int (int irq, void *dev_id) void mvme147_sched_init (irq_handler_t timer_routine) { - if (request_irq(PCC_IRQ_TIMER1, mvme147_timer_int, 0, "timer 1", - timer_routine)) + if (request_irq(PCC_IRQ_TIMER1, mvme147_timer_int, IRQF_TIMER, + "timer 1", timer_routine)) pr_err("Couldn't register timer interrupt\n"); /* Init the clock with a value */ - /* our clock goes off every 6.25us */ + /* The clock counter increments until 0xFFFF then reloads */ m147_pcc->t1_preload = PCC_TIMER_PRELOAD; m147_pcc->t1_cntrl = 0x0; /* clear timer */ m147_pcc->t1_cntrl = 0x3; /* start timer */ m147_pcc->t1_int_cntrl = PCC_TIMER_INT_CLR; /* clear pending ints */ m147_pcc->t1_int_cntrl = PCC_INT_ENAB|PCC_LEVEL_TIMER1; + + clocksource_register_hz(&mvme147_clk, PCC_TIMER_CLOCK_FREQ); } -/* This is always executed with interrupts disabled. */ /* XXX There are race hazards in this code XXX */ -u32 mvme147_gettimeoffset(void) +static u64 mvme147_read_clk(struct clocksource *cs) { + unsigned long flags; volatile unsigned short *cp = (volatile unsigned short *)0xfffe1012; unsigned short n; + u32 ticks; + local_irq_save(flags); n = *cp; while (n != *cp) n = *cp; n -= PCC_TIMER_PRELOAD; - return ((unsigned long)n * 25 / 4) * 1000; + ticks = clk_total + n; + local_irq_restore(flags); + + return ticks; } static int bcd2int (unsigned char b) -- 2.18.1