Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id ; Tue, 7 Jan 2003 09:28:40 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id ; Tue, 7 Jan 2003 09:28:40 -0500 Received: from nimbus19.internetters.co.uk ([209.61.216.65]:1965 "HELO nimbus19.internetters.co.uk") by vger.kernel.org with SMTP id ; Tue, 7 Jan 2003 09:28:39 -0500 Subject: Re: Why do some net drivers require __OPTIMIZE__? From: Alex Bennee To: Alan Cox Cc: Linux Kernel Mailing List In-Reply-To: <1041867367.17472.40.camel@irongate.swansea.linux.org.uk> References: <1041863609.21044.11.camel@cambridge.braddahead> <1041867367.17472.40.camel@irongate.swansea.linux.org.uk> Content-Type: text/plain Content-Transfer-Encoding: 7bit X-Mailer: Ximian Evolution 1.0.8-3mdk Date: 07 Jan 2003 14:33:07 +0000 Message-Id: <1041949988.21044.37.camel@cambridge.braddahead> Mime-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1821 Lines: 42 On Mon, 2003-01-06 at 15:36, Alan Cox wrote: > > Does anybody know the history behind those lines? Do they serve any > > purpose now or in the past? Should I be nervous about compiling the > > kernel at a *lower* than normal optimization level? After all > > optimizations are generally processor specific and shouldn't affect the > > meaning of the C. > > Some of our inline and asm blocks assume things like optimisation. Killing > that check and adding -finline-functions ought to be enough to get what > you expect. It appears to go deeper than a few network drivers. Droping to -O0 breaks a host of other sections (ipc, sockets etc.) for less than obvious reasons. The only source files that seem to depend on the __OPTIMIZE__ define are a few of the other drivers and the byteswap macros. I'll investigate the gcc pages to see if there is anyway to allow optimisation without the out-of-order stuff that makes tracing the start up so hard. *sigh* I assume I can't drop the -fomit-frame-pointer for the same reason (inline and asm blocks assuming register assigment?). On a related note should enabling -g on the kernel CFLAGS be ok? For some reason vmlinux kernels compiled with -g (even after being stripped) seem to break the bootmem allocator on my setup. I'm trying to track down if this is due to some linker weirdness due to the symbol table being bigger than physical memory even though its not actually being loaded into the system. -- Alex Bennee Senior Hacker, Braddahead Ltd The above is probably my personal opinion and may not be that of my employer - 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/