Page MenuHomeFreeBSD

sys/intr: switch to index vars from table size vars
AbandonedPublic

Authored by ehem_freebsd_m5p.com on Jan 19 2023, 3:37 AM.
Tags
None
Referenced Files
F107110038: D38116.diff
Fri, Jan 10, 6:31 AM
Unknown Object (File)
Tue, Dec 24, 9:15 PM
Unknown Object (File)
Fri, Dec 13, 11:54 PM
Unknown Object (File)
Nov 21 2024, 6:42 AM
Unknown Object (File)
Nov 16 2024, 1:03 PM
Unknown Object (File)
Oct 24 2024, 11:40 PM
Unknown Object (File)
Oct 3 2024, 3:32 PM
Unknown Object (File)
Oct 3 2024, 12:58 PM
Subscribers

Details

Reviewers
markj
mmel
Summary

Since all interrupt table implementations use the same index variable to
indicate current table size, use that instead of size variables.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 49160
Build 46049: arc lint + arc unit

Event Timeline

This seems reasonable to me overall.

sys/kern/kern_intr.c
1659

Shouldn't "MAXCOMLEN+1" be INTRNAME_LEN or so?

1715

Before we were iterating over the entire table, now we're iterating up to the last allocated index. Do we still need this check?

ehem_freebsd_m5p.com added inline comments.
sys/kern/kern_intr.c
1659

Unfortunately, INTRNAME_LEN is INTRNG-only whereas this is shared by the distinct architectural interrupt subsystems. As a result MAXCOM + 1 must be used. This is also why D38116 depends upon D38115 (without D38115 the entry lengths vary by architecture and this doesn't work).

1715

I agree, I'll adjust this.

ehem_freebsd_m5p.com marked 2 inline comments as done.

Update db_show_intrcnt() rather more than suggested, fully adjust to match how all architectures have been handling intrnames for some time.

Testing identified trouble with watchdog_fire(), do similar work there.

sys/kern/kern_intr.c
1659

I should add. I could do a second commit (which may or may not work as part of D38116) which moves INTRNAME_LEN from sys/sys/intr.h to sys/sys/interrupt.h and modifies sys/powerpc/powerpc/intr_machdep.c/sys/x86/x86/intr_machdep.c to use that instead of MAXCOMLEN + 1.

If that was done then it would be appropriate to use INTRNAME_LEN instead and I would do so.

Update in light of D38116. The impact was interesting to figure out.