aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/sam
diff options
context:
space:
mode:
authorRuss Cox <rsc@swtch.com>2021-01-14 10:05:50 -0500
committerRuss Cox <rsc@swtch.com>2021-01-14 10:05:50 -0500
commit3ccd61629b641613bcccbc51125330efab9c89a7 (patch)
tree58afc0266e867d2fa8fbeeb4efde3c961dc58840 /src/cmd/sam
parent6a80119eb509bd948d87ad1b84b0a82855a3c691 (diff)
downloadplan9port-3ccd61629b641613bcccbc51125330efab9c89a7.tar.gz
plan9port-3ccd61629b641613bcccbc51125330efab9c89a7.tar.bz2
plan9port-3ccd61629b641613bcccbc51125330efab9c89a7.zip
sam: avoid out-of-bounds read in rterm
Usually r->nused < r->nalloc and the read is in bounds. But it could in theory be right on the line and reading past the end of the allocation. Make it safe but preserve as much of the old semantics as possible. This use of rterm appears to be only for optimization purposes so the result does not matter for correctness.
Diffstat (limited to 'src/cmd/sam')
-rw-r--r--src/cmd/sam/rasp.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/src/cmd/sam/rasp.c b/src/cmd/sam/rasp.c
index c96101df..55d16cfb 100644
--- a/src/cmd/sam/rasp.c
+++ b/src/cmd/sam/rasp.c
@@ -283,8 +283,8 @@ rterm(List *r, Posn p1)
for(p = 0,i = 0; i<r->nused && p+L(i)<=p1; p+=L(i++))
;
- if(i==r->nused && (i==0 || !T(i-1)))
- return 0;
+ if(i==r->nused)
+ return i > 0 && T(i-1);
return T(i);
}