[PATCH] Only make one active partition in sysinstall(8)
Scott Long
scottl at samsco.org
Mon Sep 6 09:21:53 PDT 2004
Xin,
Please feel free to commit this to HEAD right now and get it reviewed
for RELENG_5.
Thanks!
Scott
Xin LI wrote:
>>Submitter-Id: current-users
>>Originator: Xin LI
>>Organization: The FreeBSD Simplified Chinese Project
>>Confidential: no
>>Synopsis: [PATCH] Only make one active partition in sysinstall(8)
>>Severity: serious
>>Priority: high
>>Category: bin
>>Class: sw-bug
>>Release: FreeBSD 5.2-delphij i386
>>Environment:
>
> System: FreeBSD beastie.frontfree.net 5.2-delphij FreeBSD 5.2-delphij #0: Tue Aug 17 14:22:25 CST 2004 delphij at beastie.frontfree.net:/usr/obj/usr/src/sys/BEASTIE i386
>
>
>>Description:
>
> The handling of active partition in sysinstall(8) contained a minor
> flaw that allows two partitions to be marked as "active" in the same time.
> Before having a user shoot his or her feet, I think it would be a good idea
> not permitting this at all.
>
>
>>How-To-Repeat:
>
> Run sysinstall(8), Configure -> Fdisk -> (choose a disk having more
> than one partition) -> try to use "S" on more than one partition.
>
>
>>Fix:
>
>
> The attached patch would reset active states in the whole partition
> chain and hence won't allow two partitions to be set "active" at the same
> time. Might be a good candidate for the upcoming 5.3-RELEASE.
>
> Along with the functional patch I have added a "CHUNK_INFO_ENTRIES"
> define to make it easier to have consist code.
>
> --- patch-sysinstall::disks.c begins here ---
> Index: disks.c
> ===================================================================
> RCS file: /home/fcvs/src/usr.sbin/sysinstall/disks.c,v
> retrieving revision 1.152
> diff -u -r1.152 disks.c
> --- disks.c 2 Aug 2004 23:18:48 -0000 1.152
> +++ disks.c 5 Sep 2004 16:39:22 -0000
> @@ -74,7 +74,8 @@
> #define CHUNK_START_ROW 5
>
> /* Where we keep track of MBR chunks */
> -static struct chunk *chunk_info[16];
> +#define CHUNK_INFO_ENTRIES 16
> +static struct chunk *chunk_info[CHUNK_INFO_ENTRIES];
> static int current_chunk;
>
> static void diskPartitionNonInteractive(Device *dev);
> @@ -312,6 +313,7 @@
> {
> char *cp, *p;
> int rv, key = 0;
> + int i;
> Boolean chunking;
> char *msg = NULL;
> #ifdef PC98
> @@ -535,6 +537,10 @@
> break;
>
> case 'S':
> + /* Clear active states so we won't have two */
> + for (i = 0; (chunk_info[i] != NULL) && (i < CHUNK_INFO_ENTRIES); i++)
> + chunk_info[i]->flags &= !CHUNK_ACTIVE;
> +
> /* Set Bootable */
> chunk_info[current_chunk]->flags |= CHUNK_ACTIVE;
> break;
> --- patch-sysinstall::disks.c ends here ---
>
>
More information about the freebsd-qa
mailing list