From mboxrd@z Thu Jan 1 00:00:00 1970 From: Russell King Subject: Re: [PATCH 04/27] asm-generic: add legacy I/O header files Date: Fri, 1 May 2009 13:37:28 +0100 Message-ID: <20090501123728.GC27799@flint.arm.linux.org.uk> References: <10b3a32656e5552458db7412ef9ff8530d5f92aa.1241105648.git.arnd@arndb.de> <200905011422.29753.arnd@arndb.de> <49FAEA2A.50504@monstr.eu> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Received: from caramon.arm.linux.org.uk ([78.32.30.218]:58465 "EHLO caramon.arm.linux.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754368AbZEAMhk (ORCPT ); Fri, 1 May 2009 08:37:40 -0400 Content-Disposition: inline In-Reply-To: <49FAEA2A.50504@monstr.eu> Sender: linux-arch-owner@vger.kernel.org List-ID: To: Michal Simek Cc: Arnd Bergmann , linux-arch@vger.kernel.org, Remis Lima Baima , linux-kernel@vger.kernel.org On Fri, May 01, 2009 at 02:25:14PM +0200, Michal Simek wrote: > Arnd Bergmann wrote: > > On Friday 01 May 2009, Michal Simek wrote: > >>> +/* > >>> + * CLOCK_TICK_RATE is highly PC-specific and should not > >>> + * be used in portable code. 1193182 is the value for the > >>> + * original i8253 PIC. > >>> + */ > >>> +#ifndef CLOCK_TICK_RATE > >>> +#define CLOCK_TICK_RATE 1193182 > >>> +#endif > >> > >> Why is this in generic code? > > > > CLOCK_TICK_RATE is only used in a few places: > > > > drivers/char/vt_ioctl.c: arg = CLOCK_TICK_RATE / arg; > > drivers/char/vt_ioctl.c: count = CLOCK_TICK_RATE / count; > > drivers/clocksource/acpi_pm.c: ((CALIBRATE_LATCH * (PMTMR_TICKS_PER_SEC >> 10)) / (CLOCK_TICK_RATE>>10)) > > drivers/input/joystick/analog.c:#define DELTA(x,y) (cpu_has_tsc ? ((y) - (x)) : ((x) - (y) + ((x) < (y) ? CLOCK_TICK_RATE / HZ : 0 > > drivers/rtc/rtc-pxa.c:#define TIMER_FREQ CLOCK_TICK_RATE > > drivers/serial/serial_ks8695.c: .uartclk = CLOCK_TICK_RATE * 16, > > drivers/watchdog/davinci_wdt.c: timer_margin = (((u64)heartbeat * CLOCK_TICK_RATE) & 0xffffffff); > > drivers/watchdog/davinci_wdt.c: timer_margin = (((u64)heartbeat * CLOCK_TICK_RATE) >> 32); > > drivers/watchdog/ks8695_wdt.c: unsigned long tval = wdt_time * CLOCK_TICK_RATE; > > include/linux/jiffies.h:#define LATCH ((CLOCK_TICK_RATE + HZ/2) / HZ) /* For divider */ > > include/linux/jiffies.h:#define ACTHZ (SH_DIV (CLOCK_TICK_RATE, LATCH, 8)) > > include/linux/timex.h: * Moved CLOCK_TICK_RATE, CLOCK_TICK_FACTOR and FINETUNE to asm/timex.h > > sound/oss/pas2_pcm.c: foo = ((CLOCK_TICK_RATE / 2) + (arg / 2)) / arg; > > sound/oss/pas2_pcm.c: arg = ((CLOCK_TICK_RATE / 2) + (foo / 2)) / foo; > > sound/oss/pas2_pcm.c: foo = (CLOCK_TICK_RATE + (arg / 2)) / arg; > > sound/oss/pas2_pcm.c: arg = (CLOCK_TICK_RATE + (foo / 2)) / foo; > > > > All of these are either PC-specific, or they don't actually care > > about the specific value. Most architectures just use the > > value from the IBM PC, so we might as well make that the generic > > default. > > ok. Let's move out from arch to generic location. That's only possible once the users have been fixed - otherwise the ARM stuff listed above _will_ break. -- Russell King Linux kernel 2.6 ARM Linux - http://www.arm.linux.org.uk/ maintainer of: