Skip to content

Commit

Permalink
mmap: disallow MAP_STACK into a reservation
Browse files Browse the repository at this point in the history
It doesn't make sense to insert a stack into a reservation so disallow
MAP_FIXED|MAP_STACK with a valid capability in addr.  It's still allowed
to MAP_FIXED|MAP_STACK, but only if there's nothing in that location
(and you shouldn't be doing that).
  • Loading branch information
brooksdavis committed Jan 8, 2025
1 parent 4ae1c7e commit b1c070a
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 7 deletions.
15 changes: 8 additions & 7 deletions bin/cheribsdtest/cheribsdtest_vm.c
Original file line number Diff line number Diff line change
Expand Up @@ -2851,7 +2851,8 @@ CHERIBSDTEST(cheri_revoke_shm_anon_hoard_closed,
* caused a panic.
* https://github.com/CTSRD-CHERI/cheribsd/issues/2252
*/
CHERIBSDTEST(mmap_insert_stack, "insert a stack mapping in a reservation")
CHERIBSDTEST(mmap_insert_stack,
"try to insert a stack mapping in a reservation")
{
void *p;

Expand All @@ -2860,13 +2861,13 @@ CHERIBSDTEST(mmap_insert_stack, "insert a stack mapping in a reservation")
MAP_FIXED | MAP_ANONYMOUS | MAP_PRIVATE, -1, 0));

/*
* This would fail, but leave the map in a broken state due to
* trying to insert a reservation inside an existing one.
*
* We don't check it because it is needed to set up the panic.
* Historically would fail, but leave the map in a broken state
* due to trying to insert a reservation inside an existing one.
* This is now rejected outright.
*/
mmap(cheri_setaddress(p, 0x20ffc000), 0x2000,
PROT_WRITE | PROT_READ, MAP_STACK | MAP_FIXED, -1, 0);
CHERIBSDTEST_CHECK_CALL_ERROR(mmap(cheri_setaddress(p, 0x20ffc000),
0x2000, PROT_WRITE | PROT_READ, MAP_STACK | MAP_FIXED, -1, 0),
ENOMEM);

/*
* This would trigger a panic by trying to remove an unmapped
Expand Down
8 changes: 8 additions & 0 deletions lib/libsys/mmap.2
Original file line number Diff line number Diff line change
Expand Up @@ -409,6 +409,14 @@ and
.Dv PROT_WRITE .
The size of the guard, in pages, is specified by sysctl
.Dv security.bsd.stack_guard_page .
.Pp
Under CheriABI,
.Dv MAP_STACK
may not be combined with
.Dv MAP_FIXED
and an
.Fa addr
argument that is a valid pointer.
.El
.Pp
The
Expand Down
2 changes: 2 additions & 0 deletions sys/vm/vm_mmap.c
Original file line number Diff line number Diff line change
Expand Up @@ -335,6 +335,8 @@ sys_mmap(struct thread *td, struct mmap_args *uap)
if (cheri_gettag(uap->addr)) {
if ((flags & MAP_FIXED) == 0)
return (EPROT);
else if ((flags & MAP_STACK) != 0)
return (ENOMEM);
else if ((cheri_getperm(uap->addr) & CHERI_PERM_SW_VMEM))
source_cap = uap->addr;
else {

Check warning on line 342 in sys/vm/vm_mmap.c

View workflow job for this annotation

GitHub Actions / Style Checker

Missing Signed-off-by: line
Expand Down

0 comments on commit b1c070a

Please sign in to comment.