Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc
Commits
995535ec
Commit
995535ec
authored
Nov 01, 2014
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
picture_pool: simplify and clean-up reserve pool
parent
2d314967
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
59 deletions
+28
-59
src/misc/picture_pool.c
src/misc/picture_pool.c
+28
-59
No files found.
src/misc/picture_pool.c
View file @
995535ec
...
@@ -45,13 +45,10 @@ struct picture_gc_sys_t {
...
@@ -45,13 +45,10 @@ struct picture_gc_sys_t {
};
};
struct
picture_pool_t
{
struct
picture_pool_t
{
/* */
picture_pool_t
*
master
;
int64_t
tick
;
int64_t
tick
;
/* */
/* */
unsigned
picture_count
;
unsigned
picture_count
;
picture_t
**
picture
;
picture_t
**
picture
;
bool
*
picture_reserved
;
int
(
*
pic_lock
)(
picture_t
*
);
int
(
*
pic_lock
)(
picture_t
*
);
void
(
*
pic_unlock
)(
picture_t
*
);
void
(
*
pic_unlock
)(
picture_t
*
);
...
@@ -72,7 +69,6 @@ static void Release(picture_pool_t *pool)
...
@@ -72,7 +69,6 @@ static void Release(picture_pool_t *pool)
return
;
return
;
vlc_mutex_destroy
(
&
pool
->
lock
);
vlc_mutex_destroy
(
&
pool
->
lock
);
free
(
pool
->
picture_reserved
);
free
(
pool
->
picture
);
free
(
pool
->
picture
);
free
(
pool
);
free
(
pool
);
}
}
...
@@ -128,20 +124,17 @@ static picture_t *picture_pool_ClonePicture(picture_pool_t *pool,
...
@@ -128,20 +124,17 @@ static picture_t *picture_pool_ClonePicture(picture_pool_t *pool,
return
clone
;
return
clone
;
}
}
static
picture_pool_t
*
Create
(
picture_pool_t
*
master
,
int
picture_count
)
static
picture_pool_t
*
Create
(
int
picture_count
)
{
{
picture_pool_t
*
pool
=
calloc
(
1
,
sizeof
(
*
pool
));
picture_pool_t
*
pool
=
calloc
(
1
,
sizeof
(
*
pool
));
if
(
!
pool
)
if
(
!
pool
)
return
NULL
;
return
NULL
;
pool
->
master
=
master
;
pool
->
tick
=
1
;
pool
->
tick
=
master
?
master
->
tick
:
1
;
pool
->
picture_count
=
picture_count
;
pool
->
picture_count
=
picture_count
;
pool
->
picture
=
calloc
(
pool
->
picture_count
,
sizeof
(
*
pool
->
picture
));
pool
->
picture
=
calloc
(
pool
->
picture_count
,
sizeof
(
*
pool
->
picture
));
pool
->
picture_reserved
=
calloc
(
pool
->
picture_count
,
sizeof
(
*
pool
->
picture_reserved
));
if
(
!
pool
->
picture
)
{
if
(
!
pool
->
picture
||
!
pool
->
picture_reserved
)
{
free
(
pool
->
picture
);
free
(
pool
->
picture
);
free
(
pool
->
picture_reserved
);
free
(
pool
);
free
(
pool
);
return
NULL
;
return
NULL
;
}
}
...
@@ -152,7 +145,7 @@ static picture_pool_t *Create(picture_pool_t *master, int picture_count)
...
@@ -152,7 +145,7 @@ static picture_pool_t *Create(picture_pool_t *master, int picture_count)
picture_pool_t
*
picture_pool_NewExtended
(
const
picture_pool_configuration_t
*
cfg
)
picture_pool_t
*
picture_pool_NewExtended
(
const
picture_pool_configuration_t
*
cfg
)
{
{
picture_pool_t
*
pool
=
Create
(
NULL
,
cfg
->
picture_count
);
picture_pool_t
*
pool
=
Create
(
cfg
->
picture_count
);
if
(
!
pool
)
if
(
!
pool
)
return
NULL
;
return
NULL
;
...
@@ -167,7 +160,6 @@ picture_pool_t *picture_pool_NewExtended(const picture_pool_configuration_t *cfg
...
@@ -167,7 +160,6 @@ picture_pool_t *picture_pool_NewExtended(const picture_pool_configuration_t *cfg
atomic_init
(
&
picture
->
gc
.
refcount
,
0
);
atomic_init
(
&
picture
->
gc
.
refcount
,
0
);
pool
->
picture
[
i
]
=
picture
;
pool
->
picture
[
i
]
=
picture
;
pool
->
picture_reserved
[
i
]
=
false
;
pool
->
refs
++
;
pool
->
refs
++
;
}
}
return
pool
;
return
pool
;
...
@@ -211,65 +203,48 @@ error:
...
@@ -211,65 +203,48 @@ error:
picture_pool_t
*
picture_pool_Reserve
(
picture_pool_t
*
master
,
unsigned
count
)
picture_pool_t
*
picture_pool_Reserve
(
picture_pool_t
*
master
,
unsigned
count
)
{
{
picture_pool_t
*
pool
=
Create
(
master
,
count
);
picture_t
*
picture
[
count
?
count
:
1
];
unsigned
i
;
for
(
i
=
0
;
i
<
count
;
i
++
)
{
picture
[
i
]
=
picture_pool_Get
(
master
);
if
(
picture
[
i
]
==
NULL
)
goto
error
;
}
picture_pool_t
*
pool
=
picture_pool_New
(
count
,
picture
);
if
(
!
pool
)
if
(
!
pool
)
return
NULL
;
goto
error
;
pool
->
pic_lock
=
master
->
pic_lock
;
pool
->
pic_lock
=
master
->
pic_lock
;
pool
->
pic_unlock
=
master
->
pic_unlock
;
pool
->
pic_unlock
=
master
->
pic_unlock
;
return
pool
;
unsigned
found
=
0
;
error:
for
(
unsigned
i
=
0
;
i
<
master
->
picture_count
&&
found
<
count
;
i
++
)
{
while
(
i
>
0
)
if
(
master
->
picture_reserved
[
i
])
picture_Release
(
picture
[
--
i
]);
continue
;
assert
(
atomic_load
(
&
master
->
picture
[
i
]
->
gc
.
refcount
)
==
0
);
master
->
picture_reserved
[
i
]
=
true
;
pool
->
picture
[
found
]
=
master
->
picture
[
i
];
pool
->
picture_reserved
[
found
]
=
false
;
found
++
;
}
if
(
found
<
count
)
{
picture_pool_Delete
(
pool
);
return
NULL
;
return
NULL
;
}
return
pool
;
}
}
void
picture_pool_Delete
(
picture_pool_t
*
pool
)
void
picture_pool_Delete
(
picture_pool_t
*
pool
)
{
{
for
(
unsigned
i
=
0
;
i
<
pool
->
picture_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
pool
->
picture_count
;
i
++
)
{
picture_t
*
picture
=
pool
->
picture
[
i
];
picture_t
*
picture
=
pool
->
picture
[
i
];
if
(
pool
->
master
)
{
for
(
unsigned
j
=
0
;
j
<
pool
->
master
->
picture_count
;
j
++
)
{
if
(
pool
->
master
->
picture
[
j
]
==
picture
)
pool
->
master
->
picture_reserved
[
j
]
=
false
;
}
}
else
{
picture_gc_sys_t
*
gc_sys
=
picture
->
gc
.
p_sys
;
assert
(
!
pool
->
picture_reserved
[
i
]);
/* Restore the initial reference that was cloberred in
/* Restore the initial reference that was cloberred in
* picture_pool_NewExtended(). */
* picture_pool_NewExtended(). */
atomic_fetch_add
(
&
picture
->
gc
.
refcount
,
1
);
atomic_fetch_add
(
&
picture
->
gc
.
refcount
,
1
);
/* The picture might still locked and then the G.C. state cannot be
/* The picture might still locked and then the G.C. state cannot be
* modified (w/o memory synchronization). */
* modified (w/o memory synchronization). */
atomic_store
(
&
gc_sys
->
zombie
,
true
);
atomic_store
(
&
picture
->
gc
.
p_sys
->
zombie
,
true
);
picture_Release
(
picture
);
picture_Release
(
picture
);
}
}
}
Release
(
pool
);
Release
(
pool
);
}
}
picture_t
*
picture_pool_Get
(
picture_pool_t
*
pool
)
picture_t
*
picture_pool_Get
(
picture_pool_t
*
pool
)
{
{
for
(
unsigned
i
=
0
;
i
<
pool
->
picture_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
pool
->
picture_count
;
i
++
)
{
if
(
pool
->
picture_reserved
[
i
])
continue
;
picture_t
*
picture
=
pool
->
picture
[
i
];
picture_t
*
picture
=
pool
->
picture
[
i
];
uintptr_t
refs
=
0
;
uintptr_t
refs
=
0
;
...
@@ -292,9 +267,6 @@ picture_t *picture_pool_Get(picture_pool_t *pool)
...
@@ -292,9 +267,6 @@ picture_t *picture_pool_Get(picture_pool_t *pool)
void
picture_pool_Reset
(
picture_pool_t
*
pool
)
void
picture_pool_Reset
(
picture_pool_t
*
pool
)
{
{
for
(
unsigned
i
=
0
;
i
<
pool
->
picture_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
pool
->
picture_count
;
i
++
)
{
if
(
pool
->
picture_reserved
[
i
])
continue
;
picture_t
*
picture
=
pool
->
picture
[
i
];
picture_t
*
picture
=
pool
->
picture
[
i
];
if
(
atomic_load
(
&
picture
->
gc
.
refcount
)
>
0
)
{
if
(
atomic_load
(
&
picture
->
gc
.
refcount
)
>
0
)
{
if
(
pool
->
pic_unlock
!=
NULL
)
if
(
pool
->
pic_unlock
!=
NULL
)
...
@@ -309,9 +281,6 @@ void picture_pool_NonEmpty(picture_pool_t *pool)
...
@@ -309,9 +281,6 @@ void picture_pool_NonEmpty(picture_pool_t *pool)
picture_t
*
oldest
=
NULL
;
picture_t
*
oldest
=
NULL
;
for
(
unsigned
i
=
0
;
i
<
pool
->
picture_count
;
i
++
)
{
for
(
unsigned
i
=
0
;
i
<
pool
->
picture_count
;
i
++
)
{
if
(
pool
->
picture_reserved
[
i
])
continue
;
picture_t
*
picture
=
pool
->
picture
[
i
];
picture_t
*
picture
=
pool
->
picture
[
i
];
if
(
atomic_load
(
&
picture
->
gc
.
refcount
)
==
0
)
if
(
atomic_load
(
&
picture
->
gc
.
refcount
)
==
0
)
return
;
/* Nothing to do */
return
;
/* Nothing to do */
...
...
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