summaryrefslogtreecommitdiffstats
path: root/release/libdisk
diff options
context:
space:
mode:
authorphk <phk@FreeBSD.org>1995-05-15 00:58:25 +0000
committerphk <phk@FreeBSD.org>1995-05-15 00:58:25 +0000
commitad0a2407f547e45373455e020abd83ae9373a5d1 (patch)
treea3d40b18367e731283cf34b06a0483aa9e006708 /release/libdisk
parentc4c737dae7209c4b077ced801011c20802ba437a (diff)
downloadFreeBSD-src-ad0a2407f547e45373455e020abd83ae9373a5d1.zip
FreeBSD-src-ad0a2407f547e45373455e020abd83ae9373a5d1.tar.gz
Create_Chunk_DWIM will not allocate anything in the last cylinder of a
CHUNK_BAD144 slice. Also mknod the 'c' partition for freebsd slices, so bad144(8) will have something to work on.
Diffstat (limited to 'release/libdisk')
-rw-r--r--release/libdisk/create_chunk.c21
1 files changed, 18 insertions, 3 deletions
diff --git a/release/libdisk/create_chunk.c b/release/libdisk/create_chunk.c
index f0e0374..3be4560 100644
--- a/release/libdisk/create_chunk.c
+++ b/release/libdisk/create_chunk.c
@@ -6,7 +6,7 @@
* this stuff is worth it, you can buy me a beer in return. Poul-Henning Kamp
* ----------------------------------------------------------------------------
*
- * $Id: create_chunk.c,v 1.14 1995/05/11 05:22:52 phk Exp $
+ * $Id: create_chunk.c,v 1.15 1995/05/12 18:49:57 phk Exp $
*
*/
@@ -166,7 +166,7 @@ Create_Chunk_DWIM(struct disk *d, struct chunk *parent , u_long size, chunk_e ty
{
int i;
struct chunk *c1;
- u_long offset;
+ u_long offset,edge;
if (!parent)
parent = d->chunks;
@@ -179,6 +179,13 @@ Create_Chunk_DWIM(struct disk *d, struct chunk *parent , u_long size, chunk_e ty
warn("Not enough unused space");
return 0;
found:
+ if (c1->flags & CHUNK_BAD144) {
+ edge = c1->end - (d->bios_hd * d->bios_sect);
+ if (offset > edge)
+ return 0;
+ if (offset + size > edge)
+ size = edge - offset + 1;
+ }
i = Add_Chunk(d,offset,size,"X",type,subtype,flags);
if (i) {
warn("Didn't cut it");
@@ -196,8 +203,10 @@ MakeDev(struct chunk *c1, char *path)
{
char *p = c1->name;
u_long cmaj,bmaj,min,unit,part,slice;
- char buf[BUFSIZ];
+ char buf[BUFSIZ],buf2[BUFSIZ];
+ *buf2 = '\0';
+
if(!strcmp(p,"X"))
return 0;
@@ -238,6 +247,8 @@ MakeDev(struct chunk *c1, char *path)
slice = slice+1;
if (!*p) {
part = 2;
+ if(c1->type == freebsd)
+ sprintf(buf2,"%sc",c1->name);
goto done;
}
if (*p < 'a' || *p > 'h')
@@ -251,6 +262,10 @@ MakeDev(struct chunk *c1, char *path)
min = unit * 8 + 65536 * slice + part;
sprintf(buf,"%s/r%s",path,c1->name);
unlink(buf); mknod(buf,S_IFCHR|0640,makedev(cmaj,min));
+ if(*buf2) {
+ sprintf(buf,"%s/r%s",path,buf2);
+ unlink(buf); mknod(buf,S_IFCHR|0640,makedev(cmaj,min));
+ }
sprintf(buf,"%s/%s",path,c1->name);
unlink(buf); mknod(buf,S_IFBLK|0640,makedev(bmaj,min));
return 1;
OpenPOWER on IntegriCloud