⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mkioconf.c

📁 早期freebsd实现
💻 C
📖 第 1 页 / 共 3 页
字号:
}char *sirq(num){	if (num == -1)		return ("0");	sprintf(errbuf, "IRQ%d", num);	return (errbuf);}#endif#if MACHINE_PMAXpmax_ioconf(){	register struct device *dp, *mp;	FILE *fp;	fp = fopen(path("ioconf.c"), "w");	if (fp == 0) {		perror(path("ioconf.c"));		exit(1);	}	fprintf(fp, "#include \"sys/types.h\"\n");	fprintf(fp, "#include \"sys/time.h\"\n");	fprintf(fp, "#include \"pmax/dev/device.h\"\n\n");	fprintf(fp, "#define C (char *)\n\n");	/* print controller initialization structures */	for (dp = dtab; dp != 0; dp = dp->d_next) {		if (dp->d_type == PSEUDO_DEVICE)			continue;		fprintf(fp, "extern struct driver %sdriver;\n", dp->d_name);	}	fprintf(fp, "\nstruct pmax_ctlr pmax_cinit[] = {\n");	fprintf(fp, "/*\tdriver,\t\tunit,\taddr,\t\tpri,\tflags */\n");	for (dp = dtab; dp != 0; dp = dp->d_next) {		if (dp->d_type != CONTROLLER && dp->d_type != MASTER)			continue;		if (dp->d_conn != TO_NEXUS) {			printf("%s%s must be attached to a nexus (internal bus)\n",				dp->d_name, wnum(dp->d_unit));			continue;		}		if (dp->d_drive != UNKNOWN || dp->d_slave != UNKNOWN) {			printf("can't specify drive/slave for %s%s\n",				dp->d_name, wnum(dp->d_unit));			continue;		}		if (dp->d_unit == UNKNOWN || dp->d_unit == QUES)			dp->d_unit = 0;		fprintf(fp,			"\t{ &%sdriver,\t%d,\tC 0x%x,\t%d,\t0x%x },\n",			dp->d_name, dp->d_unit, dp->d_addr, dp->d_pri,			dp->d_flags);	}	fprintf(fp, "\t0\n};\n");	/* print devices connected to other controllers */	fprintf(fp, "\nstruct scsi_device scsi_dinit[] = {\n");	fprintf(fp,	   "/*driver,\tcdriver,\tunit,\tctlr,\tdrive,\tslave,\tdk,\tflags*/\n");	for (dp = dtab; dp != 0; dp = dp->d_next) {		if (dp->d_type == CONTROLLER || dp->d_type == MASTER ||		    dp->d_type == PSEUDO_DEVICE)			continue;		mp = dp->d_conn;		if (mp == 0 ||		    !eq(mp->d_name, "asc") && !eq(mp->d_name, "sii")) {			printf("%s%s: devices must be attached to a SCSI (asc or sii) controller\n",				dp->d_name, wnum(dp->d_unit));			continue;		}		if ((unsigned)dp->d_drive > 6) {			printf("%s%s: SCSI drive must be in the range 0..6\n",				dp->d_name, wnum(dp->d_unit));			continue;		}		/* may want to allow QUES later */		if ((unsigned)dp->d_slave > 7) {			printf("%s%s: SCSI slave (LUN) must be in the range 0..7\n",				dp->d_name, wnum(dp->d_unit));			continue;		}		fprintf(fp, "{ &%sdriver,\t&%sdriver,", dp->d_name, mp->d_name);		fprintf(fp, "\t%d,\t%d,\t%d,\t%d,\t%d,\t0x%x },\n",			dp->d_unit, mp->d_unit, dp->d_drive, dp->d_slave,			dp->d_dk, dp->d_flags);	}	fprintf(fp, "0\n};\n");	pseudo_ioconf(fp);	(void) fclose(fp);}#endif#if MACHINE_NEWS3400int have_iop = 0;int have_hb = 0;int have_vme = 0;news_ioconf(){	register struct device *dp, *mp;	register int slave;	FILE *fp;	fp = fopen(path("ioconf.c"), "w");	if (fp == 0) {		perror(path("ioconf.c"));		exit(1);	}	fprintf(fp, "#include \"sys/param.h\"\n");	fprintf(fp, "#include \"sys/buf.h\"\n");	fprintf(fp, "#include \"sys/map.h\"\n");	fprintf(fp, "#include \"vm/vm.h\"\n");	fprintf(fp, "#include \"iop.h\"\n");	fprintf(fp, "#include \"hb.h\"\n");	fprintf(fp, "\n");	fprintf(fp, "#if NIOP > 0\n");	fprintf(fp, "#include \"news3400/iop/iopvar.h\"\n");	fprintf(fp, "#endif\n");	fprintf(fp, "#if NHB > 0\n");	fprintf(fp, "#include \"news3400/hbdev/hbvar.h\"\n");	fprintf(fp, "#endif\n");	fprintf(fp, "\n");	fprintf(fp, "#define C (caddr_t)\n\n");	fprintf(fp, "\n");/* BEGIN HB */	fprintf(fp, "#if NHB > 0\n");	/*	 * Now generate interrupt vectors for the HYPER-BUS	 */	for (dp = dtab; dp != 0; dp = dp->d_next) {		if (dp->d_pri >= 0) {			mp = dp->d_conn;			if (mp == 0 || mp == TO_NEXUS ||			    !eq(mp->d_name, "hb"))				continue;			fprintf(fp, "extern struct hb_driver %sdriver;\n",			    dp->d_name);			have_hb++;		}	}	/*	 * Now spew forth the hb_cinfo structure	 */	fprintf(fp, "\nstruct hb_ctlr hminit[] = {\n");	fprintf(fp, "/*\t driver,\tctlr,\talive,\taddr,\tintpri */\n");	for (dp = dtab; dp != 0; dp = dp->d_next) {		mp = dp->d_conn;		if ((dp->d_type != MASTER && dp->d_type != CONTROLLER)		    || mp == TO_NEXUS || mp == 0 ||		    !eq(mp->d_name, "hb"))			continue;		if (dp->d_pri < 0) {			printf("must specify priority for %s%d\n",			    dp->d_name, dp->d_unit);			continue;		}		if (dp->d_drive != UNKNOWN || dp->d_slave != UNKNOWN) {			printf("drives need their own entries; ");			printf("dont specify drive or slave for %s%d\n",			    dp->d_name, dp->d_unit);			continue;		}		if (dp->d_flags) {			printf("controllers (e.g. %s%d) don't have flags, ");			printf("only devices do\n",			    dp->d_name, dp->d_unit);			continue;		}		fprintf(fp, "\t{ &%sdriver,\t%d,\t0,\tC 0x%x,\t%d },\n",		    dp->d_name, dp->d_unit, dp->d_addr, dp->d_pri);	}	fprintf(fp, "\t0\n};\n");	/*	 * Now we go for the hb_device stuff	 */	fprintf(fp, "\nstruct hb_device hdinit[] = {\n");	fprintf(fp,"\t/* driver,  unit, ctlr,  slave,   addr,    pri,    dk, flags*/\n");	for (dp = dtab; dp != 0; dp = dp->d_next) {		mp = dp->d_conn;		if (dp->d_unit == QUES || dp->d_type != DEVICE || mp == 0 ||		    mp == TO_NEXUS || /* mp->d_type == MASTER || */		    eq(mp->d_name, "iop") || eq(mp->d_name, "vme"))			continue;		if (eq(mp->d_name, "hb")) {			if (dp->d_pri < 0) {				printf("must specify vector for device %s%d\n",				    dp->d_name, dp->d_unit);				continue;			}			if (dp->d_drive != UNKNOWN || dp->d_slave != UNKNOWN) {				printf("drives/slaves can be specified only ");				printf("for controllers, not for device %s%d\n",				    dp->d_name, dp->d_unit);				continue;			}			slave = QUES;		} else {			if (mp->d_conn == 0) {				printf("%s%d isn't connected to anything, ",				    mp->d_name, mp->d_unit);				printf("so %s%d is unattached\n",				    dp->d_name, dp->d_unit);				continue;			}			if (dp->d_drive == UNKNOWN) {				printf("must specify ``drive number'' for %s%d\n",				   dp->d_name, dp->d_unit);				continue;			}			/* NOTE THAT ON THE IOP ``drive'' IS STORED IN */			/* ``SLAVE'' AND WE DON'T WANT A SLAVE SPECIFIED */			if (dp->d_slave != UNKNOWN) {				printf("slave numbers should be given only ");				printf("for massbus tapes, not for %s%d\n",				    dp->d_name, dp->d_unit);				continue;			}			if (dp->d_pri >= 0) {				printf("interrupt priority should not be ");				printf("given for drive %s%d\n",				    dp->d_name, dp->d_unit);				continue;			}			if (dp->d_addr != 0) {				printf("csr addresses should be given only");				printf("on controllers, not on %s%d\n",				    dp->d_name, dp->d_unit);				continue;			}			slave = dp->d_drive;		}		fprintf(fp,"\t{ &%sdriver,  %2d,   %s,    %2d,   C 0x%x, %d,  %d,  0x%x },\n",		    eq(mp->d_name, "hb") ? dp->d_name : mp->d_name, dp->d_unit,		    eq(mp->d_name, "hb") ? " -1" : qu(mp->d_unit),		    slave, dp->d_addr, dp->d_pri, dp->d_dk, dp->d_flags);	}	fprintf(fp, "\t0\n};\n\n");	fprintf(fp, "#endif\n\n");/* END HB */	pseudo_ioconf(fp);	(void) fclose(fp);}#endifchar *intv(dev)	register struct device *dev;{	static char buf[20];	if (dev->d_vec == 0)		return ("     0");	(void) sprintf(buf, "%sint%d", dev->d_name, dev->d_unit);	return (buf);}char *qu(num){	if (num == QUES)		return ("'?'");	if (num == UNKNOWN)		return (" -1");	(void) sprintf(errbuf, "%3d", num);	return (errbuf);}char *wnum(num){	if (num == QUES || num == UNKNOWN)		return ("?");	(void) sprintf(errbuf, "%d", num);	return (errbuf);}voidpseudo_ioconf(fp)	register FILE *fp;{	register struct device *dp;	(void)fprintf(fp, "\n#include <sys/device.h>\n\n");	for (dp = dtab; dp != NULL; dp = dp->d_next)		if (dp->d_type == PSEUDO_DEVICE)			(void)fprintf(fp, "extern void %sattach __P((int));\n",			    dp->d_name);	/*	 * XXX concatonated disks are pseudo-devices but appear as DEVICEs	 * since they don't adhere to normal pseudo-device conventions	 * (i.e. one entry with total count in d_slave).	 */	if (seen_cd)		(void)fprintf(fp, "extern void cdattach __P((int));\n");	/* XXX temporary for HP300, others */	(void)fprintf(fp, "\n#include <sys/systm.h> /* XXX */\n");	(void)fprintf(fp, "#define etherattach (void (*)__P((int)))nullop\n");	(void)fprintf(fp, "#define iteattach (void (*) __P((int)))nullop\n");	(void)fprintf(fp, "\nstruct pdevinit pdevinit[] = {\n");	for (dp = dtab; dp != NULL; dp = dp->d_next)		if (dp->d_type == PSEUDO_DEVICE)			(void)fprintf(fp, "\t{ %sattach, %d },\n", dp->d_name,			    dp->d_slave > 0 ? dp->d_slave : 1);	/*	 * XXX count up cds and put out an entry	 */	if (seen_cd) {		struct file_list *fl;		int cdmax = -1;		for (fl = comp_list; fl != NULL; fl = fl->f_next)			if (fl->f_type == COMPDEVICE && fl->f_compinfo > cdmax)				cdmax = fl->f_compinfo;		(void)fprintf(fp, "\t{ cdattach, %d },\n", cdmax+1);	}	(void)fprintf(fp, "\t{ 0, 0 }\n};\n");	if (seen_cd)		comp_config(fp);}comp_config(fp)	FILE *fp;{	register struct file_list *fl;	register struct device *dp;	fprintf(fp, "\n#include \"dev/cdvar.h\"\n");	fprintf(fp, "\nstruct cddevice cddevice[] = {\n");	fprintf(fp, "/*\tunit\tileave\tflags\tdk\tdevs\t\t\t\t*/\n");	fl = comp_list;	while (fl) {		if (fl->f_type != COMPDEVICE) {			fl = fl->f_next;			continue;		}		for (dp = dtab; dp != 0; dp = dp->d_next)			if (dp->d_type == DEVICE &&			    eq(dp->d_name, fl->f_fn) &&			    dp->d_unit == fl->f_compinfo)				break;		if (dp == 0)			continue;		fprintf(fp, "\t%d,\t%d,\t%d,\t%d,\t{",			dp->d_unit, dp->d_pri < 0 ? 0 : dp->d_pri,			dp->d_flags, 1);		for (fl = fl->f_next; fl->f_type == COMPSPEC; fl = fl->f_next)			fprintf(fp, " 0x%x,", fl->f_compdev);		fprintf(fp, " NODEV },\n");	}	fprintf(fp, "\t-1,\t0,\t0,\t0,\t{ 0 },\n};\n");}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -