197e01b6dc
* arm-tdep.c: * ia64-tdep.c: * i386-tdep.c: * hpread.c: * hppa-tdep.c: * hppa-hpux-tdep.c: * gnu-nat.c: * gdbtypes.c: * gdbarch.h: * gdbarch.c: * eval.c: * dwarf2read.c: * dbxread.c: * copying: * symfile.c: * stabsread.c: * sh64-tdep.c: * sh-tdep.c: * s390-tdep.c: * rs6000-tdep.c: * remote.c: * remote-mips.c: * mips-tdep.c: * mdebugread.c: * linux-nat.c: * infrun.c: * xcoffread.c: * win32-nat.c: * valops.c: * utils.c: * tracepoint.c: * target.c: * symtab.c: * c-exp.y: * ada-valprint.c: * ada-typeprint.c: * ada-lex.l: * ada-lang.h: * ada-lang.c: * ada-exp.y: * alphafbsd-tdep.c: * alphabsd-tdep.h: * alphabsd-tdep.c: * alphabsd-nat.c: * alpha-tdep.h: * alpha-tdep.c: * alpha-osf1-tdep.c: * alpha-nat.c: * alpha-mdebug-tdep.c: * alpha-linux-tdep.c: * alpha-linux-nat.c: * aix-thread.c: * abug-rom.c: * arch-utils.c: * annotate.h: * annotate.c: * amd64obsd-tdep.c: * amd64obsd-nat.c: * amd64nbsd-tdep.c: * amd64nbsd-nat.c: * amd64fbsd-tdep.c: * amd64fbsd-nat.c: * amd64bsd-nat.c: * amd64-tdep.h: * amd64-tdep.c: * amd64-sol2-tdep.c: * amd64-nat.h: * amd64-nat.c: * amd64-linux-tdep.c: * amd64-linux-nat.c: * alphanbsd-tdep.c: * block.h: * block.c: * bfd-target.h: * bfd-target.c: * bcache.h: * bcache.c: * ax.h: * ax-general.c: * ax-gdb.h: * ax-gdb.c: * avr-tdep.c: * auxv.h: * auxv.c: * armnbsd-tdep.c: * armnbsd-nat.c: * arm-tdep.h: * arm-linux-nat.c: * arch-utils.h: * charset.c: * call-cmds.h: * c-valprint.c: * c-typeprint.c: * c-lang.h: * c-lang.c: * buildsym.h: * buildsym.c: * bsd-uthread.h: * bsd-uthread.c: * bsd-kvm.h: * bsd-kvm.c: * breakpoint.h: * core-regset.c: * core-aout.c: * completer.h: * completer.c: * complaints.h: * complaints.c: * command.h: * coffread.c: * coff-solib.h: * coff-solib.c: * coff-pe-read.h: * coff-pe-read.c: * cli-out.h: * cli-out.c: * charset.h: * dink32-rom.c: * dictionary.h: * dictionary.c: * demangle.c: * defs.h: * dcache.h: * dcache.c: * d10v-tdep.c: * cpu32bug-rom.c: * cp-valprint.c: * cp-support.h: * cp-support.c: * cp-namespace.c: * cp-abi.h: * cp-abi.c: * corelow.c: * corefile.c: * environ.c: * elfread.c: * dwarfread.c: * dwarf2loc.c: * dwarf2expr.h: * dwarf2expr.c: * dwarf2-frame.h: * dwarf2-frame.c: * dve3900-rom.c: * dummy-frame.h: * dummy-frame.c: * dsrec.c: * doublest.h: * doublest.c: * disasm.h: * disasm.c: * fork-child.c: * findvar.c: * fbsd-nat.h: * fbsd-nat.c: * f-valprint.c: * f-typeprint.c: * f-lang.h: * f-lang.c: * expression.h: * expprint.c: * exec.h: * exec.c: * exceptions.h: * exceptions.c: * event-top.h: * event-top.c: * event-loop.h: * event-loop.c: * gdb.c: * gdb-stabs.h: * gdb-events.h: * gdb-events.c: * gcore.c: * frv-tdep.h: * frv-tdep.c: * frv-linux-tdep.c: * frame.h: * frame.c: * frame-unwind.h: * frame-unwind.c: * frame-base.h: * frame-base.c: * gdb_vfork.h: * gdb_thread_db.h: * gdb_string.h: * gdb_stat.h: * gdb_regex.h: * gdb_ptrace.h: * gdb_proc_service.h: * gdb_obstack.h: * gdb_locale.h: * gdb_dirent.h: * gdb_curses.h: * gdb_assert.h: * gdbarch.sh: * gdb.h: * hpux-thread.c: * hppabsd-nat.c: * hppa-tdep.h: * hpacc-abi.c: * h8300-tdep.c: * gregset.h: * go32-nat.c: * gnu-v3-abi.c: * gnu-v2-abi.h: * gnu-v2-abi.c: * gnu-nat.h: * glibc-tdep.c: * gdbtypes.h: * gdbcore.h: * gdbcmd.h: * i386nbsd-tdep.c: * i386nbsd-nat.c: * i386gnu-tdep.c: * i386gnu-nat.c: * i386fbsd-tdep.c: * i386fbsd-nat.c: * i386bsd-tdep.c: * i386bsd-nat.h: * i386bsd-nat.c: * i386-tdep.h: * i386-sol2-nat.c: * i386-nto-tdep.c: * i386-nat.c: * i386-linux-tdep.h: * i386-linux-tdep.c: * i386-linux-nat.c: * i386-cygwin-tdep.c: * inf-ttrace.c: * inf-ptrace.h: * inf-ptrace.c: * inf-loop.h: * inf-loop.c: * inf-child.h: * inf-child.c: * ia64-tdep.h: * ia64-linux-nat.c: * i387-tdep.h: * i387-tdep.c: * i386v4-nat.c: * i386v-nat.c: * i386obsd-tdep.c: * i386obsd-nat.c: * kod.c: * jv-valprint.c: * jv-typeprint.c: * jv-lang.h: * jv-lang.c: * irix5-nat.c: * iq2000-tdep.c: * interps.h: * interps.c: * inftarg.c: * inflow.h: * inflow.c: * inferior.h: * infcmd.c: * infcall.h: * infcall.c: * inf-ttrace.h: * m32r-tdep.h: * m32r-tdep.c: * m32r-rom.c: * m32r-linux-tdep.c: * m32r-linux-nat.c: * m2-valprint.c: * m2-typeprint.c: * m2-lang.h: * m2-lang.c: * lynx-nat.c: * linux-thread-db.c: * linux-nat.h: * linespec.c: * libunwind-frame.h: * libunwind-frame.c: * language.h: * language.c: * macroexp.c: * macrocmd.c: * m88kbsd-nat.c: * m88k-tdep.h: * m88k-tdep.c: * m68klinux-tdep.c: * m68klinux-nat.c: * m68kbsd-tdep.c: * m68kbsd-nat.c: * m68k-tdep.h: * m68k-tdep.c: * mips-linux-nat.c: * mips-irix-tdep.c: * minsyms.c: * memattr.h: * memattr.c: * mem-break.c: * mdebugread.h: * main.h: * main.c: * macrotab.h: * macrotab.c: * macroscope.h: * macroscope.c: * macroexp.h: * nbsd-tdep.c: * mt-tdep.c: * monitor.h: * monitor.c: * mn10300-tdep.h: * mn10300-tdep.c: * mn10300-linux-tdep.c: * mipsv4-nat.c: * mipsread.c: * mipsnbsd-tdep.h: * mipsnbsd-tdep.c: * mipsnbsd-nat.c: * mips64obsd-tdep.c: * mips64obsd-nat.c: * mips-tdep.h: * mips-mdebug-tdep.c: * mips-linux-tdep.c: * osabi.h: * osabi.c: * ocd.h: * ocd.c: * observer.c: * objfiles.h: * objfiles.c: * objc-lang.h: * objc-lang.c: * objc-exp.y: * nto-tdep.h: * nto-tdep.c: * nto-procfs.c: * nlmread.c: * nbsd-tdep.h: * ppcobsd-tdep.c: * ppcobsd-nat.c: * ppcnbsd-tdep.h: * ppcnbsd-tdep.c: * ppcnbsd-nat.c: * ppcbug-rom.c: * ppc-tdep.h: * ppc-sysv-tdep.c: * ppc-linux-tdep.c: * ppc-linux-nat.c: * ppc-bdm.c: * parser-defs.h: * parse.c: * p-valprint.c: * p-typeprint.c: * p-lang.h: * p-lang.c: * remote-fileio.h: * remote-fileio.c: * remote-est.c: * remote-e7000.c: * regset.h: * regset.c: * reggroups.h: * reggroups.c: * regcache.h: * regcache.c: * proc-why.c: * proc-service.c: * proc-events.c: * printcmd.c: * ppcobsd-tdep.h: * sentinel-frame.h: * sentinel-frame.c: * scm-valprint.c: * scm-tags.h: * scm-lang.h: * scm-lang.c: * scm-exp.c: * s390-tdep.h: * rom68k-rom.c: * remote.h: * remote-utils.c: * remote-st.c: * remote-sim.c: * remote-sds.c: * remote-rdp.c: * remote-rdi.c: * remote-hms.c: * sim-regno.h: * shnbsd-tdep.h: * shnbsd-tdep.c: * shnbsd-nat.c: * sh-tdep.h: * serial.h: * serial.c: * ser-unix.h: * ser-unix.c: * ser-tcp.c: * ser-pipe.c: * ser-go32.c: * ser-e7kpc.c: * ser-base.h: * ser-base.c: * solib.c: * solib-svr4.h: * solib-svr4.c: * solib-sunos.c: * solib-som.h: * solib-som.c: * solib-pa64.h: * solib-pa64.c: * solib-osf.c: * solib-null.c: * solib-legacy.c: * solib-irix.c: * solib-frv.c: * solib-aix5.c: * sol-thread.c: * sparc64-linux-tdep.c: * sparc64-linux-nat.c: * sparc-tdep.h: * sparc-tdep.c: * sparc-sol2-tdep.c: * sparc-sol2-nat.c: * sparc-nat.h: * sparc-nat.c: * sparc-linux-tdep.c: * sparc-linux-nat.c: * source.h: * source.c: * somread.c: * solist.h: * solib.h: * std-regs.c: * stack.h: * stack.c: * stabsread.h: * sparcobsd-tdep.c: * sparcnbsd-tdep.c: * sparcnbsd-nat.c: * sparc64obsd-tdep.c: * sparc64nbsd-tdep.c: * sparc64nbsd-nat.c: * sparc64fbsd-tdep.c: * sparc64fbsd-nat.c: * sparc64-tdep.h: * sparc64-tdep.c: * sparc64-sol2-tdep.c: * sparc64-nat.c: * ui-file.c: * typeprint.h: * typeprint.c: * tramp-frame.h: * tramp-frame.c: * trad-frame.h: * trad-frame.c: * tracepoint.h: * top.c: * tobs.inc: * thread.c: * terminal.h: * target.h: * symfile.h: * stop-gdb.c: * vaxbsd-nat.c: * vax-tdep.h: * vax-tdep.c: * vax-nat.c: * varobj.h: * varobj.c: * value.h: * value.c: * valprint.h: * valprint.c: * v850-tdep.c: * uw-thread.c: * user-regs.c: * ui-out.h: * ui-out.c: * ui-file.h: * xcoffsolib.h: * xcoffsolib.c: * wrapper.c: * wince.c: * wince-stub.h: * wince-stub.c: * vaxobsd-tdep.c: * vaxnbsd-tdep.c: * gdb_gcore.sh: * copying.c: * configure.ac: * aclocal.m4: * acinclude.m4: * reply_mig_hack.awk: * observer.sh: * gdb_mbuild.sh: * arm-linux-tdep.c: * blockframe.c: * dbug-rom.c: * environ.h: * dwarf2loc.h: * gdb-events.sh: * glibc-tdep.h: * gdb_wait.h: * gdbthread.h: * i386-sol2-tdep.c: * hppabsd-tdep.c: * hppa-linux-nat.c: * hppa-hpux-nat.c: * ia64-linux-tdep.c: * infptrace.c: * linespec.h: * maint.c: * mips-mdebug-tdep.h: * remote-m32r-sdi.c: * s390-nat.c: * rs6000-nat.c: * remote-utils.h: * sh3-rom.c: * sh-linux-tdep.c: * top.h: * symtab.h: * symmisc.c: * symfile-mem.c: * srec.h: * user-regs.h: * version.h: * valarith.c: * xstormy16-tdep.c: * wrapper.h: * Makefile.in: * f-exp.y: * cris-tdep.c: * cp-name-parser.y: * procfs.c: * proc-utils.h: * proc-flags.c: * proc-api.c: * p-exp.y: * m68hc11-tdep.c: * m2-exp.y: * kod.h: * kod-cisco.c: * jv-exp.y: * hppa-linux-tdep.c: Add (c) after Copyright. Update the FSF address.
436 lines
9.1 KiB
C
436 lines
9.1 KiB
C
/* Remote serial interface using Renesas E7000 PC ISA card in a PC
|
|
Copyright (C) 1994, 1996, 1997, 1998, 1999, 2000
|
|
Free Software Foundation, Inc.
|
|
|
|
This file is part of GDB.
|
|
|
|
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 of the License, 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., 51 Franklin Street, Fifth Floor,
|
|
Boston, MA 02110-1301, USA. */
|
|
|
|
#include "defs.h"
|
|
#if defined __GO32__ || defined _WIN32
|
|
#include "serial.h"
|
|
#include "gdb_string.h"
|
|
|
|
#ifdef _WIN32
|
|
#define WIN32_LEAN_AND_MEAN
|
|
#include <windows.h>
|
|
#endif
|
|
|
|
#ifdef __GO32__
|
|
#include <sys/dos.h>
|
|
#endif
|
|
|
|
static int e7000pc_open (struct serial *scb, const char *name);
|
|
static void e7000pc_raw (struct serial *scb);
|
|
static int e7000pc_readchar (struct serial *scb, int timeout);
|
|
static int e7000pc_setbaudrate (struct serial *scb, int rate);
|
|
static int e7000pc_write (struct serial *scb, const char *str, int len);
|
|
static void e7000pc_close (struct serial *scb);
|
|
static serial_ttystate e7000pc_get_tty_state (struct serial *scb);
|
|
static int e7000pc_set_tty_state (struct serial *scb, serial_ttystate state);
|
|
|
|
#define OFF_DPD 0x0000
|
|
#define OFF_DDP 0x1000
|
|
#define OFF_CPD 0x2000
|
|
#define OFF_CDP 0x2400
|
|
#define OFF_FA 0x3000
|
|
#define OFF_FB 0x3002
|
|
#define OFF_FC 0x3004
|
|
#define OFF_IRQTOD 0x3008
|
|
#define OFF_IRQTOP 0x300a
|
|
#define OFF_READY 0x300c
|
|
#define OFF_PON 0x300e
|
|
|
|
#define IDLE 0x0000
|
|
#define CMD_CI 0x4349
|
|
#define CMD_CO 0x434f
|
|
#define CMD_LO 0x4c4f
|
|
#define CMD_LS 0x4c53
|
|
#define CMD_SV 0x5356
|
|
#define CMD_SS 0x5353
|
|
#define CMD_OK 0x4f4b
|
|
#define CMD_ER 0x4552
|
|
#define CMD_NF 0x4e46
|
|
#define CMD_AB 0x4142
|
|
#define CMD_ED 0x4544
|
|
#define CMD_CE 0x4345
|
|
|
|
static unsigned long fa;
|
|
static unsigned long irqtod;
|
|
static unsigned long ready;
|
|
static unsigned long fb;
|
|
static unsigned long cpd;
|
|
static unsigned long cdp;
|
|
static unsigned long ready;
|
|
static unsigned long pon;
|
|
static unsigned long irqtop;
|
|
static unsigned long board_at;
|
|
|
|
#ifdef __GO32__
|
|
|
|
#define SET_BYTE(x,y) { char _buf = y;dosmemput(&_buf,1, x);}
|
|
#define SET_WORD(x,y) { short _buf = y;dosmemput(&_buf,2, x);}
|
|
#define GET_BYTE(x) ( dosmemget(x,1,&bb), bb)
|
|
#define GET_WORD(x) ( dosmemget(x,2,&sb), sb)
|
|
static unsigned char bb;
|
|
static unsigned short sb;
|
|
|
|
#else /* win32 */
|
|
|
|
#define SET_BYTE(x,y) *(volatile unsigned char *)(x) = (y)
|
|
#define SET_WORD(x,y) *(volatile unsigned short *)(x) = (y)
|
|
#define GET_BYTE(x) (*(volatile unsigned char *)(x))
|
|
#define GET_WORD(x) (*(volatile unsigned short *)(x))
|
|
#define dosmemget(FROM, LEN, TO) memcpy ((void *)(TO), (void *)(FROM), (LEN))
|
|
#define dosmemput(FROM, LEN, TO) memcpy ((void *)(TO), (void *)(FROM), (LEN))
|
|
#endif
|
|
|
|
static struct sw
|
|
{
|
|
int sw;
|
|
int addr;
|
|
}
|
|
sigs[] =
|
|
{
|
|
{
|
|
0x14, 0xd0000
|
|
}
|
|
,
|
|
{
|
|
0x15, 0xd4000
|
|
}
|
|
,
|
|
{
|
|
0x16, 0xd8000
|
|
}
|
|
,
|
|
{
|
|
0x17, 0xdc000
|
|
}
|
|
,
|
|
0
|
|
};
|
|
|
|
#define get_ds_base() 0
|
|
|
|
static int
|
|
e7000pc_init (void)
|
|
{
|
|
int try;
|
|
unsigned long dsbase;
|
|
|
|
dsbase = get_ds_base ();
|
|
|
|
/* Look around in memory for the board's signature */
|
|
|
|
for (try = 0; sigs[try].sw; try++)
|
|
{
|
|
int val;
|
|
board_at = sigs[try].addr - dsbase;
|
|
fa = board_at + OFF_FA;
|
|
fb = board_at + OFF_FB;
|
|
cpd = board_at + OFF_CPD;
|
|
cdp = board_at + OFF_CDP;
|
|
ready = board_at + OFF_READY;
|
|
pon = board_at + OFF_PON;
|
|
irqtop = board_at + OFF_IRQTOP;
|
|
irqtod = board_at + OFF_IRQTOD;
|
|
|
|
val = GET_WORD (ready);
|
|
|
|
if (val == (0xaaa0 | sigs[try].sw))
|
|
{
|
|
if (GET_WORD (pon) & 0xf)
|
|
{
|
|
SET_WORD (fa, 0);
|
|
SET_WORD (fb, 0);
|
|
|
|
SET_WORD (irqtop, 1); /* Disable interrupts from e7000 */
|
|
SET_WORD (ready, 1);
|
|
printf_filtered ("\nConnected to the E7000PC at address 0x%x\n",
|
|
sigs[try].addr);
|
|
return 1;
|
|
}
|
|
error (_("The E7000 PC board is working, but the E7000 is turned off."));
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
error (_("GDB cannot connect to the E7000 PC board, check that it is installed\n\
|
|
and that the switch settings are correct. Some other DOS programs can \n\
|
|
stop the board from working. Try starting from a very minimal boot, \n\
|
|
perhaps you need to disable EMM386 over the region where the board has\n\
|
|
its I/O space, remove other unneeded cards, etc etc\n"));
|
|
return 0;
|
|
|
|
}
|
|
|
|
static int pbuf_size;
|
|
static int pbuf_index;
|
|
|
|
/* Return next byte from cdp. If no more, then return -1. */
|
|
|
|
static int
|
|
e7000_get (void)
|
|
{
|
|
static char pbuf[1000];
|
|
char tmp[1000];
|
|
int x;
|
|
|
|
if (pbuf_index < pbuf_size)
|
|
{
|
|
x = pbuf[pbuf_index++];
|
|
}
|
|
else if ((GET_WORD (fb) & 1))
|
|
{
|
|
int i;
|
|
pbuf_size = GET_WORD (cdp + 2);
|
|
|
|
dosmemget (cdp + 8, pbuf_size + 1, tmp);
|
|
|
|
/* Tell the E7000 we've eaten */
|
|
SET_WORD (fb, 0);
|
|
/* Swap it around */
|
|
for (i = 0; i < pbuf_size; i++)
|
|
{
|
|
pbuf[i] = tmp[i ^ 1];
|
|
}
|
|
pbuf_index = 0;
|
|
x = pbuf[pbuf_index++];
|
|
}
|
|
else
|
|
{
|
|
x = -1;
|
|
}
|
|
return x;
|
|
}
|
|
|
|
/* Works just like read(), except that it takes a TIMEOUT in seconds. Note
|
|
that TIMEOUT == 0 is a poll, and TIMEOUT == -1 means wait forever. */
|
|
|
|
static int
|
|
dosasync_read (int fd, char *buf, int len, int timeout)
|
|
{
|
|
long now;
|
|
long then;
|
|
int i = 0;
|
|
|
|
/* Then look for some more if we're still hungry */
|
|
time (&now);
|
|
then = now + timeout;
|
|
while (i < len)
|
|
{
|
|
int ch = e7000_get ();
|
|
|
|
/* While there's room in the buffer, and we've already
|
|
read the stuff in, suck it over */
|
|
if (ch != -1)
|
|
{
|
|
buf[i++] = ch;
|
|
while (i < len && pbuf_index < pbuf_size)
|
|
{
|
|
ch = e7000_get ();
|
|
if (ch == -1)
|
|
break;
|
|
buf[i++] = ch;
|
|
}
|
|
}
|
|
|
|
time (&now);
|
|
|
|
if (timeout == 0)
|
|
return i;
|
|
if (now >= then && timeout > 0)
|
|
{
|
|
return i;
|
|
}
|
|
}
|
|
return len;
|
|
}
|
|
|
|
|
|
static int
|
|
dosasync_write (int fd, const char *buf, int len)
|
|
{
|
|
int i;
|
|
char dummy[1000];
|
|
|
|
/* Construct copy locally */
|
|
((short *) dummy)[0] = CMD_CI;
|
|
((short *) dummy)[1] = len;
|
|
((short *) dummy)[2] = 0;
|
|
((short *) dummy)[3] = 0;
|
|
for (i = 0; i < len; i++)
|
|
{
|
|
dummy[(8 + i) ^ 1] = buf[i];
|
|
}
|
|
|
|
/* Wait for the card to get ready */
|
|
while (GET_WORD (fa) & 1);
|
|
|
|
/* Blast onto the ISA card */
|
|
dosmemput (dummy, 8 + len + 1, cpd);
|
|
|
|
SET_WORD (fa, 1);
|
|
SET_WORD (irqtod, 1); /* Interrupt the E7000 */
|
|
|
|
return len;
|
|
}
|
|
|
|
static int
|
|
e7000pc_open (struct serial *scb, const char *name)
|
|
{
|
|
if (strncasecmp (name, "pc", 2) != 0)
|
|
{
|
|
errno = ENOENT;
|
|
return -1;
|
|
}
|
|
|
|
scb->fd = e7000pc_init ();
|
|
|
|
if (!scb->fd)
|
|
return -1;
|
|
|
|
return 0;
|
|
}
|
|
|
|
static int
|
|
e7000pc_noop (struct serial *scb)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static void
|
|
e7000pc_raw (struct serial *scb)
|
|
{
|
|
/* Always in raw mode */
|
|
}
|
|
|
|
static int
|
|
e7000pc_readchar (struct serial *scb, int timeout)
|
|
{
|
|
char buf;
|
|
|
|
top:
|
|
|
|
if (dosasync_read (scb->fd, &buf, 1, timeout))
|
|
{
|
|
if (buf == 0)
|
|
goto top;
|
|
return buf;
|
|
}
|
|
else
|
|
return SERIAL_TIMEOUT;
|
|
}
|
|
|
|
struct e7000pc_ttystate
|
|
{
|
|
int dummy;
|
|
};
|
|
|
|
/* e7000pc_{get set}_tty_state() are both dummys to fill out the function
|
|
vector. Someday, they may do something real... */
|
|
|
|
static serial_ttystate
|
|
e7000pc_get_tty_state (struct serial *scb)
|
|
{
|
|
struct e7000pc_ttystate *state;
|
|
|
|
state = (struct e7000pc_ttystate *) xmalloc (sizeof *state);
|
|
|
|
return (serial_ttystate) state;
|
|
}
|
|
|
|
static int
|
|
e7000pc_set_tty_state (struct serial *scb, serial_ttystate ttystate)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static int
|
|
e7000pc_noflush_set_tty_state (struct serial *scb,
|
|
serial_ttystate new_ttystate,
|
|
serial_ttystate old_ttystate)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static void
|
|
e7000pc_print_tty_state (struct serial *scb,
|
|
serial_ttystate ttystate,
|
|
struct ui_file *stream)
|
|
{
|
|
/* Nothing to print. */
|
|
return;
|
|
}
|
|
|
|
static int
|
|
e7000pc_setbaudrate (struct serial *scb, int rate)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static int
|
|
e7000pc_setstopbits (struct serial *scb, int rate)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static int
|
|
e7000pc_write (struct serial *scb, const char *str, int len)
|
|
{
|
|
dosasync_write (scb->fd, str, len);
|
|
|
|
return 0;
|
|
}
|
|
|
|
static void
|
|
e7000pc_close (struct serial *scb)
|
|
{
|
|
}
|
|
|
|
static struct serial_ops e7000pc_ops =
|
|
{
|
|
"pc",
|
|
0,
|
|
e7000pc_open,
|
|
e7000pc_close,
|
|
e7000pc_readchar,
|
|
e7000pc_write,
|
|
e7000pc_noop, /* flush output */
|
|
e7000pc_noop, /* flush input */
|
|
e7000pc_noop, /* send break -- currently used only for nindy */
|
|
e7000pc_raw,
|
|
e7000pc_get_tty_state,
|
|
e7000pc_set_tty_state,
|
|
e7000pc_print_tty_state,
|
|
e7000pc_noflush_set_tty_state,
|
|
e7000pc_setbaudrate,
|
|
e7000pc_setstopbits,
|
|
e7000pc_noop, /* wait for output to drain */
|
|
};
|
|
|
|
#endif /*_WIN32 or __GO32__*/
|
|
|
|
extern initialize_file_ftype _initialize_ser_e7000pc; /* -Wmissing-prototypes */
|
|
|
|
void
|
|
_initialize_ser_e7000pc (void)
|
|
{
|
|
#if defined __GO32__ || defined _WIN32
|
|
serial_add_interface (&e7000pc_ops);
|
|
#endif
|
|
}
|