cvs commit: src/sys/kern subr_bus.c
Poul-Henning Kamp
phk at phk.freebsd.dk
Sat Jan 14 15:35:46 PST 2006
In message <43C9636B.6070500 at root.org>, Nate Lawson writes:
>Poul-Henning Kamp wrote:
>> Index: src/sys/kern/subr_bus.c
>> diff -u src/sys/kern/subr_bus.c:1.187 src/sys/kern/subr_bus.c:1.188
>> --- src/sys/kern/subr_bus.c:1.187 Tue Oct 4 22:25:14 2005
>> +++ src/sys/kern/subr_bus.c Sat Jan 14 09:41:35 2006
>> @@ -2820,7 +2820,7 @@
>> {
>> struct resource_list_entry *rle;
>>
>> - STAILQ_FOREACH(rle, rl, link) {
>> + while ((rle = STAILQ_FIRST(rl)) != NULL) {
>> if (rle->res)
>> bus_release_resource(rman_get_device(rle->res),
>> rle->type, rle->rid, rle->res);
>
>Isn't that what the STAILQ_FOREACH_SAFE() macro is for? List traversal
>with deletion? Your approach is also fine.
In this case we empty the entire list, so this should be marginally
faster, which is probably irrelevevant, and maybe a tiny bit clearer
on the intent.
--
Poul-Henning Kamp | UNIX since Zilog Zeus 3.20
phk at FreeBSD.ORG | TCP/IP since RFC 956
FreeBSD committer | BSD since 4.3-tahoe
Never attribute to malice what can adequately be explained by incompetence.
More information about the cvs-all
mailing list