Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
0ea03dbb
Commit
0ea03dbb
authored
Aug 15, 2016
by
Paul B Mahol
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
avcodec/iff: remove palette swapping for anim
It appears it is wrong.
parent
ce5ba770
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
8 additions
and
12 deletions
+8
-12
iff.c
libavcodec/iff.c
+8
-12
No files found.
libavcodec/iff.c
View file @
0ea03dbb
...
@@ -65,7 +65,7 @@ typedef struct IffContext {
...
@@ -65,7 +65,7 @@ typedef struct IffContext {
GetByteContext
gb
;
GetByteContext
gb
;
uint8_t
*
video
[
2
];
uint8_t
*
video
[
2
];
unsigned
video_size
;
unsigned
video_size
;
uint32_t
*
pal
[
2
]
;
uint32_t
*
pal
;
}
IffContext
;
}
IffContext
;
#define LUT8_PART(plane, v) \
#define LUT8_PART(plane, v) \
...
@@ -243,7 +243,7 @@ static int extract_header(AVCodecContext *const avctx,
...
@@ -243,7 +243,7 @@ static int extract_header(AVCodecContext *const avctx,
break
;
break
;
}
else
if
(
chunk_id
==
MKTAG
(
'C'
,
'M'
,
'A'
,
'P'
))
{
}
else
if
(
chunk_id
==
MKTAG
(
'C'
,
'M'
,
'A'
,
'P'
))
{
int
count
=
data_size
/
3
;
int
count
=
data_size
/
3
;
uint32_t
*
pal
=
s
->
pal
[
0
]
;
uint32_t
*
pal
=
s
->
pal
;
if
(
count
>
256
)
if
(
count
>
256
)
return
AVERROR_INVALIDDATA
;
return
AVERROR_INVALIDDATA
;
...
@@ -373,8 +373,7 @@ static av_cold int decode_end(AVCodecContext *avctx)
...
@@ -373,8 +373,7 @@ static av_cold int decode_end(AVCodecContext *avctx)
av_freep
(
&
s
->
ham_palbuf
);
av_freep
(
&
s
->
ham_palbuf
);
av_freep
(
&
s
->
video
[
0
]);
av_freep
(
&
s
->
video
[
0
]);
av_freep
(
&
s
->
video
[
1
]);
av_freep
(
&
s
->
video
[
1
]);
av_freep
(
&
s
->
pal
[
0
]);
av_freep
(
&
s
->
pal
);
av_freep
(
&
s
->
pal
[
1
]);
return
0
;
return
0
;
}
}
...
@@ -424,9 +423,8 @@ static av_cold int decode_init(AVCodecContext *avctx)
...
@@ -424,9 +423,8 @@ static av_cold int decode_init(AVCodecContext *avctx)
s
->
video_size
=
FFALIGN
(
avctx
->
width
,
2
)
*
avctx
->
height
*
s
->
bpp
;
s
->
video_size
=
FFALIGN
(
avctx
->
width
,
2
)
*
avctx
->
height
*
s
->
bpp
;
s
->
video
[
0
]
=
av_calloc
(
FFALIGN
(
avctx
->
width
,
2
)
*
avctx
->
height
,
s
->
bpp
);
s
->
video
[
0
]
=
av_calloc
(
FFALIGN
(
avctx
->
width
,
2
)
*
avctx
->
height
,
s
->
bpp
);
s
->
video
[
1
]
=
av_calloc
(
FFALIGN
(
avctx
->
width
,
2
)
*
avctx
->
height
,
s
->
bpp
);
s
->
video
[
1
]
=
av_calloc
(
FFALIGN
(
avctx
->
width
,
2
)
*
avctx
->
height
,
s
->
bpp
);
s
->
pal
[
0
]
=
av_calloc
(
256
,
sizeof
(
*
s
->
pal
[
0
]));
s
->
pal
=
av_calloc
(
256
,
sizeof
(
*
s
->
pal
));
s
->
pal
[
1
]
=
av_calloc
(
256
,
sizeof
(
*
s
->
pal
[
1
]));
if
(
!
s
->
video
[
0
]
||
!
s
->
video
[
1
]
||
!
s
->
pal
)
if
(
!
s
->
video
[
0
]
||
!
s
->
video
[
1
]
||
!
s
->
pal
[
0
]
||
!
s
->
pal
[
1
])
return
AVERROR
(
ENOMEM
);
return
AVERROR
(
ENOMEM
);
}
}
...
@@ -1457,7 +1455,7 @@ static int decode_frame(AVCodecContext *avctx,
...
@@ -1457,7 +1455,7 @@ static int decode_frame(AVCodecContext *avctx,
if
(
s
->
compression
<=
0xff
&&
(
avctx
->
codec_tag
==
MKTAG
(
'A'
,
'N'
,
'I'
,
'M'
)))
{
if
(
s
->
compression
<=
0xff
&&
(
avctx
->
codec_tag
==
MKTAG
(
'A'
,
'N'
,
'I'
,
'M'
)))
{
if
(
avctx
->
pix_fmt
==
AV_PIX_FMT_PAL8
)
if
(
avctx
->
pix_fmt
==
AV_PIX_FMT_PAL8
)
memcpy
(
s
->
pal
[
0
]
,
s
->
frame
->
data
[
1
],
256
*
4
);
memcpy
(
s
->
pal
,
s
->
frame
->
data
[
1
],
256
*
4
);
}
}
switch
(
s
->
compression
)
{
switch
(
s
->
compression
)
{
...
@@ -1689,7 +1687,6 @@ static int decode_frame(AVCodecContext *avctx,
...
@@ -1689,7 +1687,6 @@ static int decode_frame(AVCodecContext *avctx,
}
}
if
(
s
->
compression
<=
0xff
&&
(
avctx
->
codec_tag
==
MKTAG
(
'A'
,
'N'
,
'I'
,
'M'
)))
{
if
(
s
->
compression
<=
0xff
&&
(
avctx
->
codec_tag
==
MKTAG
(
'A'
,
'N'
,
'I'
,
'M'
)))
{
memcpy
(
s
->
pal
[
1
],
s
->
pal
[
0
],
256
*
4
);
memcpy
(
s
->
video
[
1
],
s
->
video
[
0
],
s
->
video_size
);
memcpy
(
s
->
video
[
1
],
s
->
video
[
0
],
s
->
video_size
);
}
}
...
@@ -1704,14 +1701,14 @@ static int decode_frame(AVCodecContext *avctx,
...
@@ -1704,14 +1701,14 @@ static int decode_frame(AVCodecContext *avctx,
buf
+=
s
->
planesize
;
buf
+=
s
->
planesize
;
}
}
}
}
memcpy
(
frame
->
data
[
1
],
s
->
pal
[
0
]
,
256
*
4
);
memcpy
(
frame
->
data
[
1
],
s
->
pal
,
256
*
4
);
}
else
if
(
s
->
ham
)
{
}
else
if
(
s
->
ham
)
{
int
i
,
count
=
1
<<
s
->
ham
;
int
i
,
count
=
1
<<
s
->
ham
;
buf
=
s
->
video
[
0
];
buf
=
s
->
video
[
0
];
memset
(
s
->
ham_palbuf
,
0
,
(
1
<<
s
->
ham
)
*
2
*
sizeof
(
uint32_t
));
memset
(
s
->
ham_palbuf
,
0
,
(
1
<<
s
->
ham
)
*
2
*
sizeof
(
uint32_t
));
for
(
i
=
0
;
i
<
count
;
i
++
)
{
for
(
i
=
0
;
i
<
count
;
i
++
)
{
s
->
ham_palbuf
[
i
*
2
+
1
]
=
s
->
pal
[
0
][
i
];
s
->
ham_palbuf
[
i
*
2
+
1
]
=
s
->
pal
[
i
];
}
}
for
(
i
=
0
;
i
<
count
;
i
++
)
{
for
(
i
=
0
;
i
<
count
;
i
++
)
{
uint32_t
tmp
=
i
<<
(
8
-
s
->
ham
);
uint32_t
tmp
=
i
<<
(
8
-
s
->
ham
);
...
@@ -1742,7 +1739,6 @@ static int decode_frame(AVCodecContext *avctx,
...
@@ -1742,7 +1739,6 @@ static int decode_frame(AVCodecContext *avctx,
if
(
!
s
->
is_brush
)
{
if
(
!
s
->
is_brush
)
{
FFSWAP
(
uint8_t
*
,
s
->
video
[
0
],
s
->
video
[
1
]);
FFSWAP
(
uint8_t
*
,
s
->
video
[
0
],
s
->
video
[
1
]);
FFSWAP
(
uint32_t
*
,
s
->
pal
[
0
],
s
->
pal
[
1
]);
}
}
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment