1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-06 13:09:50 +00:00

o Catch up with pnp changes - kget no longer saves pnp data.

o Catch up with ncurses updates - some internal function names have changed.
This commit is contained in:
Jordan K. Hubbard 1999-09-04 16:01:15 +00:00
parent 2c6dd93a11
commit 29ed216a4d
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=50917
10 changed files with 14 additions and 126 deletions

View File

@ -50,6 +50,7 @@
#include <sys/stat.h>
#include <sys/sysctl.h>
#include <unistd.h>
#include <termios.h>
static void create_termcap(void);
static void fixit_common(void);

View File

@ -38,7 +38,6 @@ kget(char *out)
#include "sysinstall.h"
#include <sys/sysctl.h>
#include <i386/isa/isa_device.h>
#include <i386/isa/pnp.h>
int
kget(char *out)
@ -46,11 +45,9 @@ kget(char *out)
int len, i, bytes_written = 0;
char *buf;
char *mib1 = "machdep.uc_devlist";
char *mib2 = "machdep.uc_pnplist";
char name[9];
FILE *fout = NULL;
struct isa_device *id;
struct pnp_cinfo *c;
char *p;
/* create the output file; if we end up not writing to it, we'll
@ -66,17 +63,17 @@ kget(char *out)
i = sysctlbyname(mib1, NULL, &len, NULL, NULL);
if (i) {
msgDebug("kget: error buffer sizing\n");
goto pnp;
goto bail;
}
if (len <= 0) {
msgDebug("kget: mib1 has length of %d\n", len);
goto pnp;
goto bail;
}
buf = (char *)alloca(len * sizeof(char));
i = sysctlbyname(mib1, buf, &len, NULL, NULL);
if (i) {
msgDebug("kget: error retrieving data\n");
goto pnp;
goto bail;
}
@ -116,57 +113,6 @@ kget(char *out)
i += sizeof(struct isa_device) + 8;
}
pnp:
/* Now, print the changes to PnP override table */
i = sysctlbyname(mib2, NULL, &len, NULL, NULL);
if (i) {
/* Possibly our kernel doesn't support PnP. Ignore the error. */
msgDebug("kget: can't get PnP data - skipping...\n");
goto bail;
}
if (len <= 0) {
msgDebug("kget: PnP data has length of %d\n", len);
goto bail;
}
buf = (char *)alloca(len * sizeof(char));
i = sysctlbyname(mib2, buf, &len, NULL, NULL);
if (i) {
msgDebug("kget: error retrieving data mib2\n");
goto bail;
}
/* Print the PnP override table. Taken from userconfig.c */
i = 0;
do {
c = (struct pnp_cinfo *)(buf + i);
if (c->csn >0 && c->csn != 255) {
int pmax, mmax;
if (c->enable == 0) {
bytes_written += fprintf(fout, "pnp %d %d disable\n",
c->csn, c->ldn);
continue;
}
bytes_written += fprintf(fout, "pnp %d %d %s irq0 %d irq1 %d drq0 %d drq1 %d",
c->csn, c->ldn, c->override ? "os":"bios",
c->irq[0], c->irq[1], c->drq[0], c->drq[1]);
if (c->flags)
bytes_written += fprintf(fout, " flags 0x%lx", c->flags);
pmax = 0;
while (c->port[pmax] != 0 && pmax < 8) {
bytes_written += fprintf(fout, " port%d %d", pmax, c->port[pmax]);
pmax++;
}
mmax = 0;
while (c->mem[mmax].base != 0 && mmax < 8) {
bytes_written += fprintf(fout, " mem%d %d",
mmax, (int)c->mem[mmax].base);
mmax++;
}
bytes_written += fprintf(fout,"\n");
}
} while ((i += sizeof(struct pnp_cinfo)) < len);
bail:
if (bytes_written)
fprintf(fout, "q\n");

View File

@ -39,6 +39,7 @@
#include "sysinstall.h"
#include <signal.h>
#include <termios.h>
#include <sys/fcntl.h>
#include <sys/ioctl.h>
#include <sys/stat.h>

View File

@ -18,6 +18,7 @@
#include "sysinstall.h"
#include <signal.h>
#include <termios.h>
#include <sys/reboot.h>
#include <machine/console.h>
#include <sys/fcntl.h>
@ -257,15 +258,12 @@ void
systemChangeTerminal(char *color, const u_char c_term[],
char *mono, const u_char m_term[])
{
extern void init_acs(void);
if (OnVTY) {
if (ColorDisplay) {
setenv("TERM", color, 1);
setenv("TERMCAP", c_term, 1);
reset_shell_mode();
setterm(color);
init_acs();
cbreak(); noecho();
}
else {
@ -273,7 +271,6 @@ systemChangeTerminal(char *color, const u_char c_term[],
setenv("TERMCAP", m_term, 1);
reset_shell_mode();
setterm(mono);
init_acs();
cbreak(); noecho();
}
}

View File

@ -50,6 +50,7 @@
#include <sys/stat.h>
#include <sys/sysctl.h>
#include <unistd.h>
#include <termios.h>
static void create_termcap(void);
static void fixit_common(void);

View File

@ -18,6 +18,7 @@
#include "sysinstall.h"
#include <signal.h>
#include <termios.h>
#include <sys/reboot.h>
#include <machine/console.h>
#include <sys/fcntl.h>
@ -257,15 +258,12 @@ void
systemChangeTerminal(char *color, const u_char c_term[],
char *mono, const u_char m_term[])
{
extern void init_acs(void);
if (OnVTY) {
if (ColorDisplay) {
setenv("TERM", color, 1);
setenv("TERMCAP", c_term, 1);
reset_shell_mode();
setterm(color);
init_acs();
cbreak(); noecho();
}
else {
@ -273,7 +271,6 @@ systemChangeTerminal(char *color, const u_char c_term[],
setenv("TERMCAP", m_term, 1);
reset_shell_mode();
setterm(mono);
init_acs();
cbreak(); noecho();
}
}

View File

@ -50,6 +50,7 @@
#include <sys/stat.h>
#include <sys/sysctl.h>
#include <unistd.h>
#include <termios.h>
static void create_termcap(void);
static void fixit_common(void);

View File

@ -38,7 +38,6 @@ kget(char *out)
#include "sysinstall.h"
#include <sys/sysctl.h>
#include <i386/isa/isa_device.h>
#include <i386/isa/pnp.h>
int
kget(char *out)
@ -46,11 +45,9 @@ kget(char *out)
int len, i, bytes_written = 0;
char *buf;
char *mib1 = "machdep.uc_devlist";
char *mib2 = "machdep.uc_pnplist";
char name[9];
FILE *fout = NULL;
struct isa_device *id;
struct pnp_cinfo *c;
char *p;
/* create the output file; if we end up not writing to it, we'll
@ -66,17 +63,17 @@ kget(char *out)
i = sysctlbyname(mib1, NULL, &len, NULL, NULL);
if (i) {
msgDebug("kget: error buffer sizing\n");
goto pnp;
goto bail;
}
if (len <= 0) {
msgDebug("kget: mib1 has length of %d\n", len);
goto pnp;
goto bail;
}
buf = (char *)alloca(len * sizeof(char));
i = sysctlbyname(mib1, buf, &len, NULL, NULL);
if (i) {
msgDebug("kget: error retrieving data\n");
goto pnp;
goto bail;
}
@ -116,57 +113,6 @@ kget(char *out)
i += sizeof(struct isa_device) + 8;
}
pnp:
/* Now, print the changes to PnP override table */
i = sysctlbyname(mib2, NULL, &len, NULL, NULL);
if (i) {
/* Possibly our kernel doesn't support PnP. Ignore the error. */
msgDebug("kget: can't get PnP data - skipping...\n");
goto bail;
}
if (len <= 0) {
msgDebug("kget: PnP data has length of %d\n", len);
goto bail;
}
buf = (char *)alloca(len * sizeof(char));
i = sysctlbyname(mib2, buf, &len, NULL, NULL);
if (i) {
msgDebug("kget: error retrieving data mib2\n");
goto bail;
}
/* Print the PnP override table. Taken from userconfig.c */
i = 0;
do {
c = (struct pnp_cinfo *)(buf + i);
if (c->csn >0 && c->csn != 255) {
int pmax, mmax;
if (c->enable == 0) {
bytes_written += fprintf(fout, "pnp %d %d disable\n",
c->csn, c->ldn);
continue;
}
bytes_written += fprintf(fout, "pnp %d %d %s irq0 %d irq1 %d drq0 %d drq1 %d",
c->csn, c->ldn, c->override ? "os":"bios",
c->irq[0], c->irq[1], c->drq[0], c->drq[1]);
if (c->flags)
bytes_written += fprintf(fout, " flags 0x%lx", c->flags);
pmax = 0;
while (c->port[pmax] != 0 && pmax < 8) {
bytes_written += fprintf(fout, " port%d %d", pmax, c->port[pmax]);
pmax++;
}
mmax = 0;
while (c->mem[mmax].base != 0 && mmax < 8) {
bytes_written += fprintf(fout, " mem%d %d",
mmax, (int)c->mem[mmax].base);
mmax++;
}
bytes_written += fprintf(fout,"\n");
}
} while ((i += sizeof(struct pnp_cinfo)) < len);
bail:
if (bytes_written)
fprintf(fout, "q\n");

View File

@ -39,6 +39,7 @@
#include "sysinstall.h"
#include <signal.h>
#include <termios.h>
#include <sys/fcntl.h>
#include <sys/ioctl.h>
#include <sys/stat.h>

View File

@ -18,6 +18,7 @@
#include "sysinstall.h"
#include <signal.h>
#include <termios.h>
#include <sys/reboot.h>
#include <machine/console.h>
#include <sys/fcntl.h>
@ -257,15 +258,12 @@ void
systemChangeTerminal(char *color, const u_char c_term[],
char *mono, const u_char m_term[])
{
extern void init_acs(void);
if (OnVTY) {
if (ColorDisplay) {
setenv("TERM", color, 1);
setenv("TERMCAP", c_term, 1);
reset_shell_mode();
setterm(color);
init_acs();
cbreak(); noecho();
}
else {
@ -273,7 +271,6 @@ systemChangeTerminal(char *color, const u_char c_term[],
setenv("TERMCAP", m_term, 1);
reset_shell_mode();
setterm(mono);
init_acs();
cbreak(); noecho();
}
}