|
|
|
/*
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Cable driver interface
|
|
|
|
* Copyright (C) 2003 ETC s.r.o.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
* Written by Marcel Telka <marcel@telka.sk>, 2003.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef CABLE_H
|
|
|
|
#define CABLE_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
typedef struct cable_t cable_t;
|
2003-03-13 Marcel Telka <marcel@telka.sk>
* include/chain.h: New file.
* src/tap/chain.c: Ditto.
* src/tap/Makefile.am (libtap_a_SOURCES): Added chain.c.
* include/Makefile.am (noinst_HEADERS): Added chain.h.
* src/jtag.c: Encapsulated parts, cable and TAP state into one object - chain.
All relevant function parameters changed to `chain'.
* src/tap/state.c: `trst' state moved to cable drivers.
All cable drivers changed.
* include/cable.h (cable_driver_t) <set_trst>: Changed return value from void to int.
All cable drivers changed.
(cable_driver_t) <get_trst>: New function.
Implemented this function to all cable drivers.
* include/part.h (part_shift_instruction, part_shift_data_register)
(parts_shift_instructions, parts_shift_data_registers): Funcions removed.
* src/part/part.c (part_shift_instruction, part_shift_data_register)
(parts_shift_instructions, parts_shift_data_registers): Ditto.
* src/tap/cable/arcom.c: Removed dependency on state.h.
* src/tap/cable/byteblaster.c: Ditto.
* src/tap/cable/dlc5.c: Ditto.
* src/tap/cable/ea253.c: Ditto.
* src/tap/cable/ei012.c: Ditto.
* src/tap/cable/mpcbdm.c: Ditto.
* src/tap/cable/wiggler.c: Ditto.
* include/state.h (bit): Replaced with common.h include.
(Unknown_State, Run_Test_Idle, Select_DR_Scan, Select_IR_Scan): Removed parentheses.
* include/tap.h (write_command): Removed unused declaration.
* src/detect.h: Removed file.
* src/jtag.h: New file with common jtag function declarations.
* src/Makefile.am (jtag_SOURCES): Removed detect.h, added jtag.h.
* src/cfi.c: Added jtag.h include. Moved common function declarations to jtag.h file.
* src/detect.c: Ditto.
* src/discovery.c: Ditto.
* src/flash.c: Ditto.
* src/help.c: Ditto.
* src/jtag.c: Ditto.
* src/readmem.c: Ditto.
* src/jtag.c (jtag_create_jtagdir, jtag_load_history, jtag_save_history, jtag_parse_line)
(jtag_readline_loop, jtag_parse_file, jtag_parse_rc): Changed functions to `static'.
* src/tap/tap.c: Added l10n support.
* po/POTFILES.in: Added src/tap/chain.c and src/tap/tap.c.
git-svn-id: https://urjtag.svn.sourceforge.net/svnroot/urjtag/trunk@392 b68d4a1b-bc3d-0410-92ed-d4ac073336b7
22 years ago
|
|
|
|
|
|
|
#include "parport.h"
|
|
|
|
#include "chain.h"
|
|
|
|
|
|
|
|
typedef struct cable_driver_t cable_driver_t;
|
|
|
|
|
|
|
|
struct cable_driver_t {
|
|
|
|
const char *name;
|
|
|
|
const char *description;
|
|
|
|
int (*connect)( char *params[], cable_t *cable );
|
|
|
|
void (*disconnect)( cable_t *cable );
|
|
|
|
void (*cable_free)( cable_t *cable );
|
|
|
|
int (*init)( cable_t * );
|
|
|
|
void (*done)( cable_t * );
|
|
|
|
void (*clock)( cable_t *, int, int, int );
|
|
|
|
int (*get_tdo)( cable_t * );
|
|
|
|
int (*transfer)( cable_t *, int, char *, char * );
|
|
|
|
int (*set_trst)( cable_t *, int );
|
|
|
|
int (*get_trst)( cable_t * );
|
|
|
|
void (*help)( const char * );
|
|
|
|
};
|
|
|
|
|
|
|
|
struct cable_t {
|
|
|
|
cable_driver_t *driver;
|
|
|
|
parport_t *port;
|
|
|
|
void *params;
|
|
|
|
chain_t *chain;
|
|
|
|
};
|
|
|
|
|
|
|
|
void cable_free( cable_t *cable );
|
|
|
|
int cable_init( cable_t *cable );
|
|
|
|
void cable_done( cable_t *cable );
|
|
|
|
void cable_clock( cable_t *cable, int tms, int tdi, int n );
|
|
|
|
int cable_get_tdo( cable_t *cable );
|
|
|
|
int cable_set_trst( cable_t *cable, int trst );
|
|
|
|
int cable_get_trst( cable_t *cable );
|
|
|
|
int cable_transfer( cable_t *cable, int len, char *in, char *out );
|
|
|
|
|
|
|
|
void cable_set_frequency( cable_t *cable, uint32_t frequency );
|
|
|
|
uint32_t cable_get_frequency( cable_t *cable );
|
|
|
|
void cable_wait( void );
|
|
|
|
|
|
|
|
extern cable_driver_t *cable_drivers[];
|
|
|
|
|
|
|
|
#endif /* CABLE_H */
|