Page MenuHomeFreeBSD

Introduce kdb-level watchpoint functions
ClosedPublic

Authored by mhorne on Mar 9 2021, 6:36 PM.
Tags
None
Referenced Files
F107279316: D29155.id85846.diff
Sat, Jan 11, 9:41 PM
Unknown Object (File)
Sun, Dec 15, 12:08 AM
Unknown Object (File)
Dec 10 2024, 3:12 PM
Unknown Object (File)
Nov 25 2024, 3:53 AM
Unknown Object (File)
Nov 20 2024, 9:03 AM
Unknown Object (File)
Nov 19 2024, 1:37 PM
Unknown Object (File)
Nov 16 2024, 7:38 PM
Unknown Object (File)
Nov 6 2024, 1:34 AM

Details

Summary

This basically mirrors what already exists in ddb, but provides a
slightly improved interface. It allows the caller to specify the
watchpoint access type, and returns more specific error codes to
differentiate failure cases.

These functions will be used to support hardware watchpoint use in
gdb(4). It is about the same amount of work to add per-arch calls there
than it is to lift this interface to KDB, so I opted for the latter.

Stubs are provided for architectures lacking hardware watchpoint logic
(mips, powerpc, riscv). Other architectures are handled in individual
commits, but presented here for easier review.

Removal of the ddb routines will be in a follow-up commit.

Summary of error codes:

  • ENXIO, not supported by platform
  • EBUSY, no free hardware watchpoints
  • EINVAL, invalid address, size, or access type
Test Plan

Tinderbox'd. Runtime testing done with later commits in the series.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 37702
Build 34591: arc lint + arc unit

Event Timeline

mhorne held this revision as a draft.
sys/sys/kdb.h
131

This particular value is unused, but maps to analogous execute bits in the supported debug register implementations, so I don't think it hurts to have.

mhorne published this revision for review.Mar 9 2021, 6:53 PM
mhorne edited the summary of this revision. (Show Details)
sys/amd64/amd64/db_trace.c
392

Is this line too long?

sys/x86/x86/dbreg.c
248

This is strange. Should it be #if defined(DDB) || defined(KDB) or do I miss something?

sys/x86/x86/dbreg.c
292

Why do we have both this db_md_set_watchpoint?

sys/x86/x86/dbreg.c
248

The #endifs are in different places. Still, this construct only makes sense under the original assumption that dbreg.c would always be compiled in.

I will update this review shortly.

292

The new function will replace db_md_set_watchpoint in the next commit, see D29156. Then, both ddb and gdb will use the new functions (D29173).

Rebase on top of changes to D29153. Remove some unneeded #ifdef lines.

jhb added inline comments.
sys/sys/kdb.h
131

I would probably just spell it '_X' rather than '_EXEC' FWIW.

This revision is now accepted and ready to land.Mar 19 2021, 6:28 PM