diff options
Diffstat (limited to 'lldb/source/Plugins/Process/Linux/NativeProcessLinux.cpp')
| -rw-r--r-- | lldb/source/Plugins/Process/Linux/NativeProcessLinux.cpp | 11 | 
1 files changed, 11 insertions, 0 deletions
| diff --git a/lldb/source/Plugins/Process/Linux/NativeProcessLinux.cpp b/lldb/source/Plugins/Process/Linux/NativeProcessLinux.cpp index ea0972c..15498ea 100644 --- a/lldb/source/Plugins/Process/Linux/NativeProcessLinux.cpp +++ b/lldb/source/Plugins/Process/Linux/NativeProcessLinux.cpp @@ -2247,6 +2247,7 @@ NativeProcessLinux::GetSoftwareBreakpointPCOffset(uint32_t &actual_opcode_size)      // FIXME put this behind a breakpoint protocol class that can be      // set per architecture.  Need ARM, MIPS support here.      static const uint8_t g_i386_opcode [] = { 0xCC }; +    static const uint8_t g_s390x_opcode[] = { 0x00, 0x01 };      switch (m_arch.GetMachine ())      { @@ -2255,6 +2256,10 @@ NativeProcessLinux::GetSoftwareBreakpointPCOffset(uint32_t &actual_opcode_size)              actual_opcode_size = static_cast<uint32_t> (sizeof(g_i386_opcode));              return Error (); +        case llvm::Triple::systemz: +            actual_opcode_size = static_cast<uint32_t> (sizeof(g_s390x_opcode)); +            return Error (); +          case llvm::Triple::arm:          case llvm::Triple::aarch64:          case llvm::Triple::mips64: @@ -2294,6 +2299,7 @@ NativeProcessLinux::GetSoftwareBreakpointTrapOpcode (size_t trap_opcode_size_hin      static const uint8_t g_i386_opcode [] = { 0xCC };      static const uint8_t g_mips64_opcode[] = { 0x00, 0x00, 0x00, 0x0d };      static const uint8_t g_mips64el_opcode[] = { 0x0d, 0x00, 0x00, 0x00 }; +    static const uint8_t g_s390x_opcode[] = { 0x00, 0x01 };      static const uint8_t g_thumb_breakpoint_opcode[] = { 0x01, 0xde };      switch (m_arch.GetMachine ()) @@ -2337,6 +2343,11 @@ NativeProcessLinux::GetSoftwareBreakpointTrapOpcode (size_t trap_opcode_size_hin          actual_opcode_size = sizeof(g_mips64el_opcode);          return Error (); +    case llvm::Triple::systemz: +        trap_opcode_bytes = g_s390x_opcode; +        actual_opcode_size = sizeof(g_s390x_opcode); +        return Error (); +      default:          assert(false && "CPU type not supported!");          return Error ("CPU type not supported"); | 
