[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20071221005303.771032f3@werewolf>
Date: Fri, 21 Dec 2007 00:53:03 +0100
From: "J.A. Magallón" <jamagallon@....com>
To: "linux-os (Dick Johnson)" <linux-os@...logic.com>
Cc: "Linux kernel" <linux-kernel@...r.kernel.org>
Subject: Re: Trying to convert old modules to newer kernels
On Thu, 20 Dec 2007 18:05:48 -0500, "linux-os (Dick Johnson)" <linux-os@...logic.com> wrote:
>
> On Thu, 20 Dec 2007, Sam Ravnborg wrote:
>
> > On Thu, Dec 20, 2007 at 04:27:37PM -0500, linux-os (Dick Johnson) wrote:
> >>
> >> On Thu, 20 Dec 2007, Sam Ravnborg wrote:
> >>
> >>>>
> >>>> It never gets to the printk(). You were right about the
> >>>> compilation. Somebody changed the kernel to compile with
> >>>> parameter passing in REGISTERS! This means that EVERYTHING
> >>>> needs to be compiled the same way, 'C' calling conventions
> >>>> were not good enough!
> >>>
> >>> How did you build the module. It reads like you failed to use
> >>> kbuild to build your module which is why you did not pass
> >>> correct options to gcc - correct?
> >>>
> >>> If you did not use kbuild - why not?
> >>> Is there anything missing you need?
> >>>
> >>
> >> I need to get rid of -mregparm=3 on gcc's command line. It
> >> is completely incompatible with the standard calling conventions
> >> used in all our assembly-language files in our drivers. We make
> >> very high-speed number-crunching drivers that munge high-speed
> >> data into images. We need to do that in assembly as we have
> >> always done.
>
Just for curiosity... yep, I understand now you have everything written
in assembler, but why not consider start writing it in C and stop
doing the compiler work (such as pipelining, out of order reordering,
loop unrolling for specific processor, and so on...)
That's what everyone taught me, nowadays you won't be better than the
compiler in anything longer than three lines...
--
J.A. Magallon <jamagallon()ono!com> \ Software is like sex:
\ It's better when it's free
Mandriva Linux release 2008.1 (Cooker) for i586
Linux 2.6.23-jam05 (gcc 4.2.2 20071128 (4.2.2-2mdv2008.1)) SMP PREEMPT
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists