I wrote up some notes on QEMU‘s QCOW image format for anyone who might be interested.
Stateless Linux Cached Client
I’ve posted description to the Fedora wiki about how we’re implementing the cached client part of Stateless Linux in FC6.
Pile onto the stateless-list if you want to yak about it.
Eben Moglen’s Talk
What Chris said. Go watch Eben’s talk, it really is worth it. I’m going to watch it again.
Chris had a nice quote, but you can skip randomly to any part and get other equally nice quotes.
“The patent has become a real estate entitlement, not based upon the social value it produces, but rather irrespective of the social harm it may induce.”
Mugshot Design Process
What I find most interesting about Mughsot is the team’s total and no-bullshit commitment to making new and interesting software which doesn’t suck.
I love the way they say their design process “isn’t a checklist of activites you must do – it’s an idea list, suggestions for how to work smarter”. I love the way they prototyped a photos feature using flickr but were willing to drop it again after trying it on real people. I love the way they lock themselves in a room, leaving their laptops behind, and give themselves the time to hash out ideas properly.
I hope Mugshot itself is a success. But, more than that, I hope they help change the way the rest of us make software.
Patch Management
As part of the work I’ve started doing on Stateless Linux, I’ve found myself hacking on device-mapper‘s snapshot support. It’s actually been really good fun to do a bit of kernel hacking again after such a long time … and this time I feel like I actually have some clue what I’m doing.
I’m really behind the times when it comes to all the new fangled revision control systems out there like bzr, git, mercurial, svn etc. – cvs and manual patch mangling is all I know.
So, when agk pointed me at quilt, I was a bit dubious at first but gave it a shot. It turned out to be a really simple and useful way of maintaining your own patchset in parallel with an upstream codebase.
Even though it’s a really simple tool, it seems to me to have some of the important advantages of other systems like distributed offline branches and change sets. If I had time to hack on GNOME again, I’d use quilt a lot for offline branches alongside CVS. It’s given me an appetite for looking at other systems too.
GObject Private Data (again)
Aren’t discussions via blogs fun? 🙂
Federico: two points:
-
Using the new GObject instance private data API, rather than the private data scheme that GNOME hackers have always used, is a small optimization in itself – the private data is allocated in the same chunk as the object itself.
As with all optimizations, you weigh up the benefit against the code obfuscation. In this case, I don’t think the GObject scheme makes the code more difficult to understand … especially since it’s likely to become as much of a second-nature idiom as the old scheme. It’s also one less opportunity to leak memory.
-
Using the GObject scheme, instance private data could have been added without the runtime hit you were seeing … even where the object structure couldn’t be extended without breaking ABI.
To do so, you’d just go back to something similar to Owen’s initial suggestion for how the API should be used – in a static variable, you’d store the offset between the address of the object structure and the private data and use that offset for efficient access to the data. add_private() originally returned this offset, but it no longer does, so you’d need to calculate the offset in instance_init() – but it is guaranteed to be constant.
Granted, that’s a nasty hack which would genuinely obfuscate the code … but at least it would actually be possible to add private data, whereas it wouldn’t be possible with the old scheme.
Update: Tim points out that the offset to the private data isn’t constant across all instances – the offset will be larger for subtypes since the private data is allocated after all object data.
LDAP Notifications (again)
Yesterday I posted some code which shows how to use Fedora Directory Server’s “persistent searches” using OpenLDAP’s client library. Here’s that same code, but as a Python module.
GObject Private Data
Federico: the combination of a “*priv” field and GObject private data is the best way to go:
struct _PangoFcFont { ... gpointer priv; ... }; #define PANGO_FC_FONT_GET_PRIVATE(obj) ((PangoFcFontPrivate *) ((PangoFcFont *) obj)->priv) static void pango_fc_font_class_init (PangoFcFontClass *class) { ... g_type_class_add_private (object_class, sizeof (PangoFcFontPrivate)); } static void pango_fc_font_init (PangoFcFont *fcfont) { fcfont->priv = G_TYPE_INSTANCE_GET_PRIVATE (fcfont, PANGO_TYPE_FC_FONT, PangoFcFontPrivate) }
Indeed, that’s why g_type_get_private() was added. You get the best of both worlds – the convenience of a priv pointer with the fact that the private data is allocated in the same chunk as the object itself, without the inefficiency of calling get_private() a lot or the extra static variable in Owen‘s original proposal.
LDAP Notifications
Figuring out what the story is with LDAP notifications isn’t terribly easy. There are a number of different protocol extensions out there:
- Netscape’s Persistent Search or PSEARCH. Fedora Directory Server supports this. Extends the standard searchRequest such that it doesn’t complete immediately, and returns any changes to the matched by the search.
- Triggered Search Control or TSEARCH. Not sure what implements this. Similar to psearch.
- Microsoft LDAP Control for Directory Synchronization or DIRSYNC. Implemented by Active Directory, but requires the client to poll for changes.
- LDAP Content Synchronization Operation or SYNC. Implemented by OpenLDAP and allows both polling and persistent modes.
- LDAP Client Update Protocol (RFC 3928) or LCUP. Similar to SYNC. Not sure who actually implements this.
The strangest thing about all this is that LCUP is the only one of these that progressed from Internet Draft to RFC, yet neither OpenLDAP nor Fedora Directory Server implement it. SYNC seems to have been proposed by the OpenLDAP crew because when they went to implement LCUP they found that it “requires server implementations to maintain complete history information in order to provide eventually convergent incremental refreshes”, which presumably wasn’t something that OpenLDAP already did. Yet the working group went ahead and progressed LCUP to RFC and not SYNC.
Anyway, moral of the story is that if you want notifications, then you want PSEARCH if you’re using Fedora Directory Server and SYNC if you’re using OpenLDAP.
If you’re using OpenLDAP’s client library, rather than the Mozilla LDAP C SDK, then it’s a little tricky since you have to manually create the psearch control and parse the entryChange controls. Here’s some example code.
Google Map Pedometer
This Google Map Pedometer thing is pretty damn cool. I mapped out the 17k route I ran tonight. Now I can put aside my deep suspicion of the distances reported by my own pedometer 🙂
If only the satellite imagery for Dublin was a bit better …