<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
span.EmailStyle17
        {mso-style-type:personal-compose;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal">I have a very simple lldb script:<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">thread select 1<o:p></o:p></p>
<p class="MsoNormal">disassemble --start-address $pc-24 --end-address $pc+24<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">When I run lldb with -o “process launch -s” and -s “dis.lldb”, I get odd output – the disassembly from “thread select 1” and from the disassemble command run together.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">This is what I see with top-of-tree on Ubuntu 16:<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">bin/lldb /bin/ls -o "process launch -s" -s dis.lldb <o:p></o:p></p>
<p class="MsoNormal">(lldb) target create "/bin/ls"<o:p></o:p></p>
<p class="MsoNormal">Current executable set to '/bin/ls' (x86_64).<o:p></o:p></p>
<p class="MsoNormal">(lldb) process launch -s<o:p></o:p></p>
<p class="MsoNormal">Process 32258 launched: '/bin/ls' (x86_64)<o:p></o:p></p>
<p class="MsoNormal">(lldb) command source -s 0 'dis.lldb'<o:p></o:p></p>
<p class="MsoNormal">Executing commands in '/local/mnt/ted/tip/full/dis.lldb'.<o:p></o:p></p>
<p class="MsoNormal">(lldb) thread select 1<o:p></o:p></p>
<p class="MsoNormal">(lldb) disassemble --start-address $pc-24 --end-address $pc+24<o:p></o:p></p>
<p class="MsoNormal">* thread #1, name = 'ls', stop reason = signal SIGSTOP<o:p></o:p></p>
<p class="MsoNormal">    frame #0: 0x00007ffff7dd7c30 ld-2.23.so`_start<o:p></o:p></p>
<p class="MsoNormal">ld-2.23.so`_start:<o:p></o:p></p>
<p class="MsoNormal">->  0x7ffff7dd7c30 <+0>: movq   %rsp, %rdi<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c33 <+3>: callq  0x7ffff7dd89b0            ; _dl_start at rtld.c:353<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">ld-2.23.so`_dl_start_user:<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c38 <+0>: movq   %rax, %r12<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c3b <+3>: movl   0x225037(%rip), %eax      ; _dl_skip_args<o:p></o:p></p>
<p class="MsoNormal">ld-2.23.so`oom:<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c18 <+13>: xorl   %eax, %eax<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c1a <+15>: callq  0x7ffff7de88f0            ; _dl_dprintf at dl-misc.c:275<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c1f <+20>: movl   $0x7f, %edi<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c24 <+25>: callq  0x7ffff7df24f0            ; __GI__exit at _exit.c:27<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c29:       nopl   (%rax)<o:p></o:p></p>
<p class="MsoNormal">ld-2.23.so`_start:<o:p></o:p></p>
<p class="MsoNormal">->  0x7ffff7dd7c30 <+0>:  movq   %rsp, %rdi<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c33 <+3>:  callq  0x7ffff7dd89b0            ; _dl_start at rtld.c:353<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">ld-2.23.so`_dl_start_user:<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c38 <+0>:  movq   %rax, %r12<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c3b <+3>:  movl   0x225037(%rip), %eax      ; _dl_skip_args<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c41 <+9>:  popq   %rdx<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c42 <+10>: leaq   (%rsp,%rax,8), %rsp<o:p></o:p></p>
<p class="MsoNormal">    0x7ffff7dd7c46 <+14>: subl   %eax, %edx<o:p></o:p></p>
<p class="MsoNormal">(lldb)<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Note that the address goes from c3b to c18 right after ld-2.23.so`oom.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">How can I separate the outputs of thread select and disassemble? If I stick in something like “register read pc” in between the thread select and the dis, I get the output from it before the output from the thread select and dis.<o:p></o:p></p>
</div>
</body>
</html>