From 6005ef5a1c0bb17a3a5da683d95ed9e1e6f44e68 Mon Sep 17 00:00:00 2001 From: Frans Kaashoek Date: Tue, 20 Aug 2019 11:57:24 -0400 Subject: [PATCH] Release buffer also when copyin fails --- kernel/fs.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/kernel/fs.c b/kernel/fs.c index 454d52b..da9bcca 100644 --- a/kernel/fs.c +++ b/kernel/fs.c @@ -495,8 +495,10 @@ writei(struct inode *ip, int user_src, uint64 src, uint off, uint n) for(tot=0; totdev, bmap(ip, off/BSIZE)); m = min(n - tot, BSIZE - off%BSIZE); - if(either_copyin(bp->data + (off % BSIZE), user_src, src, m) == -1) + if(either_copyin(bp->data + (off % BSIZE), user_src, src, m) == -1) { + brelse(bp); break; + } log_write(bp); brelse(bp); }