Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933029AbZJOQHX (ORCPT ); Thu, 15 Oct 2009 12:07:23 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1760264AbZJOQHX (ORCPT ); Thu, 15 Oct 2009 12:07:23 -0400 Received: from xenotime.net ([72.52.64.118]:41109 "HELO xenotime.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with SMTP id S1758037AbZJOQHW (ORCPT ); Thu, 15 Oct 2009 12:07:22 -0400 Date: Thu, 15 Oct 2009 09:06:45 -0700 From: Randy Dunlap To: Gregory Haskins Cc: Daniel Walker , "linux-kernel@vger.kernel.org" Subject: Re: Tips for module_init() dependencies Message-Id: <20091015090645.140e04f4.rdunlap@xenotime.net> In-Reply-To: <4AD7469B.9070907@gmail.com> References: <4AD71D12.9060203@gmail.com> <1255621559.22917.35.camel@desktop> <4AD7469B.9070907@gmail.com> Organization: YPO4 X-Mailer: Sylpheed 2.7.1 (GTK+ 2.12.0; x86_64-unknown-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1929 Lines: 50 On Thu, 15 Oct 2009 11:58:19 -0400 Gregory Haskins wrote: > Daniel Walker wrote: > > On Thu, 2009-10-15 at 09:01 -0400, Gregory Haskins wrote: > > > >> may break, because the kernel seems to have no concept of > >> interdependency between foo_init() and bar_init(), and therefore > >> bar_init() may call foo() before foo_init() has executed. > >> > >> There are various ways to solve this problem, such as deferring calling > >> foo() with a workqueue or something, but I was wondering if there was a > >> better/standard way to do this that I am missing? > >> > >> The problem I am having specifically is that I am trying to call > >> configfs_register_subsystem() in a module_init(), but this breaks when > >> built into the kernel based on sheer bad luck that configfs gets > >> initialized after me. To date I have worked around this by forcing my > >> code to only support built-in, and using late_initcall() instead or > >> module_init. This works, but it only means I am putting the problem off > >> (code that depends on *me* has to use similar tricks, etc. > > > > You can't modify the build order so your module get "builtin" after > > configfs? > > > > Hi Daniel, > > Possibly. > > A) Any suggestions on how? Can I express this in Kconfig or something > (i.e. "depends on FOO"). I currently have "select FOO" in the BAR > object, but this doesn't seem to be sufficient to describe the relationship. Not in Kconfig, only in Makefile(s). and please put #comments in them explaining the ordering requirements/needs. > B) Do I have to make the entire chain follow suit? (I have C deps on B, > B deps on A kind of scenarios) > > Kind Regards, > -Greg --- ~Randy -- 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/