From mboxrd@z Thu Jan 1 00:00:00 1970 From: Thomas Gleixner Subject: Re: [PATCH V8 08/13] posix clocks: cleanup the CLOCK_DISPTACH macro Date: Thu, 13 Jan 2011 12:25:42 +0100 (CET) Message-ID: References: <503cd1fa268867573001cfc9bb5681ee3b5b32fa.1293820862.git.richard.cochran@omicron.at> <20110113043037.GA17726@riccoc20.at.omicron.at> Mime-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Return-path: In-Reply-To: <20110113043037.GA17726-7KxsofuKt4IfAd9E5cN8NEzG7cXyKsk/@public.gmane.org> Sender: linux-api-owner-u79uwXL29TY76Z2rM5mHXA@public.gmane.org To: Richard Cochran Cc: linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, linux-api-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, netdev-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, Alan Cox , Arnd Bergmann , Christoph Lameter , David Miller , John Stultz , Krzysztof Halasa , Peter Zijlstra , Rodolfo Giometti List-Id: linux-api@vger.kernel.org On Thu, 13 Jan 2011, Richard Cochran wrote: > On Tue, Jan 11, 2011 at 01:57:23PM +0100, Thomas Gleixner wrote: > > > > static clockid_t clock_get_array_id(const clockid_t id) > > { > > if (id >= 0) > > return id < MAX_CLOCKS ? id : POSIX_INV_CLOCK_ID; > > > > if (clock_is_posix_cpu(id)) > > return POSIX_CPU_CLOCK_ID; > > > > return POSIX_INV_CLOCK_ID; > > } > > > > static inline int dispatch_clock_getres(const clockid_t id, struct timespec *ts) > > { > > struct k_clock *clk = &posix_clocks[clock_get_array_id(id)]; > > > > return clk->clock_getres ? clk->clock_getres(id, ts) : -EINVAL; > > } > > I would like to take this idea one step further, like so: > > static struct k_clock *clockid_to_kclock(const clockid_t id) > { > if (id >= 0) > return id < MAX_CLOCKS ? > &posix_clocks[id] : &posix_clocks[POSIX_INV_CLOCK_ID]; > ... > } > > SYSCALL( ... , const clockid_t id, struct timespec *ts) > { > struct k_clock *clk = clockid_to_kclock(id); > > return clk->clock_getres ? clk->clock_getres(id, ts) : -EINVAL; > } > > What do you think? Yeah, that's even better!