Re: [PATCH] Open Firmware device tree virtual filesystem
From: Segher Boessenkool
Date: Tue Jan 02 2007 - 06:04:41 EST
It has proved a good idea in general as I can easily get an exact
device-tree dump from users by asking for a tarball of
/proc/device-tree
and in some case, the data in there -is- binary (For example, the EDID
properties for monitors left by video drivers, or things like that).
Yes and with openpromfs I can get the EDID too :-)
root@sunset:/proc/openprom/pci@1f,700000/SUNW,XVR-100@3# cat edid
00ffffff.ffffff00.4dd9d000.67175700.2d0d0103.0e321f78.eacea9a3.574c9926
.19484cbd.ee80a940.81808140.01010101.01010101.0101734b.80a072b0.2a4080d
0.1300ef35.1100001c.483f4030.62b03240.40c01300.ef351100.001e0000.00fd00
37.411e5f14.000a2020.20202020.000000fc.0053444d.2d503233.32570a20.20200
0af
root@sunset:/proc/openprom/pci@1f,700000/SUNW,XVR-100@3#
And how do you know from this output that the property
didn't contain this stuff as a text string?
I think there is high value in an OFW filesystem representation
that gives you _EXACTLY_ what the OFW command line prompt does
when you try to traverse the device tree from there, and that
is what openpromfs tries to do.
I suppose you're referring to the OF .properties command,
it's trivial to get at the *actual property contents* from
the OF prompt too.
.properties is a OF _user interface_ command, it is a helper
thing to show the properties in a more easily human digestible
format. The analogue in Linux would be a user land tool.
If you want raw access, use a character device or a similar auxilliary
access to the data items. Another idea is to provide a seperate file
operation (such as ioctl) on the OFW property files in order to fetch
things raw and in binary.
If user space can get raw access to the data via a device
file, there shouldn't be a filesystem at all, just some
tool that interfaces to the device. Since the data we're
representing is naturally tree-based though, a filesystem
is a much nicer solution than a character device with a
bunch of ioctls.
When I get some binary data out of a procfs or sysfs file I feel like
strangling somebody.
Right, let's encode PCI config space (all of it, not just the
few standard fields) into 256 files config-00, ..., config-ff.
Superb plan!
The fact is, if you get some data (a property value, or the
contents of config space), that you do not know what it means
or how it is structured even, there is no good way to represent
it other than passing it through as-is. Or you can guess, and
guess wrong (sometimes at least). Scripts parsing your output
will have to read all formats you produce and transform it back
into something usable -- they can *never* use it as-is, they
can't assume some property will always be text for example (be
text according to your heuristic, that is). Oh, except the format
you chose cannot be transformed back at all.
Another example of that then: I'd like to _see_ the difference
between (as hex bytes) "61 62 63" and "61 62 63 00" -- if only
to find bugs in OF code, or whatever. With the property_show()
thing in openpromfs, I can't tell (well maybe the first one
crashes on the strlen() call, if prop->val doesn't get an extra
0 tagged onto the end during creation, I didn't check).
I'm grovelling around in a filesystem from the
command line so that I can get some information as a user. If you
don't give me text I can't tell what the heck it is.
Sure, but you don't need the kernel to present it as text, use
some helper thing instead, that can use *much* better heuristics
(like .properties in OF actually does) to decide on matters.
Simple system tools should not need to interpret binary data in
order to provide access to simple structured data like this, that's
just stupid.
The structure within a property is context-dependent, it isn't
simple at all (in general). And the binary data doesn't need
interpretation, the text representation of it does though --
interpretation back to usable binary form.
Segher
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/