Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757090AbZJTDux (ORCPT ); Mon, 19 Oct 2009 23:50:53 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1755139AbZJTDux (ORCPT ); Mon, 19 Oct 2009 23:50:53 -0400 Received: from www.tglx.de ([62.245.132.106]:49435 "EHLO www.tglx.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753247AbZJTDuw (ORCPT ); Mon, 19 Oct 2009 23:50:52 -0400 Date: Tue, 20 Oct 2009 05:50:21 +0200 (CEST) From: Thomas Gleixner To: Linus Walleij cc: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mips@linux-mips.org, Mikael Pettersson , Ralf Baechle Subject: Re: [PATCH] Make MIPS dynamic clocksource/clockevent clock code generic In-Reply-To: <1255819715-19763-1-git-send-email-linus.walleij@stericsson.com> Message-ID: References: <1255819715-19763-1-git-send-email-linus.walleij@stericsson.com> User-Agent: Alpine 2.00 (LFD 1167 2008-08-23) MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2387 Lines: 79 On Sun, 18 Oct 2009, Linus Walleij wrote: > This moves the clocksource_set_clock() and clockevent_set_clock() > from the MIPS timer code into clockchips and clocksource where > it belongs. The patch was triggered by code posted by Mikael > Pettersson duplicating this code for the IOP ARM system. The > function signatures where altered slightly to fit into their > destination header files, unsigned int changed to u32 and inlined. > > Signed-off-by: Linus Walleij > Cc: Thomas Gleixner > Cc: Mikael Pettersson > Cc: Ralf Baechle > --- > Ralf has stated in earlier conversation that this should be moved, > now we risk duplicating code so let's move it. Please do not make that functions inline. They are too large and there is no benefit of inlining them. > +/** > + * clockevent_set_clock - dynamically calculates an appropriate shift > + * and mult value for a clocksource given a > + * known clock frequency > + * @dev: Clockevent device to initialize > + * @hz: Clockevent clock frequency in Hz > + */ > +static inline void clockevent_set_clock(struct clock_event_device *dev, u32 hz) > +{ > + u64 temp; > + u32 shift; > + > + /* Find a shift value */ > + for (shift = 32; shift > 0; shift--) { > + temp = (u64) hz << shift; > + do_div(temp, NSEC_PER_SEC); > + if ((temp >> 32) == 0) > + break; > + } > + dev->shift = shift; > + dev->mult = (u32) temp; > +} > + > + > +static inline void clocksource_set_clock(struct clocksource *cs, u32 hz) > +{ > + u64 temp; > + u32 shift; > + > + /* Find a shift value */ > + for (shift = 32; shift > 0; shift--) { > + temp = (u64) NSEC_PER_SEC << shift; > + do_div(temp, hz); > + if ((temp >> 32) == 0) > + break; > + } > + cs->shift = shift; > + cs->mult = (u32) temp; > +} > + So that's the same function twice, right ? The reason for it are the different data structures. So could you please do something like: void calc_shift_mult(u32 *shift, u32 *mult, u32 hz) { do the magic math } and have wrapper inline functions for clocksource and clockevents around it. Thanks, tglx -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/