From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1764727AbZEASVb (ORCPT ); Fri, 1 May 2009 14:21:31 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1754711AbZEASVU (ORCPT ); Fri, 1 May 2009 14:21:20 -0400 Received: from mail-out.m-online.net ([212.18.0.9]:60732 "EHLO mail-out.m-online.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754709AbZEASVT (ORCPT ); Fri, 1 May 2009 14:21:19 -0400 X-Auth-Info: GiIO25L+RbaAoCszG47hweK2ezlOw7Y7S43FNHKIWUE= Message-ID: <49FB3D9B.3050704@grandegger.com> Date: Fri, 01 May 2009 20:21:15 +0200 From: Wolfgang Grandegger User-Agent: Thunderbird 2.0.0.21 (X11/20090320) MIME-Version: 1.0 To: Jonathan Corbet CC: netdev@vger.kernel.org, linux-kernel@vger.kernel.org, Oliver Hartkopp Subject: Re: [PATCH 4/8] can: Driver for the SJA1000 CAN controller References: <1235070082-7069-1-git-send-email-wg@grandegger.com> <1235070082-7069-2-git-send-email-wg@grandegger.com> <1235070082-7069-3-git-send-email-wg@grandegger.com> <1235070082-7069-4-git-send-email-wg@grandegger.com> <1235070082-7069-5-git-send-email-wg@grandegger.com> <20090219171440.0c8286a1@bike.lwn.net> In-Reply-To: <20090219171440.0c8286a1@bike.lwn.net> X-Enigmail-Version: 0.95.7 Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org I'm now back fixing the open issues of this patch series... Jonathan Corbet wrote: [snip] >> +/* >> + * SJA1000 private data structure >> + */ >> +struct sja1000_priv { >> + struct can_priv can; /* must be the first member! */ > > AHA! I knew it! > > This kind of pointer trickery is fragile and dangerous, please don't do > it. Much better would be something like: > > dev->priv = &dev_specific_priv->can; > > Then the higher layers know they have a proper struct can_priv pointer. > Then you can use container_of() at this level to get the outer structure > pointer. Much more robust and in line with normal kernel coding idiom. Unfortunately, the "struct net_device" does not have a "priv" field. Using struct can_priv *can = netdev_priv(dev); struct sja1000_priv *sja1000 = candev_priv(dev); instead is awkward. That's what we had at first. Any other more elegant solution in mind? Wolfgang.