Add a sysctl kern.disallow_high_osrel which disables executing the

images compiled on the world with higher major version number than the
high version number of the booted kernel.  Default to disable.

Sponsored by:	The FreeBSD Foundation
Discussed with:	bapt
MFC after:	1 week
This commit is contained in:
Konstantin Belousov 2013-10-15 06:38:40 +00:00
parent cd4dd444dd
commit eda6009c04
2 changed files with 16 additions and 0 deletions

View File

@ -123,6 +123,11 @@ u_long ps_arg_cache_limit = PAGE_SIZE / 16;
SYSCTL_ULONG(_kern, OID_AUTO, ps_arg_cache_limit, CTLFLAG_RW, SYSCTL_ULONG(_kern, OID_AUTO, ps_arg_cache_limit, CTLFLAG_RW,
&ps_arg_cache_limit, 0, ""); &ps_arg_cache_limit, 0, "");
static int disallow_high_osrel;
SYSCTL_INT(_kern, OID_AUTO, disallow_high_osrel, CTLFLAG_RW,
&disallow_high_osrel, 0,
"Disallow execution of binaries built for higher version of the world");
static int map_at_zero = 0; static int map_at_zero = 0;
TUNABLE_INT("security.bsd.map_at_zero", &map_at_zero); TUNABLE_INT("security.bsd.map_at_zero", &map_at_zero);
SYSCTL_INT(_security_bsd, OID_AUTO, map_at_zero, CTLFLAG_RW, &map_at_zero, 0, SYSCTL_INT(_security_bsd, OID_AUTO, map_at_zero, CTLFLAG_RW, &map_at_zero, 0,
@ -552,6 +557,15 @@ interpret:
vn_fullpath(td, imgp->vp, &imgp->execpath, &imgp->freepath) != 0)) vn_fullpath(td, imgp->vp, &imgp->execpath, &imgp->freepath) != 0))
imgp->execpath = args->fname; imgp->execpath = args->fname;
if (disallow_high_osrel &&
P_OSREL_MAJOR(p->p_osrel) > P_OSREL_MAJOR(__FreeBSD_version)) {
error = ENOEXEC;
uprintf("Osrel %d for image %s too high\n", p->p_osrel,
imgp->execpath != NULL ? imgp->execpath : "<unresolved>");
vn_lock(imgp->vp, LK_SHARED | LK_RETRY);
goto exec_fail_dealloc;
}
/* /*
* Copy out strings (args and env) and initialize stack base * Copy out strings (args and env) and initialize stack base
*/ */

View File

@ -80,6 +80,8 @@
#define P_OSREL_SIGWAIT 700000 #define P_OSREL_SIGWAIT 700000
#define P_OSREL_SIGSEGV 700004 #define P_OSREL_SIGSEGV 700004
#define P_OSREL_MAP_ANON 800104 #define P_OSREL_MAP_ANON 800104
#define P_OSREL_MAJOR(x) ((x) / 100000)
#endif #endif
#ifndef LOCORE #ifndef LOCORE