Page MenuHomeFreeBSD

Add mrsasutil(8) as alias to mfiutil(8)
ClosedPublic

Authored by ambrisko on Aug 24 2022, 10:51 PM.
Tags
None
Referenced Files
F108746729: D36343.id114910.diff
Mon, Jan 27, 4:51 PM
Unknown Object (File)
Thu, Jan 23, 6:26 PM
Unknown Object (File)
Tue, Jan 21, 11:48 PM
Unknown Object (File)
Sun, Jan 19, 8:42 PM
Unknown Object (File)
Sat, Jan 18, 9:36 PM
Unknown Object (File)
Sat, Jan 18, 8:10 AM
Unknown Object (File)
Sat, Jan 18, 1:36 AM
Unknown Object (File)
Fri, Jan 17, 4:47 PM

Details

Summary

mfiutil(8) in theory can work on devices attached to mrsas(4) but
mrsas(4) is missing the FreeBSD mfi(4) ioctl support. Once that
support is added to mrsas(4) then mrsasutil(8) can manage mrsas(4)
attached devices. So this commit depends on that. When mrsasutil(8)
is run it automatically opens /dev/mrsas0 instead of /dev/mfi0.
Also a -t <type> flag to optionally specify mrsas or mfi to work
with the existing -u <unit>.

PR: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=265794
Tested by: Dan Mahoney <freebsd@gushi.org>

Test Plan

This depends on https://reviews.freebsd.org/D36342 to provide the FreeBSD mfi(4) ioctl in mrsas(4) so this tool can run with mrsas(4). Tested on some random mrsas(4) attached controlled as mrsasutil and a long time ago mfiutuil -t mrsas. Other people have found this useful so adding to FreeBSD src.

Diff Detail

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

Event Timeline

ambrisko added reviewers: imp, emaste, jhb.

I wonder if we want some kind of '-D mfi0' type option (either with or without leading /dev) that specifies the device name as well as -t? If you went this route then maybe what would happen is '-D' would set a char *mfi_device variable, and after parsing the options in main(), mfi_device would be constructed from mfi_type and mfi_unit if it isn't already set.

usr.sbin/mfiutil/mfiutil.c
132

Using strdup would seem simpler? Plus, why do you need it allocated vs just assigning to the constant? That is, I would make mfi_type a const char * and have this code just do:

if (strcmp(pn, "mrsasutil") == 0)
    mfi_type = MRSAS_TYPE;
else
    mfi_type = MFI_TYPE;

Address feedback on malloc. I thought I ran into type conflicts before.
I'll look at the -D suggestion.

This change looks pretty mechanical, but one of the sorts of changes that if it compiles it looks like it would work :)

This revision is now accepted and ready to land.Aug 30 2022, 1:46 AM

Add the mfi_device and get rid of mfi_type and mfi_unit.
-D <device> will be made of -t <type> and -u <unit> if not
specified. -t <type> will come from the program name if neither
are specified. Fix up a couple of "mfi" messages and fix unit in the
-t man page description.

This revision now requires review to proceed.Aug 30 2022, 11:42 PM

Fix white space in mfiutil.c.

Thanks for using the mfi_device approach. A few more comments.

usr.sbin/mfiutil/mfi_cmd.c
212

Maybe pass in const char *mfi_device here instead? That avoids having to deal with allocating the type name and freeing that out in the callers.

218–228

This could then become something like:

const char *cp;
int mfi_unit;

cp = mfi_device + strlen("/dev/");
if (strncmp(cp, MRSAS_TYPE, strlen(MRSAS_TYPE)) == 0)
    return (1);

cp += strlen("mfi");
mfi_unit = strtol(cp, , NULL, 10);
len = sizeof(dummy);
...
usr.sbin/mfiutil/mfi_config.c
56–79

Maybe do the whitespace fixes as a separate commit before the content changes to use mfi_device?

usr.sbin/mfiutil/mfiutil.c
162
163–172

It is probably simpler to just use asprintf(3) here. That is, something like:

if (asprintf(&mfi_device, "/dev/%s%d", mfi_type, mfi_unit) == -1)
    errx(1, "Can't allocate memory for device name");
174

Maybe #include <paths.h> and use _PATH_DEV?

176

I would use asprintf() + errx() here as well.

Address jhb's latest round of comments.

ambrisko added inline comments.
usr.sbin/mfiutil/mfi_cmd.c
212

Changed it to address the initial issue so sort of done.

usr.sbin/mfiutil/mfiutil.8
270

three options are supported?

ambrisko marked an inline comment as done.

Address global count and make plural.

Yes, three options and make plural.

One thing that does occur to me is that now a few messages will say things like "/dev/mfi0: <blah blah>" instead of "mfi0: <blah blah>", but that's probably ok. If you wanted you could maybe make a little const char *mfi_name(const char *mfi_device) that just returned mfi_device + strlen(_PATH_DEV) or some such.

That said, I'm fine with you committing regardless.

usr.sbin/mfiutil/mfi_config.c
207

Nit: might want to drop (4) here as it would now say something like "The current mfi0(4) driver"

usr.sbin/mfiutil/mfi_properties.c
67

An old typo, but maybe fix it since you are changing the line anyway?

This revision is now accepted and ready to land.Jan 20 2023, 12:06 AM
yuri_aetern.org added inline comments.
usr.sbin/mfiutil/mfiutil.8
34

Or at least add whitespace between mfiutil and comma so the latter isn't parsed as part of the macro.

274

New sentence, new line.

280

Punctuation and links.

816

Add mrsas to "see also"

Updated based on man page comments.

This revision now requires review to proceed.Apr 14 2023, 10:36 PM

Missed a couple of changes to man page.

ambrisko marked 4 inline comments as done.

Missing a couple of comments from jhb.

This revision is now accepted and ready to land.Apr 18 2023, 8:24 PM
This revision was automatically updated to reflect the committed changes.