| @ Tremolo library |
| @----------------------------------------------------------------------- |
| @ Copyright (C) 2002-2009, Xiph.org Foundation |
| @ Copyright (C) 2010, Robin Watts for Pinknoise Productions Ltd |
| @ All rights reserved. |
| |
| @ Redistribution and use in source and binary forms, with or without |
| @ modification, are permitted provided that the following conditions |
| @ are met: |
| |
| @ * Redistributions of source code must retain the above copyright |
| @ notice, this list of conditions and the following disclaimer. |
| @ * Redistributions in binary form must reproduce the above |
| @ copyright notice, this list of conditions and the following disclaimer |
| @ in the documentation and/or other materials provided with the |
| @ distribution. |
| @ * Neither the names of the Xiph.org Foundation nor Pinknoise |
| @ Productions Ltd nor the names of its contributors may be used to |
| @ endorse or promote products derived from this software without |
| @ specific prior written permission. |
| @ |
| @ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| @ "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| @ LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| @ A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| @ OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| @ SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| @ LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| @ DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| @ THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| @ (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| @ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| @ ---------------------------------------------------------------------- |
| |
| .text |
| |
| .global render_lineARM |
| |
| render_lineARM: |
| @ r0 = n |
| @ r1 = d |
| @ r2 = floor |
| @ r3 = base |
| @ <> = err |
| @ <> = adx |
| @ <> = ady |
| MOV r12,r13 |
| STMFD r13!,{r4-r6,r11,r14} |
| LDMFD r12,{r11,r12,r14} @ r11 = err |
| @ r12 = adx |
| @ r14 = ady |
| rl_loop: |
| LDR r4,[r1] @ r4 = *d |
| LDR r5,[r2],r3,LSL #2 @ r5 = *floor r2 = floor+base |
| SUBS r11,r11,r14 @ err -= ady |
| ADDLT r11,r11,r12 @ if (err < 0) err+=adx |
| SMULL r6, r5, r4, r5 @ (r6,r5) = *d * *floor |
| ADDLT r2, r2, #4 @ floor+=1 |
| MOVS r6, r6, LSR #15 |
| ADC r5, r6, r5, LSL #17 @ r5 = MULT31_SHIFT15 |
| STR r5,[r1],#4 |
| SUBS r0, r0, #1 |
| BGT rl_loop |
| |
| LDMFD r13!,{r4-r6,r11,PC} |
| |
| @ END |