This patch will distinguish _HID exact match and match by _CID
compatibility match. Generally _CID match is suboptimal  and 
now we can tell its match priority to the FreeBSD bus framwork. 
It sometimes may not appropriate to attach if compatiblity match.
This changes ACPI related KPI and it needs kernel revision bump.
(It should be ACPI module revision bump, but it is not tribial so 
it should be done in another changeset if we do.)
Details
Diff Detail
- Lint
- Lint Passed 
- Unit
- No Test Coverage 
- Build Status
- Buildable 20413 - Build 19853: arc lint + arc unit 
Event Timeline
Generally, I like this, modulo the couple of issues that need to be addressed. the biggest one is the ENXIO test being too specific.
| sys/dev/acpi_support/acpi_ibm.c | ||
|---|---|---|
| 352 | This might be unrelated. | |
| 421–424 | style nit: there should be a space between if and (. | |
| sys/dev/acpica/acpi.c | ||
| 1186 | There's a mix of styles used here. Some places you test against 0 (eg > 0 is an error) other places the exact error. I think it would be better to test <= 0 here and other places you explicitly tested against ENXIO. | |
I would probably suggest doing a pass over the diff to fix the style things and Warner's suggestion of comparing '< 0' instead of against ENXIO, removing goto's, etc.
I think overall the change is fine. One possible issue is that if you match on a CID before a HID you might return the wrong return value (e.g. if a device has both a _HID and a _CID that are in the list of IDs, but the _CID is first in the driver table). We could fix this by changing how the matching loop works. Rather than looping through the list of IDs in the table calling acpi_matchHid(), you would take the _HID and look for that value in the table of IDs. Then do the same for each entry in _CID. This would mean you couldn't use acpi_MatchHid() in ACPI_IDS_PROBE() anymore, but would give a more accurate bus probe value.
| sys/dev/acpi_support/acpi_fujitsu.c | ||
|---|---|---|
| 234 | Space after '>' | |
| 235–236 | Trailing whitespace here? | |
| sys/dev/acpi_support/acpi_ibm.c | ||
| 422 | I would check the indent on this line, should be two tabs. | |
| sys/dev/acpi_support/acpi_rapidstart.c | ||
| 67–68 | Please keep the blank line between variable declarations and the first line of code (various instances of this in the diff). | |
| 71 | Space after 'if' here as well. | |
| sys/dev/acpi_support/acpi_sony.c | ||
| 119–120 | I would follow what you've done for other drivers here. I would also break out the side effect from the if and do: ret = ACPI_ID_PROBE(...);
if (ret < 0)
    device_set_desc(...);
return (ret); | |
| sys/dev/acpica/acpi.c | ||
| 1660 | I don't think you need this assignment. I think callers can only expect 'match' to be set if the function finds a match (we have other APIs that work similarly) | |
| 1662 | Perhaps 'if (rv != ACPI_MATCHHID_NOMATCH)', but you could also use 'continue' to reduce the indentation if you wanted: rv = acpi_MatchHid(h, ids[i]);
if (rv == ACPI_MATCHHID_NOMATCH)
    continue;
if (match != NULL)
    *match = ids[i];
return (...); | |
| sys/dev/acpica/acpi_if.m | ||
| 83 | Keep an empty line before 'Returns:' | |
| sys/dev/acpica/acpi_resource.c | ||
| 705 | I'm not sure about keeping this check. If we do want this, this should be a separate commit as it would introduce a behavior change on its own right. However, I'm not sure we want to ignore devices that have SYSRES as a CID. We don't do that today. | |
| sys/dev/acpica/acpi_smbat.c | ||
| 116 | Just use 'return' directly instead of a goto. | |
updated:  
Thank you for your comments.
Style nits.
Remove non-related change.
Compare with 0 to check ACPI_ID_PROBE
add comment on acpi_MatchHID
(Sorry, I thought you were going to go over the patch to find other examples of style things besides the ones Warner and I had pointed out. I've gone over the whole diff now.)
| sys/dev/acpi_support/acpi_panasonic.c | ||
|---|---|---|
| 147–149 | Space after 'if' here. | |
| sys/dev/acpi_support/acpi_toshiba.c | ||
| 225–226 | Blank line here between variables and code. | |
| sys/dev/acpi_support/acpi_wmi.c | ||
| 216 | You could drop this blank line perhaps. | |
| sys/dev/acpica/acpi.c | ||
| 1662 | Move the space before the open paren instead of after. | |
| 1665 | Space after 'if' here and also before '{' | |
| sys/dev/acpica/acpi_button.c | ||
| 106 | Space after 'if'. | |
| sys/dev/acpica/acpi_cmbat.c | ||
| 124 | Space after 'if'. | |
| sys/dev/acpica/acpi_cpu.c | ||
| 255 | Maybe '> 0' rather than '== ENXIO'? | |
| sys/dev/acpica/acpi_ec.c | ||
| 365–368 | I think for here it might be more consistent to do this: } else {
    ret = ACPI_ID_PROBE(device_get_parent(dev), dev, ec_ids, NULL);
    if (ret > 0)
        goto out;
    ...And then fix the 'out' label to handle return values that aren't 0. | |
| 427 | This would also need to be updated to handle 'ret' to set it to ENXIO in the device_disable case, maybe by just inverting the conditional: if (peer != NULL && device_is_alive(peer)) {
    device_disable(dev);
    ret = ENXIO;
} | |
| 435 | Make this 'if (ret <= 0) {'. | |
| sys/dev/acpica/acpi_hpet.c | ||
| 459 | Space after 'if'. | |
| sys/dev/acpica/acpi_isab.c | ||
| 101 | Space after 'if'. | |
| sys/dev/acpica/acpi_pci_link.c | ||
| 159 | return (rv) perhaps? That seems more consistent with your other changes. | |
| sys/dev/acpica/acpi_resource.c | ||
| 705 | return (rv)? | |
| sys/dev/acpica/acpi_smbat.c | ||
| 115 | Space after 'if'. | |
| 116 | return (rv)? | |
| sys/dev/asmc/asmc.c | ||
| 381–383 | Could do return (rv) here. | |
| sys/dev/fdc/fdc_acpi.c | ||
| 87 | Space after 'if'. | |
| 87–89 | return (rv)? | |
| sys/dev/gpio/bytgpio.c | ||
| 549 | Space after 'if' | |
| sys/dev/gpio/chvgpio.c | ||
| 351 | Space after 'if' | |
| sys/dev/hyperv/vmbus/vmbus_res.c | ||
| 82 | Space after 'if' | |
| sys/dev/ichiic/ig4_acpi.c | ||
| 90 | Space after 'if' | |
| sys/dev/intel/spi.c | ||
| 431 | Space after 'if' | |