<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;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
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’m seeing 2 issues with “target modules load”:<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Issue #1: load address is forgotten after a connect:<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>(lldb) file u:\lldb_test\dlopen<o:p></o:p></p><p class=MsoNormal>Current executable set to 'u:\lldb_test\dlopen' (hexagon).<o:p></o:p></p><p class=MsoNormal>(lldb) target modules load -f dlopen -s 0x20000<o:p></o:p></p><p class=MsoNormal>(lldb) b main<o:p></o:p></p><p class=MsoNormal>Breakpoint 1: where = dlopen`main + 24 at dlopen.c:26, address = 0x00030018<o:p></o:p></p><p class=MsoNormal>(lldb) gdb-remote tedwood-ubuntu:5556<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>But it’s set the breakpoint at 0x10018 instead of 0x30018:<o:p></o:p></p><p class=MsoNormal>ProcessGDBRemote::EnableBreakpointSite (size_id = 14) address = 0x10018<o:p></o:p></p><p class=MsoNormal><  14> send packet: $Z0,10018,4#10<o:p></o:p></p><p class=MsoNormal><   4> read packet: $#00<o:p></o:p></p><p class=MsoNormal>Software breakpoints are unsupported<o:p></o:p></p><p class=MsoNormal><  14> send packet: $Z1,10018,4#11<o:p></o:p></p><p class=MsoNormal><   6> read packet: $OK#9a<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>(lldb) br l<o:p></o:p></p><p class=MsoNormal>Current breakpoints:<o:p></o:p></p><p class=MsoNormal>1: name = 'main', locations = 1, resolved = 1, hit count = 0<o:p></o:p></p><p class=MsoNormal>  1.1: where = dlopen`main + 24 at dlopen.c:26, address = 0x00010018, resolved, hit count = 0<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Issue #2: breakpoints on the remote server aren’t updated with a new load address, even though they’re updated in the breakpoint list:<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>(lldb) br l<o:p></o:p></p><p class=MsoNormal>Current breakpoints:<o:p></o:p></p><p class=MsoNormal>1: name = 'main', locations = 1, resolved = 1, hit count = 0<o:p></o:p></p><p class=MsoNormal>  1.1: where = dlopen`main + 24 at dlopen.c:26, address = 0x00010018, resolved,<o:p></o:p></p><p class=MsoNormal>hit count = 0<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>(lldb) target modules load -f dlopen -s 0x20000<o:p></o:p></p><p class=MsoNormal>(lldb) br l<o:p></o:p></p><p class=MsoNormal><   7> send packet: $p29#db<o:p></o:p></p><p class=MsoNormal><  12> read packet: $00100000#81<o:p></o:p></p><p class=MsoNormal><   7> send packet: $p1d#05<o:p></o:p></p><p class=MsoNormal><  12> read packet: $00000000#80<o:p></o:p></p><p class=MsoNormal>Current breakpoints:<o:p></o:p></p><p class=MsoNormal>1: name = 'main', locations = 1, resolved = 1, hit count = 0<o:p></o:p></p><p class=MsoNormal>  1.1: where = dlopen`main + 24 at dlopen.c:26, address = 0x00030018, resolved,<o:p></o:p></p><p class=MsoNormal>hit count = 0<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>(lldb) c<o:p></o:p></p><p class=MsoNormal>Process 1 stopped<o:p></o:p></p><p class=MsoNormal>* thread #1: tid = 0x0001, 0x00030018 dlopen`main(argc=1, argv=0x00052348) + 24<o:p></o:p></p><p class=MsoNormal>at dlopen.c:26, stop reason = breakpoint 1.1<o:p></o:p></p><p class=MsoNormal>    frame #0: 0x00030018 dlopen`main(argc=1, argv=0x00052348) + 24 at dlopen.c:26<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>(lldb) re r pc<o:p></o:p></p><p class=MsoNormal>      pc = 0x00010018  dlopen`main + 24 at dlopen.c:26<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Note that lldb says it’s stopped at 0x30018, but it’s really stopped at 0x10018. It never sent a z packet to remove the breakpoint at 0x10018 or a Z packet to add one at 0x30018.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>--<o:p></o:p></p><p class=MsoNormal>Qualcomm Innovation Center, Inc.<o:p></o:p></p><p class=MsoNormal>The Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux Foundation Collaborative Project<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p></div></body></html>