memcpy limitation
    Olivier Houchard 
    mlfbsd at ci0.org
       
    Thu Jan 18 19:07:57 UTC 2007
    
    
  
On Thu, Jan 11, 2007 at 11:15:28AM +0100, Bernd Walter wrote:
> I get a sigbus with the following:
> #0  0x00033158 in $a () at lcp.c:939
> 939           memcpy(&req, opt, sizeof req);
> (gdb) print req
> $1 = {hdr = {id = 0 '\0', len = 0 '\0'}, proto = 0, period = 0}
> (gdb) print &req
> $2 = (struct lqrreq *) 0xbfffe4a0
> (gdb) print opt
> $3 = (struct fsm_opt *) 0xbfffe5b6
> 
> Shouldn't memcpy work with any alignment?
> 
It certainly does. Would you have a simple test case which reproduce this ?
Or does it happen as soon as you try to do an unaligned copy ?
I'm quite confused on why it would happen, memcpy is shared between the kernel
and the userland, and in kernel I'm sure it does unaligned copies. 
Thanks,
Olivier
    
    
More information about the freebsd-arm
mailing list