diff options
author | Edwin Groothuis <edwin@FreeBSD.org> | 2007-09-08 12:09:40 +0000 |
---|---|---|
committer | Edwin Groothuis <edwin@FreeBSD.org> | 2007-09-08 12:09:40 +0000 |
commit | df643d44dba777ca9e8b492d510faea46628c317 (patch) | |
tree | 3edbf5ac3eb0899bca0a8fa8198ed5eda6f43169 /multimedia | |
parent | 26bc676b7f51e974296c5887b0c4763181e38332 (diff) |
[patch] multimedia/fxtv: unbreak on HEAD (gcc 4.2)
This patch unbreaks building this port on 7-CURRENT (with gcc 4.2)
PR: ports/116126
Submitted by: Simun Mikecin <numisemis@yahoo.com>
Notes
Notes:
svn path=/head/; revision=199101
Diffstat (limited to 'multimedia')
-rw-r--r-- | multimedia/fxtv/Makefile | 6 | ||||
-rw-r--r-- | multimedia/fxtv/files/patch-videolib_videolib.c | 38 |
2 files changed, 39 insertions, 5 deletions
diff --git a/multimedia/fxtv/Makefile b/multimedia/fxtv/Makefile index 6c4870f45911..e4f6abba39cd 100644 --- a/multimedia/fxtv/Makefile +++ b/multimedia/fxtv/Makefile @@ -7,7 +7,7 @@ PORTNAME= fxtv PORTVERSION= 1.03 -PORTREVISION= 5 +PORTREVISION= 6 CATEGORIES= multimedia MASTER_SITES= ${MASTER_SITE_LOCAL} MASTER_SITE_SUBDIR= rhh @@ -31,10 +31,6 @@ OPTIONS= EXTRA "Extra programs required to record/playback/save" off .include <bsd.port.pre.mk> -.if ${OSVERSION} >= 700042 -BROKEN= Broken with gcc 4.2 -.endif - # This program does not actually require the programs below unless you # use audio/video recording and/or playback and save to a non-raw format. .if defined(WITH_EXTRA) diff --git a/multimedia/fxtv/files/patch-videolib_videolib.c b/multimedia/fxtv/files/patch-videolib_videolib.c new file mode 100644 index 000000000000..4da6856d39c8 --- /dev/null +++ b/multimedia/fxtv/files/patch-videolib_videolib.c @@ -0,0 +1,38 @@ +--- videolib/videolib.c.orig 1999-11-03 03:22:04.000000000 +0100 ++++ videolib/videolib.c 2007-09-05 18:31:05.000000000 +0200 +@@ -479,9 +479,8 @@ + *(p++) = (*src16 >> 8) | (*src16 << 8); + src16++; + } +- for ( i = dst_line_pad; i > 0; i-- ) +- *(((VL_UINT8 *)p)++) = 0x00; +- (VL_UINT8 *)dst_line += dst->geom.bytes_per_line; ++ memset(p, 0, dst_line_pad); ++ dst_line += dst->geom.bytes_per_line / sizeof(VL_UINT16); + } + + src16 = dst_line = (VL_UINT16 *) dst->buf; +@@ -513,9 +512,9 @@ + if ( src_padded ) + src16 = (VL_UINT16 *)( (VL_UINT8 *)src16 + dst_line_pad ); + else +- for ( i = dst_line_pad; i > 0; i-- ) +- *(((VL_UINT8 *)dst)++) = 0x00; +- (VL_UINT8 *)dst_line += dst->geom.bytes_per_line; ++ memset(dst, 0, dst_line_pad); ++ dst += dst_line_pad / sizeof(VL_IMAGE); ++ dst_line += dst->geom.bytes_per_line / sizeof(VL_UINT16); + } + + if ( !dst_swap_b ) { /* More ugliness */ +@@ -527,8 +526,8 @@ + *(p++) = (*src16 >> 8) | (*src16 << 8); + src16++; + } +- (VL_UINT8 *)dst_line += dst->geom.bytes_per_line; +- (VL_UINT8 *)src16 += dst->geom.bytes_per_line; ++ dst_line += dst->geom.bytes_per_line / sizeof(VL_UINT16); ++ src16 += dst->geom.bytes_per_line / sizeof(VL_UINT16); + } + } + } |