2549d2b385
* ocd.c (ocd_insert_breakpoint, ocd_remove_breakpoint): macro BDM_BREAKPOINT already has braces around it, remove erroneous ones. * ser-ocd.c (ocd_write): conditionalize on _WIN32 instead of __CYGWIN32__ * config/powerpc/tm-ppc-eabi.h: remove BDM_NUM_REGS, BDM_REGMAP * ppc-bdm.c: move BDM_NUM_REGS, BDM_REGMAP here from tm.h file, fill in doc fields of bdm_ppc_ops. (bdm_ppc_fetch_registers): don't ask for invalid registers such as the MQ or floating point regs not present on ppc 8xx boards (bdm_ppc_store_registers): don't write those same invalid registers * config/i386/cygwin32.mh: stop including ocd.o ser-ocd.o * config/powerpc/ppc-eabi.mt: * config/powerpc/ppcle-eabi.mt: * config/powerpc/ppc-sim.mt: * config/powerpc/ppcle-sim.mt: include ser-ocd.o
201 lines
4.5 KiB
C
201 lines
4.5 KiB
C
/* Remote serial interface for Macraigor Systems implementation of
|
|
On-Chip Debugging using serial target box or serial wiggler
|
|
|
|
Copyright 1994, 1997 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
|
|
|
|
#include "defs.h"
|
|
#include "serial.h"
|
|
|
|
#ifdef _WIN32
|
|
#include <windows.h>
|
|
#endif
|
|
|
|
static int ser_ocd_open PARAMS ((serial_t scb, const char *name));
|
|
static void ser_ocd_raw PARAMS ((serial_t scb));
|
|
static int ser_ocd_readchar PARAMS ((serial_t scb, int timeout));
|
|
static int ser_ocd_setbaudrate PARAMS ((serial_t scb, int rate));
|
|
static int ser_ocd_write PARAMS ((serial_t scb, const char *str, int len));
|
|
static void ser_ocd_close PARAMS ((serial_t scb));
|
|
static serial_ttystate ser_ocd_get_tty_state PARAMS ((serial_t scb));
|
|
static int ser_ocd_set_tty_state PARAMS ((serial_t scb, serial_ttystate state));
|
|
|
|
#ifdef _WIN32
|
|
/* On Windows, this function pointer is initialized to a function in
|
|
the wiggler DLL. */
|
|
static int (*dll_do_command) PARAMS ((const char *, char *));
|
|
#endif
|
|
|
|
static int
|
|
ocd_open (scb, name)
|
|
serial_t scb;
|
|
const char *name;
|
|
{
|
|
#ifdef _WIN32
|
|
/* Find the wiggler DLL which talks to the board. */
|
|
if (dll_do_command == NULL)
|
|
{
|
|
HINSTANCE handle;
|
|
|
|
/* FIXME: Should the user be able to configure this? */
|
|
handle = LoadLibrary ("Wigglers.dll");
|
|
if (handle == NULL)
|
|
error ("Can't load Wigglers.dll");
|
|
|
|
dll_do_command = ((int (*) PARAMS ((const char *, char *)))
|
|
GetProcAddress (handle, "do_command"));
|
|
if (dll_do_command == NULL)
|
|
error ("Can't find do_command function in Wigglers.dll");
|
|
}
|
|
#endif
|
|
|
|
return 0;
|
|
}
|
|
|
|
static int
|
|
ocd_noop (scb)
|
|
serial_t scb;
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static void
|
|
ocd_raw (scb)
|
|
serial_t scb;
|
|
{
|
|
/* Always in raw mode */
|
|
}
|
|
|
|
/* We need a buffer to store responses from the Wigglers.dll */
|
|
#define WIGGLER_BUFF_SIZE 512
|
|
unsigned char from_wiggler_buffer[WIGGLER_BUFF_SIZE];
|
|
unsigned char * wiggler_buffer_ptr; /* curr spot in buffer */
|
|
|
|
static void
|
|
ocd_readremote ()
|
|
{
|
|
}
|
|
|
|
static int
|
|
ocd_readchar (scb, timeout)
|
|
serial_t scb;
|
|
int timeout;
|
|
{
|
|
return (int) *wiggler_buffer_ptr++; /* return curr char and increment ptr */
|
|
}
|
|
|
|
struct ocd_ttystate {
|
|
int dummy;
|
|
};
|
|
|
|
/* ocd_{get set}_tty_state() are both dummys to fill out the function
|
|
vector. Someday, they may do something real... */
|
|
|
|
static serial_ttystate
|
|
ocd_get_tty_state (scb)
|
|
serial_t scb;
|
|
{
|
|
struct ocd_ttystate *state;
|
|
|
|
state = (struct ocd_ttystate *) xmalloc (sizeof *state);
|
|
|
|
return (serial_ttystate) state;
|
|
}
|
|
|
|
static int
|
|
ocd_set_tty_state (scb, ttystate)
|
|
serial_t scb;
|
|
serial_ttystate ttystate;
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static int
|
|
ocd_noflush_set_tty_state (scb, new_ttystate, old_ttystate)
|
|
serial_t scb;
|
|
serial_ttystate new_ttystate;
|
|
serial_ttystate old_ttystate;
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static void
|
|
ocd_print_tty_state (scb, ttystate)
|
|
serial_t scb;
|
|
serial_ttystate ttystate;
|
|
{
|
|
/* Nothing to print. */
|
|
return;
|
|
}
|
|
|
|
static int
|
|
ocd_setbaudrate (scb, rate)
|
|
serial_t scb;
|
|
int rate;
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static int
|
|
ocd_write (scb, str, len)
|
|
serial_t scb;
|
|
const char *str;
|
|
int len;
|
|
{
|
|
char c;
|
|
|
|
#ifdef _WIN32
|
|
/* send packet to Wigglers.dll and store response so we can give it to
|
|
remote-wiggler.c when get_packet is run */
|
|
dll_do_command (str, from_wiggler_buffer);
|
|
wiggler_buffer_ptr = from_wiggler_buffer;
|
|
#endif
|
|
|
|
return 0;
|
|
}
|
|
|
|
static void
|
|
ocd_close (scb)
|
|
serial_t scb;
|
|
{
|
|
}
|
|
|
|
static struct serial_ops ocd_ops =
|
|
{
|
|
"ocd",
|
|
0,
|
|
ocd_open,
|
|
ocd_close,
|
|
ocd_readchar,
|
|
ocd_write,
|
|
ocd_noop, /* flush output */
|
|
ocd_noop, /* flush input */
|
|
ocd_noop, /* send break -- currently used only for nindy */
|
|
ocd_raw,
|
|
ocd_get_tty_state,
|
|
ocd_set_tty_state,
|
|
ocd_print_tty_state,
|
|
ocd_noflush_set_tty_state,
|
|
ocd_setbaudrate,
|
|
};
|
|
|
|
void
|
|
_initialize_ser_ocd_bdm ()
|
|
{
|
|
serial_add_interface (&ocd_ops);
|
|
}
|