ts-7000
[Top] [All Lists]

[ts-7000] Re: pointer weirdness

To:
Subject: [ts-7000] Re: pointer weirdness
From: "Yan Seiner" <>
Date: Thu, 13 Sep 2007 18:02:14 -0000
--- In  Eddie Dawydiuk <> wrote:
>
> Hello,
> 
> >> If TS have found that a specific assembly instruction
> >> is required, then you may want to rename their PEEK
> >> and POKE as fpga_in_le16(), fpga_out_le16(), or 'be' if
> >> the processor is running in big-endian mode (I forget).
> >> At least then the code will look more standard than
> >> with PEEK and POKE scattered through-out.
> 
> The issue you are running into is that older ARM cores only had 
> strb/ldrb and str/ldr instructions. There was no strh/ldrh, as a result 
> gcc will emit two 8 bit reads/writes unless instructed otherwise. This 
> is why we provided the PEEK/POKE routines to abstract this away. If one 
> chooses to not use the PEEK/POKE routines they should pass gcc the 
> -mcpu=arm9 to ensure the strh/ldrh instructions are used. Below is an 
> example demonstrating the issue.
> 
> e.g.
> 
> :joff]#cat test.c
> #include <stdio.h>
> 
> int main(void) {
>          volatile char *foo = (char *)0x12345678;
>          volatile short *foos = (short *)0x12345678;
>          volatile int *fool = (int *)0x12345978;
> 
>          *foo = 0xaa;
>          *foos = 0xaaaa;
>          *fool = 0xaaaaaaaa;
> }
> :joff]#gcc test.c -S -o test.s
> :joff]#gcc test.c -S -o test_arm9.s -mcpu=arm9
> :joff]#diff -u test.s test_arm9.s
> --- test.s      Thu Sep 13 10:10:28 2007
> +++ test_arm9.s Thu Sep 13 10:10:44 2007
> @@ -20,11 +20,10 @@
>          mvn     r3, #85
>          strb    r3, [r2, #0]
>          ldr     r2, [fp, #-20]
> -       mov     r3, #170
> -       strb    r3, [r2, #0]
> -       strb    r3, [r2, #1]
> -       ldr     r2, [fp, #-24]
>          ldr     r3, .L2+8
> +       strh    r3, [r2, #0]    @ movhi
> +       ldr     r2, [fp, #-24]
> +       ldr     r3, .L2+12
>          str     r3, [r2, #0]
>          mov     r0, r3
>          ldmea   fp, {fp, sp, pc}
> 


HAH!

Thanks, Eddie.  That reflects exactly what I was seeing.  Now at least
I know what to do and how to go about cleaning it up.

:-)

--Yan



 
Yahoo! Groups Links

<*> To visit your group on the web, go to:
    http://groups.yahoo.com/group/ts-7000/

<*> Your email settings:
    Individual Email | Traditional

<*> To change settings online go to:
    http://groups.yahoo.com/group/ts-7000/join
    (Yahoo! ID required)

<*> To change settings via email:
     
    

<*> To unsubscribe from this group, send an email to:
    

<*> Your use of Yahoo! Groups is subject to:
    http://docs.yahoo.com/info/terms/
 

<Prev in Thread] Current Thread [Next in Thread>
Admin

Disclaimer: Neither Andrew Taylor nor the University of NSW School of Computer and Engineering take any responsibility for the contents of this archive. It is purely a compilation of material sent by many people to the birding-aus mailing list. It has not been checked for accuracy nor its content verified in any way. If you wish to get material removed from the archive or have other queries about the archive e-mail Andrew Taylor at this address: andrewt@cse.unsw.EDU.AU