124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//===-- RNBRemote.h ---------------------------------------------*- C++ -*-===//
224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//
324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//                     The LLVM Compiler Infrastructure
424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//
524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner// This file is distributed under the University of Illinois Open Source
624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner// License. See LICENSE.TXT for details.
724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//
824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//===----------------------------------------------------------------------===//
924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//
1024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//  Created by Greg Clayton on 12/12/07.
1124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//
1224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner//===----------------------------------------------------------------------===//
1324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
1424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#ifndef __RNBRemote_h__
1524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#define __RNBRemote_h__
1624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
1724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#include "RNBDefs.h"
1824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#include "DNB.h"
1924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#include "RNBContext.h"
2024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#include "RNBSocket.h"
2124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#include "PThreadMutex.h"
2224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#include <string>
2324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#include <vector>
2424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#include <deque>
2524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#include <map>
2624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
2724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattnerclass RNBSocket;
2824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattnerclass RNBContext;
2924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattnerclass PThreadEvents;
3024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
3124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattnerenum event_loop_mode { debug_nub, gdb_remote_protocol, done };
3224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
3324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattnerclass RNBRemote
3424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner{
3524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattnerpublic:
3624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
3724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    typedef enum {
3824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        invalid_packet = 0,
3924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        ack,                            // '+'
4024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        nack,                           // '-'
4124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        halt,                           // ^C  (async halt)
4224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        use_extended_mode,              // '!'
4324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        why_halted,                     // '?'
4424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        set_argv,                       // 'A'
4524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        set_bp,                         // 'B'
4624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        cont,                           // 'c'
4724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        continue_with_sig,              // 'C'
4824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        detach,                         // 'D'
4924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        read_general_regs,              // 'g'
5024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        write_general_regs,             // 'G'
5124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        set_thread,                     // 'H'
5224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        step_inferior_one_cycle,        // 'i'
5324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        signal_and_step_inf_one_cycle,  // 'I'
5424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        kill,                           // 'k'
5524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        read_memory,                    // 'm'
5624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        write_memory,                   // 'M'
5724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        read_register,                  // 'p'
5824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        write_register,                 // 'P'
5924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        restart,                        // 'R'
6024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        single_step,                    // 's'
6124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        single_step_with_sig,           // 'S'
6224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        search_mem_backwards,           // 't'
6324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        thread_alive_p,                 // 'T'
64c1d3775eb2494c6e88ebee44c7d49beefcb3bb6aGreg Clayton        vattach,                        // 'vAttach;pid'
65c1d3775eb2494c6e88ebee44c7d49beefcb3bb6aGreg Clayton        vattachwait,                    // 'vAttachWait:XX...' where XX is one or more hex encoded process name ASCII bytes
663a458eb1e413d39546b664813bba9f9ac292357eJim Ingham        vattachorwait,                  // 'vAttachOrWait:XX...' where XX is one or more hex encoded process name ASCII bytes
67c1d3775eb2494c6e88ebee44c7d49beefcb3bb6aGreg Clayton        vattachname,                    // 'vAttachName:XX...' where XX is one or more hex encoded process name ASCII bytes
6824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        vcont,                          // 'vCont'
6924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        vcont_list_actions,             // 'vCont?'
7024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        write_data_to_memory,           // 'X'
7124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        insert_mem_bp,                  // 'Z0'
7224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        remove_mem_bp,                  // 'z0'
7324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        insert_hardware_bp,             // 'Z1'
7424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        remove_hardware_bp,             // 'z1'
7524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        insert_write_watch_bp,          // 'Z2'
7624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        remove_write_watch_bp,          // 'z2'
7724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        insert_read_watch_bp,           // 'Z3'
7824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        remove_read_watch_bp,           // 'z3'
7924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        insert_access_watch_bp,         // 'Z4'
8024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        remove_access_watch_bp,         // 'z4'
8124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
82151e3be552fea65cc4f03eaa1c425f793266fe56Greg Clayton        query_monitor,                  // 'qRcmd'
8324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        query_current_thread_id,        // 'qC'
84d05213b79411eb12bcd75f07d33f5245c07edb0dJason Molenda        query_get_pid,                  // 'qGetPid'
8524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        query_thread_ids_first,         // 'qfThreadInfo'
8624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        query_thread_ids_subsequent,    // 'qsThreadInfo'
8724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        query_thread_extra_info,        // 'qThreadExtraInfo'
8824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        query_thread_stop_info,         // 'qThreadStopInfo'
8924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        query_image_offsets,            // 'qOffsets'
9024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        query_symbol_lookup,            // 'gSymbols'
9124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        query_launch_success,           // 'qLaunchSuccess'
9224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        query_register_info,            // 'qRegisterInfo'
9324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        query_shlib_notify_info_addr,   // 'qShlibInfoAddr'
9424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        query_step_packet_supported,    // 'qStepPacketSupported'
953a458eb1e413d39546b664813bba9f9ac292357eJim Ingham        query_vattachorwait_supported,  // 'qVAttachOrWaitSupported'
9673f6b49b568f48755bb5058a3db679c3b9093682Jim Ingham        query_sync_thread_state_supported,// 'QSyncThreadState'
9724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        query_host_info,                // 'qHostInfo'
982b67961c05a0296e7773875a7a6f2cb82fa5c575Jason Molenda        query_process_info,             // 'qProcessInfo'
9924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        pass_signals_to_inferior,       // 'QPassSignals'
10024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        start_noack_mode,               // 'QStartNoAckMode'
101c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton        prefix_reg_packets_with_tid,    // 'QPrefixRegisterPacketsWithThreadID
10224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        set_logging_mode,               // 'QSetLogging:'
10324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        set_max_packet_size,            // 'QSetMaxPacketSize:'
10424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        set_max_payload_size,           // 'QSetMaxPayloadSize:'
10524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        set_environment_variable,       // 'QEnvironment:'
10604f081d0572d046456009ce8273ab2ff0a985219Jason Molenda        set_environment_variable_hex,   // 'QEnvironmentHexEncoded:'
107a4582404fa50f89485e69a17281673147217d64fGreg Clayton        set_launch_arch,                // 'QLaunchArch:'
1080a7f75f9e375911ca91a884968b0efa36f18588dGreg Clayton        set_disable_aslr,               // 'QSetDisableASLR:'
109a2f7423310044cf76d8d52aa9153b7fd8b226b49Greg Clayton        set_stdin,                      // 'QSetSTDIN:'
110a2f7423310044cf76d8d52aa9153b7fd8b226b49Greg Clayton        set_stdout,                     // 'QSetSTDOUT:'
111a2f7423310044cf76d8d52aa9153b7fd8b226b49Greg Clayton        set_stderr,                     // 'QSetSTDERR:'
112a2f7423310044cf76d8d52aa9153b7fd8b226b49Greg Clayton        set_working_dir,                // 'QSetWorkingDir:'
113a1f645e66c8e52ef287b9ab42f521eb57bcf217dGreg Clayton        set_list_threads_in_stop_reply, // 'QListThreadsInStopReply:'
11473f6b49b568f48755bb5058a3db679c3b9093682Jim Ingham        sync_thread_state,              // 'QSyncThreadState:'
115bcf07b37b3e3cd37ac74cc42c12009f130f185a3Jason Molenda        memory_region_info,             // 'qMemoryRegionInfo:'
116fb9cee64303d36d6fe5d87e63dd8701d1ddb70a9Han Ming Ong        get_profile_data,               // 'qGetProfileData'
117245dc927c0fc10aa4d8dda2a43a8bf35ffff53f9Han Ming Ong        set_enable_profiling,           // 'QSetEnableAsyncProfiling'
1187cbdcfb0cefcfd877b507ff2d83e51a1bde3fcc7Johnny Chen        watchpoint_support_info,        // 'qWatchpointSupportInfo:'
11924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        allocate_memory,                // '_M'
12024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        deallocate_memory,              // '_m'
12124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
122cc152b20d7b07aa4c229977b7b0d8d94cbda2ff5Johnny Chen        unknown_type
12324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    } PacketEnum;
12424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
12524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    typedef rnb_err_t (RNBRemote::*HandlePacketCallback)(const char *p);
12624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
127a2f7423310044cf76d8d52aa9153b7fd8b226b49Greg Clayton    RNBRemote ();
12820d338fad87eba91de65aa9bec76e01c04472848Greg Clayton    ~RNBRemote ();
12924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
13020d338fad87eba91de65aa9bec76e01c04472848Greg Clayton    void            Initialize();
13120d338fad87eba91de65aa9bec76e01c04472848Greg Clayton
1324d4ff9e8f7746ba1b1d597512b7cb711350c0206Greg Clayton    bool            InitializeRegisters (bool force = false);
13324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
13424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t       HandleAsyncPacket(PacketEnum *type = NULL);
13524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t       HandleReceivedPacket(PacketEnum *type = NULL);
13624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
13724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    nub_thread_t    GetContinueThread () const
13824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                    {
13924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                        return m_continue_thread;
14024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                    }
14124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
14224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    void            SetContinueThread (nub_thread_t tid)
14324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                    {
14424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                        m_continue_thread = tid;
14524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                    }
14624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
14724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    nub_thread_t    GetCurrentThread () const
14824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                    {
14924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                        if (m_thread == 0 || m_thread == -1)
15024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                            return DNBProcessGetCurrentThread (m_ctx.ProcessID());
15124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                        return m_thread;
15224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                    }
15324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
15424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    void            SetCurrentThread (nub_thread_t tid)
15524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                    {
15624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                        DNBProcessSetCurrentThread (m_ctx.ProcessID(), tid);
15724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                        m_thread = tid;
15824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                    }
15924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
16024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    static void*    ThreadFunctionReadRemoteData(void *arg);
16124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    void            StartReadRemoteDataThread ();
16224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    void            StopReadRemoteDataThread ();
16324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
16424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    void NotifyThatProcessStopped (void);
16524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
16624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_A (const char *p);
16724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_H (const char *p);
16824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_qC (const char *p);
169151e3be552fea65cc4f03eaa1c425f793266fe56Greg Clayton    rnb_err_t HandlePacket_qRcmd (const char *p);
170d05213b79411eb12bcd75f07d33f5245c07edb0dJason Molenda    rnb_err_t HandlePacket_qGetPid (const char *p);
17124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_qLaunchSuccess (const char *p);
17224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_qRegisterInfo (const char *p);
17324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_qShlibInfoAddr (const char *p);
17424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_qStepPacketSupported (const char *p);
1753a458eb1e413d39546b664813bba9f9ac292357eJim Ingham    rnb_err_t HandlePacket_qVAttachOrWaitSupported (const char *p);
17673f6b49b568f48755bb5058a3db679c3b9093682Jim Ingham    rnb_err_t HandlePacket_qSyncThreadStateSupported (const char *p);
17724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_qThreadInfo (const char *p);
17824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_qThreadExtraInfo (const char *p);
17924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_qThreadStopInfo (const char *p);
18024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_qHostInfo (const char *p);
1812b67961c05a0296e7773875a7a6f2cb82fa5c575Jason Molenda    rnb_err_t HandlePacket_qProcessInfo (const char *p);
182c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton    rnb_err_t HandlePacket_QStartNoAckMode (const char *p);
183c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton    rnb_err_t HandlePacket_QThreadSuffixSupported (const char *p);
184c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton    rnb_err_t HandlePacket_QSetLogging (const char *p);
185c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton    rnb_err_t HandlePacket_QSetDisableASLR (const char *p);
186a2f7423310044cf76d8d52aa9153b7fd8b226b49Greg Clayton    rnb_err_t HandlePacket_QSetSTDIO (const char *p);
187a2f7423310044cf76d8d52aa9153b7fd8b226b49Greg Clayton    rnb_err_t HandlePacket_QSetWorkingDir (const char *p);
188c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton    rnb_err_t HandlePacket_QSetMaxPayloadSize (const char *p);
189c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton    rnb_err_t HandlePacket_QSetMaxPacketSize (const char *p);
190c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton    rnb_err_t HandlePacket_QEnvironment (const char *p);
19104f081d0572d046456009ce8273ab2ff0a985219Jason Molenda    rnb_err_t HandlePacket_QEnvironmentHexEncoded (const char *p);
192a4582404fa50f89485e69a17281673147217d64fGreg Clayton    rnb_err_t HandlePacket_QLaunchArch (const char *p);
193a1f645e66c8e52ef287b9ab42f521eb57bcf217dGreg Clayton    rnb_err_t HandlePacket_QListThreadsInStopReply (const char *p);
19473f6b49b568f48755bb5058a3db679c3b9093682Jim Ingham    rnb_err_t HandlePacket_QSyncThreadState (const char *p);
195c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton    rnb_err_t HandlePacket_QPrefixRegisterPacketsWithThreadID (const char *p);
19624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_last_signal (const char *p);
19724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_m (const char *p);
19824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_M (const char *p);
19924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_X (const char *p);
20024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_g (const char *p);
20124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_G (const char *p);
20224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_z (const char *p);
20324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_T (const char *p);
20424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_p (const char *p);
20524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_P (const char *p);
20624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_c (const char *p);
20724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_C (const char *p);
20824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_D (const char *p);
20924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_k (const char *p);
21024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_s (const char *p);
21124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_S (const char *p);
21224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_v (const char *p);
21324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_UNIMPLEMENTED (const char *p);
214db2bab463047edba4b01da1fcaf70f15e778095eGreg Clayton    rnb_err_t HandlePacket_ILLFORMED (const char *file, int line, const char *p, const char *description);
21524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_AllocateMemory (const char *p);
21624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_DeallocateMemory (const char *p);
217bcf07b37b3e3cd37ac74cc42c12009f130f185a3Jason Molenda    rnb_err_t HandlePacket_MemoryRegionInfo (const char *p);
218fb9cee64303d36d6fe5d87e63dd8701d1ddb70a9Han Ming Ong    rnb_err_t HandlePacket_GetProfileData(const char *p);
219245dc927c0fc10aa4d8dda2a43a8bf35ffff53f9Han Ming Ong    rnb_err_t HandlePacket_SetEnableAsyncProfiling(const char *p);
2207cbdcfb0cefcfd877b507ff2d83e51a1bde3fcc7Johnny Chen    rnb_err_t HandlePacket_WatchpointSupportInfo (const char *p);
22124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
22224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t HandlePacket_stop_process (const char *p);
22324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
22424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t SendStopReplyPacketForThread (nub_thread_t tid);
22524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t SendHexEncodedBytePacket (const char *header, const void *buf, size_t buf_len, const char *footer);
22624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t SendSTDOUTPacket (char *buf, nub_size_t buf_size);
22724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t SendSTDERRPacket (char *buf, nub_size_t buf_size);
22824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    void      FlushSTDIO ();
229fb9cee64303d36d6fe5d87e63dd8701d1ddb70a9Han Ming Ong    void      SendAsyncProfileData ();
230fb9cee64303d36d6fe5d87e63dd8701d1ddb70a9Han Ming Ong    rnb_err_t SendAsyncProfileDataPacket (char *buf, nub_size_t buf_size);
23124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
23224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    RNBContext&     Context() { return m_ctx; }
23324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    RNBSocket&      Comm() { return m_comm; }
23424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
235a2f7423310044cf76d8d52aa9153b7fd8b226b49Greg Clayton    void
236a2f7423310044cf76d8d52aa9153b7fd8b226b49Greg Clayton    SetUseNativeRegisters (bool b)
237a2f7423310044cf76d8d52aa9153b7fd8b226b49Greg Clayton    {
238a2f7423310044cf76d8d52aa9153b7fd8b226b49Greg Clayton        m_use_native_regs = b;
239a2f7423310044cf76d8d52aa9153b7fd8b226b49Greg Clayton    }
24024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattnerprivate:
24124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    // Outlaw some contructors
24224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    RNBRemote (const RNBRemote &);
24324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
24424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattnerprotected:
24524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
24624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t GetCommData ();
24724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    void CommDataReceived(const std::string& data);
24824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    struct Packet
24924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    {
25024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        typedef std::vector<Packet>         collection;
25124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        typedef collection::iterator        iterator;
25224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        typedef collection::const_iterator  const_iterator;
25324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        PacketEnum type;
25424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        HandlePacketCallback normal;    // Function to call when inferior is halted
25524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        HandlePacketCallback async;     // Function to call when inferior is running
25624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        std::string abbrev;
25724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        std::string printable_name;
2584fdf7602bedd8be648f3c549074cf13d90a05f03Greg Clayton
2594fdf7602bedd8be648f3c549074cf13d90a05f03Greg Clayton        bool
2604fdf7602bedd8be648f3c549074cf13d90a05f03Greg Clayton        IsPlatformPacket () const
2614fdf7602bedd8be648f3c549074cf13d90a05f03Greg Clayton        {
2624fdf7602bedd8be648f3c549074cf13d90a05f03Greg Clayton            switch (type)
2634fdf7602bedd8be648f3c549074cf13d90a05f03Greg Clayton            {
2644fdf7602bedd8be648f3c549074cf13d90a05f03Greg Clayton            case set_logging_mode:
2654fdf7602bedd8be648f3c549074cf13d90a05f03Greg Clayton            case query_host_info:
2664fdf7602bedd8be648f3c549074cf13d90a05f03Greg Clayton                return true;
267e1f50b9df1299f6b9181b5ac2699ed4a3ad38a59Greg Clayton            default:
268e1f50b9df1299f6b9181b5ac2699ed4a3ad38a59Greg Clayton                    break;
2694fdf7602bedd8be648f3c549074cf13d90a05f03Greg Clayton            }
2704fdf7602bedd8be648f3c549074cf13d90a05f03Greg Clayton            return false;
2714fdf7602bedd8be648f3c549074cf13d90a05f03Greg Clayton        }
27224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        Packet() :
27324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner            type(invalid_packet),
27424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner            normal (NULL),
27524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner            async (NULL),
27624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner            abbrev (),
27724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner            printable_name ()
27824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        {
27924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        }
28024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
28124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        Packet( PacketEnum in_type,
28224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                HandlePacketCallback in_normal,
28324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                HandlePacketCallback in_async,
28424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                const char *in_abbrev,
28524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner                const char *in_printable_name) :
28624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner            type    (in_type),
28724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner            normal  (in_normal),
28824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner            async   (in_async),
28924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner            abbrev  (in_abbrev),
29024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner            printable_name (in_printable_name)
29124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        {
29224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner        }
29324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    };
29424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
29524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t       GetPacket (std::string &packet_data, RNBRemote::Packet& packet_info, bool wait);
29624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t       SendPacket (const std::string &);
29724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
29824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    void CreatePacketTable ();
29924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    rnb_err_t GetPacketPayload (std::string &);
30024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
301c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton    nub_thread_t
302c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton    ExtractThreadIDFromThreadSuffix (const char *p);
303c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton
30424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    RNBContext      m_ctx;              // process context
30524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    RNBSocket       m_comm;             // communication port
30620d338fad87eba91de65aa9bec76e01c04472848Greg Clayton    std::string     m_arch;
30724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    nub_thread_t    m_continue_thread;  // thread to continue; 0 for any, -1 for all
30824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    nub_thread_t    m_thread;           // thread for other ops; 0 for any, -1 for all
30924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    PThreadMutex    m_mutex;            // Mutex that protects
31024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    uint32_t        m_packets_recvd;
31124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    Packet::collection m_packets;
31224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    std::deque<std::string> m_rx_packets;
31324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    std::string     m_rx_partial_data;  // For packets that may come in more than one batch, anything left over can be left here
31424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    pthread_t       m_rx_pthread;
31524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner    uint32_t        m_max_payload_size;  // the maximum sized payload we should send to gdb
316a1f645e66c8e52ef287b9ab42f521eb57bcf217dGreg Clayton    bool            m_extended_mode;   // are we in extended mode?
317a1f645e66c8e52ef287b9ab42f521eb57bcf217dGreg Clayton    bool            m_noack_mode;      // are we in no-ack mode?
318a1f645e66c8e52ef287b9ab42f521eb57bcf217dGreg Clayton    bool            m_use_native_regs; // Use native registers by querying DNB layer for register definitions?
319a1f645e66c8e52ef287b9ab42f521eb57bcf217dGreg Clayton    bool            m_thread_suffix_supported; // Set to true if the 'p', 'P', 'g', and 'G' packets should be prefixed with the thread ID and colon:
320c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton                                                                // "$pRR;thread:TTTT;" instead of "$pRR"
321c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton                                                                // "$PRR=VVVVVVVV;thread:TTTT;" instead of "$PRR=VVVVVVVV"
322c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton                                                                // "$g;thread:TTTT" instead of "$g"
323c71899ef308e6134d1b0ca5f30cbc64414855e1aGreg Clayton                                                                // "$GVVVVVVVVVVVVVV;thread:TTTT;#00 instead of "$GVVVVVVVVVVVVVV"
324a1f645e66c8e52ef287b9ab42f521eb57bcf217dGreg Clayton    bool            m_list_threads_in_stop_reply;
32524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner};
32624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
32724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner/* We translate the /usr/include/mach/exception_types.h exception types
32824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner   (e.g. EXC_BAD_ACCESS) to the fake BSD signal numbers that gdb uses
32924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner   in include/gdb/signals.h (e.g. TARGET_EXC_BAD_ACCESS).  These hard
33024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner   coded values for TARGET_EXC_BAD_ACCESS et al must match the gdb
33124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner   values in its include/gdb/signals.h.  */
33224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
33324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#define TARGET_EXC_BAD_ACCESS      0x91
33424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#define TARGET_EXC_BAD_INSTRUCTION 0x92
33524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#define TARGET_EXC_ARITHMETIC      0x93
33624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#define TARGET_EXC_EMULATION       0x94
33724943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#define TARGET_EXC_SOFTWARE        0x95
33824943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#define TARGET_EXC_BREAKPOINT      0x96
33924943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
34024943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner/* Generally speaking, you can't assume gdb can receive more than 399 bytes
34124943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner   at a time with a random gdb.  This bufsize constant is only specifying
34224943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner   how many bytes gdb can *receive* from debugserver -- it tells us nothing
34324943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner   about how many bytes gdb might try to send in a single packet.  */
34424943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#define DEFAULT_GDB_REMOTE_PROTOCOL_BUFSIZE 399
34524943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner
34624943d2ee8bfaa7cf5893e4709143924157a5c1eChris Lattner#endif // #ifndef __RNBRemote_h__
347