Page MenuHomeFreeBSD

LinuxKPI,lindebugfs: add more base type support
ClosedPublic

Authored by bz on Oct 22 2022, 6:15 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Dec 26, 9:37 AM
Unknown Object (File)
Wed, Dec 25, 11:49 PM
Unknown Object (File)
Nov 21 2024, 6:33 AM
Unknown Object (File)
Nov 11 2024, 9:07 AM
Unknown Object (File)
Oct 30 2024, 2:20 AM
Unknown Object (File)
Oct 29 2024, 10:59 PM
Unknown Object (File)
Oct 28 2024, 9:46 PM
Unknown Object (File)
Oct 28 2024, 12:19 PM

Details

Summary

Add debugfs_create_u8() based on other already present implementations.
I am unclear if we need to add extra checks.

Add a dummy (no real implementation yet) for debugfs_create_blob().

Both are needed for iwlwifi debugfs support.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

bz requested review of this revision.Oct 22 2022, 6:15 PM

This is just so to have the skeleton for a discussion on how to implement "blob" properly. I am hoping @jfree may have a good idea.

Add missing struct definition already in my local file from earlier work.

I feel like the scattered nature of debugfs material makes it incredibly difficult to work with.
Perhaps something along the lines of this would work:

static int
debugfs_blob_get(void *data, uint64_t *value)
{
	struct debugfs_blob_wrapper *blob = data;
	memcpy(value, blob->data, blob->size);
	return (0);
}

static int
debugfs_blob_set(void *data, uint64_t value)
{
	struct debugfs_blob_wrapper *blob = data;
	blob->size = sizeof(value);
	memcpy(blob->data, &value, blob->size);
	return (0);
}

I think the blob's fops should be defined manually rather than using DEFINE_DEBUGFS_ATTRIBUTE.
This will allow us to malloc the blob->data member in an open fop and free data in the release fop.
The problem is, this malloc would only account for a single sized blob. We would need to add bounds
checking in the blob's get and set functions to ensure safety.

Alternatively, we could dynamically malloc in debugfs_blob_set, but I do not know how to reliably free that.

I am not sure what the origin authors intended for the implementation. Let me know what you think.

Implement ro blob support.

I just took a quick glance, but everything looks good :)
Take a look at my inline comment, though.

sys/compat/lindebugfs/lindebugfs.c
460–462

You can probably use debugfs_create_file() instead of debugfs_create_mode_unsafe() since both of your fops are RO.

Use debugfs_create_file() to create blobs as suggested by @jfree

bz marked an inline comment as done.Nov 7 2022, 1:23 PM

Anyone care to further review / accept this?

This revision was not accepted when it landed; it landed in state Needs Review.Nov 28 2022, 5:25 PM
This revision was automatically updated to reflect the committed changes.