add directory Linux-0.95
This commit is contained in:
3
Linux-0.95/INSTALL/pfdisk/MAKE_TCC.BAT
Normal file
3
Linux-0.95/INSTALL/pfdisk/MAKE_TCC.BAT
Normal file
@@ -0,0 +1,3 @@
|
||||
@echo This batch file uses Turbo C to build pfdisk.exe
|
||||
@echo Note that only SMALL model has been tested...
|
||||
tcc -v- -epfdisk.exe pfdiskaz.c syscodes.c s_msdos.c
|
||||
264
Linux-0.95/INSTALL/pfdisk/PFDISK.DOC
Normal file
264
Linux-0.95/INSTALL/pfdisk/PFDISK.DOC
Normal file
@@ -0,0 +1,264 @@
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
PFDISK(8) MAINTENANCE COMMANDS PFDISK(8)
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
NAME
|
||||
pfdisk - partition fixed disk
|
||||
|
||||
SYNOPSIS
|
||||
pfdisk device
|
||||
|
||||
DESCRIPTION
|
||||
pfdisk partitions the fixed disk identified as device into (at
|
||||
most) four parts, each of which may be independently loaded with
|
||||
an operating system. The actual name of device depends on the
|
||||
operating system in use. For ESIX (System V/386) the device
|
||||
name is either "/dev/rdsk/0s0" or "/dev/rdsk/1s0". For Minix,
|
||||
it is "/dev/hd0" or "/dev/hd5". For MS-DOS it is a single digit
|
||||
(zero or one).
|
||||
|
||||
pfdisk reads the hard disk partition table from block zero of
|
||||
device into memory and allows the user to examine, modify, or
|
||||
save the partition table. A regular file may be used instead of
|
||||
a real device for testing purposes, though the device geometry
|
||||
must be specified manually, and some systems will requrire a
|
||||
file-name argument with the "R" and "W" commands (DOS, ESIX).
|
||||
|
||||
The partition table on device is NOT modified unless the write
|
||||
command (W) is used with no argument.
|
||||
|
||||
USAGE
|
||||
Commands
|
||||
All pfdisk commands consist of a command word followed by
|
||||
optional blank-separated command arguments. Note that only the
|
||||
first letter of a command word is significant (except for "wq"
|
||||
and "q!"). All command letters are accepted in either upper or
|
||||
lower case. Numeric arguments are specified using C syntax.
|
||||
Extra arguments are silently ignored.
|
||||
|
||||
The commands are:
|
||||
|
||||
? Prints a command summary (help).
|
||||
|
||||
1 sys_id first last sys_name
|
||||
Set the partition table entry for part one, using:
|
||||
sys_id as its system ID code, first as the lowest num-
|
||||
bered cylinder it uses, last as the highest numbered
|
||||
cylinder it uses, and sys_name (optional) as the system
|
||||
name (in the menu name table).
|
||||
|
||||
2|3|4 sys-id first last sys-name
|
||||
Similar to 1 but sets partition two, three, or four,
|
||||
respectively.
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
Release 1.3 Last change: Oct 1990 1
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
PFDISK(8) MAINTENANCE COMMANDS PFDISK(8)
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
A number
|
||||
Mark partition number as active (so it will be used for
|
||||
booting). If number is zero, no partition will be
|
||||
active.
|
||||
|
||||
G cylinders heads sectors
|
||||
Inform pfdisk what the geometry of the device is.
|
||||
|
||||
I Print a summary of the known ID codes.
|
||||
|
||||
L List the partition table. See Output Format below.
|
||||
|
||||
Q Quit without saving. If the memory copy of the parti-
|
||||
tion table was modified, a warning will be issued and
|
||||
the command ignored.
|
||||
|
||||
Q! Quit, even if the memory copy of the partition table was
|
||||
not saved.
|
||||
|
||||
R file-name
|
||||
Read boot sector from file-name (if given) otherwise
|
||||
read from device.
|
||||
|
||||
W file-name
|
||||
Write boot sector to file-name. (if given) otherwise
|
||||
write to device.
|
||||
|
||||
WQ Same as "write" followed by "quit".
|
||||
|
||||
# This line is a comment (to be ignored).
|
||||
|
||||
Output Format
|
||||
Here is a sample of the output from the L command:
|
||||
|
||||
# Partition table on device: /dev/rdsk/0s0
|
||||
geometry 1222 15 34 (cyls heads sectors)
|
||||
# ID First(cyl) Last(cyl) Name # start, length (sectors)
|
||||
1 4 0 127 MS-LOSS # 34, 65246
|
||||
2 129 128 255 Minix # 65280, 65280
|
||||
3 0 0 0 # 0, 0
|
||||
4 99 256 1220 ESIX # 130560, 492150
|
||||
# note: last(4): phys=(1023,14,34) logical=(1220,14,34)
|
||||
active: 4
|
||||
|
||||
This output format is carefully constructed so that it may be
|
||||
saved in a file (by redirecting standard output) and later used
|
||||
as input (by redirecting standard input). On a UNIX system, one
|
||||
can save this output using the command:
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
Release 1.3 Last change: Oct 1990 2
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
PFDISK(8) MAINTENANCE COMMANDS PFDISK(8)
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
(echo L) | pfdisk device-name > save-file
|
||||
|
||||
save-file is a complete record of the partition table. On a
|
||||
UNIX system, one could use save-file to re-initialize the parti-
|
||||
tion table using the command:
|
||||
|
||||
(cat save-file ; echo wq) | pfdisk device-name
|
||||
|
||||
Consistency of each partition table entry is checked while the
|
||||
table is listed. Any inconsistencies discovered are reported in
|
||||
a commentary note as shown above.
|
||||
|
||||
Physical vs. Logical
|
||||
Each partition table entry has both "physical" and a "logical"
|
||||
fields. The physical fields specify the lowest and highest
|
||||
cylinder,head,sector combinations to be used in that partition.
|
||||
The logical start field has the total number of sectors which
|
||||
precede this partition, and the logical length field has the
|
||||
total number of sectors contained in this partition. These
|
||||
fields should be self consistent unless the disk has more than
|
||||
1024 cylinders.
|
||||
|
||||
The physical cylinder fields are only ten-bits wide so the con-
|
||||
tents are limited to 1023. The logical sector fields are 32 bits
|
||||
wide and always show the true logical beginning and length of
|
||||
the partition. Generally, the physical start field is used only
|
||||
to locate the secondary boot sector, and the logical start and
|
||||
length fields are used to actually delimit the partition used by
|
||||
a particular system.
|
||||
|
||||
Partition Names
|
||||
The Name field in the partition table is treated specially if
|
||||
the bootmenu program is installed in the primary boot sector.
|
||||
(See the file bootmenu.doc for more information.) pfdisk can
|
||||
recognize the name table used by bootmenu and will show the
|
||||
actual names present in that name table. If any other boot pro-
|
||||
gram is used then the Name field reflects the result of a
|
||||
table-lookup of the system ID.
|
||||
|
||||
If you provide a name when setting any partition entry, the
|
||||
boot-sector is marked as using a name table, so that on subse-
|
||||
quent uses of pfdisk you will see the partition names you have
|
||||
specified.
|
||||
|
||||
Boot program replacement
|
||||
You can replace the boot program in your boot sector without
|
||||
affecting the partition table by using pfdisk as follows.
|
||||
First, (as always) save a copy of the current boot sector (on a
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
Release 1.3 Last change: Oct 1990 3
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
PFDISK(8) MAINTENANCE COMMANDS PFDISK(8)
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
floppy) using the "W file" command. Then, use the "R file" com-
|
||||
mand to read the new boot program. If the boot program read in
|
||||
is less than 446 bytes long, the partition table will be
|
||||
unchanged.
|
||||
|
||||
Unlike the DOS or UNIX fdisk programs, pfdisk has NO boot pro-
|
||||
gram compiled into its executable image. If you wish to use
|
||||
pfdisk to partition a newly formatted hard disk, you must have a
|
||||
boot program image available to read in using the "r file" com-
|
||||
mand. Two boot programs, "bootmenu.bin" and "bootauto.bin" are
|
||||
distributed with pfdisk and should be found with its source
|
||||
files. See the file bootmenu.doc for further information about
|
||||
these boot programs.
|
||||
|
||||
AUTHOR
|
||||
Gordon W. Ross
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
Release 1.3 Last change: Oct 1990 4
|
||||
|
||||
BIN
Linux-0.95/INSTALL/pfdisk/PFDISK.EXE
Normal file
BIN
Linux-0.95/INSTALL/pfdisk/PFDISK.EXE
Normal file
Binary file not shown.
605
Linux-0.95/INSTALL/pfdisk/PFDISKAZ.C
Normal file
605
Linux-0.95/INSTALL/pfdisk/PFDISKAZ.C
Normal file
@@ -0,0 +1,605 @@
|
||||
/*
|
||||
* pfdisk - Partition a Fixed DISK
|
||||
* by Gordon W. Ross, Jan. 1990
|
||||
*
|
||||
* See the file "pfdisk.doc" for user instructions.
|
||||
*
|
||||
* This program uses a simple, line-oriented interpreter,
|
||||
* designed for both interactive and non-interactive use.
|
||||
* To facilitate non-interactive use, the output from the
|
||||
* 'L' (list partitions) command is carefully arranged so it
|
||||
* can be used directly as command input. Neat trick, eh?
|
||||
*/
|
||||
|
||||
char *versionString =
|
||||
"# pfdisk version 1.2.1 by Gordon W. Ross Aug. 1990\nModified by S. Lubkin Oct. 1991\n";
|
||||
|
||||
/* These don't really matter. The user is asked to set them. */
|
||||
#define DEFAULT_CYLS 306
|
||||
#define DEFAULT_HEADS 4
|
||||
#define DEFAULT_SECTORS 17
|
||||
#define PROMPT_STRING "pfdisk> "
|
||||
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <ctype.h>
|
||||
#include "sysdep.h"
|
||||
#include "syscodes.h"
|
||||
|
||||
typedef unsigned char uchar;
|
||||
typedef unsigned int uint;
|
||||
typedef unsigned long ulong;
|
||||
|
||||
struct part { /* An entry in the partition table */
|
||||
uchar active; /* active flag (0x80 or 0) */
|
||||
uchar b_head; /* begin head */
|
||||
uchar b_sec; /* sector */
|
||||
uchar b_cyl; /* cylinder */
|
||||
uchar sysid; /* system id (see sysid.c) */
|
||||
uchar e_head; /* end head */
|
||||
uchar e_sec; /* end sector */
|
||||
uchar e_cyl; /* end cylinder */
|
||||
/* These two are just longs, but this way is machine independent. */
|
||||
/* uchar lsBeg[4]; /* logical sectors, beginning Saul */
|
||||
ulong lsBeg; /* logical sectors, beginning Saul */
|
||||
/* uchar lsLen[4]; /* logical sectors, length Saul */
|
||||
ulong lsLen; /* logical sectors, length Saul */
|
||||
};
|
||||
|
||||
#define LOC_PT 0x1BE
|
||||
#define LOC_NT 0x1AA /* Saul */
|
||||
/* #define LOC_NT 0x180 Saul */
|
||||
/* #define LOC_GWR 0x1A0 Saul */
|
||||
#define LOC_GWR 0x1A9 /* Saul */
|
||||
#define MAGIC_LOC 0x1FE
|
||||
#define MAGIC_0 0x55
|
||||
#define MAGIC_1 0xAA
|
||||
#define MAX_LINE 80
|
||||
#define NT_ENTRY_SIZE 5 /* Saul */
|
||||
/* Note: Entry in "printf" command, should be manually changed, to
|
||||
"%-NT_ENTRY_SIZE.NT_ENTRY_SIZEs" Saul */
|
||||
/* And header printf line should have blanks adjusted Saul */
|
||||
|
||||
char s[22]; /* For holding error string */
|
||||
char buffer[SECSIZE]; /* The boot block buffer */
|
||||
int bufmod=0; /* buffer modified... */
|
||||
/* (zero means buffer is unmodified) */
|
||||
int useNTable; /* boot sector uses name table */
|
||||
|
||||
/* device parameters (force someone to set them!) */
|
||||
unsigned cyls = DEFAULT_CYLS;
|
||||
unsigned heads = DEFAULT_HEADS;
|
||||
unsigned sectors = DEFAULT_SECTORS;
|
||||
|
||||
char *devname; /* device name */
|
||||
char cmdline[MAX_LINE];
|
||||
char filename[80]; /* used by r/w commands */
|
||||
char *prompt; /* null if no tty input */
|
||||
|
||||
/* Some of these strings are used in more than one place.
|
||||
* For consistency, I put a newline on all of them.
|
||||
*/
|
||||
char h_h[] = "? <enter> : Help summary\n";
|
||||
char h_l[] = "L : List partition table\n";
|
||||
char h_1[] = "1 id first last [name]: set partition 1\n";
|
||||
char h_2[] = "2,3,4 ... (like 1) : set respective partition\n";
|
||||
char h_a[] = "A n [m, ...] : Activate partition(s) n [m, ...]\n";
|
||||
char h_g[] = "G cyls heads sectors : set disk Geometry\n";
|
||||
char h_i[] = "I : list known ID numbers\n";
|
||||
char h_r[] = "R [optional-file] : Read device (or specified file)\n";
|
||||
char h_w[] = "W [optional-file] : Write device (or specified file)\n";
|
||||
char h_q[] = "Q[!] : Quit (! means force)\n";
|
||||
|
||||
char * helpTable[] = {
|
||||
h_h, h_l, h_1, h_2, h_a, h_g, h_i, h_r, h_w, h_q,
|
||||
"# (All command letters have lower-case equivalents.)\n",
|
||||
(char *) 0 }; /* This MUST have a zero as the last element */
|
||||
|
||||
char *BadArg="Error: bad argument: %s\n";
|
||||
char *WarnNotSaved =
|
||||
"Warning, modified partition table not saved.\n";
|
||||
|
||||
help()
|
||||
{
|
||||
char ** p;
|
||||
for (p = helpTable; *p; p++)
|
||||
printf(*p);
|
||||
}
|
||||
|
||||
/* forward declarations */
|
||||
void checkValidity();
|
||||
char * setPartition();
|
||||
char * makeActive();
|
||||
char * setGeometry();
|
||||
ulong chs2long();
|
||||
char * nameID();
|
||||
int printIDs();
|
||||
|
||||
main(argc,argv)
|
||||
int argc;
|
||||
char *argv[];
|
||||
{
|
||||
char *cmdp; /* points to command word */
|
||||
char *argp; /* points to command args */
|
||||
|
||||
/* check command line args (device name) */
|
||||
if (argc != 2) {
|
||||
usage(argv[0]); /* See s-sysname.c */
|
||||
exit(1);
|
||||
}
|
||||
devname = argv[1];
|
||||
|
||||
/* Should we prompt? */
|
||||
prompt = (isatty(fileno(stdin))) ? PROMPT_STRING : (char *) 0;
|
||||
|
||||
/* Print version name. */
|
||||
fputs(versionString, stderr);
|
||||
|
||||
/* get disk parameters */
|
||||
getGeometry(devname,&cyls,&heads,§ors);
|
||||
|
||||
/* Get the boot block. */
|
||||
if (getBBlk(devname, buffer) < 0)
|
||||
fprintf(stderr,"%s: read failed\n", devname);
|
||||
checkValidity();
|
||||
|
||||
if (prompt) fprintf(stderr,"For help, enter: '?'\n");
|
||||
|
||||
|
||||
/* Read and process commands a line at a time. */
|
||||
while (1) {
|
||||
if (prompt) fputs(prompt,stdout);
|
||||
if (! fgets(cmdline, MAX_LINE, stdin)) break;
|
||||
|
||||
/* Find beginning of command word */
|
||||
cmdp = cmdline;
|
||||
while (isspace(*cmdp)) cmdp++;
|
||||
|
||||
/* find beginning of args */
|
||||
argp = cmdp;
|
||||
while (*argp && !isspace(*argp)) argp++;
|
||||
while (isspace(*argp) || *argp=='=') argp++;
|
||||
|
||||
switch (*cmdp) {
|
||||
|
||||
case '\0': /* blank line */
|
||||
case '#': /* line comment */
|
||||
break;
|
||||
|
||||
case '?': case 'h': case 'H':
|
||||
help();
|
||||
break;
|
||||
|
||||
case '1': /* set partition entry */
|
||||
case '2': case '3': case '4':
|
||||
argp = setPartition(cmdp, argp);
|
||||
if (argp) { /* arg list error */
|
||||
fprintf(stderr,BadArg,argp);
|
||||
fprintf(stderr,h_1);
|
||||
fprintf(stderr,h_2);
|
||||
break;
|
||||
}
|
||||
bufmod = 1;
|
||||
break;
|
||||
|
||||
case 'a': case 'A': /* activate partition */
|
||||
argp = makeActive(argp);
|
||||
if (argp) {
|
||||
fprintf(stderr,BadArg,argp);
|
||||
fprintf(stderr,h_a);
|
||||
break;
|
||||
}
|
||||
bufmod = 1;
|
||||
break;
|
||||
|
||||
case 'g': case 'G': /* set disk parameters (Geometry) */
|
||||
argp = setGeometry(argp);
|
||||
if (argp) { /* arg list error */
|
||||
fprintf(stderr,BadArg,argp);
|
||||
fprintf(stderr,h_g);
|
||||
}
|
||||
break;
|
||||
|
||||
case 'i': case 'I': /* List known ID numbers */
|
||||
printIDs();
|
||||
break;
|
||||
|
||||
case 'l': case 'L': /* List the partition table */
|
||||
listPTable();
|
||||
break;
|
||||
|
||||
case 'q': case 'Q': /* Quit */
|
||||
if (bufmod && (cmdp[1] != '!')) {
|
||||
fprintf(stderr,"\007%s%s\n", WarnNotSaved,
|
||||
"Use 'wq' or 'q!' (enter ? for help).");
|
||||
break;
|
||||
}
|
||||
exit(0);
|
||||
/*NOTREACHED*/
|
||||
|
||||
case 'r': case 'R': /* read from device or file */
|
||||
if (sscanf(argp,"%80s",filename) == 1) {
|
||||
/* Arg specified, read from filename */
|
||||
if (getFile(filename, buffer, SECSIZE) < 0)
|
||||
fprintf(stderr,"%s: read failed\n", filename);
|
||||
bufmod = 1;
|
||||
} else {
|
||||
/* No arg, use device. */
|
||||
if (getBBlk(devname, buffer) < 0)
|
||||
fprintf(stderr,"%s: read failed\n", devname);
|
||||
bufmod = 0;
|
||||
}
|
||||
checkValidity();
|
||||
break;
|
||||
|
||||
case 'w': case 'W': /* Write to file or device */
|
||||
if (sscanf(argp,"%80s",filename) == 1) {
|
||||
/* Arg specified, write to filename */
|
||||
if (putFile(filename, buffer, SECSIZE) < 0)
|
||||
fprintf(stderr, "%s: write failed\n", filename);
|
||||
} else { /* No arg, use device. */
|
||||
if (putBBlk(devname, buffer) < 0)
|
||||
fprintf(stderr, "%s: write failed\n", devname);
|
||||
bufmod = 0;
|
||||
}
|
||||
if (cmdp[1] == 'q' || cmdp[1] == 'Q') exit(0);
|
||||
break;
|
||||
|
||||
default:
|
||||
fprintf(stderr,"'%c': unrecognized. Enter '?' for help.\n", *cmdp);
|
||||
break;
|
||||
|
||||
} /* switch */
|
||||
} /* while */
|
||||
if (bufmod) fprintf(stderr, WarnNotSaved);
|
||||
exit(0);
|
||||
} /* main */
|
||||
|
||||
|
||||
/* Check for valid boot block (magic number in last two bytes).
|
||||
* Also, check for presence of partition name table.
|
||||
*/
|
||||
void checkValidity()
|
||||
{
|
||||
/* Check the magic number. */
|
||||
if ((buffer[MAGIC_LOC] & 0xFF) != MAGIC_0 ||
|
||||
(buffer[MAGIC_LOC+1] & 0xFF) != MAGIC_1 ) {
|
||||
/* The boot sector is not valid -- Fix it. */
|
||||
buffer[MAGIC_LOC] = MAGIC_0;
|
||||
buffer[MAGIC_LOC+1] = MAGIC_1;
|
||||
bufmod = 1;
|
||||
fprintf(stderr,
|
||||
"\n\tWarning: The boot sector has an invalid magic number.\n\
|
||||
\tThe magic number has been fixed, but the other contents\n\
|
||||
\tare probably garbage. Initialize using the command:\n\
|
||||
\t\tR boot-program-file (i.e. bootmenu.bin)\n\
|
||||
\tthen set each partition entry if necessary.\n");
|
||||
}
|
||||
|
||||
/* Does it use a name table (for a boot menu)?
|
||||
* My boot program does, and can be identified by
|
||||
* finding my name in a particular (unused) area.
|
||||
*/
|
||||
useNTable = ( buffer[LOC_GWR] == (char)0x3A ); /* Saul */
|
||||
/* useNTable = !strcmp(&buffer[LOC_GWR], "Gordon W. Ross"); Saul */
|
||||
|
||||
}
|
||||
|
||||
char * setPartition(cmdp,argp) /* return string on error */
|
||||
char *cmdp,*argp;
|
||||
{
|
||||
struct part *pp; /* partition entry */
|
||||
char * np; /* name table pointer */
|
||||
char tmpname[20];
|
||||
char * newname = tmpname; /* name field */
|
||||
int index; /* partition index (0..3) */
|
||||
uint id; /* ID code (see syscodes.c) */
|
||||
uint first,last; /* user supplied cylinders */
|
||||
uint c,h,s; /* working cyl,head,sect, */
|
||||
int i; /* returned by sscanf */
|
||||
ulong lsbeg, lslen; /* logical begin, length */
|
||||
|
||||
/* Value check the index */
|
||||
index = *cmdp - '1';
|
||||
if (index < 0 || index > 3)
|
||||
return("index");
|
||||
pp = (struct part *) &buffer[LOC_PT + index * 16];
|
||||
np = &buffer[LOC_NT + index * NT_ENTRY_SIZE]; /* Saul */
|
||||
/* np = &buffer[LOC_NT + index * 8]; Saul */
|
||||
|
||||
/* Read System ID */
|
||||
if ((i=sscanf(argp,"%d%d%d%s", &id, &first, &last, newname)) < 1)
|
||||
return("id");
|
||||
|
||||
/* If ID==0, just clear out the entry and return. */
|
||||
if (id == 0) {
|
||||
strncpy( (char *) pp, "", 16);
|
||||
if (useNTable) strncpy( np, "", NT_ENTRY_SIZE); /* Saul */
|
||||
/* if (useNTable) strncpy( np, "", 8); Saul */
|
||||
return((char *)0);
|
||||
}
|
||||
|
||||
/* Read first and last cylinder */
|
||||
if (i < 3)
|
||||
return("first last (missing)");
|
||||
|
||||
/* Reasonable start,end cylinder numbers? */
|
||||
if (first > last) return("first > last");
|
||||
if (first > 1023) return("first > 1023");
|
||||
if (last >= cyls) return("last >= cyls");
|
||||
|
||||
/* Get (optional) system name. */
|
||||
if (i == 3) { /* no name given, use default */
|
||||
newname = nameID(id);
|
||||
}
|
||||
else useNTable = 1;
|
||||
|
||||
/* Set the ID and name. */
|
||||
pp->sysid = id;
|
||||
if (useNTable) {
|
||||
strncpy(np, newname, NT_ENTRY_SIZE); /* Saul */
|
||||
/* strncpy(np, newname, 8); Saul */
|
||||
/* strcpy(&buffer[LOC_GWR], "Gordon W. Ross"); Saul */
|
||||
buffer[LOC_GWR] = (char)0x3A; /* Saul */
|
||||
}
|
||||
|
||||
/* set beginning c,h,s */
|
||||
c = first;
|
||||
/* if c == 0, head == 1 (reserve track 0) */
|
||||
h = (first) ? 0 : 1;
|
||||
s = 1;
|
||||
pp->b_cyl = c & 0xFF;
|
||||
pp->b_head = h;
|
||||
pp->b_sec = s | ((c >> 2) & 0xC0);
|
||||
/* Set the logical sector begin field */
|
||||
lsbeg = lslen = chs2long(c,h,s); /* using lslen as temp. */
|
||||
/* pp->lsBeg[0] = lslen & 0xff; lslen >>= 8;
|
||||
pp->lsBeg[1] = lslen & 0xff; lslen >>= 8;
|
||||
pp->lsBeg[2] = lslen & 0xff; lslen >>= 8;
|
||||
pp->lsBeg[3] = lslen & 0xff; lslen >>= 8; Saul */
|
||||
pp->lsBeg = lslen; /* Saul */
|
||||
|
||||
/* set ending c,h,s (last may be larger than 1023) */
|
||||
c = (last>1023) ? 1023 : last; /* limit c to 1023 */
|
||||
h = heads - 1; s = sectors;
|
||||
pp->e_cyl = c & 0xFF;
|
||||
pp->e_head = h;
|
||||
pp->e_sec = s | ((c >> 2) & 0xC0);
|
||||
/* Set the logical sector length field (using REAL end cylinder) */
|
||||
lslen = chs2long(last,h,s) + 1 - lsbeg;
|
||||
/* pp->lsLen[0] = lslen & 0xff; lslen >>= 8;
|
||||
pp->lsLen[1] = lslen & 0xff; lslen >>= 8;
|
||||
pp->lsLen[2] = lslen & 0xff; lslen >>= 8;
|
||||
pp->lsLen[3] = lslen & 0xff; lslen >>= 8; Saul */
|
||||
pp->lsLen = lslen; /* Saul */
|
||||
|
||||
return((char *)0); /* success */
|
||||
} /* setPartition() */
|
||||
|
||||
char * makeActive(argp) /* return error string or zero */
|
||||
char *argp;
|
||||
{
|
||||
struct part *pp; /* partition entry */
|
||||
int i,act1,act2,act3,act4,act5; /* which one becomes active */
|
||||
|
||||
act1=0;
|
||||
act2=0;
|
||||
act3=0;
|
||||
act4=0;
|
||||
if ((i=sscanf(argp,"%d%d%d%d%d", &act1, &act2, &act3, &act4, &act5)) < 1)
|
||||
return("missing partition number");
|
||||
if ( i > 4)
|
||||
return("at most four partition numbers");
|
||||
act1--; /* make it zero-origin */
|
||||
act2--; /* make it zero-origin */
|
||||
act3--; /* make it zero-origin */
|
||||
act4--; /* make it zero-origin */
|
||||
|
||||
i=0; pp = (struct part *) &buffer[LOC_PT];
|
||||
while (i<4) {
|
||||
if (pp->sysid == 0 && (i == act1|| i == act2 || i == act3 || i == act4)) {
|
||||
sprintf(s, "partition %d empty", i+1);
|
||||
return(s);
|
||||
}
|
||||
i++; pp++;
|
||||
}
|
||||
i=0; pp -= 4;
|
||||
while (i<4) {
|
||||
if (i == act1|| i == act2 || i == act3 || i == act4)
|
||||
pp->active = 0x80;
|
||||
else
|
||||
pp->active = 0;
|
||||
i++; pp++;
|
||||
}
|
||||
return((char *)0);
|
||||
}
|
||||
|
||||
char * setGeometry(argp) /* return string on error */
|
||||
char *argp;
|
||||
{
|
||||
int c,h,s;
|
||||
|
||||
if (sscanf(argp,"%d%d%d", &c, &h, &s) < 3)
|
||||
return("(missing)");
|
||||
if (c<1) return("cyls");
|
||||
if (h<1) return("heads");
|
||||
if (s<1) return("sectors");
|
||||
cyls=c; heads=h; sectors=s;
|
||||
return((char *)0);
|
||||
}
|
||||
|
||||
listPTable() /* print out partition table */
|
||||
{
|
||||
struct part * pp; /* partition table entry */
|
||||
char *name;
|
||||
int i; /* partition number */
|
||||
/* int numActive=0; /* active partition [1-4], 0==none */
|
||||
char Active[20]; /* active partitions [1-4], 0==none */
|
||||
uint pbc,pbh,pbs; /* physical beginning c,h,s */
|
||||
uint pec,peh,pes; /* physical ending c,h,s */
|
||||
uint lbc,lbh,lbs; /* logical beginning c,h,s */
|
||||
uint lec,leh,les; /* logical ending c,h,s */
|
||||
ulong lsbeg,lslen; /* logical sectors: begin, length */
|
||||
|
||||
strcpy(Active, "active:");
|
||||
printf("# Partition table on device: %s\n", devname);
|
||||
printf("geometry %d %d %d (cyls heads sectors)\n",
|
||||
cyls, heads, sectors);
|
||||
/* printf("# ID First(cyl) Last(cyl) Name "); Saul */
|
||||
printf("# ID First(cyl) Last(cyl) Name "); /* Saul */
|
||||
printf("# start, length (sectors)\n");
|
||||
|
||||
for (i=0; i<4; i++) {
|
||||
pp = (struct part *) &buffer[LOC_PT + i * 16];
|
||||
|
||||
if (pp->active) {
|
||||
char s[3];
|
||||
sprintf(s, " %d", i+1);
|
||||
strcat(Active,s);
|
||||
if (pp->active != 0x80)
|
||||
fprintf(stderr, "Warning: Partition %d is active, with the illegal activity byte %d.\nCorrect with the \"A\" command.\n", i+1, pp->active);
|
||||
/* if(numActive)
|
||||
fprintf(stderr,"Error: multiple active partitions.\n");
|
||||
else numActive = i+1; */
|
||||
}
|
||||
|
||||
/* physical beginning c,h,s */
|
||||
pbc = pp->b_cyl & 0xff | (pp->b_sec << 2) & 0x300;
|
||||
pbh = pp->b_head;
|
||||
pbs = pp->b_sec & 0x3F;
|
||||
|
||||
/* physical ending c,h,s */
|
||||
pec = pp->e_cyl & 0xff | (pp->e_sec << 2) & 0x300;
|
||||
peh = pp->e_head;
|
||||
pes = pp->e_sec & 0x3F;
|
||||
|
||||
/* compute logical beginning (c,h,s) */
|
||||
/* lsbeg = ((((((pp->lsBeg[3] ) << 8 )
|
||||
| pp->lsBeg[2] ) << 8 )
|
||||
| pp->lsBeg[1] ) << 8 )
|
||||
| pp->lsBeg[0] ; Saul */
|
||||
lsbeg = pp->lsBeg; /* Saul */
|
||||
long2chs(lsbeg, &lbc, &lbh, &lbs);
|
||||
/* compute logical ending (c,h,s) */
|
||||
/* lslen = ((((((pp->lsLen[3]) << 8 )
|
||||
| pp->lsLen[2]) << 8 )
|
||||
| pp->lsLen[1]) << 8 )
|
||||
| pp->lsLen[0] ; Saul */
|
||||
lslen = pp->lsLen; /* Saul*/
|
||||
/* keep beginning <= end ... */
|
||||
if (lslen > 0) long2chs(lsbeg+lslen-1, &lec, &leh, &les);
|
||||
else long2chs(lsbeg, &lec, &leh, &les);
|
||||
|
||||
if (useNTable)
|
||||
name = &buffer[LOC_NT + i * NT_ENTRY_SIZE ]; /* Saul */
|
||||
/* name = &buffer[LOC_NT + i * 8]; Saul */
|
||||
else
|
||||
name = nameID((uint) pp->sysid);
|
||||
|
||||
/* show physical begin, logical end (works for cyl>1023) */
|
||||
/* # ID First(cyl) Last(cyl) Name... # ... */
|
||||
/* printf("%d %3d %4d %4d %-8.8s # %ld, %ld\n", Saul */
|
||||
printf("%d %3d %4d %4d %-5.5s # %ld, %ld\n", /* Saul */
|
||||
i+1, pp->sysid, pbc, lec, name, lsbeg, lslen );
|
||||
|
||||
/* That's all, for an empty partition. */
|
||||
if (pp->sysid == 0) continue;
|
||||
|
||||
/*
|
||||
* Now do some consistency checks...
|
||||
*/
|
||||
|
||||
/* Same physical / logical beginning? */
|
||||
if (pbc != lbc || pbh != lbh || pbs != lbs ) {
|
||||
printf("# note: first(%d): ", i+1);
|
||||
printf("phys=(%d,%d,%d) ", pbc, pbh, pbs);
|
||||
printf("logical=(%d,%d,%d)\n",lbc, lbh, lbs);
|
||||
}
|
||||
/* Same physical / logical ending? */
|
||||
if (pec != lec || peh != leh || pes != les ) {
|
||||
printf("# note: last(%d): ", i+1);
|
||||
printf("phys=(%d,%d,%d) ", pec, peh, pes);
|
||||
printf("logical=(%d,%d,%d)\n",lec, leh, les);
|
||||
}
|
||||
|
||||
/* Beginning on cylinder boundary? */
|
||||
if (pbc == 0) { /* exception: start on head 1 */
|
||||
if (pbh != 1 || pbs != 1) {
|
||||
printf("# note: first(%i): ", i+1);
|
||||
printf("phys=(%d,%d,%d) ", pbc, pbh, pbs);
|
||||
printf("should be (%d,1,1)\n", pbc);
|
||||
}
|
||||
} else { /* not on cyl 0 */
|
||||
if (pbh != 0 || pbs != 1) {
|
||||
printf("# note: first(%i): ", i+1);
|
||||
printf("phys=(%d,%d,%d) ", pbc, pbh, pbs);
|
||||
printf("should be (%d,0,1)\n", pbc);
|
||||
}
|
||||
}
|
||||
|
||||
/* Ending on cylinder boundary? */
|
||||
if (peh != (heads-1) || pes != sectors) {
|
||||
printf("# note: last(%i): ", i+1);
|
||||
printf("phys=(%d,%d,%d) ", pec, peh, pes);
|
||||
printf("should be (%d,%d,%d)\n",
|
||||
pec, heads-1, sectors);
|
||||
}
|
||||
|
||||
} /* for */
|
||||
if ( !Active[7] ) /* No active partitions */
|
||||
strcat(Active, " 0 (none)");
|
||||
strcat(Active, "\n");
|
||||
printf(Active);
|
||||
/* printf("active: %d %s\n", numActive,
|
||||
(numActive) ? "" : "(none)"); */
|
||||
} /* listPTable() */
|
||||
|
||||
ulong chs2long(c,h,s)
|
||||
uint c,h,s;
|
||||
{
|
||||
ulong l;
|
||||
if (s<1) s=1;
|
||||
l = c; l *= heads;
|
||||
l += h; l *= sectors;
|
||||
l += (s - 1);
|
||||
return(l);
|
||||
}
|
||||
|
||||
long2chs(ls, c, h, s) /* convert logical sec-num to c,h,s */
|
||||
ulong ls; /* Logical Sector number */
|
||||
uint *c,*h,*s; /* cyl, head, sector */
|
||||
{
|
||||
int spc = heads * sectors;
|
||||
*c = ls / spc;
|
||||
ls = ls % spc;
|
||||
*h = ls / sectors;
|
||||
*s = ls % sectors + 1; /* sectors count from 1 */
|
||||
}
|
||||
|
||||
char * nameID(n)
|
||||
unsigned int n;
|
||||
{
|
||||
struct intString *is;
|
||||
|
||||
is = sysCodes;
|
||||
while (is->i) {
|
||||
if (is->i == n) return(is->s);
|
||||
is++;
|
||||
}
|
||||
if (!n) return(is->s);
|
||||
return("unknown");
|
||||
}
|
||||
|
||||
int printIDs() /* print the known system IDs */
|
||||
{
|
||||
struct intString * is = sysCodes;
|
||||
|
||||
/* This might need to do more processing eventually, i.e.
|
||||
* if (prompt) { ... do more processing ... }
|
||||
*/
|
||||
printf("_ID_\t__Name__ ____Description____\n");
|
||||
while (is->i) {
|
||||
printf("%3d\t%s\n", is->i, is->s);
|
||||
is++;
|
||||
}
|
||||
}
|
||||
43
Linux-0.95/INSTALL/pfdisk/SYSCODES.C
Normal file
43
Linux-0.95/INSTALL/pfdisk/SYSCODES.C
Normal file
@@ -0,0 +1,43 @@
|
||||
/* This file holds all knowledge of partition ID codes.
|
||||
* Thanks to leendert@cs.vu.nl (Leendert van Doorn) for
|
||||
* collecting most of this information.
|
||||
*/
|
||||
|
||||
#define extern
|
||||
#include "syscodes.h"
|
||||
#undef extern
|
||||
|
||||
/* Note that my boot program menu can only use the first 8 characters
|
||||
* of these names. The colon in the nineth position shows where the
|
||||
* first truncated char is. (There's not much room in the bootblock!)
|
||||
* changed sysCodes[] below, adding SIZE tms */
|
||||
struct intString sysCodes[SIZE] = {
|
||||
{ 0x01, "DOS12 :12-bit FAT" },
|
||||
{ 0x02, "XENIX :root" },
|
||||
{ 0x03, "XENIX :usr" },
|
||||
{ 0x04, "DOS16 :16-bit FAT" },
|
||||
{ 0x05, "DOSex :DOS 3.3 extended volume" },
|
||||
{ 0x06, "DOSbi :DOS 4.0 large volume" },
|
||||
{ 0x07, "OS/2 :OS/2 (or QNX or Adv. UNIX...)" },
|
||||
{ 0x08, "AIX :file system" },
|
||||
{ 0x09, "AIXbt:boot partition" },
|
||||
|
||||
{ 0x10, "OPUS :?" },
|
||||
{ 0x40, "VENIX :Venix 80286" },
|
||||
{ 0x51, "NOVEL :?" },
|
||||
{ 0x52, "CPM :?" },
|
||||
{ 0x63, "UNIX :System V/386" },
|
||||
{ 0x64, "NOVEL :?" },
|
||||
{ 0x75, "PC/IX :?" },
|
||||
{ 0x80, "Minix :Minix (ver. 1.4a and earlier)" },
|
||||
{ 0x81, "Minix :Minix (ver. 1.4b and later)" },
|
||||
{ 0x93, "Ameba :Amoeba file system" },
|
||||
{ 0x94, "Ameba :Amoeba bad block table?" },
|
||||
{ 0xDB, "C.DOS :Concurrent DOS" },
|
||||
|
||||
/* { 0xF2, "DOS-2nd :DOS 3.3+ second partition" }, */
|
||||
/* { 0xFF, "BAD-TRK :Bad track table?" }, */
|
||||
|
||||
/* Make sure this is last! */
|
||||
{ 0, "empty" }
|
||||
};
|
||||
4
Linux-0.95/INSTALL/pfdisk/SYSCODES.H
Normal file
4
Linux-0.95/INSTALL/pfdisk/SYSCODES.H
Normal file
@@ -0,0 +1,4 @@
|
||||
#define SIZE 40 /* added tms */
|
||||
struct intString { unsigned int i; char * s; };
|
||||
extern struct intString sysCodes[SIZE]; /* was sysCodes[] modified tms */
|
||||
|
||||
22
Linux-0.95/INSTALL/pfdisk/SYSDEP.H
Normal file
22
Linux-0.95/INSTALL/pfdisk/SYSDEP.H
Normal file
@@ -0,0 +1,22 @@
|
||||
/* communicate declarations from the files: s_*.c */
|
||||
|
||||
#define SECSIZE 0x200
|
||||
|
||||
extern int usage(); /* print a usage message */
|
||||
/* (char *progname) */
|
||||
|
||||
extern void getGeometry(); /* determine disk parameters */
|
||||
/* (char *dev, uint *cyls, uint *heads, uint *sectors) */
|
||||
|
||||
extern int getFile(); /* open, read, close, return(num-read) */
|
||||
/* (char *name, char *buf, int len) */
|
||||
|
||||
extern int putFile(); /* open, write, close, return(num-writen) */
|
||||
/* (char *name, char *buf, int len) */
|
||||
|
||||
extern int getBBlk(); /* open, read, close, return(num-read) */
|
||||
/* (char *dev, char *buf) */
|
||||
|
||||
extern int putBBlk(); /* open, write, close, return(num-writen) */
|
||||
/* (char *dev, char *buf) */
|
||||
|
||||
163
Linux-0.95/INSTALL/pfdisk/S_MSDOS.C
Normal file
163
Linux-0.95/INSTALL/pfdisk/S_MSDOS.C
Normal file
@@ -0,0 +1,163 @@
|
||||
/* This file contains system-specific functions for MS-DOS.
|
||||
* The program pfdisk.c calls these routines.
|
||||
*/
|
||||
#include <stdio.h>
|
||||
#include <fcntl.h>
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
#include <dos.h>
|
||||
|
||||
#define extern
|
||||
#include "sysdep.h"
|
||||
#undef extern
|
||||
|
||||
int usage(prog) /* print a usage message */
|
||||
char *prog; /* program name */
|
||||
{
|
||||
fprintf(stderr,"Usage: %s <disk>\n", prog);
|
||||
fprintf(stderr,"\twhere <disk> is a digit [0-9]\n");
|
||||
}
|
||||
|
||||
void getGeometry(name, c, h, s)
|
||||
char *name; /* device name */
|
||||
unsigned *c,*h,*s; /* cyls, heads, sectors */
|
||||
{
|
||||
int dev; /* hard disk number */
|
||||
union REGS regs;
|
||||
struct SREGS sregs;
|
||||
|
||||
if (name[0] < '0' ||
|
||||
name[0] > '9' ||
|
||||
name[1] != 0 )
|
||||
{
|
||||
fprintf(stderr,"%s: device name must be a digit\n", name);
|
||||
return;
|
||||
}
|
||||
dev = (name[0] - '0');
|
||||
|
||||
regs.h.ah = 8; /* get param. */
|
||||
regs.h.dl = dev | 0x80;
|
||||
|
||||
int86x(0x13,®s,®s,&sregs);
|
||||
|
||||
/* Are that many drives responding? */
|
||||
if (regs.h.dl <= dev ) {
|
||||
fprintf(stderr,"%s: drive not found\n", name);
|
||||
return;
|
||||
}
|
||||
if (regs.x.cflag) {
|
||||
fprintf(stderr,"%s: can't get disk parameters\n", name);
|
||||
return;
|
||||
}
|
||||
*c = ((((int) regs.h.cl << 2) & 0x300) | regs.h.ch) + 1;
|
||||
*h = regs.h.dh + 1;
|
||||
*s = regs.h.cl & 0x3F;
|
||||
}
|
||||
|
||||
int getFile(name, buf, len) /* read file into buffer */
|
||||
char *name, *buf;
|
||||
int len;
|
||||
{ /* (open, read, close) */
|
||||
int devfd, retval;
|
||||
|
||||
devfd = open(name, O_RDONLY|O_BINARY, 0);
|
||||
if (devfd < 0) {
|
||||
fprintf(stderr,"%s: can't open for reading\n", name);
|
||||
return(devfd);
|
||||
}
|
||||
retval = read(devfd, buf, len);
|
||||
if (retval < 0)
|
||||
fprintf(stderr,"%s: read failed\n", name);
|
||||
close(devfd);
|
||||
return(retval);
|
||||
}
|
||||
|
||||
int putFile(name, buf, len) /* write buffer to file */
|
||||
char *name, *buf;
|
||||
int len;
|
||||
{ /* (open, write, close) */
|
||||
int devfd, retval;
|
||||
|
||||
devfd = open(name,
|
||||
O_WRONLY|O_CREAT|O_BINARY,
|
||||
S_IREAD|S_IWRITE ); /* stupid DOS... */
|
||||
if (devfd < 0) {
|
||||
fprintf(stderr,"%s: can't open for writing\n", name);
|
||||
return(devfd);
|
||||
}
|
||||
retval = write(devfd, buf, len);
|
||||
if (retval < 0)
|
||||
fprintf(stderr,"%s: write failed\n", name);
|
||||
close(devfd);
|
||||
return(retval);
|
||||
}
|
||||
|
||||
int getBBlk(name, buf) /* read boot block into buffer */
|
||||
char *name, *buf;
|
||||
{ /* BIOS absolute disk read */
|
||||
int dev;
|
||||
union REGS regs;
|
||||
struct SREGS sregs;
|
||||
|
||||
if (name[0] < '0' ||
|
||||
name[0] > '9' ||
|
||||
name[1] != 0 )
|
||||
{
|
||||
fprintf(stderr,"%s: device name must be a digit\n",name);
|
||||
return(-1);
|
||||
}
|
||||
dev = (name[0] - '0');
|
||||
|
||||
segread(&sregs); /* get ds */
|
||||
sregs.es = sregs.ds; /* buffer address */
|
||||
regs.x.bx = (int) buf;
|
||||
|
||||
regs.h.ah = 2; /* read */
|
||||
regs.h.al = 1; /* sector count */
|
||||
regs.h.ch = 0; /* track */
|
||||
regs.h.cl = 1; /* start sector */
|
||||
regs.h.dh = 0; /* head */
|
||||
regs.h.dl = dev|0x80; /* drive */
|
||||
|
||||
int86x(0x13,®s,®s,&sregs);
|
||||
if (regs.x.cflag) {
|
||||
fprintf(stderr,"%s: read failed\n", name);
|
||||
return(-1);
|
||||
}
|
||||
return(SECSIZE);
|
||||
}
|
||||
|
||||
int putBBlk(name, buf) /* write buffer to boot block */
|
||||
char *name, *buf;
|
||||
{ /* BIOS absolute disk write */
|
||||
int dev;
|
||||
union REGS regs;
|
||||
struct SREGS sregs;
|
||||
|
||||
if (name[0] < '0' ||
|
||||
name[0] > '9' ||
|
||||
name[1] != 0 )
|
||||
{
|
||||
fprintf(stderr,"%s: device name must be a digit\n", name);
|
||||
return(-1);
|
||||
}
|
||||
dev = (name[0] - '0');
|
||||
|
||||
segread(&sregs); /* get ds */
|
||||
sregs.es = sregs.ds; /* buffer address */
|
||||
regs.x.bx = (int) buf;
|
||||
|
||||
regs.h.ah = 3; /* write */
|
||||
regs.h.al = 1; /* sector count */
|
||||
regs.h.ch = 0; /* track */
|
||||
regs.h.cl = 1; /* start sector */
|
||||
regs.h.dh = 0; /* head */
|
||||
regs.h.dl = dev|0x80; /* drive */
|
||||
|
||||
int86x(0x13,®s,®s,&sregs);
|
||||
if (regs.x.cflag) {
|
||||
fprintf(stderr,"%s: write failed\n",name);
|
||||
return(-1);
|
||||
}
|
||||
return(SECSIZE);
|
||||
}
|
||||
Reference in New Issue
Block a user