2022-10-29 04:45:44 +08:00
|
|
|
/**
|
|
|
|
* css_get - obtain a reference on the specified css
|
|
|
|
* @css: target css
|
|
|
|
*
|
|
|
|
* The caller must already have a reference.
|
|
|
|
*/
|
|
|
|
CGROUP_REF_FN_ATTRS
|
|
|
|
void css_get(struct cgroup_subsys_state *css)
|
|
|
|
{
|
|
|
|
if (!(css->flags & CSS_NO_REF))
|
|
|
|
percpu_ref_get(&css->refcnt);
|
|
|
|
}
|
2022-11-01 01:12:13 +08:00
|
|
|
CGROUP_REF_EXPORT(css_get)
|
2022-10-29 04:45:44 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* css_get_many - obtain references on the specified css
|
|
|
|
* @css: target css
|
|
|
|
* @n: number of references to get
|
|
|
|
*
|
|
|
|
* The caller must already have a reference.
|
|
|
|
*/
|
|
|
|
CGROUP_REF_FN_ATTRS
|
|
|
|
void css_get_many(struct cgroup_subsys_state *css, unsigned int n)
|
|
|
|
{
|
|
|
|
if (!(css->flags & CSS_NO_REF))
|
|
|
|
percpu_ref_get_many(&css->refcnt, n);
|
|
|
|
}
|
2022-11-01 01:12:13 +08:00
|
|
|
CGROUP_REF_EXPORT(css_get_many)
|
2022-10-29 04:45:44 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* css_tryget - try to obtain a reference on the specified css
|
|
|
|
* @css: target css
|
|
|
|
*
|
|
|
|
* Obtain a reference on @css unless it already has reached zero and is
|
|
|
|
* being released. This function doesn't care whether @css is on or
|
|
|
|
* offline. The caller naturally needs to ensure that @css is accessible
|
|
|
|
* but doesn't have to be holding a reference on it - IOW, RCU protected
|
|
|
|
* access is good enough for this function. Returns %true if a reference
|
|
|
|
* count was successfully obtained; %false otherwise.
|
|
|
|
*/
|
|
|
|
CGROUP_REF_FN_ATTRS
|
|
|
|
bool css_tryget(struct cgroup_subsys_state *css)
|
|
|
|
{
|
|
|
|
if (!(css->flags & CSS_NO_REF))
|
|
|
|
return percpu_ref_tryget(&css->refcnt);
|
|
|
|
return true;
|
|
|
|
}
|
2022-11-01 01:12:13 +08:00
|
|
|
CGROUP_REF_EXPORT(css_tryget)
|
2022-10-29 04:45:44 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* css_tryget_online - try to obtain a reference on the specified css if online
|
|
|
|
* @css: target css
|
|
|
|
*
|
|
|
|
* Obtain a reference on @css if it's online. The caller naturally needs
|
|
|
|
* to ensure that @css is accessible but doesn't have to be holding a
|
|
|
|
* reference on it - IOW, RCU protected access is good enough for this
|
|
|
|
* function. Returns %true if a reference count was successfully obtained;
|
|
|
|
* %false otherwise.
|
|
|
|
*/
|
|
|
|
CGROUP_REF_FN_ATTRS
|
|
|
|
bool css_tryget_online(struct cgroup_subsys_state *css)
|
|
|
|
{
|
|
|
|
if (!(css->flags & CSS_NO_REF))
|
|
|
|
return percpu_ref_tryget_live(&css->refcnt);
|
|
|
|
return true;
|
|
|
|
}
|
2022-11-01 01:12:13 +08:00
|
|
|
CGROUP_REF_EXPORT(css_tryget_online)
|
2022-10-29 04:45:44 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* css_put - put a css reference
|
|
|
|
* @css: target css
|
|
|
|
*
|
|
|
|
* Put a reference obtained via css_get() and css_tryget_online().
|
|
|
|
*/
|
|
|
|
CGROUP_REF_FN_ATTRS
|
|
|
|
void css_put(struct cgroup_subsys_state *css)
|
|
|
|
{
|
|
|
|
if (!(css->flags & CSS_NO_REF))
|
|
|
|
percpu_ref_put(&css->refcnt);
|
|
|
|
}
|
2022-11-01 01:12:13 +08:00
|
|
|
CGROUP_REF_EXPORT(css_put)
|
2022-10-29 04:45:44 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* css_put_many - put css references
|
|
|
|
* @css: target css
|
|
|
|
* @n: number of references to put
|
|
|
|
*
|
|
|
|
* Put references obtained via css_get() and css_tryget_online().
|
|
|
|
*/
|
|
|
|
CGROUP_REF_FN_ATTRS
|
|
|
|
void css_put_many(struct cgroup_subsys_state *css, unsigned int n)
|
|
|
|
{
|
|
|
|
if (!(css->flags & CSS_NO_REF))
|
|
|
|
percpu_ref_put_many(&css->refcnt, n);
|
|
|
|
}
|
2022-11-01 01:12:13 +08:00
|
|
|
CGROUP_REF_EXPORT(css_put_many)
|