FS#8961 - Anti-Aliased Fonts.
[kugel-rb/myfork.git] / apps / codecs / libmad / imdct_mcf5249.S
blobd6d4460986db223847b05c29056affd5fe8b71b8
1 /***************************************************************************
2  *             __________               __   ___.
3  *   Open      \______   \ ____   ____ |  | _\_ |__   _______  ___
4  *   Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  /
5  *   Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  <
6  *   Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \
7  *                     \/            \/     \/    \/            \/
8  * $Id$
9  *
10  * Copyright (C) 2005 by Thom Johansen
11  *
12  * This program is free software; you can redistribute it and/or
13  * modify it under the terms of the GNU General Public License
14  * as published by the Free Software Foundation; either version 2
15  * of the License, or (at your option) any later version.
16  *
17  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
18  * KIND, either express or implied.
19  *
20  ****************************************************************************/
21 /* this will also be the home to III_imdct_l in the future */
23     .global III_imdct_s
24 III_imdct_s:
25     /* we need to save 9 registers and 36 samples of temp buffer */
26     lea.l (-45*4, %sp), %sp
27     movem.l %d2-%d7/%a2-%a4, (36*4, %sp)
28     move.l (45*4 + 4, %sp), %a2  /* a2 = X */
29     move.l %sp, %a3
30   
31     /* IMDCT */
33     /* if additional precision is needed in this block, it is possible to
34      * get more low bits out of the accext01 register _before_ doing the
35      * movclrs.
36      */
37     sub.l %a0, %a0                      /* clear loop variable */
38 .imdctloop:                             /* outer loop label */
39     lea.l imdct_s, %a1                  /* load pointer to imdct coefs in a1 */
40     movem.l (%a2), %d0-%d5              /* load some input data in d0-d5 */
41     lea.l (6*4, %a2), %a2
43     clr.l %d7                           /* clear loop variable */
44     move.l (%a1)+, %a4                  /* load imdct coef in a4 */
45 .macloop:                               /* inner loop label */
46     mac.l %d0, %a4, (%a1)+, %a4, %acc0  /* mac sequence */
47     mac.l %d1, %a4, (%a1)+, %a4, %acc0
48     mac.l %d2, %a4, (%a1)+, %a4, %acc0
49     mac.l %d3, %a4, (%a1)+, %a4, %acc0
50     mac.l %d4, %a4, (%a1)+, %a4, %acc0
51     mac.l %d5, %a4, (%a1)+, %a4, %acc0
52     movclr.l %acc0, %d6                 /* get result, left shifted once */
53     asl.l #3, %d6                       /* one shift free, shift three more */
54     move.l %d6, (%a3, %d7.l*4)          /* yptr[i] = result */
55     neg.l %d6
56     neg.l %d7
57     move.l %d6, (5*4, %a3, %d7.l*4)     /* yptr[5 - i] = -result */
58     mac.l %d0, %a4, (%a1)+, %a4, %acc0  /* mac sequence */
59     mac.l %d1, %a4, (%a1)+, %a4, %acc0
60     mac.l %d2, %a4, (%a1)+, %a4, %acc0
61     mac.l %d3, %a4, (%a1)+, %a4, %acc0
62     mac.l %d4, %a4, (%a1)+, %a4, %acc0
63     mac.l %d5, %a4, (%a1)+, %a4, %acc0
64     movclr.l %acc0, %d6                 /* get result */
65     asl.l #3, %d6
66     move.l %d6, (11*4, %a3, %d7.l*4)    /* yptr[11 - i] = result */
67     neg.l %d7
68     move.l %d6, (6*4, %a3, %d7.l*4)     /* yptr[i + 6] = result */
69     addq.l #1, %d7                      /* increment inner loop variable */
70     moveq.l #3, %d6
71     cmp.l %d6, %d7                      /* we do three inner loop iterations */
72     jne .macloop
74     lea.l (12*4, %a3), %a3              /* add pointer increment */
75     addq.l #1, %a0                      /* increment outer loop variable */
76     moveq.l #3, %d0
77     cmp.l %d0, %a0                      /* we do three outer loop iterations */
78     jne .imdctloop
80     /* windowing, overlapping and concatenation */
82     move.l (45*4 + 8, %sp), %a2       /* a2 = z */
83     move.l %sp, %a3                   /* a3 = tmp buffer ptr */
84     lea.l window_s, %a4               /* a4 = window coef pointer */
86     moveq.l #6, %d7                   /* six iterations */
87 .overlaploop:
88     clr.l (%a2)                       /* z[i + 0] = 0 */
89     move.l (%a4), %d0
90     move.l (%a3), %d2
91     mac.l %d0, %d2, (6*4, %a4), %d1, %acc0
92     move.l (6*4, %a3), %d2
93     movclr.l %acc0, %d6
94     asl.l #3, %d6
95     move.l %d6, (6*4, %a2)            /* z[i + 6] = result */
97     mac.l %d1, %d2, (12*4, %a3), %d2, %acc0
98     mac.l %d0, %d2, (18*4, %a3), %d2, %acc0
99     movclr.l %acc0, %d6
100     asl.l #3, %d6
101     move.l %d6, (12*4, %a2)           /* z[i + 12] = result */
103     mac.l %d1, %d2, (24*4, %a3), %d2, %acc0
104     mac.l %d0, %d2, (30*4, %a3), %d2, %acc0
105     movclr.l %acc0, %d6
106     asl.l #3, %d6
107     move.l %d6, (18*4, %a2)           /* z[i + 18] = result */
109     mac.l %d1, %d2, %acc0
110     movclr.l %acc0, %d6
111     asl.l #3, %d6
112     move.l %d6, (24*4, %a2)           /* z[i + 24] = result */
114     clr.l (30*4, %a2)                 /* z[i + 30] = 0 */
115     addq.l #4, %a2                    /* increment all pointers */
116     addq.l #4, %a3
117     addq.l #4, %a4
118     subq.l #1, %d7                    /* decrement loop counter */
119     jne .overlaploop
120     /* fall through to exit if we're done */
121     
122     /* clean up */
123     movem.l (36*4, %sp), %d2-%d7/%a2-%a4
124     lea.l (45*4, %sp), %sp
125     rts