Create a new enum so that a caller can specify the expected type of property they want to read.
This way the bus logic can use that information to process the underlying data.
For example in DT all integer properties are stored in BE format.
In order to get constant results across different platforms we need to convert its endianness to match the host.
Details
- Reviewers
mw wma bz andrew imp - Group Reviewers
manpages - Commits
- rG817556add336: Extend device_get_property API
rGb344de4d0d16: Extend device_get_property API
Diff Detail
- Lint
Lint Skipped - Unit
Tests Skipped
Event Timeline
sys/sys/bus.h | ||
---|---|---|
73 | Is the integer data always 32-bit? I think it should be named DEVICE_PROP_INT as it may be used to read a 64-bit integer used as a physical address. |
sys/sys/bus.h | ||
---|---|---|
73 | Yes, my intention here is to put emphasis on the 32bit size of underlying property. ACPI stores integers(ACPI_TYPE_INTEGER) as uint64_t. uint32_t temp; (...) device_get_property(..., &temp, sizeof(temp)); This will work just fine with ofw, but will fail on ACPI systems as the buffer is not big enough to store the property. I've also thought about adding some helpers, e.g ssize_t device_get_property_u32(device_t dev, const char *prop, uint32_t *val) Now I'm not sure if that won't pollute the API too much. |
sys/sys/bus.h | ||
---|---|---|
73 |
How about keeping DEVICE_PROP_UINT32 for explicit casting and adding DEVICE_PROP_INT for the cases where the maxium supported type will be returned (ofw - 32-bit, acpi - 64-bit)? The binding is somewhat an ABI and it's user's responsibility to parse this with caution.
Type passed as parameter works better IMO. Linux has a callback-per-type (overall > 10) and I do not fancy following this direction. |
Add DEVICE_PROP_UINT64 to handle 8 byte integer properties.
The DEVICE_PROP_UINT32 won't work for ACPI, since it will cast the underlying property to uint32.
share/man/man9/BUS_GET_PROPERTY.9 | ||
---|---|---|
39 | There should be a description of the type argument in the man page. | |
share/man/man9/device_get_property.9 | ||
40 | And in this manpage. | |
sys/dev/acpica/acpi.c | ||
147 | I would keep the signature as it was (with the new argument) for consistancy. | |
1855 | What should happen if we ask for an integer type, but the data is a string or vice versa? | |
sys/dev/fdt/simplebus.c | ||
381 | Is this correct on little endian in the DEVICE_PROP_UINT64 case? Won't the two 32 bit halves be backwards? | |
sys/dev/fdt/simplebus.h | ||
73 | Do any subclasses use this directly? If not we could move it to simplebus.c and make static. |
Update according to @andrew review.
Sorry for taking this long.
sys/dev/acpica/acpi.c | ||
---|---|---|
1855 | Initially I wanted to be as lax as possible with type checking in order no to break poorly written firmware. | |
sys/dev/fdt/simplebus.c | ||
381 | Whoops, you're right. | |
sys/dev/fdt/simplebus.h | ||
73 | All buses that expose OFW will need to sue it, see D33437. |
sys/dev/fdt/simplebus.h | ||
---|---|---|
73 | Couldn't we have a default implementation that calls the parent device_get_property? |
sys/dev/fdt/simplebus.h | ||
---|---|---|
73 | Good idea. I'll look into it. |
Other than that, the manual page spelling and grammar LGTM. Can't say anything about consistency with the implementation.
share/man/man9/BUS_GET_PROPERTY.9 | ||
---|---|---|
44 | "a child's" maybe? | |
46 | What I think you mean, reworded for clarity and slightly simpler language. | |
57 | Also, not sure what you mean by "implementation". Is that the macro/function code? | |
59 | "a multiple of"? Do you mean "larger than"? | |
59 | Since you're touching this page. | |
62 | ||
share/man/man9/device_get_property.9 | ||
48 | ||
54 | Or maybe "...is a string of bytes", depending on what you mean. (Would be consistent with the other types.) | |
61 | ||
66 |
Update man pages
share/man/man9/BUS_GET_PROPERTY.9 | ||
---|---|---|
57 | It's something similar to polymorphism in c++. We have multiple implementations of BUS_GET_PROPERTY depending on which bus a device resides on. This man page is mostly meant to describe the API, rather then any particular one. | |
59 | Yes, multiple of is the right term. |
share/man/man9/BUS_GET_PROPERTY.9 | ||
---|---|---|
57 | In that case, "shall" in the spots I suggested changing it is correct even if stilted, except the one that says "shall to", which should be "shall" instead. | |
59 | I would add "size" somewhere for clarity, but this being the kernel, I don't know the audience well enough to insist on it. | |
share/man/man9/device_get_property.9 | ||
61 | Or "shall" if you don't want to use "must". "shall to" is ungrammatical. | |
66 | Same as above. "shall", not "shall to". |
Manual page language looks good to me now. (Sorry for the "shall to" request-and-revert.)
I'll let others check consistency between manual page and source code.
I keep meaning to give it a try for my local application; after all I think I triggered this? I cannot even remember. If you have a few more days I'll try hard; otherwise please don't wait for me.
No manual page changes I could see since, so my earlier LGTM about that still applies with its disclaimers.
I tested has_prop fine; And get_prop with DEVICE_PROP_BUFFER was also working with FDT it seems. Haven't tried ACPI yet. But feel free to go ahead. Scrolling through it seems fine modulo the comments which probably deserve a mention in the commit message (type size change).
share/man/man9/BUS_GET_PROPERTY.9 | ||
---|---|---|
28 | Please update before commit. | |
share/man/man9/device_get_property.9 | ||
28 | Please update before commit. | |
sys/dev/mmc/mmc_helpers.c | ||
92 | Is this size change an explicit bugfix as well? | |
sys/dev/sdhci/sdhci_xenon.c | ||
474 | Same as above. I'd probably mention this somewhere. |
sys/dev/mmc/mmc_helpers.c | ||
---|---|---|
92 | Well, kind of. |
There are minor style issues (they will be fixed when commiting), but otherwise LGTM.
The patch was tested on MacchiatoBin and CN913x-DB with DT and ACPI.