annotate libavutil/arm/intreadwrite.h @ 9:ea1ba68cf0ed

update to match api changes + add sscc produced source
author Nina Engelhardt <nengel@mailbox.tu-berlin.de>
date Wed, 05 Jun 2013 14:43:26 +0200
parents
children
rev   line source
nengel@2 1 /*
nengel@2 2 * This file is part of FFmpeg.
nengel@2 3 *
nengel@2 4 * FFmpeg is free software; you can redistribute it and/or
nengel@2 5 * modify it under the terms of the GNU Lesser General Public
nengel@2 6 * License as published by the Free Software Foundation; either
nengel@2 7 * version 2.1 of the License, or (at your option) any later version.
nengel@2 8 *
nengel@2 9 * FFmpeg is distributed in the hope that it will be useful,
nengel@2 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
nengel@2 11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
nengel@2 12 * Lesser General Public License for more details.
nengel@2 13 *
nengel@2 14 * You should have received a copy of the GNU Lesser General Public
nengel@2 15 * License along with FFmpeg; if not, write to the Free Software
nengel@2 16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
nengel@2 17 */
nengel@2 18
nengel@2 19 #ifndef AVUTIL_ARM_INTREADWRITE_H
nengel@2 20 #define AVUTIL_ARM_INTREADWRITE_H
nengel@2 21
nengel@2 22 #include <stdint.h>
nengel@2 23 #include "config.h"
nengel@2 24
nengel@2 25 #if HAVE_FAST_UNALIGNED && HAVE_INLINE_ASM
nengel@2 26
nengel@2 27 #define AV_RN16 AV_RN16
nengel@2 28 static av_always_inline uint16_t AV_RN16(const void *p)
nengel@2 29 {
nengel@2 30 uint16_t v;
nengel@2 31 __asm__ ("ldrh %0, %1" : "=r"(v) : "m"(*(const uint16_t *)p));
nengel@2 32 return v;
nengel@2 33 }
nengel@2 34
nengel@2 35 #define AV_WN16 AV_WN16
nengel@2 36 static av_always_inline void AV_WN16(void *p, uint16_t v)
nengel@2 37 {
nengel@2 38 __asm__ ("strh %1, %0" : "=m"(*(uint16_t *)p) : "r"(v));
nengel@2 39 }
nengel@2 40
nengel@2 41 #define AV_RN32 AV_RN32
nengel@2 42 static av_always_inline uint32_t AV_RN32(const void *p)
nengel@2 43 {
nengel@2 44 uint32_t v;
nengel@2 45 __asm__ ("ldr %0, %1" : "=r"(v) : "m"(*(const uint32_t *)p));
nengel@2 46 return v;
nengel@2 47 }
nengel@2 48
nengel@2 49 #define AV_WN32 AV_WN32
nengel@2 50 static av_always_inline void AV_WN32(void *p, uint32_t v)
nengel@2 51 {
nengel@2 52 __asm__ ("str %1, %0" : "=m"(*(uint32_t *)p) : "r"(v));
nengel@2 53 }
nengel@2 54
nengel@2 55 #define AV_RN64 AV_RN64
nengel@2 56 static av_always_inline uint64_t AV_RN64(const void *p)
nengel@2 57 {
nengel@2 58 union { uint64_t v; uint32_t hl[2]; } v;
nengel@2 59 __asm__ ("ldr %0, %2 \n\t"
nengel@2 60 "ldr %1, %3 \n\t"
nengel@2 61 : "=&r"(v.hl[0]), "=r"(v.hl[1])
nengel@2 62 : "m"(*(const uint32_t*)p), "m"(*((const uint32_t*)p+1)));
nengel@2 63 return v.v;
nengel@2 64 }
nengel@2 65
nengel@2 66 #define AV_WN64 AV_WN64
nengel@2 67 static av_always_inline void AV_WN64(void *p, uint64_t v)
nengel@2 68 {
nengel@2 69 union { uint64_t v; uint32_t hl[2]; } vv = { v };
nengel@2 70 __asm__ ("str %2, %0 \n\t"
nengel@2 71 "str %3, %1 \n\t"
nengel@2 72 : "=m"(*(uint32_t*)p), "=m"(*((uint32_t*)p+1))
nengel@2 73 : "r"(vv.hl[0]), "r"(vv.hl[1]));
nengel@2 74 }
nengel@2 75
nengel@2 76 #endif /* HAVE_INLINE_ASM */
nengel@2 77
nengel@2 78 #endif /* AVUTIL_ARM_INTREADWRITE_H */