Add tunables for channel programs
This patch adds tunables for modifying the maximum memory limit and maximum instruction limit that can be specified when running a channel program. Reviewed-by: Matthew Ahrens <mahrens@delphix.com> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov Reviewed-by: Sara Hartse <sara.hartse@delphix.com> Signed-off-by: John Gallagher <john.gallagher@delphix.com> External-issue: LX-1085 Closes #7618
This commit is contained in:
parent
7b98f0d91f
commit
917f475fba
|
@ -21,7 +21,7 @@
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||||
* Copyright (c) 2011, 2017 by Delphix. All rights reserved.
|
* Copyright (c) 2011, 2018 by Delphix. All rights reserved.
|
||||||
* Copyright 2012 Milan Jurik. All rights reserved.
|
* Copyright 2012 Milan Jurik. All rights reserved.
|
||||||
* Copyright (c) 2012, Joyent, Inc. All rights reserved.
|
* Copyright (c) 2012, Joyent, Inc. All rights reserved.
|
||||||
* Copyright (c) 2013 Steven Hartland. All rights reserved.
|
* Copyright (c) 2013 Steven Hartland. All rights reserved.
|
||||||
|
@ -7308,24 +7308,10 @@ zfs_do_channel_program(int argc, char **argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (c == 't') {
|
if (c == 't') {
|
||||||
if (arg > ZCP_MAX_INSTRLIMIT || arg == 0) {
|
instrlimit = arg;
|
||||||
(void) fprintf(stderr, gettext(
|
|
||||||
"Invalid instruction limit: "
|
|
||||||
"%s\n"), optarg);
|
|
||||||
return (1);
|
|
||||||
} else {
|
|
||||||
instrlimit = arg;
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
ASSERT3U(c, ==, 'm');
|
ASSERT3U(c, ==, 'm');
|
||||||
if (arg > ZCP_MAX_MEMLIMIT || arg == 0) {
|
memlimit = arg;
|
||||||
(void) fprintf(stderr, gettext(
|
|
||||||
"Invalid memory limit: "
|
|
||||||
"%s\n"), optarg);
|
|
||||||
return (1);
|
|
||||||
} else {
|
|
||||||
memlimit = arg;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2016, 2017 by Delphix. All rights reserved.
|
* Copyright (c) 2016, 2018 by Delphix. All rights reserved.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _SYS_ZCP_H
|
#ifndef _SYS_ZCP_H
|
||||||
|
@ -33,8 +33,8 @@ extern "C" {
|
||||||
|
|
||||||
#define ZCP_RUN_INFO_KEY "runinfo"
|
#define ZCP_RUN_INFO_KEY "runinfo"
|
||||||
|
|
||||||
extern uint64_t zfs_lua_max_instrlimit;
|
extern unsigned long zfs_lua_max_instrlimit;
|
||||||
extern uint64_t zfs_lua_max_memlimit;
|
extern unsigned long zfs_lua_max_memlimit;
|
||||||
|
|
||||||
int zcp_argerror(lua_State *, int, const char *, ...);
|
int zcp_argerror(lua_State *, int, const char *, ...);
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
'\" te
|
'\" te
|
||||||
.\" Copyright (c) 2013 by Turbo Fredriksson <turbo@bayour.com>. All rights reserved.
|
.\" Copyright (c) 2013 by Turbo Fredriksson <turbo@bayour.com>. All rights reserved.
|
||||||
.\" Copyright (c) 2017 Datto Inc.
|
.\" Copyright (c) 2017 Datto Inc.
|
||||||
|
.\" Copyright (c) 2018 by Delphix. All rights reserved.
|
||||||
.\" The contents of this file are subject to the terms of the Common Development
|
.\" The contents of this file are subject to the terms of the Common Development
|
||||||
.\" and Distribution License (the "License"). You may not use this file except
|
.\" and Distribution License (the "License"). You may not use this file except
|
||||||
.\" in compliance with the License. You can obtain a copy of the license at
|
.\" in compliance with the License. You can obtain a copy of the license at
|
||||||
|
@ -1560,6 +1561,30 @@ dataset being written to had the property setting \fBlogbias=throughput\fR.
|
||||||
Default value: \fB32,768\fR.
|
Default value: \fB32,768\fR.
|
||||||
.RE
|
.RE
|
||||||
|
|
||||||
|
.sp
|
||||||
|
.ne 2
|
||||||
|
.na
|
||||||
|
\fBzfs_lua_max_instrlimit\fR (ulong)
|
||||||
|
.ad
|
||||||
|
.RS 12n
|
||||||
|
The maximum execution time limit that can be set for a ZFS channel program,
|
||||||
|
specified as a number of Lua instructions.
|
||||||
|
.sp
|
||||||
|
Default value: \fB100,000,000\fR.
|
||||||
|
.RE
|
||||||
|
|
||||||
|
.sp
|
||||||
|
.ne 2
|
||||||
|
.na
|
||||||
|
\fBzfs_lua_max_memlimit\fR (ulong)
|
||||||
|
.ad
|
||||||
|
.RS 12n
|
||||||
|
The maximum memory limit that can be set for a ZFS channel program, specified
|
||||||
|
in bytes.
|
||||||
|
.sp
|
||||||
|
Default value: \fB104,857,600\fR.
|
||||||
|
.RE
|
||||||
|
|
||||||
.sp
|
.sp
|
||||||
.ne 2
|
.ne 2
|
||||||
.na
|
.na
|
||||||
|
|
|
@ -14,7 +14,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2016, 2017 by Delphix. All rights reserved.
|
* Copyright (c) 2016, 2018 by Delphix. All rights reserved.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -108,8 +108,8 @@
|
||||||
#define ZCP_NVLIST_MAX_DEPTH 20
|
#define ZCP_NVLIST_MAX_DEPTH 20
|
||||||
|
|
||||||
uint64_t zfs_lua_check_instrlimit_interval = 100;
|
uint64_t zfs_lua_check_instrlimit_interval = 100;
|
||||||
uint64_t zfs_lua_max_instrlimit = ZCP_MAX_INSTRLIMIT;
|
unsigned long zfs_lua_max_instrlimit = ZCP_MAX_INSTRLIMIT;
|
||||||
uint64_t zfs_lua_max_memlimit = ZCP_MAX_MEMLIMIT;
|
unsigned long zfs_lua_max_memlimit = ZCP_MAX_MEMLIMIT;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Forward declarations for mutually recursive functions
|
* Forward declarations for mutually recursive functions
|
||||||
|
@ -1417,3 +1417,15 @@ zcp_parse_args(lua_State *state, const char *fname, const zcp_arg_t *pargs,
|
||||||
zcp_parse_pos_args(state, fname, pargs, kwargs);
|
zcp_parse_pos_args(state, fname, pargs, kwargs);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(_KERNEL)
|
||||||
|
/* BEGIN CSTYLED */
|
||||||
|
module_param(zfs_lua_max_instrlimit, ulong, 0644);
|
||||||
|
MODULE_PARM_DESC(zfs_lua_max_instrlimit,
|
||||||
|
"Max instruction limit that can be specified for a channel program");
|
||||||
|
|
||||||
|
module_param(zfs_lua_max_memlimit, ulong, 0644);
|
||||||
|
MODULE_PARM_DESC(zfs_lua_max_memlimit,
|
||||||
|
"Max memory limit that can be specified for a channel program");
|
||||||
|
/* END CSTYLED */
|
||||||
|
#endif
|
||||||
|
|
|
@ -61,12 +61,12 @@ log_mustnot_checkerror_program "Memory limit exhausted" -m 1 $TESTPOOL - <<-EOF
|
||||||
return s
|
return s
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
log_mustnot_checkerror_program "Invalid memory limit" \
|
log_mustnot_checkerror_program "Invalid instruction or memory limit" \
|
||||||
-m 1000000000000 $TESTPOOL - <<-EOF
|
-m 200000000 $TESTPOOL - <<-EOF
|
||||||
return 1;
|
return 1;
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
log_mustnot_checkerror_program "Invalid memory limit" \
|
log_mustnot_checkerror_program "Return value too large" \
|
||||||
-m 9223372036854775808 $TESTPOOL - <<-EOF
|
-m 9223372036854775808 $TESTPOOL - <<-EOF
|
||||||
return 1;
|
return 1;
|
||||||
EOF
|
EOF
|
||||||
|
|
Loading…
Reference in New Issue