1fa521b03SWarner Losh /*- 272d44f31SMarcel Moolenaar * Copyright (c) 2004 Marcel Moolenaar 372d44f31SMarcel Moolenaar * All rights reserved. 472d44f31SMarcel Moolenaar * 572d44f31SMarcel Moolenaar * Redistribution and use in source and binary forms, with or without 672d44f31SMarcel Moolenaar * modification, are permitted provided that the following conditions 772d44f31SMarcel Moolenaar * are met: 872d44f31SMarcel Moolenaar * 972d44f31SMarcel Moolenaar * 1. Redistributions of source code must retain the above copyright 1072d44f31SMarcel Moolenaar * notice, this list of conditions and the following disclaimer. 1172d44f31SMarcel Moolenaar * 2. Redistributions in binary form must reproduce the above copyright 1272d44f31SMarcel Moolenaar * notice, this list of conditions and the following disclaimer in the 1372d44f31SMarcel Moolenaar * documentation and/or other materials provided with the distribution. 1472d44f31SMarcel Moolenaar * 1572d44f31SMarcel Moolenaar * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 1672d44f31SMarcel Moolenaar * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 1772d44f31SMarcel Moolenaar * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 1872d44f31SMarcel Moolenaar * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 1972d44f31SMarcel Moolenaar * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 2072d44f31SMarcel Moolenaar * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 2172d44f31SMarcel Moolenaar * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 2272d44f31SMarcel Moolenaar * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 2372d44f31SMarcel Moolenaar * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 2472d44f31SMarcel Moolenaar * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 2572d44f31SMarcel Moolenaar * 2672d44f31SMarcel Moolenaar * $FreeBSD$ 2772d44f31SMarcel Moolenaar */ 2872d44f31SMarcel Moolenaar 2972d44f31SMarcel Moolenaar #ifndef _GDB_GDB_INT_H_ 3072d44f31SMarcel Moolenaar #define _GDB_GDB_INT_H_ 3172d44f31SMarcel Moolenaar 3272d44f31SMarcel Moolenaar extern struct gdb_dbgport *gdb_cur; 3372d44f31SMarcel Moolenaar 3472d44f31SMarcel Moolenaar extern char *gdb_rxp; 3572d44f31SMarcel Moolenaar extern size_t gdb_rxsz; 3672d44f31SMarcel Moolenaar extern char *gdb_txp; 3772d44f31SMarcel Moolenaar 3872d44f31SMarcel Moolenaar int gdb_rx_begin(void); 3972d44f31SMarcel Moolenaar int gdb_rx_equal(const char *); 4072d44f31SMarcel Moolenaar int gdb_rx_mem(unsigned char *, size_t); 4172d44f31SMarcel Moolenaar int gdb_rx_varhex(uintmax_t *); 4272d44f31SMarcel Moolenaar 4372d44f31SMarcel Moolenaar static __inline int 4472d44f31SMarcel Moolenaar gdb_rx_char(void) 4572d44f31SMarcel Moolenaar { 4672d44f31SMarcel Moolenaar int c; 4772d44f31SMarcel Moolenaar 4872d44f31SMarcel Moolenaar if (gdb_rxsz > 0) { 4972d44f31SMarcel Moolenaar c = *gdb_rxp++; 5072d44f31SMarcel Moolenaar gdb_rxsz--; 5172d44f31SMarcel Moolenaar } else 5272d44f31SMarcel Moolenaar c = -1; 5372d44f31SMarcel Moolenaar return (c); 5472d44f31SMarcel Moolenaar } 5572d44f31SMarcel Moolenaar 5672d44f31SMarcel Moolenaar void gdb_tx_begin(char); 5772d44f31SMarcel Moolenaar int gdb_tx_end(void); 5872d44f31SMarcel Moolenaar int gdb_tx_mem(const unsigned char *, size_t); 5972d44f31SMarcel Moolenaar void gdb_tx_reg(int); 6072d44f31SMarcel Moolenaar 6172d44f31SMarcel Moolenaar static __inline void 6272d44f31SMarcel Moolenaar gdb_tx_char(char c) 6372d44f31SMarcel Moolenaar { 6472d44f31SMarcel Moolenaar *gdb_txp++ = c; 6572d44f31SMarcel Moolenaar } 6672d44f31SMarcel Moolenaar 6772d44f31SMarcel Moolenaar static __inline int 6872d44f31SMarcel Moolenaar gdb_tx_empty(void) 6972d44f31SMarcel Moolenaar { 7072d44f31SMarcel Moolenaar gdb_tx_begin('\0'); 7172d44f31SMarcel Moolenaar return (gdb_tx_end()); 7272d44f31SMarcel Moolenaar } 7372d44f31SMarcel Moolenaar 7472d44f31SMarcel Moolenaar static __inline void 7572d44f31SMarcel Moolenaar gdb_tx_hex(uintmax_t n, int sz) 7672d44f31SMarcel Moolenaar { 7772d44f31SMarcel Moolenaar gdb_txp += sprintf(gdb_txp, "%0*jx", sz, n); 7872d44f31SMarcel Moolenaar } 7972d44f31SMarcel Moolenaar 8072d44f31SMarcel Moolenaar static __inline int 8172d44f31SMarcel Moolenaar gdb_tx_err(int err) 8272d44f31SMarcel Moolenaar { 8372d44f31SMarcel Moolenaar gdb_tx_begin('E'); 8472d44f31SMarcel Moolenaar gdb_tx_hex(err, 2); 8572d44f31SMarcel Moolenaar return (gdb_tx_end()); 8672d44f31SMarcel Moolenaar } 8772d44f31SMarcel Moolenaar 8872d44f31SMarcel Moolenaar static __inline int 8972d44f31SMarcel Moolenaar gdb_tx_ok(void) 9072d44f31SMarcel Moolenaar { 9172d44f31SMarcel Moolenaar gdb_tx_begin('O'); 9272d44f31SMarcel Moolenaar gdb_tx_char('K'); 9372d44f31SMarcel Moolenaar return (gdb_tx_end()); 9472d44f31SMarcel Moolenaar } 9572d44f31SMarcel Moolenaar 9672d44f31SMarcel Moolenaar static __inline void 9772d44f31SMarcel Moolenaar gdb_tx_str(const char *s) 9872d44f31SMarcel Moolenaar { 9972d44f31SMarcel Moolenaar while (*s) 10072d44f31SMarcel Moolenaar *gdb_txp++ = *s++; 10172d44f31SMarcel Moolenaar } 10272d44f31SMarcel Moolenaar 10372d44f31SMarcel Moolenaar static __inline void 10472d44f31SMarcel Moolenaar gdb_tx_varhex(uintmax_t n) 10572d44f31SMarcel Moolenaar { 10672d44f31SMarcel Moolenaar gdb_txp += sprintf(gdb_txp, "%jx", n); 10772d44f31SMarcel Moolenaar } 10872d44f31SMarcel Moolenaar 10972d44f31SMarcel Moolenaar #endif /* !_GDB_GDB_INT_H_ */ 110