📄 isovfy.c
字号:
/* @(#)isovfy.c 1.14 00/05/07 joerg */#ifndef lintstatic char sccsid[] = "@(#)isovfy.c 1.14 00/05/07 joerg";#endif/* * File isovfy.c - verify consistency of iso9660 filesystem. * Written by Eric Youngdale (1993). Copyright 1993 Yggdrasil Computing, Incorporated This program 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 2, or (at your option) any later version. This program 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 this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */#include "../config.h"#include <stdxlib.h>#include <unixstd.h>#include <strdefs.h>#include <stdio.h>#include <standard.h>#include <signal.h>#include <schily.h>FILE * infile;int blocksize;#define PAGE sizeof(buffer)#define ISODCL(from, to) (to - from + 1)struct iso_primary_descriptor { unsigned char type [ISODCL ( 1, 1)]; /* 711 */ unsigned char id [ISODCL ( 2, 6)]; unsigned char version [ISODCL ( 7, 7)]; /* 711 */ unsigned char unused1 [ISODCL ( 8, 8)]; unsigned char system_id [ISODCL ( 9, 40)]; /* aunsigned chars */ unsigned char volume_id [ISODCL ( 41, 72)]; /* dunsigned chars */ unsigned char unused2 [ISODCL ( 73, 80)]; unsigned char volume_space_size [ISODCL ( 81, 88)]; /* 733 */ unsigned char unused3 [ISODCL ( 89, 120)]; unsigned char volume_set_size [ISODCL (121, 124)]; /* 723 */ unsigned char volume_sequence_number [ISODCL (125, 128)]; /* 723 */ unsigned char logical_block_size [ISODCL (129, 132)]; /* 723 */ unsigned char path_table_size [ISODCL (133, 140)]; /* 733 */ unsigned char type_l_path_table [ISODCL (141, 144)]; /* 731 */ unsigned char opt_type_l_path_table [ISODCL (145, 148)]; /* 731 */ unsigned char type_m_path_table [ISODCL (149, 152)]; /* 732 */ unsigned char opt_type_m_path_table [ISODCL (153, 156)]; /* 732 */ unsigned char root_directory_record [ISODCL (157, 190)]; /* 9.1 */ unsigned char volume_set_id [ISODCL (191, 318)]; /* dunsigned chars */ unsigned char publisher_id [ISODCL (319, 446)]; /* achars */ unsigned char preparer_id [ISODCL (447, 574)]; /* achars */ unsigned char application_id [ISODCL (575, 702)]; /* achars */ unsigned char copyright_file_id [ISODCL (703, 739)]; /* 7.5 dchars */ unsigned char abstract_file_id [ISODCL (740, 776)]; /* 7.5 dchars */ unsigned char bibliographic_file_id [ISODCL (777, 813)]; /* 7.5 dchars */ unsigned char creation_date [ISODCL (814, 830)]; /* 8.4.26.1 */ unsigned char modification_date [ISODCL (831, 847)]; /* 8.4.26.1 */ unsigned char expiration_date [ISODCL (848, 864)]; /* 8.4.26.1 */ unsigned char effective_date [ISODCL (865, 881)]; /* 8.4.26.1 */ unsigned char file_structure_version [ISODCL (882, 882)]; /* 711 */ unsigned char unused4 [ISODCL (883, 883)]; unsigned char application_data [ISODCL (884, 1395)]; unsigned char unused5 [ISODCL (1396, 2048)];};struct iso_directory_record { unsigned char length [ISODCL (1, 1)]; /* 711 */ unsigned char ext_attr_length [ISODCL (2, 2)]; /* 711 */ unsigned char extent [ISODCL (3, 10)]; /* 733 */ unsigned char size [ISODCL (11, 18)]; /* 733 */ unsigned char date [ISODCL (19, 25)]; /* 7 by 711 */ unsigned char flags [ISODCL (26, 26)]; unsigned char file_unit_size [ISODCL (27, 27)]; /* 711 */ unsigned char interleave [ISODCL (28, 28)]; /* 711 */ unsigned char volume_sequence_number [ISODCL (29, 32)]; /* 723 */ unsigned char name_len [ISODCL (33, 33)]; /* 711 */ unsigned char name [38];};int isonum_721 __PR((char * p));int isonum_723 __PR((char * p));int isonum_711 __PR((char * p));int isonum_731 __PR((char * p));int isonum_722 __PR((char * p));int isonum_732 __PR((char * p));int isonum_733 __PR((unsigned char * p));int parse_rr __PR((unsigned char * pnt, int len, int cont_flag));int dump_rr __PR((struct iso_directory_record * idr));void check_tree __PR((int file_addr, int file_size, int parent_addr));void check_path_tables __PR((int typel_extent, int typem_extent, int path_table_size));void usage __PR((int excode));int main __PR((int argc, char *argv[]));intisonum_721 (p) char *p;{ return ((p[0] & 0xff) | ((p[1] & 0xff) << 8));}intisonum_723 (p) char *p;{#if 0 if (p[0] != p[3] || p[1] != p[2]) {#ifdef USE_LIBSCHILY comerrno(EX_BAD, "invalid format 7.2.3 number\n");#else fprintf (stderr, "invalid format 7.2.3 number\n"); exit (1);#endif }#endif return (isonum_721 (p));}intisonum_711 (p) char *p;{ return (*p & 0xff);}intisonum_731 (p) char *p;{ return ((p[0] & 0xff) | ((p[1] & 0xff) << 8) | ((p[2] & 0xff) << 16) | ((p[3] & 0xff) << 24));}intisonum_722(p) char *p;{ return ((p[1] & 0xff) | ((p[0] & 0xff) << 8));}intisonum_732 (p) char *p;{ return ((p[3] & 0xff) | ((p[2] & 0xff) << 8) | ((p[1] & 0xff) << 16) | ((p[0] & 0xff) << 24));}intisonum_733 (p) unsigned char *p;{ return (isonum_731 ((char *)p));}char lbuffer[1024];int iline;int rr_goof;int parse_rr(pnt, len, cont_flag) unsigned char *pnt; int len; int cont_flag;{ int slen; int ncount; int flag1, flag2; int extent; unsigned char *pnts; int cont_extent, cont_offset, cont_size; char symlinkname[1024]; sprintf(lbuffer+iline," RRlen=%d ", len); iline += strlen(lbuffer+iline); cont_extent = cont_offset = cont_size = 0; symlinkname[0] = 0; ncount = 0; flag1 = flag2 = 0; while(len >= 4){ if(ncount) sprintf(lbuffer+iline,","); else sprintf(lbuffer+iline,"["); iline += strlen(lbuffer + iline); sprintf(lbuffer+iline,"%c%c", pnt[0], pnt[1]); iline += strlen(lbuffer + iline); if(pnt[0] < 'A' || pnt[0] > 'Z' || pnt[1] < 'A' || pnt[1] > 'Z') { sprintf(lbuffer+iline,"**BAD SUSP %d %d]", pnt[0], pnt[1]); rr_goof++; iline += strlen(lbuffer + iline); return flag2; }; if(pnt[3] != 1 && pnt[3] != 2) { sprintf(lbuffer+iline, "**BAD RRVERSION (%d)\n", pnt[3]); rr_goof++; iline += strlen(lbuffer + iline); return flag2; }; ncount++; if(pnt[0] == 'R' && pnt[1] == 'R') flag1 = pnt[4] & 0xff; if(strncmp((char *)pnt, "PX", 2) == 0) flag2 |= 1; if(strncmp((char *)pnt, "PN", 2) == 0) flag2 |= 2; if(strncmp((char *)pnt, "SL", 2) == 0) flag2 |= 4; if(strncmp((char *)pnt, "NM", 2) == 0) flag2 |= 8; if(strncmp((char *)pnt, "CL", 2) == 0) flag2 |= 16; if(strncmp((char *)pnt, "PL", 2) == 0) flag2 |= 32; if(strncmp((char *)pnt, "RE", 2) == 0) flag2 |= 64; if(strncmp((char *)pnt, "TF", 2) == 0) flag2 |= 128; if(strncmp((char *)pnt, "CE", 2) == 0) { cont_extent = isonum_733(pnt+4); cont_offset = isonum_733(pnt+12); cont_size = isonum_733(pnt+20); sprintf(lbuffer+iline, "=[%x,%x,%d]", cont_extent, cont_offset, cont_size); iline += strlen(lbuffer + iline); }; if(strncmp((char *)pnt, "PL", 2) == 0 || strncmp((char *)pnt, "CL", 2) == 0) { extent = isonum_733(pnt+4); sprintf(lbuffer+iline,"=%x", extent); iline += strlen(lbuffer + iline); if(extent == 0) rr_goof++; }; if(strncmp((char *)pnt, "SL", 2) == 0) { pnts = pnt+5; slen = pnt[2] - 5; while(slen >= 1){ switch(pnts[0] & 0xfe){ case 0: strncat(symlinkname, (char *)(pnts+2), pnts[1]); break; case 2: strcat (symlinkname, "."); break; case 4: strcat (symlinkname, ".."); break; case 8: strcat (symlinkname, "/"); break; case 16: strcat(symlinkname,"/mnt"); sprintf(lbuffer+iline,"Warning - mount point requested"); iline += strlen(lbuffer + iline); break; case 32: strcat(symlinkname,"kafka"); sprintf(lbuffer+iline,"Warning - host_name requested"); iline += strlen(lbuffer + iline); break; default: sprintf(lbuffer+iline,"Reserved bit setting in symlink"); rr_goof++; iline += strlen(lbuffer + iline); break; }; if((pnts[0] & 0xfe) && pnts[1] != 0) { sprintf(lbuffer+iline,"Incorrect length in symlink component"); iline += strlen(lbuffer + iline); }; if((pnts[0] & 1) == 0) strcat(symlinkname,"/"); slen -= (pnts[1] + 2); pnts += (pnts[1] + 2); }; if(symlinkname[0] != 0) { sprintf(lbuffer+iline,"=%s", symlinkname); iline += strlen(lbuffer + iline); symlinkname[0] = 0; } }; len -= pnt[2]; pnt += pnt[2]; if(len <= 3 && cont_extent) { unsigned char sector[2048]; lseek(fileno(infile), cont_extent * blocksize, 0); read(fileno(infile), sector, sizeof(sector)); flag2 |= parse_rr(§or[cont_offset], cont_size, 1); }; }; if(ncount) { sprintf(lbuffer+iline,"]"); iline += strlen(lbuffer + iline); } if (!cont_flag && flag1 && flag1 != flag2) { sprintf(lbuffer+iline,"Flag %x != %x", flag1, flag2); rr_goof++; iline += strlen(lbuffer + iline); } return flag2;}int dump_rr(idr) struct iso_directory_record *idr;{ int len; char * pnt; len = idr->length[0] & 0xff; len -= (sizeof(struct iso_directory_record) - sizeof(idr->name)); len -= idr->name_len[0]; pnt = (char *) idr; pnt += (sizeof(struct iso_directory_record) - sizeof(idr->name)); pnt += idr->name_len[0];
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -