Mercurial > libavcodec.hg
annotate ppc/mathops.h @ 9863:ff0ea87dd64e libavcodec
VC-1/WMV: Remove redundant ff_init_block_index() calls.
These are only supposed to be called once per row, not once per macroblock.
~1.5% faster according to oprofile.
| author | darkshikari |
|---|---|
| date | Wed, 17 Jun 2009 05:54:42 +0000 |
| parents | d762f9979193 |
| children | 5bf12cdf0cb6 |
| rev | line source |
|---|---|
| 3733 | 1 /* |
| 2 * simple math operations | |
|
8629
04423b2f6e0b
cosmetics: Remove pointless period after copyright statement non-sentences.
diego
parents:
8590
diff
changeset
|
3 * Copyright (c) 2001, 2002 Fabrice Bellard |
| 3733 | 4 * Copyright (c) 2006 Michael Niedermayer <michaelni@gmx.at> et al |
| 5 * | |
|
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3733
diff
changeset
|
6 * This file is part of FFmpeg. |
|
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3733
diff
changeset
|
7 * |
|
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3733
diff
changeset
|
8 * FFmpeg is free software; you can redistribute it and/or |
| 3733 | 9 * modify it under the terms of the GNU Lesser General Public |
| 10 * License as published by the Free Software Foundation; either | |
|
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3733
diff
changeset
|
11 * version 2.1 of the License, or (at your option) any later version. |
| 3733 | 12 * |
|
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3733
diff
changeset
|
13 * FFmpeg is distributed in the hope that it will be useful, |
| 3733 | 14 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
| 16 * Lesser General Public License for more details. | |
| 17 * | |
| 18 * You should have received a copy of the GNU Lesser General Public | |
|
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3733
diff
changeset
|
19 * License along with FFmpeg; if not, write to the Free Software |
| 3733 | 20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
| 21 */ | |
| 22 | |
| 7760 | 23 #ifndef AVCODEC_PPC_MATHOPS_H |
| 24 #define AVCODEC_PPC_MATHOPS_H | |
| 5163 | 25 |
|
8662
31bdc2da2e80
Add required headers to fix warnings during 'make checkheaders'.
diego
parents:
8655
diff
changeset
|
26 #include "config.h" |
|
31bdc2da2e80
Add required headers to fix warnings during 'make checkheaders'.
diego
parents:
8655
diff
changeset
|
27 |
|
8655
14ccee231565
Add a check for ppc4xx instructions; rename preprocessor directive accordingly.
diego
parents:
8629
diff
changeset
|
28 #if HAVE_PPC4XX |
| 3733 | 29 /* signed 16x16 -> 32 multiply add accumulate */ |
|
7333
a8a79f5385f6
cosmetics: Reformat PPC code in libavcodec according to style guidelines.
diego
parents:
6501
diff
changeset
|
30 #define MAC16(rt, ra, rb) \ |
| 8031 | 31 __asm__ ("maclhw %0, %2, %3" : "=r" (rt) : "0" (rt), "r" (ra), "r" (rb)); |
| 3733 | 32 |
| 33 /* signed 16x16 -> 32 multiply */ | |
|
7333
a8a79f5385f6
cosmetics: Reformat PPC code in libavcodec according to style guidelines.
diego
parents:
6501
diff
changeset
|
34 #define MUL16(ra, rb) \ |
|
a8a79f5385f6
cosmetics: Reformat PPC code in libavcodec according to style guidelines.
diego
parents:
6501
diff
changeset
|
35 ({ int __rt; \ |
| 8031 | 36 __asm__ ("mullhw %0, %1, %2" : "=r" (__rt) : "r" (ra), "r" (rb)); \ |
|
7333
a8a79f5385f6
cosmetics: Reformat PPC code in libavcodec according to style guidelines.
diego
parents:
6501
diff
changeset
|
37 __rt; }) |
| 3733 | 38 #endif |
| 5163 | 39 |
| 9596 | 40 #define MULH MULH |
| 41 static inline av_const int MULH(int a, int b){ | |
| 42 int r; | |
| 43 __asm__ ("mulhw %0, %1, %2" : "=r"(r) : "r"(a), "r"(b)); | |
| 44 return r; | |
| 45 } | |
| 46 | |
| 9713 | 47 #if !ARCH_PPC64 |
| 9625 | 48 static inline av_const int64_t MAC64(int64_t d, int a, int b) |
| 49 { | |
| 50 union { uint64_t x; unsigned hl[2]; } x = { d }; | |
| 51 int h, l; | |
| 52 __asm__ ("mullw %3, %4, %5 \n\t" | |
| 53 "mulhw %2, %4, %5 \n\t" | |
| 54 "addc %1, %1, %3 \n\t" | |
| 55 "adde %0, %0, %2 \n\t" | |
| 56 : "+r"(x.hl[0]), "+r"(x.hl[1]), "=&r"(h), "=&r"(l) | |
| 57 : "r"(a), "r"(b)); | |
| 58 return x.x; | |
| 59 } | |
| 60 #define MAC64(d, a, b) ((d) = MAC64(d, a, b)) | |
| 61 | |
| 62 static inline av_const int64_t MLS64(int64_t d, int a, int b) | |
| 63 { | |
| 64 union { uint64_t x; unsigned hl[2]; } x = { d }; | |
| 65 int h, l; | |
| 66 __asm__ ("mullw %3, %4, %5 \n\t" | |
| 67 "mulhw %2, %4, %5 \n\t" | |
| 68 "subfc %1, %3, %1 \n\t" | |
| 69 "subfe %0, %2, %0 \n\t" | |
| 70 : "+r"(x.hl[0]), "+r"(x.hl[1]), "=&r"(h), "=&r"(l) | |
| 71 : "r"(a), "r"(b)); | |
| 72 return x.x; | |
| 73 } | |
| 74 #define MLS64(d, a, b) ((d) = MLS64(d, a, b)) | |
| 75 #endif | |
| 76 | |
| 7760 | 77 #endif /* AVCODEC_PPC_MATHOPS_H */ |
