From mboxrd@z Thu Jan 1 00:00:00 1970 From: Ben Hutchings Subject: Re: [PATCH net-next 2/2] reciprocal_divide: correction/update of the algorithm Date: Thu, 16 Jan 2014 18:50:39 +0000 Message-ID: <1389898239.11912.61.camel@bwh-desktop.uk.level5networks.com> References: <1389828228-30312-1-git-send-email-dborkman@redhat.com> <1389828228-30312-3-git-send-email-dborkman@redhat.com> Mime-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit Cc: Daniel Borkmann , , , , "Hannes Frederic Sowa" , Eric Dumazet , Austin S Hemmelgarn , Jesse Gross , Jamal Hadi Salim , Stephen Hemminger , Matt Mackall , Pekka Enberg , Andy Gospodarek , "Veaceslav Falico" , Jay Vosburgh , "Jakub Zawadzki" To: Christoph Lameter Return-path: In-Reply-To: Sender: linux-kernel-owner@vger.kernel.org List-Id: netdev.vger.kernel.org On Thu, 2014-01-16 at 10:37 -0600, Christoph Lameter wrote: > On Thu, 16 Jan 2014, Daniel Borkmann wrote: > > > - * or else the performance is slower than a normal divide. > > - */ > > -extern u32 reciprocal_value(u32 B); > > +struct reciprocal_value { > > + u32 m; > > + u8 sh1, sh2; > > +}; > > > > +#define RECIPROCAL_VALUE_RESULT_TO_ZERO ((struct reciprocal_value){.sh1 = 32}) > > > > -static inline u32 reciprocal_divide(u32 A, u32 R) > > +struct reciprocal_value reciprocal_value(u32 d); > > A function that returns a struct? That works? Which gcc versions support > it? At least since gcc 1.29, given: Thu Sep 22 15:57:41 1988 Richard Stallman (rms at sugar-bombs.ai.mit.edu) [...] * stmt.c (expand_function_start): Set current_function_needs_context and current_function_returns_struct. Hope that's not a problem... Ben. -- Ben Hutchings, Staff Engineer, Solarflare Not speaking for my employer; that's the marketing department's job. They asked us to note that Solarflare product names are trademarked.