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
df7cd417
Commit
df7cd417
authored
Jun 04, 2016
by
Martin Vignali
Committed by
Paul B Mahol
Jun 06, 2016
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
avcodec/exr: move channel_line_size to thread data
In order to be used by b44 uncompress.
parent
03152e74
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
10 additions
and
9 deletions
+10
-9
exr.c
libavcodec/exr.c
+10
-9
No files found.
libavcodec/exr.c
View file @
df7cd417
...
@@ -105,6 +105,8 @@ typedef struct EXRThreadData {
...
@@ -105,6 +105,8 @@ typedef struct EXRThreadData {
uint16_t
*
lut
;
uint16_t
*
lut
;
int
ysize
,
xsize
;
int
ysize
,
xsize
;
int
channel_line_size
;
}
EXRThreadData
;
}
EXRThreadData
;
typedef
struct
EXRContext
{
typedef
struct
EXRContext
{
...
@@ -992,7 +994,6 @@ static int decode_block(AVCodecContext *avctx, void *tdata,
...
@@ -992,7 +994,6 @@ static int decode_block(AVCodecContext *avctx, void *tdata,
uint8_t
*
ptr
;
uint8_t
*
ptr
;
uint32_t
data_size
,
line
,
col
=
0
;
uint32_t
data_size
,
line
,
col
=
0
;
uint32_t
tileX
,
tileY
,
tileLevelX
,
tileLevelY
;
uint32_t
tileX
,
tileY
,
tileLevelX
,
tileLevelY
;
int
channel_line_size
;
const
uint8_t
*
src
;
const
uint8_t
*
src
;
int
axmax
=
(
avctx
->
width
-
(
s
->
xmax
+
1
))
*
2
*
s
->
desc
->
nb_components
;
/* nb pixel to add at the right of the datawindow */
int
axmax
=
(
avctx
->
width
-
(
s
->
xmax
+
1
))
*
2
*
s
->
desc
->
nb_components
;
/* nb pixel to add at the right of the datawindow */
int
bxmin
=
s
->
xmin
*
2
*
s
->
desc
->
nb_components
;
/* nb pixel to add at the left of the datawindow */
int
bxmin
=
s
->
xmin
*
2
*
s
->
desc
->
nb_components
;
/* nb pixel to add at the left of the datawindow */
...
@@ -1036,8 +1037,8 @@ static int decode_block(AVCodecContext *avctx, void *tdata,
...
@@ -1036,8 +1037,8 @@ static int decode_block(AVCodecContext *avctx, void *tdata,
if
((
col
+
td
->
xsize
)
!=
s
->
xdelta
)
/* not the last tile of the line */
if
((
col
+
td
->
xsize
)
!=
s
->
xdelta
)
/* not the last tile of the line */
axmax
=
0
;
/* doesn't add pixel at the right of the datawindow */
axmax
=
0
;
/* doesn't add pixel at the right of the datawindow */
channel_line_size
=
td
->
xsize
*
s
->
current_channel_offset
;
/* uncompress size of one line */
td
->
channel_line_size
=
td
->
xsize
*
s
->
current_channel_offset
;
/* uncompress size of one line */
uncompressed_size
=
channel_line_size
*
(
uint64_t
)
td
->
ysize
;
/* uncompress size of the block */
uncompressed_size
=
td
->
channel_line_size
*
(
uint64_t
)
td
->
ysize
;
/* uncompress size of the block */
}
else
{
}
else
{
if
(
line_offset
>
buf_size
-
8
)
if
(
line_offset
>
buf_size
-
8
)
return
AVERROR_INVALIDDATA
;
return
AVERROR_INVALIDDATA
;
...
@@ -1055,8 +1056,8 @@ static int decode_block(AVCodecContext *avctx, void *tdata,
...
@@ -1055,8 +1056,8 @@ static int decode_block(AVCodecContext *avctx, void *tdata,
td
->
ysize
=
FFMIN
(
s
->
scan_lines_per_block
,
s
->
ymax
-
line
+
1
);
/* s->ydelta - line ?? */
td
->
ysize
=
FFMIN
(
s
->
scan_lines_per_block
,
s
->
ymax
-
line
+
1
);
/* s->ydelta - line ?? */
td
->
xsize
=
s
->
xdelta
;
td
->
xsize
=
s
->
xdelta
;
channel_line_size
=
td
->
xsize
*
s
->
current_channel_offset
;
/* uncompress size of one line */
td
->
channel_line_size
=
td
->
xsize
*
s
->
current_channel_offset
;
/* uncompress size of one line */
uncompressed_size
=
channel_line_size
*
(
uint64_t
)
td
->
ysize
;
/* uncompress size of the block */
uncompressed_size
=
td
->
channel_line_size
*
(
uint64_t
)
td
->
ysize
;
/* uncompress size of the block */
if
((
s
->
compression
==
EXR_RAW
&&
(
data_size
!=
uncompressed_size
||
if
((
s
->
compression
==
EXR_RAW
&&
(
data_size
!=
uncompressed_size
||
line_offset
>
buf_size
-
uncompressed_size
))
||
line_offset
>
buf_size
-
uncompressed_size
))
||
...
@@ -1185,11 +1186,11 @@ static int decode_block(AVCodecContext *avctx, void *tdata,
...
@@ -1185,11 +1186,11 @@ static int decode_block(AVCodecContext *avctx, void *tdata,
// Zero out the end if xmax+1 is not w
// Zero out the end if xmax+1 is not w
memset
(
ptr_x
,
0
,
axmax
);
memset
(
ptr_x
,
0
,
axmax
);
channel_buffer
[
0
]
+=
channel_line_size
;
channel_buffer
[
0
]
+=
td
->
channel_line_size
;
channel_buffer
[
1
]
+=
channel_line_size
;
channel_buffer
[
1
]
+=
td
->
channel_line_size
;
channel_buffer
[
2
]
+=
channel_line_size
;
channel_buffer
[
2
]
+=
td
->
channel_line_size
;
if
(
channel_buffer
[
3
])
if
(
channel_buffer
[
3
])
channel_buffer
[
3
]
+=
channel_line_size
;
channel_buffer
[
3
]
+=
td
->
channel_line_size
;
}
}
return
0
;
return
0
;
...
...
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