Page MenuHomeFreeBSD

Fix tracking unknown syscalls for counts.
ClosedPublic

Authored by bdrewery on Oct 3 2015, 9:10 PM.
Tags
None
Referenced Files
F133393150: D3792.id9168.diff
Sat, Oct 25, 11:01 AM
Unknown Object (File)
Fri, Oct 24, 1:35 PM
Unknown Object (File)
Tue, Oct 14, 12:41 PM
Unknown Object (File)
Mon, Oct 6, 4:44 AM
Unknown Object (File)
Sun, Oct 5, 2:57 PM
Unknown Object (File)
Sun, Oct 5, 12:41 PM
Unknown Object (File)
Sun, Oct 5, 5:10 AM
Unknown Object (File)
Mon, Sep 29, 12:44 PM
Subscribers

Details

Summary

This now makes get_syscall() add the syscall into a list if it is not found.
This fixes the counts not tracking unknown syscalls and also simplifies some of
the code to not have to check if sc is valid.

I tried converting this to ohash, but it is an awful library. I gave up for
now. This works and be optimized more later.

Test Plan

A lot of truss and truss -c.

Diff Detail

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

Event Timeline

bdrewery retitled this revision from to Fix tracking unknown syscalls for counts..
bdrewery updated this object.
bdrewery edited the test plan for this revision. (Show Details)
bdrewery added a reviewer: jhb.

You could actually use hcreate(). It's not a great API in that it only supports a single hash table, but that would be ok for truss. I don't think you need to do that before commit though.

usr.bin/truss/syscalls.c
1594

This is the same as LongHex. You can either move the Unknown case so it shares its body, or just use LongHex directly when adding a dummy entry. I prefer the latter.

In D3792#78754, @jhb wrote:

You could actually use hcreate(). It's not a great API in that it only supports a single hash table, but that would be ok for truss. I don't think you need to do that before commit though.

I was hesitant about hcreate due to the db dependency. I wasn't sure if it was acceptable these days. I'll look at it again.

This revision was automatically updated to reflect the committed changes.