dsl_prop_known_index(): check for invalid prop

Resolve UBSAN array-index-out-of-bounds error in zprop_desc_t.

Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: szubersk <szuberskidamian@gmail.com>
Closes #14142
Closes #14147
This commit is contained in:
Damian Szuberski 2022-11-09 04:16:01 +10:00 committed by GitHub
parent 41715771b5
commit 109731cd73
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 28 additions and 1 deletions

View File

@ -748,6 +748,8 @@ zfs_prop_init(void)
boolean_t boolean_t
zfs_prop_delegatable(zfs_prop_t prop) zfs_prop_delegatable(zfs_prop_t prop)
{ {
ASSERT3S(prop, >=, 0);
ASSERT3S(prop, <, ZFS_NUM_PROPS);
zprop_desc_t *pd = &zfs_prop_table[prop]; zprop_desc_t *pd = &zfs_prop_table[prop];
/* The mlslabel property is never delegatable. */ /* The mlslabel property is never delegatable. */
@ -858,6 +860,8 @@ zfs_prop_valid_for_type(int prop, zfs_type_t types, boolean_t headcheck)
zprop_type_t zprop_type_t
zfs_prop_get_type(zfs_prop_t prop) zfs_prop_get_type(zfs_prop_t prop)
{ {
ASSERT3S(prop, >=, 0);
ASSERT3S(prop, <, ZFS_NUM_PROPS);
return (zfs_prop_table[prop].pd_proptype); return (zfs_prop_table[prop].pd_proptype);
} }
@ -867,6 +871,8 @@ zfs_prop_get_type(zfs_prop_t prop)
boolean_t boolean_t
zfs_prop_readonly(zfs_prop_t prop) zfs_prop_readonly(zfs_prop_t prop)
{ {
ASSERT3S(prop, >=, 0);
ASSERT3S(prop, <, ZFS_NUM_PROPS);
return (zfs_prop_table[prop].pd_attr == PROP_READONLY || return (zfs_prop_table[prop].pd_attr == PROP_READONLY ||
zfs_prop_table[prop].pd_attr == PROP_ONETIME || zfs_prop_table[prop].pd_attr == PROP_ONETIME ||
zfs_prop_table[prop].pd_attr == PROP_ONETIME_DEFAULT); zfs_prop_table[prop].pd_attr == PROP_ONETIME_DEFAULT);
@ -878,6 +884,8 @@ zfs_prop_readonly(zfs_prop_t prop)
boolean_t boolean_t
zfs_prop_visible(zfs_prop_t prop) zfs_prop_visible(zfs_prop_t prop)
{ {
ASSERT3S(prop, >=, 0);
ASSERT3S(prop, <, ZFS_NUM_PROPS);
return (zfs_prop_table[prop].pd_visible && return (zfs_prop_table[prop].pd_visible &&
zfs_prop_table[prop].pd_zfs_mod_supported); zfs_prop_table[prop].pd_zfs_mod_supported);
} }
@ -888,6 +896,8 @@ zfs_prop_visible(zfs_prop_t prop)
boolean_t boolean_t
zfs_prop_setonce(zfs_prop_t prop) zfs_prop_setonce(zfs_prop_t prop)
{ {
ASSERT3S(prop, >=, 0);
ASSERT3S(prop, <, ZFS_NUM_PROPS);
return (zfs_prop_table[prop].pd_attr == PROP_ONETIME || return (zfs_prop_table[prop].pd_attr == PROP_ONETIME ||
zfs_prop_table[prop].pd_attr == PROP_ONETIME_DEFAULT); zfs_prop_table[prop].pd_attr == PROP_ONETIME_DEFAULT);
} }
@ -895,12 +905,16 @@ zfs_prop_setonce(zfs_prop_t prop)
const char * const char *
zfs_prop_default_string(zfs_prop_t prop) zfs_prop_default_string(zfs_prop_t prop)
{ {
ASSERT3S(prop, >=, 0);
ASSERT3S(prop, <, ZFS_NUM_PROPS);
return (zfs_prop_table[prop].pd_strdefault); return (zfs_prop_table[prop].pd_strdefault);
} }
uint64_t uint64_t
zfs_prop_default_numeric(zfs_prop_t prop) zfs_prop_default_numeric(zfs_prop_t prop)
{ {
ASSERT3S(prop, >=, 0);
ASSERT3S(prop, <, ZFS_NUM_PROPS);
return (zfs_prop_table[prop].pd_numdefault); return (zfs_prop_table[prop].pd_numdefault);
} }
@ -911,6 +925,8 @@ zfs_prop_default_numeric(zfs_prop_t prop)
const char * const char *
zfs_prop_to_name(zfs_prop_t prop) zfs_prop_to_name(zfs_prop_t prop)
{ {
ASSERT3S(prop, >=, 0);
ASSERT3S(prop, <, ZFS_NUM_PROPS);
return (zfs_prop_table[prop].pd_name); return (zfs_prop_table[prop].pd_name);
} }
@ -920,6 +936,8 @@ zfs_prop_to_name(zfs_prop_t prop)
boolean_t boolean_t
zfs_prop_inheritable(zfs_prop_t prop) zfs_prop_inheritable(zfs_prop_t prop)
{ {
ASSERT3S(prop, >=, 0);
ASSERT3S(prop, <, ZFS_NUM_PROPS);
return (zfs_prop_table[prop].pd_attr == PROP_INHERIT || return (zfs_prop_table[prop].pd_attr == PROP_INHERIT ||
zfs_prop_table[prop].pd_attr == PROP_ONETIME); zfs_prop_table[prop].pd_attr == PROP_ONETIME);
} }
@ -972,6 +990,8 @@ zfs_prop_valid_keylocation(const char *str, boolean_t encrypted)
const char * const char *
zfs_prop_values(zfs_prop_t prop) zfs_prop_values(zfs_prop_t prop)
{ {
ASSERT3S(prop, >=, 0);
ASSERT3S(prop, <, ZFS_NUM_PROPS);
return (zfs_prop_table[prop].pd_values); return (zfs_prop_table[prop].pd_values);
} }
@ -983,6 +1003,8 @@ zfs_prop_values(zfs_prop_t prop)
int int
zfs_prop_is_string(zfs_prop_t prop) zfs_prop_is_string(zfs_prop_t prop)
{ {
ASSERT3S(prop, >=, 0);
ASSERT3S(prop, <, ZFS_NUM_PROPS);
return (zfs_prop_table[prop].pd_proptype == PROP_TYPE_STRING || return (zfs_prop_table[prop].pd_proptype == PROP_TYPE_STRING ||
zfs_prop_table[prop].pd_proptype == PROP_TYPE_INDEX); zfs_prop_table[prop].pd_proptype == PROP_TYPE_INDEX);
} }
@ -994,6 +1016,8 @@ zfs_prop_is_string(zfs_prop_t prop)
const char * const char *
zfs_prop_column_name(zfs_prop_t prop) zfs_prop_column_name(zfs_prop_t prop)
{ {
ASSERT3S(prop, >=, 0);
ASSERT3S(prop, <, ZFS_NUM_PROPS);
return (zfs_prop_table[prop].pd_colname); return (zfs_prop_table[prop].pd_colname);
} }
@ -1004,6 +1028,8 @@ zfs_prop_column_name(zfs_prop_t prop)
boolean_t boolean_t
zfs_prop_align_right(zfs_prop_t prop) zfs_prop_align_right(zfs_prop_t prop)
{ {
ASSERT3S(prop, >=, 0);
ASSERT3S(prop, <, ZFS_NUM_PROPS);
return (zfs_prop_table[prop].pd_rightalign); return (zfs_prop_table[prop].pd_rightalign);
} }

View File

@ -75,7 +75,8 @@ static int
dsl_prop_known_index(zfs_prop_t prop, uint64_t value) dsl_prop_known_index(zfs_prop_t prop, uint64_t value)
{ {
const char *str = NULL; const char *str = NULL;
if (zfs_prop_get_type(prop) == PROP_TYPE_INDEX) if (prop != ZPROP_CONT && prop != ZPROP_INVAL &&
zfs_prop_get_type(prop) == PROP_TYPE_INDEX)
return (!zfs_prop_index_to_string(prop, value, &str)); return (!zfs_prop_index_to_string(prop, value, &str));
return (-1); return (-1);