> On Oct 13, 2016, at 10:52 AM, Ted Woodward via lldb-dev 
> <lldb-dev@lists.llvm.org> wrote:
> 
> TCPSocket::Connect has this line:
>             host_str = ::inet_ntoa (*(struct in_addr 
> *)*host_entry->h_addr_list);
>  
> host_entry->h_addr_list is a char**, while struct in_addr contains a 
> uint32_t. Casting like this (char * to uint_32t *) could cause a bus error on 
> systems that don’t allow non-aligned loads. I think we need to memcpy the 
> data into a struct in_addr variable.
>  
> Anyone have any thoughts on this?

You will have to memcpy into a local that will be correctly aligned before you 
play with it. Or you can use DataExtractor as it already does the right thing. 
We ran into similar issues with DWARF parsing on systems that don't allow 
non-aligned loads, so DataExtractor can extract data correctly no matter what 
the alignment.

Greg

_______________________________________________
lldb-dev mailing list
lldb-dev@lists.llvm.org
http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-dev

Reply via email to