[PATCH RFC] Introduce one machine_desc instance and get_machine_desc()
Nicolas Pitre
nico at fluxnic.net
Wed Jul 7 11:03:35 EDT 2010
On Wed, 7 Jul 2010, Eric Miao wrote:
> On Wed, Jul 7, 2010 at 9:32 PM, Nicolas Pitre <nico at fluxnic.net> wrote:
> > On Wed, 7 Jul 2010, Eric Miao wrote:
> >
> >> commit 5d5d90e5d41bb0842559dd2b00f00f2a0f532a3a
> >> Author: Eric Miao <eric.miao at canonical.com>
> >> Date: Wed Jul 7 16:47:20 2010 +0800
> >>
> >> [ARM] Introduce one machine_desc instance and get_machine_desc()
> >>
> >> If some of the fields remains useful in 'struct machine_desc', it's
> >> normally a bit convenient to keep one instance there for reference.
> >>
> >> (along with more and more machine specific fields coming into this
> >> structure, e.g. pcibios_min_{io,mem})
> >>
> >> It also improves modularity a bit by not exporting variables like
> >> system_timer, init_arch_irq etc.
> >>
> >> However, the drawbacks are 1) a bit increased data and 2) increased
> >> risk of accessing those fields which are marked as __init.
> >
> > That makes me worried. Access to __init data/functions after __init
> > stuff is freed is amongst the nastiest subtle bugs that are hard to
> > reproduce and therefore fix. And copying such pointers is probably
> > defeating the simple compile time checks we currently have against that.
>
> Indeed I was upset as well :-)
>
> >
> > Maybe those fields should be partitioned differently. Having a new
> > structure to encapsulate all fields that should be kept after __init
> > stuff is gone might be a better way.
>
> That's going to invent another similar structure and produce more code
> when copying over. What about keeping those __init function pointers
> as NULL, and copying the rest?
Sure, that would be better. But how many will remain?
Right now the majority of the mdesc fields are about __init stuff. If
we're going to add more then maybe we could put them into another
structure that could be encapsulated into the mdesc structure and only
copy that part to permanent storage. That would be a good way to
distinguish between inittialization time params and post-init
operational ones.
Nicolas
More information about the linux-arm-kernel
mailing list