From d7660c364533478445331b7f53c061c04c505377 Mon Sep 17 00:00:00 2001 From: christos Date: Mon, 7 Jul 2014 18:46:45 +0000 Subject: [PATCH] From: http://marc.info/?l=openbsd-tech&m=140234174104724&w=2 Avoid off-by-one on FAT12 filesystems. --- sbin/fsck_msdos/fat.c | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/sbin/fsck_msdos/fat.c b/sbin/fsck_msdos/fat.c index 37e37b2168e9..f85e73d3e60b 100644 --- a/sbin/fsck_msdos/fat.c +++ b/sbin/fsck_msdos/fat.c @@ -1,4 +1,4 @@ -/* $NetBSD: fat.c,v 1.26 2014/07/07 17:55:53 christos Exp $ */ +/* $NetBSD: fat.c,v 1.27 2014/07/07 18:46:45 christos Exp $ */ /* * Copyright (C) 1995, 1996, 1997 Wolfgang Solfrank @@ -28,7 +28,7 @@ #include #ifndef lint -__RCSID("$NetBSD: fat.c,v 1.26 2014/07/07 17:55:53 christos Exp $"); +__RCSID("$NetBSD: fat.c,v 1.27 2014/07/07 18:46:45 christos Exp $"); #endif /* not lint */ #include @@ -554,13 +554,15 @@ writefat(int fs, struct bootblock *boot, struct fatEntry *fat, int correct_fat) default: if (fat[cl].next == CLUST_FREE) boot->NumFree++; - if (cl + 1 < boot->NumClusters - && fat[cl + 1].next == CLUST_FREE) - boot->NumFree++; *p++ = (u_char)fat[cl].next; - *p++ = (u_char)((fat[cl].next >> 8) & 0xf) - |(u_char)(fat[cl+1].next << 4); - *p++ = (u_char)(fat[++cl].next >> 4); + *p++ = (u_char)((fat[cl].next >> 8) & 0xf); + cl++; + if (cl >= boot->NumClusters) + break; + if (fat[cl].next == CLUST_FREE) + boot->NumFree++; + *p |= (u_char)(fat[cl + 1].next << 4); + *p++ = (u_char)(fat[cl + 1].next >> 4); break; } }