summaryrefslogtreecommitdiff
path: root/minfo.c
diff options
context:
space:
mode:
Diffstat (limited to 'minfo.c')
-rw-r--r--minfo.c233
1 files changed, 233 insertions, 0 deletions
diff --git a/minfo.c b/minfo.c
new file mode 100644
index 0000000..51cc65a
--- /dev/null
+++ b/minfo.c
@@ -0,0 +1,233 @@
+/* Copyright 1997-2003,2006,2007,2009 Alain Knaff.
+ * This file is part of mtools.
+ *
+ * Mtools is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Mtools is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with Mtools. If not, see <http://www.gnu.org/licenses/>.
+ *
+ * mlabel.c
+ * Make an MSDOS volume label
+ */
+
+#include "sysincludes.h"
+#include "msdos.h"
+#include "mainloop.h"
+#include "vfat.h"
+#include "mtools.h"
+#include "nameclash.h"
+
+static void usage(int ret) NORETURN;
+static void usage(int ret)
+{
+ fprintf(stderr,
+ "Mtools version %s, dated %s\n", mversion, mdate);
+ fprintf(stderr,
+ "Usage: %s [-v] drive\n", progname);
+ exit(ret);
+}
+
+
+static void displayInfosector(Stream_t *Stream, union bootsector *boot)
+{
+ InfoSector_t *infosec;
+
+ if(WORD(ext.fat32.infoSector) == MAX16)
+ return;
+
+ infosec = (InfoSector_t *) safe_malloc(WORD(secsiz));
+ force_read(Stream, (char *) infosec,
+ (mt_off_t) WORD(secsiz) * WORD(ext.fat32.infoSector),
+ WORD(secsiz));
+ printf("\nInfosector:\n");
+ printf("signature=0x%08x\n", _DWORD(infosec->signature1));
+ if(_DWORD(infosec->count) != MAX32)
+ printf("free clusters=%u\n", _DWORD(infosec->count));
+ if(_DWORD(infosec->pos) != MAX32)
+ printf("last allocated cluster=%u\n", _DWORD(infosec->pos));
+}
+
+
+void minfo(int argc, char **argv, int type)
+{
+ union bootsector boot;
+
+ char name[EXPAND_BUF];
+ int media;
+ unsigned long tot_sectors;
+ int size_code;
+ int sector_size;
+ int i;
+ struct device dev;
+ char drive;
+ int verbose=0;
+ int c;
+ Stream_t *Stream;
+ struct label_blk_t *labelBlock;
+ int have_drive = 0;
+
+ unsigned long sect_per_track;
+ int tracks_match=0;
+ int hidden;
+
+ char *imgFile=NULL;
+
+ if(helpFlag(argc, argv))
+ usage(0);
+ while ((c = getopt(argc, argv, "i:vh")) != EOF) {
+ switch (c) {
+ case 'i':
+ set_cmd_line_image(optarg);
+ imgFile=optarg;
+ break;
+ case 'v':
+ verbose = 1;
+ break;
+ case 'h':
+ usage(0);
+ default:
+ usage(1);
+ }
+ }
+
+ for(;optind <= argc; optind++) {
+ if(optind == argc) {
+ if(have_drive)
+ break;
+ drive = get_default_drive();
+ } else {
+ if(!argv[optind][0] || argv[optind][1] != ':')
+ usage(1);
+ drive = toupper(argv[optind][0]);
+ }
+ have_drive = 1;
+
+ if(! (Stream = find_device(drive, O_RDONLY, &dev, &boot,
+ name, &media, 0, NULL)))
+ exit(1);
+
+ tot_sectors = DWORD_S(bigsect);
+ SET_INT(tot_sectors, WORD_S(psect));
+ sector_size = WORD_S(secsiz);
+ size_code=2;
+ for(i=0; i<7; i++) {
+ if(sector_size == 128 << i) {
+ size_code = i;
+ break;
+ }
+ }
+ printf("device information:\n");
+ printf("===================\n");
+ printf("filename=\"%s\"\n", name);
+ printf("sectors per track: %d\n", dev.sectors);
+ printf("heads: %d\n", dev.heads);
+ printf("cylinders: %d\n\n", dev.tracks);
+
+ sect_per_track = dev.sectors * dev.heads;
+ if(sect_per_track != 0) {
+ printf("mformat command line: mformat ");
+ hidden = DWORD_S(nhs);
+ if(tot_sectors ==
+ dev.tracks * sect_per_track - hidden % sect_per_track) {
+ tracks_match=1;
+ printf("-t %d ", dev.tracks);
+ } else {
+ printf("-T %ld ", tot_sectors);
+ }
+ if(imgFile != NULL)
+ printf("-i %s ", imgFile);
+ printf (" -h %d -s %d ", dev.heads, dev.sectors);
+ if(hidden || !tracks_match)
+ printf("-H %d ", hidden);
+ if(size_code != 2)
+ printf("-S %d ",size_code);
+ printf("%c:\n", tolower(drive));
+ printf("\n");
+ }
+ printf("bootsector information\n");
+ printf("======================\n");
+ printf("banner:\"%.8s\"\n", boot.boot.banner);
+ printf("sector size: %d bytes\n", WORD_S(secsiz));
+ printf("cluster size: %d sectors\n", boot.boot.clsiz);
+ printf("reserved (boot) sectors: %d\n", WORD_S(nrsvsect));
+ printf("fats: %d\n", boot.boot.nfat);
+ printf("max available root directory slots: %d\n",
+ WORD_S(dirents));
+ printf("small size: %d sectors\n", WORD_S(psect));
+ printf("media descriptor byte: 0x%x\n", boot.boot.descr);
+ printf("sectors per fat: %d\n", WORD_S(fatlen));
+ printf("sectors per track: %d\n", WORD_S(nsect));
+ printf("heads: %d\n", WORD_S(nheads));
+ printf("hidden sectors: %d\n", DWORD_S(nhs));
+ printf("big size: %d sectors\n", DWORD_S(bigsect));
+
+ if(WORD_S(fatlen)) {
+ labelBlock = &boot.boot.ext.old.labelBlock;
+ } else {
+ labelBlock = &boot.boot.ext.fat32.labelBlock;
+ }
+
+ printf("physical drive id: 0x%x\n",
+ labelBlock->physdrive);
+ printf("reserved=0x%x\n",
+ labelBlock->reserved);
+ printf("dos4=0x%x\n",
+ labelBlock->dos4);
+ printf("serial number: %08X\n",
+ _DWORD(labelBlock->serial));
+ printf("disk label=\"%11.11s\"\n",
+ labelBlock->label);
+ printf("disk type=\"%8.8s\"\n",
+ labelBlock->fat_type);
+
+ if(!WORD_S(fatlen)){
+ printf("Big fatlen=%u\n",
+ DWORD_S(ext.fat32.bigFat));
+ printf("Extended flags=0x%04x\n",
+ WORD_S(ext.fat32.extFlags));
+ printf("FS version=0x%04x\n",
+ WORD_S(ext.fat32.fsVersion));
+ printf("rootCluster=%u\n",
+ DWORD_S(ext.fat32.rootCluster));
+ if(WORD_S(ext.fat32.infoSector) != MAX16)
+ printf("infoSector location=%d\n",
+ WORD_S(ext.fat32.infoSector));
+ if(WORD_S(ext.fat32.backupBoot) != MAX16)
+ printf("backup boot sector=%d\n",
+ WORD_S(ext.fat32.backupBoot));
+ displayInfosector(Stream,&boot);
+ }
+
+ if(verbose) {
+ int size;
+ unsigned char *buf;
+
+ printf("\n");
+ size = WORD_S(secsiz);
+
+ buf = (unsigned char *) malloc(size);
+ if(!buf) {
+ fprintf(stderr, "Out of memory error\n");
+ exit(1);
+ }
+
+ size = READS(Stream, buf, (mt_off_t) 0, size);
+ if(size < 0) {
+ perror("read boot sector");
+ exit(1);
+ }
+
+ print_sector("Boot sector hexdump", buf, size);
+ }
+ }
+ FREE(&Stream);
+ exit(0);
+}