[FFmpeg-cvslog] r23427 - in trunk/libavcodec/arm: asm-offsets.h mpegvideo_arm.c mpegvideo_neon.S

mru subversion
Wed Jun 2 20:49:53 CEST 2010


Author: mru
Date: Wed Jun  2 20:49:53 2010
New Revision: 23427

Log:
ARM: fail build if hardcoded struct offsets are wrong

Added:
   trunk/libavcodec/arm/asm-offsets.h
Modified:
   trunk/libavcodec/arm/mpegvideo_arm.c
   trunk/libavcodec/arm/mpegvideo_neon.S

Added: trunk/libavcodec/arm/asm-offsets.h
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ trunk/libavcodec/arm/asm-offsets.h	Wed Jun  2 20:49:53 2010	(r23427)
@@ -0,0 +1,39 @@
+/*
+ * Copyright (c) 2010 Mans Rullgard
+ *
+ * This file is part of FFmpeg.
+ *
+ * FFmpeg is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * FFmpeg is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with FFmpeg; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#ifndef AVCODEC_ARM_ASM_OFFSETS_H
+#define AVCODEC_ARM_ASM_OFFSETS_H
+
+#ifndef __ASSEMBLER__
+#include <stddef.h>
+#define CHK_OFFS(s, m, o) struct check_##o {    \
+        int x_##o[offsetof(s, m) == o? 1: -1];  \
+    }
+#endif
+
+/* MpegEncContext */
+#define Y_DC_SCALE               0xa54
+#define C_DC_SCALE               0xa58
+#define AC_PRED                  0xa80
+#define BLOCK_LAST_INDEX         0x2278
+#define INTER_SCANTAB_RASTER_END 0x2478
+#define H263_AIC                 0x2728
+
+#endif

Modified: trunk/libavcodec/arm/mpegvideo_arm.c
==============================================================================
--- trunk/libavcodec/arm/mpegvideo_arm.c	Wed Jun  2 18:09:19 2010	(r23426)
+++ trunk/libavcodec/arm/mpegvideo_arm.c	Wed Jun  2 20:49:53 2010	(r23427)
@@ -22,6 +22,14 @@
 #include "libavcodec/dsputil.h"
 #include "libavcodec/mpegvideo.h"
 #include "mpegvideo_arm.h"
+#include "asm-offsets.h"
+
+CHK_OFFS(MpegEncContext, y_dc_scale,       Y_DC_SCALE);
+CHK_OFFS(MpegEncContext, c_dc_scale,       C_DC_SCALE);
+CHK_OFFS(MpegEncContext, ac_pred,          AC_PRED);
+CHK_OFFS(MpegEncContext, block_last_index, BLOCK_LAST_INDEX);
+CHK_OFFS(MpegEncContext, inter_scantable.raster_end, INTER_SCANTAB_RASTER_END);
+CHK_OFFS(MpegEncContext, h263_aic,         H263_AIC);
 
 void ff_dct_unquantize_h263_inter_neon(MpegEncContext *s, DCTELEM *block,
                                        int n, int qscale);

Modified: trunk/libavcodec/arm/mpegvideo_neon.S
==============================================================================
--- trunk/libavcodec/arm/mpegvideo_neon.S	Wed Jun  2 18:09:19 2010	(r23426)
+++ trunk/libavcodec/arm/mpegvideo_neon.S	Wed Jun  2 20:49:53 2010	(r23427)
@@ -19,13 +19,7 @@
  */
 
 #include "asm.S"
-
-#define Y_DC_SCALE               0xa54
-#define C_DC_SCALE               0xa58
-#define AC_PRED                  0xa80
-#define BLOCK_LAST_INDEX         0x2278
-#define INTER_SCANTAB_RASTER_END 0x2478
-#define H263_AIC                 0x2728
+#include "asm-offsets.h"
 
 function ff_dct_unquantize_h263_inter_neon, export=1
         add             r0,  r0,  #0x2200



More information about the ffmpeg-cvslog mailing list