/** * aa_current_raw_label - find the current tasks confining label * * Returns: up to date confining label or the ns unconfined label (NOT NULL) * * This fn will not update the tasks cred to the most up to date version * of the label so it is safe to call when inside of locks.
*/ staticinlinestruct aa_label *aa_current_raw_label(void)
{ return aa_cred_raw_label(current_cred());
}
/** * aa_get_current_label - get the newest version of the current tasks label * * Returns: newest version of confining label (NOT NULL) * * This fn will not update the tasks cred, so it is safe inside of locks * * The returned reference must be put with aa_put_label()
*/ staticinlinestruct aa_label *aa_get_current_label(void)
{ struct aa_label *l = aa_current_raw_label();
if (label_is_stale(l)) return aa_get_newest_label(l); return aa_get_label(l);
}
/** * __end_current_label_crit_section - end crit section begun with __begin_... * @label: label obtained from __begin_current_label_crit_section * @needput: output: bool set by __begin_current_label_crit_section * * Returns: label to use for this crit section
*/ staticinlinevoid __end_current_label_crit_section(struct aa_label *label, bool needput)
{ if (unlikely(needput))
aa_put_label(label);
}
/** * end_current_label_crit_section - put a reference found with begin_current_label.. * @label: label reference to put * * Should only be used with a reference obtained with * begin_current_label_crit_section and never used in situations where the * task cred may be updated
*/ staticinlinevoid end_current_label_crit_section(struct aa_label *label)
{ if (label != aa_current_raw_label())
aa_put_label(label);
}
/** * __begin_current_label_crit_section - current's confining label * @needput: store whether the label needs to be put when ending crit section * * Returns: up to date confining label or the ns unconfined label (NOT NULL) * * safe to call inside locks * * The returned reference must be put with __end_current_label_crit_section() * This must NOT be used if the task cred could be updated within the * critical section between __begin_current_label_crit_section() .. * __end_current_label_crit_section()
*/ staticinlinestruct aa_label *__begin_current_label_crit_section(bool *needput)
{ struct aa_label *label = aa_current_raw_label();
if (label_is_stale(label)) {
*needput = true; return aa_get_newest_label(label);
}
*needput = false; return label;
}
/** * begin_current_label_crit_section - current's confining label and update it * * Returns: up to date confining label or the ns unconfined label (NOT NULL) * * Not safe to call inside locks * * The returned reference must be put with end_current_label_crit_section() * This must NOT be used if the task cred could be updated within the * critical section between begin_current_label_crit_section() .. * end_current_label_crit_section()
*/ staticinlinestruct aa_label *begin_current_label_crit_section(void)
{ struct aa_label *label = aa_current_raw_label();
might_sleep();
if (label_is_stale(label)) {
label = aa_get_newest_label(label); if (aa_replace_current_label(label) == 0) /* task cred will keep the reference */
aa_put_label(label);
}
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.