SELinux启动流程
SELinux启动流程包含了几个阶段:
- init进程
- libselinux
- 内核部分
1号进程
SELinux的启动由用户态init程序发起,例如CentOS上的systemd,再例如busybox的init进程。用户态初始化方法大同小异,都是利用SELinux提供的用户态接口,包括libselinux,selinuxfs调用SELinux内核接口。本文以busybox init为例介绍。
其实用户态进程部分代码非常少:
#if ENABLE_SELINUX
if (getenv("SELINUX_INIT") == NULL) {
int enforce = 0;
putenv((char*)"SELINUX_INIT=YES");
if (selinux_init_load_policy(&enforce) == 0) {
BB_EXECVP(argv[0], argv);
} else if (enforce > 0) {
/* SELinux in enforcing mode but load_policy failed */
message(L_CONSOLE, "can't load SELinux Policy. "
"Machine is in enforcing mode. Halting now.");
return EXIT_FAILURE;
}
}
#endif
其中selinux_init_load_policy
是libselinux提供的接口,用来对整个SELinux子系统进行初始化。而BB_EXECVP
是由宏定义的exec类libc接口,实际上就是init进程又重新执行了一遍,这样init进程本身就有了正确的身份了(因为定义了type_transition规则)。
#define BB_EXECVP(prog,cmd) execvp(prog,cmd)
libselinux部分
SELinux有很大一部分机制处于用户态,包括模式配置,策略查询等等。而这一切的初始化都由libselinux提供的selinux_init_load_policy
接口来实现。可以说libselinux部分是SELinux用户态最重要,而往往又容易被忽视的部分。
<svg id="dagnrwbiuur" width="100%" xmlns="http://www.w3.org/2000/svg" style="max-width: 487.84375px;" viewBox="0 0 487.84375 586.25"><style>


#dagnrwbiuur .label {
  font-family: 'trebuchet ms', verdana, arial;
  color: #333; }

#dagnrwbiuur .node rect,
#dagnrwbiuur .node circle,
#dagnrwbiuur .node ellipse,
#dagnrwbiuur .node polygon {
  fill: #ECECFF;
  stroke: #9370DB;
  stroke-width: 1px; }

#dagnrwbiuur .node.clickable {
  cursor: pointer; }

#dagnrwbiuur .arrowheadPath {
  fill: #333333; }

#dagnrwbiuur .edgePath .path {
  stroke: #333333;
  stroke-width: 1.5px; }

#dagnrwbiuur .edgeLabel {
  background-color: #e8e8e8; }

#dagnrwbiuur .cluster rect {
  fill: #ffffde !important;
  stroke: #aaaa33 !important;
  stroke-width: 1px !important; }

#dagnrwbiuur .cluster text {
  fill: #333; }

#dagnrwbiuur div.mermaidTooltip {
  position: absolute;
  text-align: center;
  max-width: 200px;
  padding: 2px;
  font-family: 'trebuchet ms', verdana, arial;
  font-size: 12px;
  background: #ffffde;
  border: 1px solid #aaaa33;
  border-radius: 2px;
  pointer-events: none;
  z-index: 100; }

#dagnrwbiuur .actor {
  stroke: #CCCCFF;
  fill: #ECECFF; }

#dagnrwbiuur text.actor {
  fill: black;
  stroke: none; }

#dagnrwbiuur .actor-line {
  stroke: grey; }

#dagnrwbiuur .messageLine0 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  stroke: #333; }

#dagnrwbiuur .messageLine1 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  stroke: #333; }

#dagnrwbiuur #arrowhead {
  fill: #333; }

#dagnrwbiuur #crosshead path {
  fill: #333 !important;
  stroke: #333 !important; }

#dagnrwbiuur .messageText {
  fill: #333;
  stroke: none; }

#dagnrwbiuur .labelBox {
  stroke: #CCCCFF;
  fill: #ECECFF; }

#dagnrwbiuur .labelText {
  fill: black;
  stroke: none; }

#dagnrwbiuur .loopText {
  fill: black;
  stroke: none; }

#dagnrwbiuur .loopLine {
  stroke-width: 2;
  stroke-dasharray: '2 2';
  stroke: #CCCCFF; }

#dagnrwbiuur .note {
  stroke: #aaaa33;
  fill: #fff5ad; }

#dagnrwbiuur .noteText {
  fill: black;
  stroke: none;
  font-family: 'trebuchet ms', verdana, arial;
  font-size: 14px; }

#dagnrwbiuur .activation0 {
  fill: #f4f4f4;
  stroke: #666; }

#dagnrwbiuur .activation1 {
  fill: #f4f4f4;
  stroke: #666; }

#dagnrwbiuur .activation2 {
  fill: #f4f4f4;
  stroke: #666; }


#dagnrwbiuur .section {
  stroke: none;
  opacity: 0.2; }

#dagnrwbiuur .section0 {
  fill: rgba(102, 102, 255, 0.49); }

#dagnrwbiuur .section2 {
  fill: #fff400; }

#dagnrwbiuur .section1,
#dagnrwbiuur .section3 {
  fill: white;
  opacity: 0.2; }

#dagnrwbiuur .sectionTitle0 {
  fill: #333; }

#dagnrwbiuur .sectionTitle1 {
  fill: #333; }

#dagnrwbiuur .sectionTitle2 {
  fill: #333; }

#dagnrwbiuur .sectionTitle3 {
  fill: #333; }

#dagnrwbiuur .sectionTitle {
  text-anchor: start;
  font-size: 11px;
  text-height: 14px; }


#dagnrwbiuur .grid .tick {
  stroke: lightgrey;
  opacity: 0.3;
  shape-rendering: crispEdges; }

#dagnrwbiuur .grid path {
  stroke-width: 0; }


#dagnrwbiuur .today {
  fill: none;
  stroke: red;
  stroke-width: 2px; }



#dagnrwbiuur .task {
  stroke-width: 2; }

#dagnrwbiuur .taskText {
  text-anchor: middle;
  font-size: 11px; }

#dagnrwbiuur .taskTextOutsideRight {
  fill: black;
  text-anchor: start;
  font-size: 11px; }

#dagnrwbiuur .taskTextOutsideLeft {
  fill: black;
  text-anchor: end;
  font-size: 11px; }


#dagnrwbiuur .taskText0,
#dagnrwbiuur .taskText1,
#dagnrwbiuur .taskText2,
#dagnrwbiuur .taskText3 {
  fill: white; }

#dagnrwbiuur .task0,
#dagnrwbiuur .task1,
#dagnrwbiuur .task2,
#dagnrwbiuur .task3 {
  fill: #8a90dd;
  stroke: #534fbc; }

#dagnrwbiuur .taskTextOutside0,
#dagnrwbiuur .taskTextOutside2 {
  fill: black; }

#dagnrwbiuur .taskTextOutside1,
#dagnrwbiuur .taskTextOutside3 {
  fill: black; }


#dagnrwbiuur .active0,
#dagnrwbiuur .active1,
#dagnrwbiuur .active2,
#dagnrwbiuur .active3 {
  fill: #bfc7ff;
  stroke: #534fbc; }

#dagnrwbiuur .activeText0,
#dagnrwbiuur .activeText1,
#dagnrwbiuur .activeText2,
#dagnrwbiuur .activeText3 {
  fill: black !important; }


#dagnrwbiuur .done0,
#dagnrwbiuur .done1,
#dagnrwbiuur .done2,
#dagnrwbiuur .done3 {
  stroke: grey;
  fill: lightgrey;
  stroke-width: 2; }

#dagnrwbiuur .doneText0,
#dagnrwbiuur .doneText1,
#dagnrwbiuur .doneText2,
#dagnrwbiuur .doneText3 {
  fill: black !important; }


#dagnrwbiuur .crit0,
#dagnrwbiuur .crit1,
#dagnrwbiuur .crit2,
#dagnrwbiuur .crit3 {
  stroke: #ff8888;
  fill: red;
  stroke-width: 2; }

#dagnrwbiuur .activeCrit0,
#dagnrwbiuur .activeCrit1,
#dagnrwbiuur .activeCrit2,
#dagnrwbiuur .activeCrit3 {
  stroke: #ff8888;
  fill: #bfc7ff;
  stroke-width: 2; }

#dagnrwbiuur .doneCrit0,
#dagnrwbiuur .doneCrit1,
#dagnrwbiuur .doneCrit2,
#dagnrwbiuur .doneCrit3 {
  stroke: #ff8888;
  fill: lightgrey;
  stroke-width: 2;
  cursor: pointer;
  shape-rendering: crispEdges; }

#dagnrwbiuur .doneCritText0,
#dagnrwbiuur .doneCritText1,
#dagnrwbiuur .doneCritText2,
#dagnrwbiuur .doneCritText3 {
  fill: black !important; }

#dagnrwbiuur .activeCritText0,
#dagnrwbiuur .activeCritText1,
#dagnrwbiuur .activeCritText2,
#dagnrwbiuur .activeCritText3 {
  fill: black !important; }

#dagnrwbiuur .titleText {
  text-anchor: middle;
  font-size: 18px;
  fill: black; }

#dagnrwbiuur g.classGroup text {
  fill: #9370DB;
  stroke: none;
  font-family: 'trebuchet ms', verdana, arial;
  font-size: 10px; }

#dagnrwbiuur g.classGroup rect {
  fill: #ECECFF;
  stroke: #9370DB; }

#dagnrwbiuur g.classGroup line {
  stroke: #9370DB;
  stroke-width: 1; }

#dagnrwbiuur .classLabel .box {
  stroke: none;
  stroke-width: 0;
  fill: #ECECFF;
  opacity: 0.5; }

#dagnrwbiuur .classLabel .label {
  fill: #9370DB;
  font-size: 10px; }

#dagnrwbiuur .relation {
  stroke: #9370DB;
  stroke-width: 1;
  fill: none; }

#dagnrwbiuur #compositionStart {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dagnrwbiuur #compositionEnd {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dagnrwbiuur #aggregationStart {
  fill: #ECECFF;
  stroke: #9370DB;
  stroke-width: 1; }

#dagnrwbiuur #aggregationEnd {
  fill: #ECECFF;
  stroke: #9370DB;
  stroke-width: 1; }

#dagnrwbiuur #dependencyStart {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dagnrwbiuur #dependencyEnd {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dagnrwbiuur #extensionStart {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dagnrwbiuur #extensionEnd {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dagnrwbiuur .commit-id,
#dagnrwbiuur .commit-msg,
#dagnrwbiuur .branch-label {
  fill: lightgrey;
  color: lightgrey; }



#dagnrwbiuur .label{
  color:#18B14E;
}
#dagnrwbiuur .te-md-container--dark .node rect {
  fill: red;
}

#dagnrwbiuur .node rect,
#dagnrwbiuur .node circle,
#dagnrwbiuur .node ellipse,
#dagnrwbiuur .node polygon {
  fill: #F9FFFB;;
  stroke: #2DBD60;
  stroke-width: 1.5px;
}
#dagnrwbiuur .arrowheadPath{
  fill: #2DBD60;
}
#dagnrwbiuur .edgePath .path {
  stroke: #2DBD60;
  stroke-width: 1px;
}
#dagnrwbiuur .edgeLabel {
  background-color: #fff;
}
#dagnrwbiuur .cluster rect {
  fill: #F9FFFB !important;
  stroke: #2DBD60 !important;
  stroke-width: 1px !important;
}

#dagnrwbiuur .cluster text {
  fill: #F9FFFB;
}

#dagnrwbiuur div.mermaidTooltip {
  background: #F9FFFB;
  border: 1px solid #2DBD60;
}


#dagnrwbiuur .actor {
  stroke: #2DBD60;
  fill: #F9FFFB;
}

#dagnrwbiuur text.actor {
  fill: #2DBD60;
  stroke: none;
}

#dagnrwbiuur .actor-line {
  stroke: #2DBD60;
}

#dagnrwbiuur .messageLine0 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  marker-end: 'url(#arrowhead)';
  stroke: #2DBD60;
}

#dagnrwbiuur .messageLine1 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  stroke: #2DBD60;
}

#dagnrwbiuur #arrowhead {
  fill: #2DBD60;
}

#dagnrwbiuur #crosshead path {
  fill: #2DBD60 !important;
  stroke: #2DBD60 !important;
}

#dagnrwbiuur .messageText {
  fill: #2DBD60;
  stroke: none;
}

#dagnrwbiuur .labelBox {
  stroke: #2DBD60;
  fill: #F9FFFB;
}

#dagnrwbiuur .labelText {
  fill: #2DBD60;
  stroke: #2DBD60;
}

#dagnrwbiuur .loopText {
  fill: #2DBD60;
  stroke: #2DBD60;
}

#dagnrwbiuur .loopLine {
  stroke-width: 2;
  stroke-dasharray: '2 2';
  marker-end: 'url(#arrowhead)';
  stroke: #2DBD60;
}

#dagnrwbiuur .note {
  stroke: #2DBD60;
  fill: #F9FFFB;
}

#dagnrwbiuur .noteText {
  fill: #2DBD60;
  stroke: #2DBD60;
}


#dagnrwbiuur .section{
  opacity:1;
}
#dagnrwbiuur .section0,#dagnrwbiuur  .section2 {
  fill: #ECF7F0;
}

#dagnrwbiuur .section1,
#dagnrwbiuur .section3 {
  fill: #FFF;
}
#dagnrwbiuur .taskText0,
#dagnrwbiuur .taskText1,
#dagnrwbiuur .taskText2,
#dagnrwbiuur .taskText3 {
  fill: #fff;
}

#dagnrwbiuur .task0,
#dagnrwbiuur .task1,
#dagnrwbiuur .task2,
#dagnrwbiuur .task3 {
  fill: #2DBD60;
  stroke: #359F5A;
}
</style><style>#dagnrwbiuur {
    color: rgb(200, 201, 198);
    font: normal normal normal normal 14px/22.399999618530273px monospace;
  }</style><g transform="translate(-12, -12)"><g class="output"><g class="clusters"></g><g class="edgePaths"><g class="edgePath" style="opacity: 1;"><path class="path" d="M249.78125,56.28125L249.78125,81.28125L249.78125,106.28125" marker-end="url(#arrowhead212)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead212" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M249.78125,142.5625L249.78125,167.5625L249.78125,192.5625" marker-end="url(#arrowhead213)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead213" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M203.63099148765997,228.84375L119.3203125,261.984375L119.3203125,295.125" marker-end="url(#arrowhead214)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead214" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M295.93150851234003,228.84375L380.2421875,261.984375L380.2421875,295.125" marker-end="url(#arrowhead215)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead215" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M119.3203125,331.40625L119.3203125,356.40625L194.9224494069178,381.40625" marker-end="url(#arrowhead216)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead216" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M380.2421875,331.40625L380.2421875,356.40625L304.6400505930822,381.40625" marker-end="url(#arrowhead217)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead217" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M249.78125,417.6875L249.78125,442.6875L249.78125,467.6875" marker-end="url(#arrowhead218)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead218" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M249.78125,503.96875L249.78125,528.96875L249.78125,553.96875" marker-end="url(#arrowhead219)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead219" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g></g><g class="edgeLabels"><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform="translate(119.3203125,261.984375)"><g transform="translate(-4.203125,-8.0078125)" class="label"><rect rx="0" ry="0" width="7.484375" height="16.5625" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1">1</tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform="translate(380.2421875,261.984375)"><g transform="translate(-4.203125,-8.0078125)" class="label"><rect rx="0" ry="0" width="7.484375" height="16.5625" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1">2</tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g></g><g class="nodes"><g class="node" style="opacity: 1;" id="A" transform="translate(249.78125,38.140625)"><rect rx="0" ry="0" x="-82.0625" y="-18.140625" width="164.125" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-72.0625,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">selinux_init_load_policy</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="B" transform="translate(249.78125,124.421875)"><rect rx="0" ry="0" x="-71.4765625" y="-18.140625" width="142.953125" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-61.4765625,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">selinux_reset_config</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="C" transform="translate(249.78125,210.703125)"><rect rx="0" ry="0" x="-63.3515625" y="-18.140625" width="126.703125" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-53.3515625,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">get enforce mode</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="D" transform="translate(119.3203125,313.265625)"><rect rx="0" ry="0" x="-99.3203125" y="-18.140625" width="198.640625" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-89.3203125,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">from /etc/selinux/config文件</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="E" transform="translate(380.2421875,313.265625)"><rect rx="0" ry="0" x="-111.6015625" y="-18.140625" width="223.203125" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-101.6015625,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">from 内核启动参数/proc/cmdline</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="F" transform="translate(249.78125,399.546875)"><rect rx="0" ry="0" x="-188.453125" y="-18.140625" width="376.90625" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-178.453125,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">mount selinuxfs到/sys/fs/selinux（旧的挂载点在/selinux）</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="G" transform="translate(249.78125,485.828125)"><rect rx="0" ry="0" x="-156.0234375" y="-18.140625" width="312.046875" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-146.0234375,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">使能SELinux，通过往/sys/fs/selinux/enforce写1</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="H" transform="translate(249.78125,572.109375)"><rect rx="0" ry="0" x="-111.8359375" y="-18.140625" width="223.671875" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-101.8359375,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">加载策略，selinux_mkload_policy</tspan></text></g></g></g></g></g></g></svg>
selinux_mkload_policy
仍然是libselinux定义的接口,其调用了libsel库,对读入的策略二进制进行了预处理,例如策略语言版本不匹配时的语法降级。最终调用security_load_policy
来加载策略,而该函数仅仅是将mmap出的文件,写入/sys/fs/selinux/load文件,从而使内核可以做真正的加载策略工作。
内核部分
SELinux最核心的部分就是内核中的LSM框架以及selinux模块部分。其位置位于security/selinux
。而刚才提到的selinuxfs源码位于security/selinux/selinuxfs.c
。
selinuxfs
其初始化位于init_sel_fs
。这是一个内核初始化函数,由内核启动时调用。其作用就是使用Linux内核的libfs接口,将selinuxfs准备好,在init进程中再进行挂载。其中有一个关键数据结构,即selinux_files
。
static const struct tree_descr selinux_files[] = {
[SEL_LOAD] = {"load", &sel_load_ops, S_IRUSR|S_IWUSR},
[SEL_ENFORCE] = {"enforce", &sel_enforce_ops, S_IRUGO|S_IWUSR},
[SEL_CONTEXT] = {"context", &transaction_ops, S_IRUGO|S_IWUGO},
[SEL_ACCESS] = {"access", &transaction_ops, S_IRUGO|S_IWUGO},
[SEL_CREATE] = {"create", &transaction_ops, S_IRUGO|S_IWUGO},
[SEL_RELABEL] = {"relabel", &transaction_ops, S_IRUGO|S_IWUGO},
[SEL_USER] = {"user", &transaction_ops, S_IRUGO|S_IWUGO},
[SEL_POLICYVERS] = {"policyvers", &sel_policyvers_ops, S_IRUGO},
[SEL_COMMIT_BOOLS] = {"commit_pending_bools", &sel_commit_bools_ops, S_IWUSR},
[SEL_MLS] = {"mls", &sel_mls_ops, S_IRUGO},
[SEL_DISABLE] = {"disable", &sel_disable_ops, S_IWUSR},
[SEL_MEMBER] = {"member", &transaction_ops, S_IRUGO|S_IWUGO},
[SEL_CHECKREQPROT] = {"checkreqprot", &sel_checkreqprot_ops, S_IRUGO|S_IWUSR},
[SEL_REJECT_UNKNOWN] = {"reject_unknown", &sel_handle_unknown_ops, S_IRUGO},
[SEL_DENY_UNKNOWN] = {"deny_unknown", &sel_handle_unknown_ops, S_IRUGO},
[SEL_STATUS] = {"status", &sel_handle_status_ops, S_IRUGO},
[SEL_POLICY] = {"policy", &sel_policy_ops, S_IRUGO},
[SEL_VALIDATE_TRANS] = {"validatetrans", &sel_transition_ops,
S_IWUGO},
/* last one */ {""}
};
他为每个selinuxfs文件均定义了file_operation。再看看运行时的selinuxfs:
[ben@localhost targeted]$ tree /sys/fs/selinux/ -L 1
/sys/fs/selinux/
├── access
├── avc
├── booleans
├── checkreqprot
├── class
├── commit_pending_bools
├── context
├── create
├── deny_unknown
├── disable
├── enforce
├── initial_contexts
├── load
├── member
├── mls
├── null
├── policy
├── policy_capabilities
├── policyvers
├── reject_unknown
├── relabel
├── ss
├── status
├── user
└── validatetrans
6 directories, 19 files
selinux_files
定义的文件在这里都可以找到,除了一个特殊的文件null。init_sel_fs
除了创建这些文件,还创建了一些目录,例如avc, booleans, class, initial_contexts等。
selinuxfs SID初始化
selinuxfs每个文件和一个普通文件一样,都有对应的context,并对应到SID。SELinux子系统在初始化时,创建了selinuxfs。selinuxfs的文件节点通过d_add(entry, inode)
函数添加。而每个文件的SID也是由d_add
打上。但因为牵扯到SELinux策略加载,过程比较复杂一些。先看看d_add
怎么最终完成selinux文件SID的加载。
<svg id="d525a5gz24z" width="100%" xmlns="http://www.w3.org/2000/svg" style="max-width: 560.8125px;" viewBox="0 0 560.8125 1053.6937561035156"><style>


#d525a5gz24z .label {
  font-family: 'trebuchet ms', verdana, arial;
  color: #333; }

#d525a5gz24z .node rect,
#d525a5gz24z .node circle,
#d525a5gz24z .node ellipse,
#d525a5gz24z .node polygon {
  fill: #ECECFF;
  stroke: #9370DB;
  stroke-width: 1px; }

#d525a5gz24z .node.clickable {
  cursor: pointer; }

#d525a5gz24z .arrowheadPath {
  fill: #333333; }

#d525a5gz24z .edgePath .path {
  stroke: #333333;
  stroke-width: 1.5px; }

#d525a5gz24z .edgeLabel {
  background-color: #e8e8e8; }

#d525a5gz24z .cluster rect {
  fill: #ffffde !important;
  stroke: #aaaa33 !important;
  stroke-width: 1px !important; }

#d525a5gz24z .cluster text {
  fill: #333; }

#d525a5gz24z div.mermaidTooltip {
  position: absolute;
  text-align: center;
  max-width: 200px;
  padding: 2px;
  font-family: 'trebuchet ms', verdana, arial;
  font-size: 12px;
  background: #ffffde;
  border: 1px solid #aaaa33;
  border-radius: 2px;
  pointer-events: none;
  z-index: 100; }

#d525a5gz24z .actor {
  stroke: #CCCCFF;
  fill: #ECECFF; }

#d525a5gz24z text.actor {
  fill: black;
  stroke: none; }

#d525a5gz24z .actor-line {
  stroke: grey; }

#d525a5gz24z .messageLine0 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  stroke: #333; }

#d525a5gz24z .messageLine1 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  stroke: #333; }

#d525a5gz24z #arrowhead {
  fill: #333; }

#d525a5gz24z #crosshead path {
  fill: #333 !important;
  stroke: #333 !important; }

#d525a5gz24z .messageText {
  fill: #333;
  stroke: none; }

#d525a5gz24z .labelBox {
  stroke: #CCCCFF;
  fill: #ECECFF; }

#d525a5gz24z .labelText {
  fill: black;
  stroke: none; }

#d525a5gz24z .loopText {
  fill: black;
  stroke: none; }

#d525a5gz24z .loopLine {
  stroke-width: 2;
  stroke-dasharray: '2 2';
  stroke: #CCCCFF; }

#d525a5gz24z .note {
  stroke: #aaaa33;
  fill: #fff5ad; }

#d525a5gz24z .noteText {
  fill: black;
  stroke: none;
  font-family: 'trebuchet ms', verdana, arial;
  font-size: 14px; }

#d525a5gz24z .activation0 {
  fill: #f4f4f4;
  stroke: #666; }

#d525a5gz24z .activation1 {
  fill: #f4f4f4;
  stroke: #666; }

#d525a5gz24z .activation2 {
  fill: #f4f4f4;
  stroke: #666; }


#d525a5gz24z .section {
  stroke: none;
  opacity: 0.2; }

#d525a5gz24z .section0 {
  fill: rgba(102, 102, 255, 0.49); }

#d525a5gz24z .section2 {
  fill: #fff400; }

#d525a5gz24z .section1,
#d525a5gz24z .section3 {
  fill: white;
  opacity: 0.2; }

#d525a5gz24z .sectionTitle0 {
  fill: #333; }

#d525a5gz24z .sectionTitle1 {
  fill: #333; }

#d525a5gz24z .sectionTitle2 {
  fill: #333; }

#d525a5gz24z .sectionTitle3 {
  fill: #333; }

#d525a5gz24z .sectionTitle {
  text-anchor: start;
  font-size: 11px;
  text-height: 14px; }


#d525a5gz24z .grid .tick {
  stroke: lightgrey;
  opacity: 0.3;
  shape-rendering: crispEdges; }

#d525a5gz24z .grid path {
  stroke-width: 0; }


#d525a5gz24z .today {
  fill: none;
  stroke: red;
  stroke-width: 2px; }



#d525a5gz24z .task {
  stroke-width: 2; }

#d525a5gz24z .taskText {
  text-anchor: middle;
  font-size: 11px; }

#d525a5gz24z .taskTextOutsideRight {
  fill: black;
  text-anchor: start;
  font-size: 11px; }

#d525a5gz24z .taskTextOutsideLeft {
  fill: black;
  text-anchor: end;
  font-size: 11px; }


#d525a5gz24z .taskText0,
#d525a5gz24z .taskText1,
#d525a5gz24z .taskText2,
#d525a5gz24z .taskText3 {
  fill: white; }

#d525a5gz24z .task0,
#d525a5gz24z .task1,
#d525a5gz24z .task2,
#d525a5gz24z .task3 {
  fill: #8a90dd;
  stroke: #534fbc; }

#d525a5gz24z .taskTextOutside0,
#d525a5gz24z .taskTextOutside2 {
  fill: black; }

#d525a5gz24z .taskTextOutside1,
#d525a5gz24z .taskTextOutside3 {
  fill: black; }


#d525a5gz24z .active0,
#d525a5gz24z .active1,
#d525a5gz24z .active2,
#d525a5gz24z .active3 {
  fill: #bfc7ff;
  stroke: #534fbc; }

#d525a5gz24z .activeText0,
#d525a5gz24z .activeText1,
#d525a5gz24z .activeText2,
#d525a5gz24z .activeText3 {
  fill: black !important; }


#d525a5gz24z .done0,
#d525a5gz24z .done1,
#d525a5gz24z .done2,
#d525a5gz24z .done3 {
  stroke: grey;
  fill: lightgrey;
  stroke-width: 2; }

#d525a5gz24z .doneText0,
#d525a5gz24z .doneText1,
#d525a5gz24z .doneText2,
#d525a5gz24z .doneText3 {
  fill: black !important; }


#d525a5gz24z .crit0,
#d525a5gz24z .crit1,
#d525a5gz24z .crit2,
#d525a5gz24z .crit3 {
  stroke: #ff8888;
  fill: red;
  stroke-width: 2; }

#d525a5gz24z .activeCrit0,
#d525a5gz24z .activeCrit1,
#d525a5gz24z .activeCrit2,
#d525a5gz24z .activeCrit3 {
  stroke: #ff8888;
  fill: #bfc7ff;
  stroke-width: 2; }

#d525a5gz24z .doneCrit0,
#d525a5gz24z .doneCrit1,
#d525a5gz24z .doneCrit2,
#d525a5gz24z .doneCrit3 {
  stroke: #ff8888;
  fill: lightgrey;
  stroke-width: 2;
  cursor: pointer;
  shape-rendering: crispEdges; }

#d525a5gz24z .doneCritText0,
#d525a5gz24z .doneCritText1,
#d525a5gz24z .doneCritText2,
#d525a5gz24z .doneCritText3 {
  fill: black !important; }

#d525a5gz24z .activeCritText0,
#d525a5gz24z .activeCritText1,
#d525a5gz24z .activeCritText2,
#d525a5gz24z .activeCritText3 {
  fill: black !important; }

#d525a5gz24z .titleText {
  text-anchor: middle;
  font-size: 18px;
  fill: black; }

#d525a5gz24z g.classGroup text {
  fill: #9370DB;
  stroke: none;
  font-family: 'trebuchet ms', verdana, arial;
  font-size: 10px; }

#d525a5gz24z g.classGroup rect {
  fill: #ECECFF;
  stroke: #9370DB; }

#d525a5gz24z g.classGroup line {
  stroke: #9370DB;
  stroke-width: 1; }

#d525a5gz24z .classLabel .box {
  stroke: none;
  stroke-width: 0;
  fill: #ECECFF;
  opacity: 0.5; }

#d525a5gz24z .classLabel .label {
  fill: #9370DB;
  font-size: 10px; }

#d525a5gz24z .relation {
  stroke: #9370DB;
  stroke-width: 1;
  fill: none; }

#d525a5gz24z #compositionStart {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#d525a5gz24z #compositionEnd {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#d525a5gz24z #aggregationStart {
  fill: #ECECFF;
  stroke: #9370DB;
  stroke-width: 1; }

#d525a5gz24z #aggregationEnd {
  fill: #ECECFF;
  stroke: #9370DB;
  stroke-width: 1; }

#d525a5gz24z #dependencyStart {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#d525a5gz24z #dependencyEnd {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#d525a5gz24z #extensionStart {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#d525a5gz24z #extensionEnd {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#d525a5gz24z .commit-id,
#d525a5gz24z .commit-msg,
#d525a5gz24z .branch-label {
  fill: lightgrey;
  color: lightgrey; }



#d525a5gz24z .label{
  color:#18B14E;
}
#d525a5gz24z .te-md-container--dark .node rect {
  fill: red;
}

#d525a5gz24z .node rect,
#d525a5gz24z .node circle,
#d525a5gz24z .node ellipse,
#d525a5gz24z .node polygon {
  fill: #F9FFFB;;
  stroke: #2DBD60;
  stroke-width: 1.5px;
}
#d525a5gz24z .arrowheadPath{
  fill: #2DBD60;
}
#d525a5gz24z .edgePath .path {
  stroke: #2DBD60;
  stroke-width: 1px;
}
#d525a5gz24z .edgeLabel {
  background-color: #fff;
}
#d525a5gz24z .cluster rect {
  fill: #F9FFFB !important;
  stroke: #2DBD60 !important;
  stroke-width: 1px !important;
}

#d525a5gz24z .cluster text {
  fill: #F9FFFB;
}

#d525a5gz24z div.mermaidTooltip {
  background: #F9FFFB;
  border: 1px solid #2DBD60;
}


#d525a5gz24z .actor {
  stroke: #2DBD60;
  fill: #F9FFFB;
}

#d525a5gz24z text.actor {
  fill: #2DBD60;
  stroke: none;
}

#d525a5gz24z .actor-line {
  stroke: #2DBD60;
}

#d525a5gz24z .messageLine0 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  marker-end: 'url(#arrowhead)';
  stroke: #2DBD60;
}

#d525a5gz24z .messageLine1 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  stroke: #2DBD60;
}

#d525a5gz24z #arrowhead {
  fill: #2DBD60;
}

#d525a5gz24z #crosshead path {
  fill: #2DBD60 !important;
  stroke: #2DBD60 !important;
}

#d525a5gz24z .messageText {
  fill: #2DBD60;
  stroke: none;
}

#d525a5gz24z .labelBox {
  stroke: #2DBD60;
  fill: #F9FFFB;
}

#d525a5gz24z .labelText {
  fill: #2DBD60;
  stroke: #2DBD60;
}

#d525a5gz24z .loopText {
  fill: #2DBD60;
  stroke: #2DBD60;
}

#d525a5gz24z .loopLine {
  stroke-width: 2;
  stroke-dasharray: '2 2';
  marker-end: 'url(#arrowhead)';
  stroke: #2DBD60;
}

#d525a5gz24z .note {
  stroke: #2DBD60;
  fill: #F9FFFB;
}

#d525a5gz24z .noteText {
  fill: #2DBD60;
  stroke: #2DBD60;
}


#d525a5gz24z .section{
  opacity:1;
}
#d525a5gz24z .section0,#d525a5gz24z  .section2 {
  fill: #ECF7F0;
}

#d525a5gz24z .section1,
#d525a5gz24z .section3 {
  fill: #FFF;
}
#d525a5gz24z .taskText0,
#d525a5gz24z .taskText1,
#d525a5gz24z .taskText2,
#d525a5gz24z .taskText3 {
  fill: #fff;
}

#d525a5gz24z .task0,
#d525a5gz24z .task1,
#d525a5gz24z .task2,
#d525a5gz24z .task3 {
  fill: #2DBD60;
  stroke: #359F5A;
}
</style><style>#d525a5gz24z {
    color: rgb(200, 201, 198);
    font: normal normal normal normal 14px/22.399999618530273px monospace;
  }</style><g transform="translate(-12, -12)"><g class="output"><g class="clusters"></g><g class="edgePaths"><g class="edgePath" style="opacity: 1;"><path class="path" d="M330.51171875,56.28125L330.51171875,81.28125L330.51171875,106.28125" marker-end="url(#arrowhead279)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead279" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M330.51171875,142.5625L330.51171875,167.5625L330.51171875,192.5625" marker-end="url(#arrowhead280)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead280" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M330.51171875,228.84375L330.51171875,253.84375L330.51171875,278.84375" marker-end="url(#arrowhead281)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead281" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M330.51171875,315.125L330.51171875,348.265625L330.51171875,381.40625" marker-end="url(#arrowhead282)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead282" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M330.51171875,417.6875L330.51171875,442.6875L330.51171875,467.6875" marker-end="url(#arrowhead283)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead283" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M290.8385463826512,503.96875L236.1640625,528.96875L236.6640625,554.4687530517576" marker-end="url(#arrowhead284)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead284" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M181.0029981322609,727.4076886840189L96.2109375,815.7093811035156L96.2109375,848.8500061035156" marker-end="url(#arrowhead285)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead285" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M292.3251238954892,727.4076855527533L376.1171875,815.7093811035156L376.1171875,848.8500061035156" marker-end="url(#arrowhead286)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead286" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M96.2109375,885.1312561035156L96.2109375,910.1312561035156L96.2109375,935.1312561035156" marker-end="url(#arrowhead287)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead287" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 0 0 L 0 0 z" style="fill: #333"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M96.2109375,971.4125061035156L96.2109375,996.4125061035156L231.98828266479535,1021.4125061035156" marker-end="url(#arrowhead288)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead288" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M429.03515483520465,1021.4125061035156L564.8125,996.4125061035156L564.8125,953.2718811035156L564.8125,910.1312561035156L564.8125,866.9906311035156L564.8125,815.7093811035156L564.8125,668.2687530517578L564.8125,528.96875L417.91796875,501.92179841324753" marker-end="url(#arrowhead289)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead289" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M376.1171875,885.1312561035156L376.1171875,910.1312561035156L376.1171875,935.1312561035156" marker-end="url(#arrowhead290)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead290" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g></g><g class="edgeLabels"><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform="translate(330.51171875,348.265625)"><g transform="translate(-40.6640625,-8.0078125)" class="label"><rect rx="0" ry="0" width="57.296875" height="15.875" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1">is SELinux</tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform="translate(96.2109375,815.7093811035156)"><g transform="translate(-4.203125,-8.0078125)" class="label"><rect rx="0" ry="0" width="8.71875" height="15.875" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1">N</tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform="translate(376.1171875,815.7093811035156)"><g transform="translate(-4.203125,-8.0078125)" class="label"><rect rx="0" ry="0" width="7.796875" height="15.875" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1">Y</tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g></g><g class="nodes"><g class="node" style="opacity: 1;" id="A" transform="translate(330.51171875,38.140625)"><rect rx="0" ry="0" x="-28.453125" y="-18.140625" width="56.90625" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-18.453125,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">d_add</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="B" transform="translate(330.51171875,124.421875)"><rect rx="0" ry="0" x="-76.953125" y="-18.140625" width="153.90625" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-66.953125,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">security_d_instantiate</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="C" transform="translate(330.51171875,210.703125)"><rect rx="0" ry="0" x="-108.734375" y="-18.140625" width="217.46875" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-98.734375,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">call_void_hook(d_instantiate,...)</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="D" transform="translate(330.51171875,296.984375)"><rect rx="0" ry="0" x="-125.59375" y="-18.140625" width="251.1875" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-115.59375,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">call each hook on list for d_instantiate</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="E" transform="translate(330.51171875,399.546875)"><rect rx="0" ry="0" x="-74.0859375" y="-18.140625" width="148.171875" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-64.0859375,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">selinux_d_instantiate</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="F" transform="translate(330.51171875,485.828125)"><rect rx="0" ry="0" x="-87.40625" y="-18.140625" width="174.8125" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-77.40625,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">inode_doinit_with_dentry</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="G" transform="translate(236.1640625,668.2687530517578)"><polygon points="114.3,0 228.6,-114.3 114.3,-228.6 0,-114.3" rx="5" ry="5" transform="translate(-114.3,114.3)"></polygon><g class="label" transform="translate(0,0)"><g transform="translate(-98.859375,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">sbsec-&gt;flags &amp; SE_SBINITIALIZED?</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="H" transform="translate(96.2109375,866.9906311035156)"><rect rx="0" ry="0" x="-45.6875" y="-18.140625" width="91.375" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-35.6875,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">delayed init</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="K" transform="translate(376.1171875,866.9906311035156)"><rect rx="0" ry="0" x="-43.1015625" y="-18.140625" width="86.203125" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-33.1015625,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">do real init</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="I" transform="translate(96.2109375,953.2718811035156)"><rect rx="0" ry="0" x="-76.2109375" y="-18.140625" width="152.421875" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-66.2109375,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">selinux_complete_init</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="J" transform="translate(330.51171875,1039.5531311035156)"><rect rx="0" ry="0" x="-108.6875" y="-18.140625" width="217.375" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-98.6875,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">sbsec-&gt;flags |= SE_SBINITIALIZED</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="L" transform="translate(376.1171875,953.2718811035156)"><rect rx="0" ry="0" x="-153.6953125" y="-18.140625" width="307.390625" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-143.6953125,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">根据sbsec-&gt;behavior)确定inode-&gt;i_security-&gt;sid</tspan></text></g></g></g></g></g></g></svg>
selinuxfs文件的SID最终由inode_doinit_with_dentry
赋值。inode_doinit_with_dentry
被执行了两遍,第一遍由最初的初始化函数__init init_sel_fs
发起,但因为此时策略还没加载,所以需要一个delayed init,第二遍调用由selinux_complete_init
发起,最终进入inode_doinit_with_dentry
完成selinuxfs SID最终的初始化。流程大致如下:
<svg id="dgth2qo4cs2" width="100%" xmlns="http://www.w3.org/2000/svg" style="max-width: 190.8125px;" viewBox="0 0 190.8125 483.6875"><style>


#dgth2qo4cs2 .label {
  font-family: 'trebuchet ms', verdana, arial;
  color: #333; }

#dgth2qo4cs2 .node rect,
#dgth2qo4cs2 .node circle,
#dgth2qo4cs2 .node ellipse,
#dgth2qo4cs2 .node polygon {
  fill: #ECECFF;
  stroke: #9370DB;
  stroke-width: 1px; }

#dgth2qo4cs2 .node.clickable {
  cursor: pointer; }

#dgth2qo4cs2 .arrowheadPath {
  fill: #333333; }

#dgth2qo4cs2 .edgePath .path {
  stroke: #333333;
  stroke-width: 1.5px; }

#dgth2qo4cs2 .edgeLabel {
  background-color: #e8e8e8; }

#dgth2qo4cs2 .cluster rect {
  fill: #ffffde !important;
  stroke: #aaaa33 !important;
  stroke-width: 1px !important; }

#dgth2qo4cs2 .cluster text {
  fill: #333; }

#dgth2qo4cs2 div.mermaidTooltip {
  position: absolute;
  text-align: center;
  max-width: 200px;
  padding: 2px;
  font-family: 'trebuchet ms', verdana, arial;
  font-size: 12px;
  background: #ffffde;
  border: 1px solid #aaaa33;
  border-radius: 2px;
  pointer-events: none;
  z-index: 100; }

#dgth2qo4cs2 .actor {
  stroke: #CCCCFF;
  fill: #ECECFF; }

#dgth2qo4cs2 text.actor {
  fill: black;
  stroke: none; }

#dgth2qo4cs2 .actor-line {
  stroke: grey; }

#dgth2qo4cs2 .messageLine0 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  stroke: #333; }

#dgth2qo4cs2 .messageLine1 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  stroke: #333; }

#dgth2qo4cs2 #arrowhead {
  fill: #333; }

#dgth2qo4cs2 #crosshead path {
  fill: #333 !important;
  stroke: #333 !important; }

#dgth2qo4cs2 .messageText {
  fill: #333;
  stroke: none; }

#dgth2qo4cs2 .labelBox {
  stroke: #CCCCFF;
  fill: #ECECFF; }

#dgth2qo4cs2 .labelText {
  fill: black;
  stroke: none; }

#dgth2qo4cs2 .loopText {
  fill: black;
  stroke: none; }

#dgth2qo4cs2 .loopLine {
  stroke-width: 2;
  stroke-dasharray: '2 2';
  stroke: #CCCCFF; }

#dgth2qo4cs2 .note {
  stroke: #aaaa33;
  fill: #fff5ad; }

#dgth2qo4cs2 .noteText {
  fill: black;
  stroke: none;
  font-family: 'trebuchet ms', verdana, arial;
  font-size: 14px; }

#dgth2qo4cs2 .activation0 {
  fill: #f4f4f4;
  stroke: #666; }

#dgth2qo4cs2 .activation1 {
  fill: #f4f4f4;
  stroke: #666; }

#dgth2qo4cs2 .activation2 {
  fill: #f4f4f4;
  stroke: #666; }


#dgth2qo4cs2 .section {
  stroke: none;
  opacity: 0.2; }

#dgth2qo4cs2 .section0 {
  fill: rgba(102, 102, 255, 0.49); }

#dgth2qo4cs2 .section2 {
  fill: #fff400; }

#dgth2qo4cs2 .section1,
#dgth2qo4cs2 .section3 {
  fill: white;
  opacity: 0.2; }

#dgth2qo4cs2 .sectionTitle0 {
  fill: #333; }

#dgth2qo4cs2 .sectionTitle1 {
  fill: #333; }

#dgth2qo4cs2 .sectionTitle2 {
  fill: #333; }

#dgth2qo4cs2 .sectionTitle3 {
  fill: #333; }

#dgth2qo4cs2 .sectionTitle {
  text-anchor: start;
  font-size: 11px;
  text-height: 14px; }


#dgth2qo4cs2 .grid .tick {
  stroke: lightgrey;
  opacity: 0.3;
  shape-rendering: crispEdges; }

#dgth2qo4cs2 .grid path {
  stroke-width: 0; }


#dgth2qo4cs2 .today {
  fill: none;
  stroke: red;
  stroke-width: 2px; }



#dgth2qo4cs2 .task {
  stroke-width: 2; }

#dgth2qo4cs2 .taskText {
  text-anchor: middle;
  font-size: 11px; }

#dgth2qo4cs2 .taskTextOutsideRight {
  fill: black;
  text-anchor: start;
  font-size: 11px; }

#dgth2qo4cs2 .taskTextOutsideLeft {
  fill: black;
  text-anchor: end;
  font-size: 11px; }


#dgth2qo4cs2 .taskText0,
#dgth2qo4cs2 .taskText1,
#dgth2qo4cs2 .taskText2,
#dgth2qo4cs2 .taskText3 {
  fill: white; }

#dgth2qo4cs2 .task0,
#dgth2qo4cs2 .task1,
#dgth2qo4cs2 .task2,
#dgth2qo4cs2 .task3 {
  fill: #8a90dd;
  stroke: #534fbc; }

#dgth2qo4cs2 .taskTextOutside0,
#dgth2qo4cs2 .taskTextOutside2 {
  fill: black; }

#dgth2qo4cs2 .taskTextOutside1,
#dgth2qo4cs2 .taskTextOutside3 {
  fill: black; }


#dgth2qo4cs2 .active0,
#dgth2qo4cs2 .active1,
#dgth2qo4cs2 .active2,
#dgth2qo4cs2 .active3 {
  fill: #bfc7ff;
  stroke: #534fbc; }

#dgth2qo4cs2 .activeText0,
#dgth2qo4cs2 .activeText1,
#dgth2qo4cs2 .activeText2,
#dgth2qo4cs2 .activeText3 {
  fill: black !important; }


#dgth2qo4cs2 .done0,
#dgth2qo4cs2 .done1,
#dgth2qo4cs2 .done2,
#dgth2qo4cs2 .done3 {
  stroke: grey;
  fill: lightgrey;
  stroke-width: 2; }

#dgth2qo4cs2 .doneText0,
#dgth2qo4cs2 .doneText1,
#dgth2qo4cs2 .doneText2,
#dgth2qo4cs2 .doneText3 {
  fill: black !important; }


#dgth2qo4cs2 .crit0,
#dgth2qo4cs2 .crit1,
#dgth2qo4cs2 .crit2,
#dgth2qo4cs2 .crit3 {
  stroke: #ff8888;
  fill: red;
  stroke-width: 2; }

#dgth2qo4cs2 .activeCrit0,
#dgth2qo4cs2 .activeCrit1,
#dgth2qo4cs2 .activeCrit2,
#dgth2qo4cs2 .activeCrit3 {
  stroke: #ff8888;
  fill: #bfc7ff;
  stroke-width: 2; }

#dgth2qo4cs2 .doneCrit0,
#dgth2qo4cs2 .doneCrit1,
#dgth2qo4cs2 .doneCrit2,
#dgth2qo4cs2 .doneCrit3 {
  stroke: #ff8888;
  fill: lightgrey;
  stroke-width: 2;
  cursor: pointer;
  shape-rendering: crispEdges; }

#dgth2qo4cs2 .doneCritText0,
#dgth2qo4cs2 .doneCritText1,
#dgth2qo4cs2 .doneCritText2,
#dgth2qo4cs2 .doneCritText3 {
  fill: black !important; }

#dgth2qo4cs2 .activeCritText0,
#dgth2qo4cs2 .activeCritText1,
#dgth2qo4cs2 .activeCritText2,
#dgth2qo4cs2 .activeCritText3 {
  fill: black !important; }

#dgth2qo4cs2 .titleText {
  text-anchor: middle;
  font-size: 18px;
  fill: black; }

#dgth2qo4cs2 g.classGroup text {
  fill: #9370DB;
  stroke: none;
  font-family: 'trebuchet ms', verdana, arial;
  font-size: 10px; }

#dgth2qo4cs2 g.classGroup rect {
  fill: #ECECFF;
  stroke: #9370DB; }

#dgth2qo4cs2 g.classGroup line {
  stroke: #9370DB;
  stroke-width: 1; }

#dgth2qo4cs2 .classLabel .box {
  stroke: none;
  stroke-width: 0;
  fill: #ECECFF;
  opacity: 0.5; }

#dgth2qo4cs2 .classLabel .label {
  fill: #9370DB;
  font-size: 10px; }

#dgth2qo4cs2 .relation {
  stroke: #9370DB;
  stroke-width: 1;
  fill: none; }

#dgth2qo4cs2 #compositionStart {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dgth2qo4cs2 #compositionEnd {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dgth2qo4cs2 #aggregationStart {
  fill: #ECECFF;
  stroke: #9370DB;
  stroke-width: 1; }

#dgth2qo4cs2 #aggregationEnd {
  fill: #ECECFF;
  stroke: #9370DB;
  stroke-width: 1; }

#dgth2qo4cs2 #dependencyStart {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dgth2qo4cs2 #dependencyEnd {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dgth2qo4cs2 #extensionStart {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dgth2qo4cs2 #extensionEnd {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dgth2qo4cs2 .commit-id,
#dgth2qo4cs2 .commit-msg,
#dgth2qo4cs2 .branch-label {
  fill: lightgrey;
  color: lightgrey; }



#dgth2qo4cs2 .label{
  color:#18B14E;
}
#dgth2qo4cs2 .te-md-container--dark .node rect {
  fill: red;
}

#dgth2qo4cs2 .node rect,
#dgth2qo4cs2 .node circle,
#dgth2qo4cs2 .node ellipse,
#dgth2qo4cs2 .node polygon {
  fill: #F9FFFB;;
  stroke: #2DBD60;
  stroke-width: 1.5px;
}
#dgth2qo4cs2 .arrowheadPath{
  fill: #2DBD60;
}
#dgth2qo4cs2 .edgePath .path {
  stroke: #2DBD60;
  stroke-width: 1px;
}
#dgth2qo4cs2 .edgeLabel {
  background-color: #fff;
}
#dgth2qo4cs2 .cluster rect {
  fill: #F9FFFB !important;
  stroke: #2DBD60 !important;
  stroke-width: 1px !important;
}

#dgth2qo4cs2 .cluster text {
  fill: #F9FFFB;
}

#dgth2qo4cs2 div.mermaidTooltip {
  background: #F9FFFB;
  border: 1px solid #2DBD60;
}


#dgth2qo4cs2 .actor {
  stroke: #2DBD60;
  fill: #F9FFFB;
}

#dgth2qo4cs2 text.actor {
  fill: #2DBD60;
  stroke: none;
}

#dgth2qo4cs2 .actor-line {
  stroke: #2DBD60;
}

#dgth2qo4cs2 .messageLine0 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  marker-end: 'url(#arrowhead)';
  stroke: #2DBD60;
}

#dgth2qo4cs2 .messageLine1 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  stroke: #2DBD60;
}

#dgth2qo4cs2 #arrowhead {
  fill: #2DBD60;
}

#dgth2qo4cs2 #crosshead path {
  fill: #2DBD60 !important;
  stroke: #2DBD60 !important;
}

#dgth2qo4cs2 .messageText {
  fill: #2DBD60;
  stroke: none;
}

#dgth2qo4cs2 .labelBox {
  stroke: #2DBD60;
  fill: #F9FFFB;
}

#dgth2qo4cs2 .labelText {
  fill: #2DBD60;
  stroke: #2DBD60;
}

#dgth2qo4cs2 .loopText {
  fill: #2DBD60;
  stroke: #2DBD60;
}

#dgth2qo4cs2 .loopLine {
  stroke-width: 2;
  stroke-dasharray: '2 2';
  marker-end: 'url(#arrowhead)';
  stroke: #2DBD60;
}

#dgth2qo4cs2 .note {
  stroke: #2DBD60;
  fill: #F9FFFB;
}

#dgth2qo4cs2 .noteText {
  fill: #2DBD60;
  stroke: #2DBD60;
}


#dgth2qo4cs2 .section{
  opacity:1;
}
#dgth2qo4cs2 .section0,#dgth2qo4cs2  .section2 {
  fill: #ECF7F0;
}

#dgth2qo4cs2 .section1,
#dgth2qo4cs2 .section3 {
  fill: #FFF;
}
#dgth2qo4cs2 .taskText0,
#dgth2qo4cs2 .taskText1,
#dgth2qo4cs2 .taskText2,
#dgth2qo4cs2 .taskText3 {
  fill: #fff;
}

#dgth2qo4cs2 .task0,
#dgth2qo4cs2 .task1,
#dgth2qo4cs2 .task2,
#dgth2qo4cs2 .task3 {
  fill: #2DBD60;
  stroke: #359F5A;
}
</style><style>#dgth2qo4cs2 {
    color: rgb(200, 201, 198);
    font: normal normal normal normal 14px/22.399999618530273px monospace;
  }</style><g transform="translate(-12, -12)"><g class="output"><g class="clusters"></g><g class="edgePaths"><g class="edgePath" style="opacity: 1;"><path class="path" d="M107.40625,56.28125L107.40625,81.28125L107.40625,106.28125" marker-end="url(#arrowhead317)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead317" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M107.40625,142.5625L107.40625,167.5625L107.40625,192.5625" marker-end="url(#arrowhead318)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead318" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M107.40625,228.84375L107.40625,253.84375L107.40625,278.84375" marker-end="url(#arrowhead319)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead319" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M107.40625,315.125L107.40625,340.125L107.40625,365.125" marker-end="url(#arrowhead320)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead320" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M107.40625,401.40625L107.40625,426.40625L107.40625,451.40625" marker-end="url(#arrowhead321)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead321" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g></g><g class="edgeLabels"><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g></g><g class="nodes"><g class="node" style="opacity: 1;" id="A" transform="translate(107.40625,38.140625)"><rect rx="0" ry="0" x="-76.2109375" y="-18.140625" width="152.421875" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-66.2109375,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">selinux_complete_init</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="B" transform="translate(107.40625,124.421875)"><rect rx="0" ry="0" x="-83.078125" y="-18.140625" width="166.15625" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-73.078125,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">delayed_superblock_init</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="C" transform="translate(107.40625,210.703125)"><rect rx="0" ry="0" x="-63.3359375" y="-18.140625" width="126.671875" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-53.3359375,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">superblock_doinit</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="D" transform="translate(107.40625,296.984375)"><rect rx="0" ry="0" x="-75.140625" y="-18.140625" width="150.28125" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-65.140625,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">selinux_set_mnt_opts</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="E" transform="translate(107.40625,383.265625)"><rect rx="0" ry="0" x="-64.953125" y="-18.140625" width="129.90625" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-54.953125,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">sb_finish_set_opts</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="F" transform="translate(107.40625,469.546875)"><rect rx="0" ry="0" x="-87.40625" y="-18.140625" width="174.8125" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-77.40625,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">inode_doinit_with_dentry</tspan></text></g></g></g></g></g></g></svg>
selinux_complete_init
由security_load_policy
调用,而调用inode_doinit_with_dentry
时policy和initial SID均已加载成功。
selinux_complete_init
调用selinux_set_mnt_opts
设置了sbsec->behavior,最终inode_doinit_with_dentry
再根据sbsec->behavior
设置SID。
if (!sbsec->behavior) { // 由sb_alloc_security分配,并被初始化为0,所以下面的security_fs_use会被调用
/*
* Determine the labeling behavior to use for this
* filesystem type.
*/
rc = security_fs_use(&selinux_state, sb);
if (rc) {
pr_warn("%s: security_fs_use(%s) returned %d\n",
__func__, sb->s_type->name, rc);
goto out;
}
}
考虑selinuxfs没用fs_use,但用了genfs,所以security_fs_use
最终会使用genfs对应的SID,参考Fedora refpolicy,即gen_context(system_u:object_r:security_t,s0)
。所以可见selinuxfs中的文件SID最终会由加载的策略二进制中对应的上下文来描述。例如selinuxfs对应的genfscon语句。可以用seinfo命令验证:
[ben@localhost gateways]$ seinfo --fs_use|grep selinux
[ben@localhost gateways]$ seinfo --genfs|grep selinux
genfscon selinuxfs / system_u:object_r:security_t:s0
第一条命令没有任何输出,而第二条命令可以看到selinuxfs的context。
selinux_init
同init_sel_fs
一样,SELinux子系统自身在系统启动时,也会进行初始化,即selinux_init
。此时init进程尚未被内核启动,所以策略数据也没被加载。selinux_init
就是为后面的selinuxfs加载策略做一些准备工作。
<svg id="dv9tj8bnmmg" width="100%" xmlns="http://www.w3.org/2000/svg" style="max-width: 447.0625px;" viewBox="0 0 447.0625 483.6875"><style>


#dv9tj8bnmmg .label {
  font-family: 'trebuchet ms', verdana, arial;
  color: #333; }

#dv9tj8bnmmg .node rect,
#dv9tj8bnmmg .node circle,
#dv9tj8bnmmg .node ellipse,
#dv9tj8bnmmg .node polygon {
  fill: #ECECFF;
  stroke: #9370DB;
  stroke-width: 1px; }

#dv9tj8bnmmg .node.clickable {
  cursor: pointer; }

#dv9tj8bnmmg .arrowheadPath {
  fill: #333333; }

#dv9tj8bnmmg .edgePath .path {
  stroke: #333333;
  stroke-width: 1.5px; }

#dv9tj8bnmmg .edgeLabel {
  background-color: #e8e8e8; }

#dv9tj8bnmmg .cluster rect {
  fill: #ffffde !important;
  stroke: #aaaa33 !important;
  stroke-width: 1px !important; }

#dv9tj8bnmmg .cluster text {
  fill: #333; }

#dv9tj8bnmmg div.mermaidTooltip {
  position: absolute;
  text-align: center;
  max-width: 200px;
  padding: 2px;
  font-family: 'trebuchet ms', verdana, arial;
  font-size: 12px;
  background: #ffffde;
  border: 1px solid #aaaa33;
  border-radius: 2px;
  pointer-events: none;
  z-index: 100; }

#dv9tj8bnmmg .actor {
  stroke: #CCCCFF;
  fill: #ECECFF; }

#dv9tj8bnmmg text.actor {
  fill: black;
  stroke: none; }

#dv9tj8bnmmg .actor-line {
  stroke: grey; }

#dv9tj8bnmmg .messageLine0 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  stroke: #333; }

#dv9tj8bnmmg .messageLine1 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  stroke: #333; }

#dv9tj8bnmmg #arrowhead {
  fill: #333; }

#dv9tj8bnmmg #crosshead path {
  fill: #333 !important;
  stroke: #333 !important; }

#dv9tj8bnmmg .messageText {
  fill: #333;
  stroke: none; }

#dv9tj8bnmmg .labelBox {
  stroke: #CCCCFF;
  fill: #ECECFF; }

#dv9tj8bnmmg .labelText {
  fill: black;
  stroke: none; }

#dv9tj8bnmmg .loopText {
  fill: black;
  stroke: none; }

#dv9tj8bnmmg .loopLine {
  stroke-width: 2;
  stroke-dasharray: '2 2';
  stroke: #CCCCFF; }

#dv9tj8bnmmg .note {
  stroke: #aaaa33;
  fill: #fff5ad; }

#dv9tj8bnmmg .noteText {
  fill: black;
  stroke: none;
  font-family: 'trebuchet ms', verdana, arial;
  font-size: 14px; }

#dv9tj8bnmmg .activation0 {
  fill: #f4f4f4;
  stroke: #666; }

#dv9tj8bnmmg .activation1 {
  fill: #f4f4f4;
  stroke: #666; }

#dv9tj8bnmmg .activation2 {
  fill: #f4f4f4;
  stroke: #666; }


#dv9tj8bnmmg .section {
  stroke: none;
  opacity: 0.2; }

#dv9tj8bnmmg .section0 {
  fill: rgba(102, 102, 255, 0.49); }

#dv9tj8bnmmg .section2 {
  fill: #fff400; }

#dv9tj8bnmmg .section1,
#dv9tj8bnmmg .section3 {
  fill: white;
  opacity: 0.2; }

#dv9tj8bnmmg .sectionTitle0 {
  fill: #333; }

#dv9tj8bnmmg .sectionTitle1 {
  fill: #333; }

#dv9tj8bnmmg .sectionTitle2 {
  fill: #333; }

#dv9tj8bnmmg .sectionTitle3 {
  fill: #333; }

#dv9tj8bnmmg .sectionTitle {
  text-anchor: start;
  font-size: 11px;
  text-height: 14px; }


#dv9tj8bnmmg .grid .tick {
  stroke: lightgrey;
  opacity: 0.3;
  shape-rendering: crispEdges; }

#dv9tj8bnmmg .grid path {
  stroke-width: 0; }


#dv9tj8bnmmg .today {
  fill: none;
  stroke: red;
  stroke-width: 2px; }



#dv9tj8bnmmg .task {
  stroke-width: 2; }

#dv9tj8bnmmg .taskText {
  text-anchor: middle;
  font-size: 11px; }

#dv9tj8bnmmg .taskTextOutsideRight {
  fill: black;
  text-anchor: start;
  font-size: 11px; }

#dv9tj8bnmmg .taskTextOutsideLeft {
  fill: black;
  text-anchor: end;
  font-size: 11px; }


#dv9tj8bnmmg .taskText0,
#dv9tj8bnmmg .taskText1,
#dv9tj8bnmmg .taskText2,
#dv9tj8bnmmg .taskText3 {
  fill: white; }

#dv9tj8bnmmg .task0,
#dv9tj8bnmmg .task1,
#dv9tj8bnmmg .task2,
#dv9tj8bnmmg .task3 {
  fill: #8a90dd;
  stroke: #534fbc; }

#dv9tj8bnmmg .taskTextOutside0,
#dv9tj8bnmmg .taskTextOutside2 {
  fill: black; }

#dv9tj8bnmmg .taskTextOutside1,
#dv9tj8bnmmg .taskTextOutside3 {
  fill: black; }


#dv9tj8bnmmg .active0,
#dv9tj8bnmmg .active1,
#dv9tj8bnmmg .active2,
#dv9tj8bnmmg .active3 {
  fill: #bfc7ff;
  stroke: #534fbc; }

#dv9tj8bnmmg .activeText0,
#dv9tj8bnmmg .activeText1,
#dv9tj8bnmmg .activeText2,
#dv9tj8bnmmg .activeText3 {
  fill: black !important; }


#dv9tj8bnmmg .done0,
#dv9tj8bnmmg .done1,
#dv9tj8bnmmg .done2,
#dv9tj8bnmmg .done3 {
  stroke: grey;
  fill: lightgrey;
  stroke-width: 2; }

#dv9tj8bnmmg .doneText0,
#dv9tj8bnmmg .doneText1,
#dv9tj8bnmmg .doneText2,
#dv9tj8bnmmg .doneText3 {
  fill: black !important; }


#dv9tj8bnmmg .crit0,
#dv9tj8bnmmg .crit1,
#dv9tj8bnmmg .crit2,
#dv9tj8bnmmg .crit3 {
  stroke: #ff8888;
  fill: red;
  stroke-width: 2; }

#dv9tj8bnmmg .activeCrit0,
#dv9tj8bnmmg .activeCrit1,
#dv9tj8bnmmg .activeCrit2,
#dv9tj8bnmmg .activeCrit3 {
  stroke: #ff8888;
  fill: #bfc7ff;
  stroke-width: 2; }

#dv9tj8bnmmg .doneCrit0,
#dv9tj8bnmmg .doneCrit1,
#dv9tj8bnmmg .doneCrit2,
#dv9tj8bnmmg .doneCrit3 {
  stroke: #ff8888;
  fill: lightgrey;
  stroke-width: 2;
  cursor: pointer;
  shape-rendering: crispEdges; }

#dv9tj8bnmmg .doneCritText0,
#dv9tj8bnmmg .doneCritText1,
#dv9tj8bnmmg .doneCritText2,
#dv9tj8bnmmg .doneCritText3 {
  fill: black !important; }

#dv9tj8bnmmg .activeCritText0,
#dv9tj8bnmmg .activeCritText1,
#dv9tj8bnmmg .activeCritText2,
#dv9tj8bnmmg .activeCritText3 {
  fill: black !important; }

#dv9tj8bnmmg .titleText {
  text-anchor: middle;
  font-size: 18px;
  fill: black; }

#dv9tj8bnmmg g.classGroup text {
  fill: #9370DB;
  stroke: none;
  font-family: 'trebuchet ms', verdana, arial;
  font-size: 10px; }

#dv9tj8bnmmg g.classGroup rect {
  fill: #ECECFF;
  stroke: #9370DB; }

#dv9tj8bnmmg g.classGroup line {
  stroke: #9370DB;
  stroke-width: 1; }

#dv9tj8bnmmg .classLabel .box {
  stroke: none;
  stroke-width: 0;
  fill: #ECECFF;
  opacity: 0.5; }

#dv9tj8bnmmg .classLabel .label {
  fill: #9370DB;
  font-size: 10px; }

#dv9tj8bnmmg .relation {
  stroke: #9370DB;
  stroke-width: 1;
  fill: none; }

#dv9tj8bnmmg #compositionStart {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dv9tj8bnmmg #compositionEnd {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dv9tj8bnmmg #aggregationStart {
  fill: #ECECFF;
  stroke: #9370DB;
  stroke-width: 1; }

#dv9tj8bnmmg #aggregationEnd {
  fill: #ECECFF;
  stroke: #9370DB;
  stroke-width: 1; }

#dv9tj8bnmmg #dependencyStart {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dv9tj8bnmmg #dependencyEnd {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dv9tj8bnmmg #extensionStart {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dv9tj8bnmmg #extensionEnd {
  fill: #9370DB;
  stroke: #9370DB;
  stroke-width: 1; }

#dv9tj8bnmmg .commit-id,
#dv9tj8bnmmg .commit-msg,
#dv9tj8bnmmg .branch-label {
  fill: lightgrey;
  color: lightgrey; }



#dv9tj8bnmmg .label{
  color:#18B14E;
}
#dv9tj8bnmmg .te-md-container--dark .node rect {
  fill: red;
}

#dv9tj8bnmmg .node rect,
#dv9tj8bnmmg .node circle,
#dv9tj8bnmmg .node ellipse,
#dv9tj8bnmmg .node polygon {
  fill: #F9FFFB;;
  stroke: #2DBD60;
  stroke-width: 1.5px;
}
#dv9tj8bnmmg .arrowheadPath{
  fill: #2DBD60;
}
#dv9tj8bnmmg .edgePath .path {
  stroke: #2DBD60;
  stroke-width: 1px;
}
#dv9tj8bnmmg .edgeLabel {
  background-color: #fff;
}
#dv9tj8bnmmg .cluster rect {
  fill: #F9FFFB !important;
  stroke: #2DBD60 !important;
  stroke-width: 1px !important;
}

#dv9tj8bnmmg .cluster text {
  fill: #F9FFFB;
}

#dv9tj8bnmmg div.mermaidTooltip {
  background: #F9FFFB;
  border: 1px solid #2DBD60;
}


#dv9tj8bnmmg .actor {
  stroke: #2DBD60;
  fill: #F9FFFB;
}

#dv9tj8bnmmg text.actor {
  fill: #2DBD60;
  stroke: none;
}

#dv9tj8bnmmg .actor-line {
  stroke: #2DBD60;
}

#dv9tj8bnmmg .messageLine0 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  marker-end: 'url(#arrowhead)';
  stroke: #2DBD60;
}

#dv9tj8bnmmg .messageLine1 {
  stroke-width: 1.5;
  stroke-dasharray: '2 2';
  stroke: #2DBD60;
}

#dv9tj8bnmmg #arrowhead {
  fill: #2DBD60;
}

#dv9tj8bnmmg #crosshead path {
  fill: #2DBD60 !important;
  stroke: #2DBD60 !important;
}

#dv9tj8bnmmg .messageText {
  fill: #2DBD60;
  stroke: none;
}

#dv9tj8bnmmg .labelBox {
  stroke: #2DBD60;
  fill: #F9FFFB;
}

#dv9tj8bnmmg .labelText {
  fill: #2DBD60;
  stroke: #2DBD60;
}

#dv9tj8bnmmg .loopText {
  fill: #2DBD60;
  stroke: #2DBD60;
}

#dv9tj8bnmmg .loopLine {
  stroke-width: 2;
  stroke-dasharray: '2 2';
  marker-end: 'url(#arrowhead)';
  stroke: #2DBD60;
}

#dv9tj8bnmmg .note {
  stroke: #2DBD60;
  fill: #F9FFFB;
}

#dv9tj8bnmmg .noteText {
  fill: #2DBD60;
  stroke: #2DBD60;
}


#dv9tj8bnmmg .section{
  opacity:1;
}
#dv9tj8bnmmg .section0,#dv9tj8bnmmg  .section2 {
  fill: #ECF7F0;
}

#dv9tj8bnmmg .section1,
#dv9tj8bnmmg .section3 {
  fill: #FFF;
}
#dv9tj8bnmmg .taskText0,
#dv9tj8bnmmg .taskText1,
#dv9tj8bnmmg .taskText2,
#dv9tj8bnmmg .taskText3 {
  fill: #fff;
}

#dv9tj8bnmmg .task0,
#dv9tj8bnmmg .task1,
#dv9tj8bnmmg .task2,
#dv9tj8bnmmg .task3 {
  fill: #2DBD60;
  stroke: #359F5A;
}
</style><style>#dv9tj8bnmmg {
    color: rgb(200, 201, 198);
    font: normal normal normal normal 14px/22.399999618530273px monospace;
  }</style><g transform="translate(-12, -12)"><g class="output"><g class="clusters"></g><g class="edgePaths"><g class="edgePath" style="opacity: 1;"><path class="path" d="M235.53125,56.28125L235.53125,81.28125L235.53125,106.28125" marker-end="url(#arrowhead348)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead348" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M235.53125,142.5625L235.53125,167.5625L235.53125,192.5625" marker-end="url(#arrowhead349)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead349" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M235.53125,228.84375L235.53125,253.84375L235.53125,278.84375" marker-end="url(#arrowhead350)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead350" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M235.53125,315.125L235.53125,340.125L235.53125,365.125" marker-end="url(#arrowhead351)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead351" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g><g class="edgePath" style="opacity: 1;"><path class="path" d="M235.53125,401.40625L235.53125,426.40625L235.53125,451.40625" marker-end="url(#arrowhead352)" style="stroke: #333; stroke-width: 1.5px;fill:none"></path><defs><marker id="arrowhead352" viewBox="0 0 10 10" refX="9" refY="5" markerUnits="strokeWidth" markerWidth="8" markerHeight="6" orient="auto"><path d="M 0 0 L 10 5 L 0 10 z" class="arrowheadPath" style="stroke-width: 1px; stroke-dasharray: 1px, 0px;"></path></marker></defs></g></g><g class="edgeLabels"><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g><g class="edgeLabel" style="opacity: 1;" transform=""><g transform="translate(0,0)" class="label"><rect rx="0" ry="0" width="0" height="0" style="fill:#e8e8e8;"></rect><text><tspan xml:space="preserve" dy="1em" x="1"></tspan></text></g></g></g><g class="nodes"><g class="node" style="opacity: 1;" id="A" transform="translate(235.53125,38.140625)"><rect rx="0" ry="0" x="-177.203125" y="-18.140625" width="354.40625" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-167.203125,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">根据selinux_enforcing_boot设置selinux_state.enforcing</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="B" transform="translate(235.53125,124.421875)"><rect rx="0" ry="0" x="-105.7265625" y="-18.140625" width="211.453125" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-95.7265625,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">selinux_ss_init, selinux_avc_init</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="D" transform="translate(235.53125,210.703125)"><rect rx="0" ry="0" x="-64.1796875" y="-18.140625" width="128.359375" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-54.1796875,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">cred_init_security</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="E" transform="translate(235.53125,296.984375)"><rect rx="0" ry="0" x="-215.53125" y="-18.140625" width="431.0625" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-205.53125,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">avc_init, avtab_cache_init, ebitmap_cache_init, hashtab_cache_init</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="F" transform="translate(235.53125,383.265625)"><rect rx="0" ry="0" x="-68.859375" y="-18.140625" width="137.71875" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-58.859375,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">security_add_hooks</tspan></text></g></g></g><g class="node" style="opacity: 1;" id="G" transform="translate(235.53125,469.546875)"><rect rx="0" ry="0" x="-62.9921875" y="-18.140625" width="125.984375" height="36.28125"></rect><g class="label" transform="translate(0,0)"><g transform="translate(-52.9921875,-8.140625)"><text><tspan xml:space="preserve" dy="1em" x="1">avc_add_callback</tspan></text></g></g></g></g></g></g></svg>
这里比较重要的是
cred_init_security
为current创建了初始身份, 注意此时init进程还未被拉起,所以init进程启动后,会继承该身份,即SECINITSID_KERNEL
tsec->osid = tsec->sid = SECINITSID_KERNEL;
cred->security = tsec;
- SELinux定义的hook列表,被加入到LSM子系统的hook列表中,自此,内核的系统调用就会进入SELinux子系统的视野。
selinux_init
会根据内核启动参数,设置enforcing模式
security_setenforce
security_setenforce
为libselinux接口,其实就是往selinuxfs的enforce文件写1。此处只考虑启动时的setenforce。此时由于libselinux中调用顺序,setenforce在load_policy之前,所以此时state->initialized
仍为0,策略也还未加载。参考selinuxfs实现,也就是调用sel_write_enforce
函数。整个sel_write_enforce
函数逻辑比较简单,主要就是做了以下几件事情:
- 在需要时设置
selinux_state.enforcing
变量 - 如果设置了变了就通知enforcing状态变更,并刷新AVC
这里值得注意的就是,selinuxfs的enforce文件也是一个文件,对其写,SELinux也进行了权限判断,如下:
length = avc_has_perm(&selinux_state,
current_sid(), SECINITSID_SECURITY,
SECCLASS_SECURITY, SECURITY__SETENFORCE,
NULL);
匹配的双方分别是:
- current_sid()
- SECINITSID_SECURITY
current_sid()
即init进程第一次运行时的SID,此时策略尚未加载,所以此时的SID是SECINITSID_KERNEL
。这里的SECINITSID_SECURITY
就是本章一直关注的initial SID, SECINITSID_KERNEL
也是。此时的权限判断,由于在系统启动的非常早期,所以判断逻辑非常简单,在security_compute_av
中:
if (!state->initialized)
goto allow;
在启动后,如果用户通过selinuxfs enforce来配置SELinux模式时,则会判断进程的身份和一个initial SID SECINITSID_SECURITY
的匹配关系。
security_load_policy
策略加载由用户态的init进程发起,其方法就是mmap策略二进制文件,并将数据写入selinuxfs的load文件,最终调用sel_write_load
函数。该函数分以下几步:
- 判断用户写load文件的权限, 此时策略尚未加载,且
state->initialized
仍为0(该变量由security_load_policy
赋值)。所以此时的avc_has_perm只是走个过场
length = avc_has_perm(&selinux_state,
current_sid(), SECINITSID_SECURITY,
SECCLASS_SECURITY, SECURITY__LOAD_POLICY, NULL);
security_load_policy
是加载策略的主角,他加载了所有策略数据,也包括了我们关注的initial SIDsel_make_policy_nodes
用来生成selinuxfs相关的节点,包括:bools,classes,policycap
security_load_policy
调用policydb_load_isids
初始化sidtab,并插入了所有的initial SID以及其对应context。intial SID由initial_sid文件指定,而其对应的context,由对应的.te文件定义。例如sid kernel
其上下文由policy/modules/kernel/kernel.te
指定:
sid kernel gen_context(system_u:system_r:kernel_t,mls_systemhigh)
策略加载是SELinux最核心也是最复杂的部分。security_load_policy
调用policydb_read
把整个策略二进制文件加载到内存的policydb数据结构中。除了加载策略,security_load_policy
还做了几件初始化的事情,标注在代码里。
rc = policydb_read(policydb, fp);
if (rc)
goto out;
policydb->len = len;
rc = selinux_set_mapping(policydb, secclass_map,
&state->ss->map);
if (rc) {
policydb_destroy(policydb);
goto out;
}
rc = policydb_load_isids(policydb, sidtab); // 加载initial SID到policydb sidtab中
if (rc) {
policydb_destroy(policydb);
goto out;
}
security_load_policycaps(state); // 加载policy capability
state->initialized = 1; // 设置SELinux初始化标志
seqno = ++state->ss->latest_granting;
selinux_complete_init(); // 完成selinuxfs super block delayed init
avc_ss_reset(state->avc, seqno);
selnl_notify_policyload(seqno);
selinux_status_update_policyload(state, seqno);
总结
整个SELinux初始化,发起于0号进程,并由内核SELinux模块完成。内核的核心初始化主要包括策略的加载和selinuxfs的初始化。所有的SELinux用户态接口都是通过selinuxfs实现的。
参考文献
- Linux source 4.20.5
- busybox master on 2020/10/11