summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorPoul-Henning Kamp <phk@FreeBSD.org>2002-09-30 19:19:47 +0000
committerPoul-Henning Kamp <phk@FreeBSD.org>2002-09-30 19:19:47 +0000
commit50c2233141ad55e3c1eb0989096310ea8ec3f643 (patch)
tree8a12dabc47e17db23849dcc73b6b229debbcfbb2 /sys
parent854add2319f1bf444badf9d0abf73e33d639a046 (diff)
Notes
Diffstat (limited to 'sys')
-rw-r--r--sys/kern/kern_ktrace.c18
1 files changed, 14 insertions, 4 deletions
diff --git a/sys/kern/kern_ktrace.c b/sys/kern/kern_ktrace.c
index 537072dae915..0ad2df332e2f 100644
--- a/sys/kern/kern_ktrace.c
+++ b/sys/kern/kern_ktrace.c
@@ -325,8 +325,11 @@ ktrsyscall(code, narg, args)
bcopy(args, buf, buflen);
}
req = ktr_getrequest(KTR_SYSCALL);
- if (req == NULL)
+ if (req == NULL) {
+ if (buf != NULL)
+ free(buf, M_KTRACE);
return;
+ }
ktp = &req->ktr_data.ktr_syscall;
ktp->ktr_code = code;
ktp->ktr_narg = narg;
@@ -372,8 +375,11 @@ ktrnamei(path)
bcopy(path, buf, namelen);
}
req = ktr_getrequest(KTR_NAMEI);
- if (req == NULL)
+ if (req == NULL) {
+ if (buf != NULL)
+ free(buf, M_KTRACE);
return;
+ }
if (namelen > 0) {
req->ktr_header.ktr_len = namelen;
req->ktr_header.ktr_buffer = buf;
@@ -621,11 +627,15 @@ utrace(td, uap)
return (EINVAL);
cp = malloc(uap->len, M_KTRACE, M_WAITOK);
error = copyin(uap->addr, cp, uap->len);
- if (error)
+ if (error) {
+ free(cp, M_KTRACE);
return (error);
+ }
req = ktr_getrequest(KTR_USER);
- if (req == NULL)
+ if (req == NULL) {
+ free(cp, M_KTRACE);
return (0);
+ }
req->ktr_header.ktr_buffer = cp;
req->ktr_header.ktr_len = uap->len;
ktr_submitrequest(req);