1
0
mirror of https://git.FreeBSD.org/src.git synced 2024-10-19 02:29:40 +00:00

Initialize page/subpage in case of modepage -d.

Previously without -m parameter it worked mostly by concodence.

While there, make page/subpage values validation more strict.

MFC after:	5 days
Sponsored by:	iXsystems, Inc.
This commit is contained in:
Alexander Motin 2019-09-09 22:08:22 +00:00
parent fee2a2fa39
commit 576649b30a
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=352111

View File

@ -4549,7 +4549,7 @@ modepage(struct cam_device *device, int argc, char **argv, char *combinedopt,
int task_attr, int retry_count, int timeout)
{
char *str_subpage;
int c, page = -1, subpage = -1, pc = 0, llbaa = 0;
int c, page = -1, subpage = 0, pc = 0, llbaa = 0;
int binary = 0, cdb_len = 10, dbd = 0, desc = 0, edit = 0, list = 0;
while ((c = getopt(argc, argv, combinedopt)) != -1) {
@ -4575,11 +4575,9 @@ modepage(struct cam_device *device, int argc, char **argv, char *combinedopt,
page = strtol(optarg, NULL, 0);
if (str_subpage)
subpage = strtol(str_subpage, NULL, 0);
else
subpage = 0;
if (page < 0)
if (page < 0 || page > 0x3f)
errx(1, "invalid mode page %d", page);
if (subpage < 0)
if (subpage < 0 || subpage > 0xff)
errx(1, "invalid mode subpage %d", subpage);
break;
case 'D':
@ -4598,7 +4596,10 @@ modepage(struct cam_device *device, int argc, char **argv, char *combinedopt,
}
}
if (page == -1 && desc == 0 && list == 0)
if (desc && page == -1)
page = SMS_ALL_PAGES_PAGE;
if (page == -1 && list == 0)
errx(1, "you must specify a mode page!");
if (dbd && desc)