From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757702AbZEBSHl (ORCPT ); Sat, 2 May 2009 14:07:41 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1754405AbZEBSHc (ORCPT ); Sat, 2 May 2009 14:07:32 -0400 Received: from smtp1.linux-foundation.org ([140.211.169.13]:54887 "EHLO smtp1.linux-foundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753813AbZEBSHa (ORCPT ); Sat, 2 May 2009 14:07:30 -0400 Date: Sat, 2 May 2009 10:58:23 -0700 From: Andrew Morton To: Lars Ellenberg Cc: Philipp Reisner , linux-kernel@vger.kernel.org, Jens Axboe , Greg KH , Neil Brown , James Bottomley , Sam Ravnborg , Dave Jones , Nikanth Karthikesan , Lars Marowsky-Bree , "Nicholas A. Bellinger" , Kyle Moffett , Bart Van Assche Subject: Re: [PATCH 02/16] DRBD: lru_cache Message-Id: <20090502105823.bf27bf22.akpm@linux-foundation.org> In-Reply-To: <20090502152620.GA6466@racke> References: <1241090812-13516-1-git-send-email-philipp.reisner@linbit.com> <1241090812-13516-2-git-send-email-philipp.reisner@linbit.com> <1241090812-13516-3-git-send-email-philipp.reisner@linbit.com> <20090501015956.ef663e9b.akpm@linux-foundation.org> <20090502152620.GA6466@racke> X-Mailer: Sylpheed 2.4.8 (GTK+ 2.12.5; x86_64-redhat-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 On Sat, 2 May 2009 17:26:20 +0200 Lars Ellenberg wrote: > in memory structure is > > struct lru_cache { > struct list_head active; > struct list_head quiet; > struct list_head free; > size_t element_size; <-- parameter to "lc_alloc" > unsigned int nr_elements; <-- parameter to "lc_alloc" > unsigned int new_number; > > unsigned int used; > unsigned long flags; > unsigned long hits, misses, starving, dirty, changed; > > struct lc_element *changing_element; /* just for paranoia */ > > const char *name; > > struct hlist_head slot[0]; > /* hash colision chains here, then element storage. */ > }; > > so we have fixed size list heads, > size of a single such "element", to allow the user > to add small payload; > number of hash slots and "elements" following this header; > some counters; > hlist_slot[0]; > } > following: > struct hlist_head[nr_elements]; > array of element_size blobs[nr_elements]; > > these "blobs" start with the struct lru_element, > possibly followed by some user payload. > > the "index" you are asking about later is > index into that "blob" array, > and is used primarily to initialize the state of this thing > from an on-disk representation (the "activity log", "AL"), > for crash recovery purposes. > > the typecasting is necessary to get from the slot[0] to the "elements" > skipping the hash slots. > using "container of" or something like that would obscure the fact that, > as currently implemented, the "lru_element" _must_ be the first member > of any payload structure. I still don't see why the lru_element must be the first member of the user's outer, containing structure.